好的,这是一个简单的问题。当我使用ptrace systemcall时android是否支持PTRACE_SINGLESTEP?当我想追踪一个安卓apk程序时,我发现我无法处理SINGLESTEP追踪。但是当我使用PTRACE_SYSCALL时情况发生了变化,它可以完美运行。 Android是否会消除此功能或手臂在硬件上缺少某些支持?任何帮助将不胜感激!谢谢。
这是我的核心程序:
int main(int argc, char *argv[])
{
if(argc != 2) {
__android_log_print(ANDROID_LOG_DEBUG,TAG,"please input the pid!");
return -1;
}
if(0 != ptrace(PTRACE_ATTACH, target_pid, NULL, NULL))
{
__android_log_print(ANDROID_LOG_DEBUG,TAG,"ptrace attach error");
return -1;
}
__android_log_print(ANDROID_LOG_DEBUG,TAG,"start monitor process :%d",target_pid);
while(1)
{
wait(&status);
if(WIFEXITED(status))
{
break;
}
if (ptrace(PTRACE_SINGLESTEP, target_pid, 0, 0) != 0)
__android_log_print(ANDROID_LOG_DEBUG,TAG,"PTRACE_SINGLESTEP attach error");
}
ptrace(PTRACE_DETACH, target_pid, NULL, NULL);
__android_log_print(ANDROID_LOG_DEBUG,TAG,"monitor finished");
return 0;
}
我在外壳上运行该程序。而且我可以获得root特权。
如果我将请求更改为PTRACE_SYSCALL,则程序将正常运行。
但是,如果请求是PTRACE_SINGLESTEP,则程序将获得错误!
最佳答案
PTRACE_SINGLESTEP已在ARM Linux check this上删除