LibC: Fix sigsetjmp
the call from C sigsetjmp messed up rbp, now sigsetjmp is also written in assembly. I did not test the 32 bit code, just ported the tested 64 bit version over :D
This commit is contained in:
parent
0dfe0b7023
commit
1d6c08478d
|
@ -19,7 +19,6 @@ setjmp:
|
|||
xorl %eax, %eax
|
||||
|
||||
ret
|
||||
|
||||
.size setjmp, . - setjmp
|
||||
|
||||
// void longjmp(jmp_buf env, int val)
|
||||
|
@ -39,5 +38,27 @@ longjmp:
|
|||
movl 16(%edx), %edi
|
||||
movl 20(%edx), %esi
|
||||
jmp *%ecx
|
||||
|
||||
.size longjmp, . - longjmp
|
||||
|
||||
// int sigsetjmp(sigjmp_buf env, int savemask)
|
||||
.global sigsetjmp
|
||||
sigsetjmp:
|
||||
movl 4(%esp), %edx
|
||||
movl 8(%esp), %ecx
|
||||
|
||||
movl %ecx, 24(%edx)
|
||||
testl %ecx, %ecx
|
||||
jz setjmp
|
||||
|
||||
leal 24(%edx), %edx
|
||||
xorl %ecx, %ecx
|
||||
|
||||
subl $12, %esp
|
||||
movl %edx, 8(%esp)
|
||||
movl %ecx, 4(%esp)
|
||||
movl %ecx, 0(%esp)
|
||||
call pthread_sigmask
|
||||
addl $12, %esp
|
||||
|
||||
jmp setjmp
|
||||
.size sigsetjmp, . - sigsetjmp
|
||||
|
|
|
@ -38,3 +38,21 @@ longjmp:
|
|||
movq 56(%rdi), %r15
|
||||
jmp *%rcx
|
||||
.size longjmp, . - longjmp
|
||||
|
||||
// int sigsetjmp(sigjmp_buf env, int savemask)
|
||||
.global sigsetjmp
|
||||
sigsetjmp:
|
||||
movq %rsi, 64(%rdi)
|
||||
testq %rsi, %rsi
|
||||
jz setjmp
|
||||
|
||||
subq $8, %rsp
|
||||
movq %rdi, (%rsp)
|
||||
leaq 72(%rsi), %rdx
|
||||
xorq %rsi, %rsi
|
||||
call pthread_sigmask
|
||||
movq (%rsp), %rdi
|
||||
addq $8, %rsp
|
||||
|
||||
jmp setjmp
|
||||
.size sigsetjmp, . - sigsetjmp
|
||||
|
|
|
@ -7,13 +7,5 @@ void siglongjmp(sigjmp_buf env, int val)
|
|||
{
|
||||
if (env[_JMP_BUF_REGS])
|
||||
pthread_sigmask(SIG_SETMASK, reinterpret_cast<sigset_t*>(&env[_JMP_BUF_REGS + 1]), nullptr);
|
||||
return longjmp(env, val);
|
||||
}
|
||||
|
||||
int sigsetjmp(sigjmp_buf env, int savemask)
|
||||
{
|
||||
env[_JMP_BUF_REGS] = savemask;
|
||||
if (savemask)
|
||||
pthread_sigmask(0, nullptr, reinterpret_cast<sigset_t*>(&env[_JMP_BUF_REGS + 1]));
|
||||
return setjmp(env);
|
||||
longjmp(env, val);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue