Re: A issue about ptrace/SINGLESTEP on arm64

From: chengjian (D)
Date: Mon Oct 16 2017 - 22:07:32 EST




On 2017/10/16 23:30, Will Deacon wrote:
Can you jump the PC once the child appears to be "stuck"?

IIRC, GDB has special heuristics to step through LDXR/STXR critical
sections.
The function can be returned, But the number of instructions looks too much
We use objdump to count the assembly code length of the program

#=======
#trace
#=======
ptrace/2-arm64-loop # objdump -d ./nop | wc -l
115885


ptrace/2-arm64-loop # ./ptrace_singlestep ./nop

./nop : nop
Please wait
Number of machine instructions : 186688022


/ptrace/2-arm64-loop # ./ptrace_singlestep ./nop

./nop : nop
Please wait
Number of machine instructions : 103670668


The number of instructions executed twice is not the same

#=======
#trace ls
#=======

ptrace/2-arm64-loop # objdump -d /bin/ls | wc -l
18095

ptrace/2-arm64-loop # ./ptrace_singlestep /bin/ls
/bin/ls : ls
Please wait
Number of machine instructions : 7718122167


It seems that the child has also been tracked by the parent process
when it goes into the kernel space.

Is this what your 'stuck' mean?
Does all the instructions been tracked in kernel space, or only the LDXR/STXR?