longjmp:
mov %rsi,%rax /* val will be longjmp return */
test %rax,%rax
- jnz .L0
+ jnz 1f
inc %rax /* if val==0, val=1 per longjmp semantics */
-.L0:
- movq (%rdi),%rbx /* rdi is the jmp_buf, restore regs from it */
- movq 8(%rdi),%rbp
- movq 16(%rdi),%r12
- movq 24(%rdi),%r13
- movq 32(%rdi),%r14
- movq 40(%rdi),%r15
- movq 48(%rdi),%rdx /* this ends up being the stack pointer */
+1:
+ mov (%rdi),%rbx /* rdi is the jmp_buf, restore regs from it */
+ mov 8(%rdi),%rbp
+ mov 16(%rdi),%r12
+ mov 24(%rdi),%r13
+ mov 32(%rdi),%r14
+ mov 40(%rdi),%r15
+ mov 48(%rdi),%rdx /* this ends up being the stack pointer */
mov %rdx,%rsp
- movq 56(%rdi),%rdx /* this is the instruction pointer */
+ mov 56(%rdi),%rdx /* this is the instruction pointer */
jmp *%rdx /* goto saved address without altering rsp */
.size _longjmp,.-_longjmp
.size longjmp,.-longjmp
mov %r13,24(%rdi)
mov %r14,32(%rdi)
mov %r15,40(%rdi)
- leaq 8(%rsp),%rdx /* this is our rsp WITHOUT current ret addr */
+ lea 8(%rsp),%rdx /* this is our rsp WITHOUT current ret addr */
mov %rdx,48(%rdi)
- movq (%rsp),%rdx /* save return addr ptr for new rip */
+ mov (%rsp),%rdx /* save return addr ptr for new rip */
mov %rdx,56(%rdi)
xor %rax,%rax /* always return 0 */
ret