fix r56030 [Bug #12711]
check whether it was syscall or not by getting previous instruction. syscall instruction is 0x0f 0x05. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@56035 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
564512db58
commit
8a1c7babec
11
vm_dump.c
11
vm_dump.c
@ -469,13 +469,14 @@ darwin_sigtramp:
|
|||||||
unw_set_reg(&cursor, UNW_X86_64_R13, uctx->uc_mcontext->__ss.__r13);
|
unw_set_reg(&cursor, UNW_X86_64_R13, uctx->uc_mcontext->__ss.__r13);
|
||||||
unw_set_reg(&cursor, UNW_X86_64_R14, uctx->uc_mcontext->__ss.__r14);
|
unw_set_reg(&cursor, UNW_X86_64_R14, uctx->uc_mcontext->__ss.__r14);
|
||||||
unw_set_reg(&cursor, UNW_X86_64_R15, uctx->uc_mcontext->__ss.__r15);
|
unw_set_reg(&cursor, UNW_X86_64_R15, uctx->uc_mcontext->__ss.__r15);
|
||||||
ip = *(unw_word_t*)uctx->uc_mcontext->__ss.__rsp;
|
|
||||||
if (!ip) { /* signal received in syscall */
|
|
||||||
ip = uctx->uc_mcontext->__ss.__rip;
|
ip = uctx->uc_mcontext->__ss.__rip;
|
||||||
}
|
if (((char*)ip)[-2] == 0x0f && ((char*)ip)[-1] == 5) {
|
||||||
unw_set_reg(&cursor, UNW_REG_IP, ip);
|
/* signal received in syscall */
|
||||||
trace[n++] = (void *)uctx->uc_mcontext->__ss.__rip;
|
|
||||||
trace[n++] = (void *)ip;
|
trace[n++] = (void *)ip;
|
||||||
|
ip = *(unw_word_t*)uctx->uc_mcontext->__ss.__rsp;
|
||||||
|
}
|
||||||
|
trace[n++] = (void *)ip;
|
||||||
|
unw_set_reg(&cursor, UNW_REG_IP, ip);
|
||||||
}
|
}
|
||||||
while (unw_step(&cursor) > 0) {
|
while (unw_step(&cursor) > 0) {
|
||||||
unw_get_reg(&cursor, UNW_REG_IP, &ip);
|
unw_get_reg(&cursor, UNW_REG_IP, &ip);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user