1

我有一个调试器,我正在从 linux 移植到 *bsd。目前,我正在开发 OpenBSD 版本。

在某些情况下,我想知道所传递信号的详细信息。例如,假设交付了一个 SIGSEGV,我想知道故障地址是什么,如果可能的话,它是读取还是写入。

另一个例子是如果我收到一个陷阱,它是一个单步事件吗?或者可能是一个 INT3 操作码。

在 linux 上,我通过调用以下命令获取此信息:

ptrace(PTRACE_GETSIGINFO, pid, 0, &siginfo);

这很有效,因为它让我可以访问我可能想知道的关于信号的所有信息。OpenBSD 上似乎没有等价物。我查看了哪些可以使用 KVM API 访问kinfo_prockinfo_proc2 但没有什么能像 siginfo_t 那样拥有相同类型的信息。获取此信息的正确方法是什么?

4

1 回答 1

0

我使用 KVM 至少找到了我的问题的部分答案:

char errbuf[_POSIX_LINE_MAX];
kvm_t *const kd = kvm_openfiles(NULL, NULL, NULL, O_READONLY, errbuf);
if(kd != NULL) {
    int rc;
    struct kinfo_proc2 *const proc = kvm_getproc2(kd, KERN_PROC_PID, pid, sizeof(struct kinfo_proc2), &rc);

    struct sigacts sigacts;
    kvm_read(kd, proc->p_sigacts, &sigacts, sizeof(sigacts));

    // sigacts.ps_code is same as siginfo.si_code
    // sigacts.ps_sigval.sival_ptr is same as siginfo.si_addr
}

几乎是我想要的所有信息,我认为如果我能继续挖掘相关的标题,我将能够找到所有这些信息。希望其他 BSD 拱门也有一些东西 ;-)。

于 2010-10-12T23:05:37.563 回答