Почему дочерний процесс не выйдет нормально? - PullRequest
0 голосов
/ 06 ноября 2018

Почему следующая программа не будет работать должным образом?

int cnt = 0;
void deal(int sig) {
    ++cnt;
}
int main() {
    signal(SIGUSR1, deal);
    pid_t child = fork();
    if (child == 0) {
        ptrace(PTRACE_TRACEME, 0, NULL, NULL);
        raise(SIGSTOP);
        freopen("ab.out", "w", stdout);
        printf("child : %d\n", cnt);
    } else {
        int app_status, app_sig, fd;
        struct user_regs_struct app_reg;
        struct rusage app_ruse;
        waitpid(child, &app_status, 0);
        printf("father: waitpid: %d\n", app_status);
        while (1) {
            ptrace(PTRACE_SYSCALL, child, NULL, NULL);
            wait4(child, &app_status, 0, &app_ruse);
            if (WIFEXITED(app_status)) {
                printf("father: child exit normally, pid - %d\n", child);
                break;
            }
            if (WIFSIGNALED(app_status) || (WIFSTOPPED(app_status)
                                        && WSTOPSIG(app_status) != SIGTRAP)) {
                ....
                break;
            }
            ptrace(PTRACE_GETREGS, child, NULL, &app_reg);
            if (app_reg.orig_rax == SYS_open && (fd = app_reg.rax) >= 0) {
                kill(child, SIGUSR1);
            }
        }
    }
    return 0;
}

При запуске программы получен следующий результат

enter image description here

Почему дочерний процесс завершил работу сразу после получения сигнала?

Полный код можно получить здесь.

https://pastebin.ubuntu.com/p/FddVZpfGH7/

...