blob: a6ec4b73c7ab169906b48ab8730ec8a1736b4a3e [file] [log] [blame]
Damien George04b91472014-05-03 23:27:38 +01001/*
2 * This file is part of the Micro Python project, http://micropython.org/
3 *
4 * The MIT License (MIT)
5 *
6 * Copyright (c) 2013, 2014 Damien P. George
7 *
8 * Permission is hereby granted, free of charge, to any person obtaining a copy
9 * of this software and associated documentation files (the "Software"), to deal
10 * in the Software without restriction, including without limitation the rights
11 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12 * copies of the Software, and to permit persons to whom the Software is
13 * furnished to do so, subject to the following conditions:
14 *
15 * The above copyright notice and this permission notice shall be included in
16 * all copies or substantial portions of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24 * THE SOFTWARE.
25 */
26
Paul Sokolovskyb1ce37d2014-04-30 04:19:20 +030027#if defined(__i386__) && !MICROPY_NLR_SETJMP
Damien George133b0832014-09-26 13:07:26 +000028
29// We only need the functions here if we are on x86, and we are not
30// using setjmp/longjmp.
31//
32// For reference, x86 callee save regs are:
33// ebx, esi, edi, ebp, esp, eip
Damience89a212013-10-15 22:25:17 +010034
Damien Georgeb4b10fd2015-01-01 23:30:53 +000035// the offset of nlr_top within mp_state_ctx_t
36#define NLR_TOP_OFFSET (2 * 4)
37
Igor Gatisf5c554d2015-11-19 13:53:37 -030038#if defined(_WIN32) || defined(__CYGWIN__)
stijnbf1570c2015-11-20 15:18:42 +010039#define NLR_OS_WINDOWS
Damien Georgeb4b10fd2015-01-01 23:30:53 +000040#define NLR_TOP (_mp_state_ctx + NLR_TOP_OFFSET)
Damien George872a8292015-01-01 22:03:44 +000041#else
Damien Georgeb4b10fd2015-01-01 23:30:53 +000042#define NLR_TOP (mp_state_ctx + NLR_TOP_OFFSET)
Damien George872a8292015-01-01 22:03:44 +000043#endif
44
Damience89a212013-10-15 22:25:17 +010045 .file "nlr.s"
46 .text
47
Damien George133b0832014-09-26 13:07:26 +000048/**************************************/
49// mp_uint_t nlr_push(4(%esp)=nlr_buf_t *nlr)
50
stijnbf1570c2015-11-20 15:18:42 +010051#if defined(NLR_OS_WINDOWS)
Markus Siemens242856c2014-01-28 19:52:04 +010052 .globl _nlr_push
53 .def _nlr_push; .scl 2; .type 32; .endef
54_nlr_push:
55#else
Damience89a212013-10-15 22:25:17 +010056 .globl nlr_push
57 .type nlr_push, @function
58nlr_push:
Markus Siemens19ccc6b2014-01-27 22:53:28 +010059#endif
Damience89a212013-10-15 22:25:17 +010060 mov 4(%esp), %edx # load nlr_buf
61 mov (%esp), %eax # load return %ip
62 mov %eax, 8(%edx) # store %ip into nlr_buf+8
63 mov %ebp, 12(%edx) # store %bp into nlr_buf+12
64 mov %esp, 16(%edx) # store %sp into nlr_buf+16
65 mov %ebx, 20(%edx) # store %bx into nlr_buf+20
66 mov %edi, 24(%edx) # store %di into nlr_buf
67 mov %esi, 28(%edx) # store %si into nlr_buf
Damien George872a8292015-01-01 22:03:44 +000068 mov NLR_TOP, %eax # load nlr_top
Damience89a212013-10-15 22:25:17 +010069 mov %eax, (%edx) # store it
Damien George872a8292015-01-01 22:03:44 +000070 mov %edx, NLR_TOP # stor new nlr_buf (to make linked list)
Damience89a212013-10-15 22:25:17 +010071 xor %eax, %eax # return 0, normal return
72 ret # return
stijnbf1570c2015-11-20 15:18:42 +010073#if !defined(NLR_OS_WINDOWS)
Damience89a212013-10-15 22:25:17 +010074 .size nlr_push, .-nlr_push
Markus Siemens19ccc6b2014-01-27 22:53:28 +010075#endif
Damience89a212013-10-15 22:25:17 +010076
Damien George133b0832014-09-26 13:07:26 +000077/**************************************/
78// void nlr_pop()
79
stijnbf1570c2015-11-20 15:18:42 +010080#if defined(NLR_OS_WINDOWS)
Markus Siemens242856c2014-01-28 19:52:04 +010081 .globl _nlr_pop
82 .def _nlr_pop; .scl 2; .type 32; .endef
83_nlr_pop:
84#else
Damience89a212013-10-15 22:25:17 +010085 .globl nlr_pop
86 .type nlr_pop, @function
87nlr_pop:
Markus Siemens19ccc6b2014-01-27 22:53:28 +010088#endif
Damien George872a8292015-01-01 22:03:44 +000089 mov NLR_TOP, %eax # load nlr_top
Damience89a212013-10-15 22:25:17 +010090 mov (%eax), %eax # load prev nlr_buf
Damien George872a8292015-01-01 22:03:44 +000091 mov %eax, NLR_TOP # store nlr_top (to unlink list)
Damience89a212013-10-15 22:25:17 +010092 ret # return
stijnbf1570c2015-11-20 15:18:42 +010093#if !defined(NLR_OS_WINDOWS)
Damience89a212013-10-15 22:25:17 +010094 .size nlr_pop, .-nlr_pop
Markus Siemens19ccc6b2014-01-27 22:53:28 +010095#endif
Damience89a212013-10-15 22:25:17 +010096
Damien George133b0832014-09-26 13:07:26 +000097/**************************************/
98// void nlr_jump(4(%esp)=mp_uint_t val)
99
stijnbf1570c2015-11-20 15:18:42 +0100100#if defined(NLR_OS_WINDOWS)
Markus Siemens242856c2014-01-28 19:52:04 +0100101 .globl _nlr_jump
102 .def _nlr_jump; .scl 2; .type 32; .endef
103_nlr_jump:
104#else
Damience89a212013-10-15 22:25:17 +0100105 .globl nlr_jump
106 .type nlr_jump, @function
107nlr_jump:
Markus Siemens19ccc6b2014-01-27 22:53:28 +0100108#endif
Damien George872a8292015-01-01 22:03:44 +0000109 mov NLR_TOP, %edx # load nlr_top
Damien George26cf55a2014-04-08 14:08:14 +0000110 test %edx, %edx # check for nlr_top being NULL
stijnbf1570c2015-11-20 15:18:42 +0100111#if defined(NLR_OS_WINDOWS)
Paul Sokolovsky41809a12014-04-20 22:14:58 +0300112 je _nlr_jump_fail # fail if nlr_top is NULL
113#else
Damien George26cf55a2014-04-08 14:08:14 +0000114 je nlr_jump_fail # fail if nlr_top is NULL
Paul Sokolovsky41809a12014-04-20 22:14:58 +0300115#endif
Damience89a212013-10-15 22:25:17 +0100116 mov 4(%esp), %eax # load return value
117 mov %eax, 4(%edx) # store return value
118 mov (%edx), %eax # load prev nlr_top
Damien George872a8292015-01-01 22:03:44 +0000119 mov %eax, NLR_TOP # store nlr_top (to unlink list)
Damience89a212013-10-15 22:25:17 +0100120 mov 28(%edx), %esi # load saved %si
121 mov 24(%edx), %edi # load saved %di
122 mov 20(%edx), %ebx # load saved %bx
123 mov 16(%edx), %esp # load saved %sp
124 mov 12(%edx), %ebp # load saved %bp
125 mov 8(%edx), %eax # load saved %ip
126 mov %eax, (%esp) # store saved %ip to stack
127 xor %eax, %eax # clear return register
128 inc %al # increase to make 1, non-local return
129 ret # return
stijnbf1570c2015-11-20 15:18:42 +0100130#if !defined(NLR_OS_WINDOWS)
Damience89a212013-10-15 22:25:17 +0100131 .size nlr_jump, .-nlr_jump
Markus Siemens19ccc6b2014-01-27 22:53:28 +0100132#endif
Damience89a212013-10-15 22:25:17 +0100133
Damien George133b0832014-09-26 13:07:26 +0000134#endif // defined(__i386__) && !MICROPY_NLR_SETJMP