2014-05-15 17:45:52 +02:00
|
|
|
/*
|
2014-08-29 18:30:37 +02:00
|
|
|
* Copyright (C) 2013, 2014 Ludwig Ortmann <ludwig.ortmann@fu-berlin.de>
|
|
|
|
* Copyright (C) 2014 Thomas Eichinger <thomas.eichinger1@gmail.com>
|
2014-05-15 17:45:52 +02:00
|
|
|
*
|
2014-07-31 19:45:27 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
2014-05-15 17:45:52 +02:00
|
|
|
*/
|
|
|
|
|
2013-05-14 18:31:47 +02:00
|
|
|
.text
|
|
|
|
|
2013-05-15 17:45:43 +02:00
|
|
|
#ifdef __MACH__
|
|
|
|
.globl __native_sig_leave_tramp
|
|
|
|
__native_sig_leave_tramp:
|
2014-01-20 22:25:52 +01:00
|
|
|
pushl __native_saved_eip
|
|
|
|
pushfl
|
|
|
|
pushal
|
2013-05-15 17:45:43 +02:00
|
|
|
|
2013-10-16 15:33:04 +02:00
|
|
|
pushl __native_isr_ctx
|
|
|
|
pushl __native_cur_ctx
|
2013-05-15 17:45:43 +02:00
|
|
|
call _swapcontext
|
2013-10-16 15:33:04 +02:00
|
|
|
addl $8, %esp
|
2013-05-15 17:45:43 +02:00
|
|
|
|
2014-01-21 12:22:55 +01:00
|
|
|
call _eINT
|
|
|
|
|
2013-10-16 15:33:04 +02:00
|
|
|
movl $0x0, __native_in_isr
|
2014-01-20 22:25:52 +01:00
|
|
|
popal
|
|
|
|
popfl
|
2013-05-15 17:45:43 +02:00
|
|
|
|
2014-05-15 11:34:54 +02:00
|
|
|
ret
|
2014-08-29 18:30:37 +02:00
|
|
|
#elif __arm__
|
|
|
|
|
|
|
|
.globl _native_sig_leave_tramp
|
|
|
|
_native_sig_leave_tramp:
|
|
|
|
/* save _native_saved_eip and registers */
|
|
|
|
stmdb sp!, {r0}
|
|
|
|
ldr r0, =_native_saved_eip
|
|
|
|
ldr r0, [r0]
|
|
|
|
stmdb sp!, {r0-r12}
|
|
|
|
stmdb sp!, {lr}
|
|
|
|
|
|
|
|
/* exchange r0 and _native_saved_eip */
|
|
|
|
ldr r0, [sp,#56]
|
|
|
|
ldr r1, [sp,#4 ]
|
|
|
|
str r0, [sp,#4 ]
|
|
|
|
str r1, [sp,#56]
|
|
|
|
|
|
|
|
/* call swapcontext ( _native_cur_ctx, _native_isr_ctx ) */
|
|
|
|
ldr r2, =_native_cur_ctx
|
|
|
|
ldr r0, [r2]
|
|
|
|
ldr r2, =_native_isr_ctx
|
|
|
|
ldr r1, [r2]
|
|
|
|
bl swapcontext
|
|
|
|
|
|
|
|
/* reeanble interrupts */
|
|
|
|
bl eINT
|
|
|
|
|
|
|
|
/* _native_in_isr = 0 */
|
|
|
|
eor r0, r0, r0
|
|
|
|
ldr r2, =_native_in_isr
|
|
|
|
str r0, [r2]
|
|
|
|
|
|
|
|
/* restore registers, jump to (saved) _native_saved_eip */
|
|
|
|
ldmia sp!, {lr}
|
|
|
|
ldmia sp!, {r0-r12}
|
|
|
|
ldmia sp!, {pc}
|
|
|
|
|
2013-05-15 17:45:43 +02:00
|
|
|
#else
|
2013-05-14 18:31:47 +02:00
|
|
|
.globl _native_sig_leave_tramp
|
|
|
|
|
|
|
|
_native_sig_leave_tramp:
|
2014-01-20 22:25:52 +01:00
|
|
|
pushl _native_saved_eip
|
|
|
|
pushfl
|
|
|
|
pushal
|
2013-05-14 18:31:47 +02:00
|
|
|
|
2013-10-16 15:33:04 +02:00
|
|
|
pushl _native_isr_ctx
|
|
|
|
pushl _native_cur_ctx
|
2013-05-14 18:31:47 +02:00
|
|
|
call swapcontext
|
2013-10-16 15:33:04 +02:00
|
|
|
addl $8, %esp
|
2013-05-14 18:31:47 +02:00
|
|
|
|
2013-11-08 13:14:44 +01:00
|
|
|
call eINT
|
|
|
|
|
2013-10-16 15:33:04 +02:00
|
|
|
movl $0x0, _native_in_isr
|
2014-01-20 22:25:52 +01:00
|
|
|
popal
|
|
|
|
popfl
|
2013-05-14 18:31:47 +02:00
|
|
|
|
2014-05-15 11:34:54 +02:00
|
|
|
ret
|
2013-05-15 17:45:43 +02:00
|
|
|
#endif
|