2013-12-30 03:38:32 +02:00
|
|
|
#ifdef __x86_64__
|
2014-02-11 00:31:17 +02:00
|
|
|
/* x64 callee save: bx, bp, sp, r12, r13, r14, r15 */
|
2013-10-15 22:25:17 +01:00
|
|
|
|
|
|
|
.file "nlr.s"
|
|
|
|
.text
|
|
|
|
|
2014-04-03 23:51:16 +01:00
|
|
|
#if !defined(__CYGWIN__)
|
|
|
|
|
2013-12-30 03:38:32 +02:00
|
|
|
/* uint nlr_push(rdi=nlr_buf_t *nlr) */
|
2014-03-21 02:05:39 -07:00
|
|
|
#if !(defined(__APPLE__) && defined(__MACH__))
|
2013-10-15 22:25:17 +01:00
|
|
|
.globl nlr_push
|
|
|
|
.type nlr_push, @function
|
|
|
|
nlr_push:
|
2014-01-04 20:15:04 +01:00
|
|
|
#else
|
|
|
|
.globl _nlr_push
|
|
|
|
_nlr_push:
|
|
|
|
#endif
|
2013-10-15 22:25:17 +01:00
|
|
|
movq (%rsp), %rax # load return %rip
|
|
|
|
movq %rax, 16(%rdi) # store %rip into nlr_buf
|
|
|
|
movq %rbp, 24(%rdi) # store %rbp into nlr_buf
|
|
|
|
movq %rsp, 32(%rdi) # store %rsp into nlr_buf
|
|
|
|
movq %rbx, 40(%rdi) # store %rbx into nlr_buf
|
|
|
|
movq %r12, 48(%rdi) # store %r12 into nlr_buf
|
|
|
|
movq %r13, 56(%rdi) # store %r13 into nlr_buf
|
|
|
|
movq %r14, 64(%rdi) # store %r14 into nlr_buf
|
|
|
|
movq %r15, 72(%rdi) # store %r15 into nlr_buf
|
|
|
|
movq nlr_top(%rip), %rax # get last nlr_buf
|
|
|
|
movq %rax, (%rdi) # store it
|
|
|
|
movq %rdi, nlr_top(%rip) # stor new nlr_buf (to make linked list)
|
|
|
|
xorq %rax, %rax # return 0, normal return
|
|
|
|
ret # return
|
2014-03-21 02:05:39 -07:00
|
|
|
#if !(defined(__APPLE__) && defined(__MACH__))
|
2014-01-04 20:19:19 +01:00
|
|
|
.size nlr_push, .-nlr_push
|
|
|
|
#endif
|
2013-10-15 22:25:17 +01:00
|
|
|
|
2013-12-30 03:38:32 +02:00
|
|
|
/* void nlr_pop() */
|
2014-03-21 02:05:39 -07:00
|
|
|
#if !(defined(__APPLE__) && defined(__MACH__))
|
2013-10-15 22:25:17 +01:00
|
|
|
.globl nlr_pop
|
|
|
|
.type nlr_pop, @function
|
|
|
|
nlr_pop:
|
2014-01-04 20:15:04 +01:00
|
|
|
#else
|
|
|
|
.globl _nlr_pop
|
|
|
|
_nlr_pop:
|
|
|
|
#endif
|
2013-10-15 22:25:17 +01:00
|
|
|
movq nlr_top(%rip), %rax # get nlr_top into %rax
|
|
|
|
movq (%rax), %rax # load prev nlr_buf
|
|
|
|
movq %rax, nlr_top(%rip) # store prev nlr_buf (to unlink list)
|
|
|
|
ret # return
|
2014-03-21 02:05:39 -07:00
|
|
|
#if !(defined(__APPLE__) && defined(__MACH__))
|
2014-01-04 20:19:19 +01:00
|
|
|
.size nlr_pop, .-nlr_pop
|
|
|
|
#endif
|
2013-10-15 22:25:17 +01:00
|
|
|
|
2013-12-30 03:38:32 +02:00
|
|
|
/* void nlr_jump(rdi=uint val) */
|
2014-03-21 02:05:39 -07:00
|
|
|
#if !(defined(__APPLE__) && defined(__MACH__))
|
2013-10-15 22:25:17 +01:00
|
|
|
.globl nlr_jump
|
|
|
|
.type nlr_jump, @function
|
|
|
|
nlr_jump:
|
2014-01-04 20:15:04 +01:00
|
|
|
#else
|
|
|
|
.globl _nlr_jump
|
|
|
|
_nlr_jump:
|
|
|
|
#endif
|
2013-10-15 22:25:17 +01:00
|
|
|
movq %rdi, %rax # put return value in %rax
|
|
|
|
movq nlr_top(%rip), %rdi # get nlr_top into %rdi
|
2014-04-08 14:08:14 +00:00
|
|
|
test %rdi, %rdi # check for nlr_top being NULL
|
|
|
|
je .fail # fail if nlr_top is NULL
|
2013-10-15 22:25:17 +01:00
|
|
|
movq %rax, 8(%rdi) # store return value
|
|
|
|
movq (%rdi), %rax # load prev nlr_buf
|
|
|
|
movq %rax, nlr_top(%rip) # store prev nlr_buf (to unlink list)
|
|
|
|
movq 72(%rdi), %r15 # load saved %r15
|
|
|
|
movq 64(%rdi), %r14 # load saved %r14
|
|
|
|
movq 56(%rdi), %r13 # load saved %r13
|
|
|
|
movq 48(%rdi), %r12 # load saved %r12
|
|
|
|
movq 40(%rdi), %rbx # load saved %rbx
|
|
|
|
movq 32(%rdi), %rsp # load saved %rsp
|
|
|
|
movq 24(%rdi), %rbp # load saved %rbp
|
|
|
|
movq 16(%rdi), %rax # load saved %rip
|
|
|
|
movq %rax, (%rsp) # store saved %rip to stack
|
|
|
|
xorq %rax, %rax # clear return register
|
|
|
|
inc %al # increase to make 1, non-local return
|
|
|
|
ret # return
|
2014-04-08 14:08:14 +00:00
|
|
|
.fail:
|
|
|
|
movq %rax, %rdi # put argument back in first-arg register
|
|
|
|
je nlr_jump_fail # transfer control to nlr_jump_fail
|
2014-03-21 02:05:39 -07:00
|
|
|
#if !(defined(__APPLE__) && defined(__MACH__))
|
2013-10-15 22:25:17 +01:00
|
|
|
.size nlr_jump, .-nlr_jump
|
2014-01-04 20:15:04 +01:00
|
|
|
#endif
|
2013-10-15 22:25:17 +01:00
|
|
|
|
2014-04-08 14:08:14 +00:00
|
|
|
.bss
|
2014-03-21 02:05:39 -07:00
|
|
|
#if !(defined(__APPLE__) && defined(__MACH__))
|
2013-10-15 22:25:17 +01:00
|
|
|
.local nlr_top
|
2014-01-04 20:15:04 +01:00
|
|
|
#endif
|
2013-10-15 22:25:17 +01:00
|
|
|
.comm nlr_top,8,8
|
2014-04-03 23:51:16 +01:00
|
|
|
|
|
|
|
#else // !defined(__CYGWIN__)
|
|
|
|
|
|
|
|
/* uint nlr_push(rcx=nlr_buf_t *nlr) */
|
|
|
|
.globl nlr_push
|
|
|
|
nlr_push:
|
|
|
|
movq (%rsp), %rax # load return %rip
|
|
|
|
movq %rax, 16(%rcx) # store %rip into nlr_buf
|
|
|
|
movq %rbp, 24(%rcx) # store %rbp into nlr_buf
|
|
|
|
movq %rsp, 32(%rcx) # store %rsp into nlr_buf
|
|
|
|
movq %rbx, 40(%rcx) # store %rbx into nlr_buf
|
|
|
|
movq %r12, 48(%rcx) # store %r12 into nlr_buf
|
|
|
|
movq %r13, 56(%rcx) # store %r13 into nlr_buf
|
|
|
|
movq %r14, 64(%rcx) # store %r14 into nlr_buf
|
|
|
|
movq %r15, 72(%rcx) # store %r15 into
|
|
|
|
movq %rdi, 80(%rcx) # store %rdr into
|
|
|
|
movq %rsi, 88(%rcx) # store %rsi into
|
|
|
|
movq nlr_top(%rip), %rax # get last nlr_buf
|
|
|
|
movq %rax, (%rcx) # store it
|
|
|
|
movq %rcx, nlr_top(%rip) # stor new nlr_buf (to make linked list)
|
|
|
|
xorq %rax, %rax # return 0, normal return
|
|
|
|
ret # return
|
|
|
|
|
2014-04-08 14:08:14 +00:00
|
|
|
/* void nlr_pop() */
|
|
|
|
.globl nlr_pop
|
|
|
|
nlr_pop:
|
|
|
|
movq nlr_top(%rip), %rax # get nlr_top into %rax
|
|
|
|
movq (%rax), %rax # load prev nlr_buf
|
|
|
|
movq %rax, nlr_top(%rip) # store prev nlr_buf (to unlink list)
|
|
|
|
ret # return
|
2014-04-03 23:51:16 +01:00
|
|
|
|
2014-04-08 14:08:14 +00:00
|
|
|
/* void nlr_jump(rcx=uint val) */
|
2014-04-03 23:51:16 +01:00
|
|
|
.globl nlr_jump
|
|
|
|
nlr_jump:
|
|
|
|
movq %rcx, %rax # put return value in %rax
|
2014-04-08 14:08:14 +00:00
|
|
|
movq nlr_top(%rip), %rcx # get nlr_top into %rcx
|
|
|
|
test %rcx, %rcx # check for nlr_top being NULL
|
|
|
|
je .fail # fail if nlr_top is NULL
|
2014-04-03 23:51:16 +01:00
|
|
|
movq %rax, 8(%rcx) # store return value
|
|
|
|
movq (%rcx), %rax # load prev nlr_buf
|
|
|
|
movq %rax, nlr_top(%rip) # store prev nlr_buf (to unlink list)
|
|
|
|
movq 72(%rcx), %r15 # load saved %r15
|
|
|
|
movq 64(%rcx), %r14 # load saved %r14
|
|
|
|
movq 56(%rcx), %r13 # load saved %r13
|
|
|
|
movq 48(%rcx), %r12 # load saved %r12
|
|
|
|
movq 40(%rcx), %rbx # load saved %rbx
|
|
|
|
movq 32(%rcx), %rsp # load saved %rsp
|
|
|
|
movq 24(%rcx), %rbp # load saved %rbp
|
|
|
|
movq 16(%rcx), %rax # load saved %rip
|
|
|
|
movq 80(%rcx), %rdi # store %rdr into
|
|
|
|
movq 88(%rcx), %rsi # store %rsi into
|
|
|
|
movq %rax, (%rsp) # store saved %rip to stack
|
|
|
|
xorq %rax, %rax # clear return register
|
|
|
|
inc %al # increase to make 1, non-local return
|
|
|
|
ret # return
|
2014-04-08 14:08:14 +00:00
|
|
|
.fail:
|
|
|
|
movq %rax, %rcx # put argument back in first-arg register
|
|
|
|
je nlr_jump_fail # transfer control to nlr_jump_fail
|
2014-04-03 23:51:16 +01:00
|
|
|
|
2014-04-08 14:08:14 +00:00
|
|
|
.bss
|
2014-04-03 23:51:16 +01:00
|
|
|
.comm nlr_top,8,8
|
|
|
|
|
|
|
|
#endif // !defined(__CYGWIN__)
|
|
|
|
|
|
|
|
#endif // __x86_64__
|