好的,这是一个简单的问题。当我使用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上删除

07-27 14:41