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
|
xorl %eax, %eax
|
||||||
|
|
||||||
ret
|
ret
|
||||||
|
|
||||||
.size setjmp, . - setjmp
|
.size setjmp, . - setjmp
|
||||||
|
|
||||||
// void longjmp(jmp_buf env, int val)
|
// void longjmp(jmp_buf env, int val)
|
||||||
|
@ -39,5 +38,27 @@ longjmp:
|
||||||
movl 16(%edx), %edi
|
movl 16(%edx), %edi
|
||||||
movl 20(%edx), %esi
|
movl 20(%edx), %esi
|
||||||
jmp *%ecx
|
jmp *%ecx
|
||||||
|
|
||||||
.size longjmp, . - longjmp
|
.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
|
movq 56(%rdi), %r15
|
||||||
jmp *%rcx
|
jmp *%rcx
|
||||||
.size longjmp, . - longjmp
|
.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])
|
if (env[_JMP_BUF_REGS])
|
||||||
pthread_sigmask(SIG_SETMASK, reinterpret_cast<sigset_t*>(&env[_JMP_BUF_REGS + 1]), nullptr);
|
pthread_sigmask(SIG_SETMASK, reinterpret_cast<sigset_t*>(&env[_JMP_BUF_REGS + 1]), nullptr);
|
||||||
return longjmp(env, val);
|
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);
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue