Paul Sokolovsky | b1ce37d | 2014-04-30 04:19:20 +0300 | [diff] [blame] | 1 | #if defined(__i386__) && !MICROPY_NLR_SETJMP |
Paul Sokolovsky | e85c389 | 2013-12-30 03:38:32 +0200 | [diff] [blame] | 2 | /* x86 callee save: bx, di, si, bp, sp */ |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 3 | |
| 4 | .file "nlr.s" |
| 5 | .text |
| 6 | |
Paul Sokolovsky | e85c389 | 2013-12-30 03:38:32 +0200 | [diff] [blame] | 7 | /* uint nlr_push(4(%esp)=nlr_buf_t *nlr) */ |
Markus Siemens | 242856c | 2014-01-28 19:52:04 +0100 | [diff] [blame] | 8 | #ifdef _WIN32 |
| 9 | .globl _nlr_push |
| 10 | .def _nlr_push; .scl 2; .type 32; .endef |
| 11 | _nlr_push: |
| 12 | #else |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 13 | .globl nlr_push |
| 14 | .type nlr_push, @function |
| 15 | nlr_push: |
Markus Siemens | 19ccc6b | 2014-01-27 22:53:28 +0100 | [diff] [blame] | 16 | #endif |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 17 | mov 4(%esp), %edx # load nlr_buf |
| 18 | mov (%esp), %eax # load return %ip |
| 19 | mov %eax, 8(%edx) # store %ip into nlr_buf+8 |
| 20 | mov %ebp, 12(%edx) # store %bp into nlr_buf+12 |
| 21 | mov %esp, 16(%edx) # store %sp into nlr_buf+16 |
| 22 | mov %ebx, 20(%edx) # store %bx into nlr_buf+20 |
| 23 | mov %edi, 24(%edx) # store %di into nlr_buf |
| 24 | mov %esi, 28(%edx) # store %si into nlr_buf |
| 25 | mov nlr_top, %eax # load nlr_top |
| 26 | mov %eax, (%edx) # store it |
| 27 | mov %edx, nlr_top # stor new nlr_buf (to make linked list) |
| 28 | xor %eax, %eax # return 0, normal return |
| 29 | ret # return |
Markus Siemens | 242856c | 2014-01-28 19:52:04 +0100 | [diff] [blame] | 30 | #ifndef _WIN32 |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 31 | .size nlr_push, .-nlr_push |
Markus Siemens | 19ccc6b | 2014-01-27 22:53:28 +0100 | [diff] [blame] | 32 | #endif |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 33 | |
Paul Sokolovsky | e85c389 | 2013-12-30 03:38:32 +0200 | [diff] [blame] | 34 | /* void nlr_pop() */ |
Markus Siemens | 242856c | 2014-01-28 19:52:04 +0100 | [diff] [blame] | 35 | #ifdef _WIN32 |
| 36 | .globl _nlr_pop |
| 37 | .def _nlr_pop; .scl 2; .type 32; .endef |
| 38 | _nlr_pop: |
| 39 | #else |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 40 | .globl nlr_pop |
| 41 | .type nlr_pop, @function |
| 42 | nlr_pop: |
Markus Siemens | 19ccc6b | 2014-01-27 22:53:28 +0100 | [diff] [blame] | 43 | #endif |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 44 | mov nlr_top, %eax # load nlr_top |
| 45 | mov (%eax), %eax # load prev nlr_buf |
| 46 | mov %eax, nlr_top # store nlr_top (to unlink list) |
| 47 | ret # return |
Markus Siemens | 242856c | 2014-01-28 19:52:04 +0100 | [diff] [blame] | 48 | #ifndef _WIN32 |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 49 | .size nlr_pop, .-nlr_pop |
Markus Siemens | 19ccc6b | 2014-01-27 22:53:28 +0100 | [diff] [blame] | 50 | #endif |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 51 | |
Paul Sokolovsky | e85c389 | 2013-12-30 03:38:32 +0200 | [diff] [blame] | 52 | /* void nlr_jump(4(%esp)=uint val) */ |
Markus Siemens | 242856c | 2014-01-28 19:52:04 +0100 | [diff] [blame] | 53 | #ifdef _WIN32 |
| 54 | .globl _nlr_jump |
| 55 | .def _nlr_jump; .scl 2; .type 32; .endef |
| 56 | _nlr_jump: |
| 57 | #else |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 58 | .globl nlr_jump |
| 59 | .type nlr_jump, @function |
| 60 | nlr_jump: |
Markus Siemens | 19ccc6b | 2014-01-27 22:53:28 +0100 | [diff] [blame] | 61 | #endif |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 62 | mov nlr_top, %edx # load nlr_top |
Damien George | 26cf55a | 2014-04-08 14:08:14 +0000 | [diff] [blame] | 63 | test %edx, %edx # check for nlr_top being NULL |
Paul Sokolovsky | 41809a1 | 2014-04-20 22:14:58 +0300 | [diff] [blame] | 64 | #ifdef _WIN32 |
| 65 | je _nlr_jump_fail # fail if nlr_top is NULL |
| 66 | #else |
Damien George | 26cf55a | 2014-04-08 14:08:14 +0000 | [diff] [blame] | 67 | je nlr_jump_fail # fail if nlr_top is NULL |
Paul Sokolovsky | 41809a1 | 2014-04-20 22:14:58 +0300 | [diff] [blame] | 68 | #endif |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 69 | mov 4(%esp), %eax # load return value |
| 70 | mov %eax, 4(%edx) # store return value |
| 71 | mov (%edx), %eax # load prev nlr_top |
| 72 | mov %eax, nlr_top # store nlr_top (to unlink list) |
| 73 | mov 28(%edx), %esi # load saved %si |
| 74 | mov 24(%edx), %edi # load saved %di |
| 75 | mov 20(%edx), %ebx # load saved %bx |
| 76 | mov 16(%edx), %esp # load saved %sp |
| 77 | mov 12(%edx), %ebp # load saved %bp |
| 78 | mov 8(%edx), %eax # load saved %ip |
| 79 | mov %eax, (%esp) # store saved %ip to stack |
| 80 | xor %eax, %eax # clear return register |
| 81 | inc %al # increase to make 1, non-local return |
| 82 | ret # return |
Markus Siemens | 242856c | 2014-01-28 19:52:04 +0100 | [diff] [blame] | 83 | #ifndef _WIN32 |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 84 | .size nlr_jump, .-nlr_jump |
Markus Siemens | 19ccc6b | 2014-01-27 22:53:28 +0100 | [diff] [blame] | 85 | #endif |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 86 | |
Damien George | 26cf55a | 2014-04-08 14:08:14 +0000 | [diff] [blame] | 87 | .bss |
Markus Siemens | 242856c | 2014-01-28 19:52:04 +0100 | [diff] [blame] | 88 | #ifndef _WIN32 |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 89 | .local nlr_top |
Markus Siemens | 19ccc6b | 2014-01-27 22:53:28 +0100 | [diff] [blame] | 90 | #endif |
Damien | ce89a21 | 2013-10-15 22:25:17 +0100 | [diff] [blame] | 91 | .comm nlr_top,4,4 |
Markus Siemens | 242856c | 2014-01-28 19:52:04 +0100 | [diff] [blame] | 92 | |
| 93 | #endif /* __i386__ */ |