问题陈述:一个程序C由一个循环组成。这个程序的执行必须由另一个进程控制,该进程会周期性地显示被控制进程的进度。在
输出结果如下:
kill(pid, SIGSTOP)
之后,函数ptrace(PTRACE_PEEKTEXT,pid,...)
不能再找到C进程了。根据我所读的,当通过pid
标识的进程停止时,ptrace(PTRACE_PEEKTEXT,pid,...
)应该可以工作。
我不知道我究竟缺少什么,所以任何帮助都将不胜感激。以下是我迄今为止所做的:
有两个进程,P和C。
第一个进程(P)通过fork()创建第二个进程(C)。
C的代码如下:
int i = 0;
int main() {
ptrace(PTRACE_TRACEME, 0, NULL, NULL);
printf("Memory address = %p", (void *)&i);
while(1) { i++;}
}
P的代码如下:
{...}
switch (pid = fork()) {
case 0: /* the child */
if (execl("C", "", (char *) NULL) == -1) {
perror("execl");
}
break;
case -1: /* Error */
perror("fork");
exit(EXIT_FAILURE);
default: /* the parent */
sleep(1);
kill(pid, SIGSTOP);
wait(&status);
if (WSTOPSIG(status)==SIGSTOP) {
printf("%s","Child was interrupted. Insert memory address\n");
scanf("%p",&address);
printf("Address = %p", address);
data = ptrace(PTRACE_PEEKTEXT, pid, address,NULL);
if(data==-1){
if(errno){
printf("%s\n","Error at PEEKTEXT\n");
printf("%s\n",strerror(errno));
}
if(errno == ESRCH){
printf("%s\n","ESRCH error\n");
}
if(errno == EIO){
printf("%s\n","EIO error\n");
}
}
printf("***Data retrieved is: %ld\n",data);
data = ptrace(PTRACE_CONT, pid, 0, 0);
}
if(WIFEXITED(status)){
printf("[Parent] - Child's exit status is: %d \n", WEXITSTATUS(status));
break;
}
break;
}
{...}
输出结果如下:
输出结果为:
- 来自C:内存地址= 0x60104c
- 来自P:子进程被中断。插入内存地址(接下来我插入C打印的内容)
地址= 0x60104c
错误信息如下:
在PEEKTEXT处出现错误
没有这样的进程
ESRCH错误
***检索到的数据为:-1
...
,正如 @roxana_roman 所提到的。 - Mirel Vlad