2015-03-13 18:52:59 +00:00
|
|
|
; Copyright (c) 2008-2015, Avian Contributors
|
2013-01-28 18:51:35 +00:00
|
|
|
;
|
|
|
|
; Permission to use, copy, modify, and/or distribute this software
|
|
|
|
; for any purpose with or without fee is hereby granted, provided
|
|
|
|
; that the above copyright notice and this permission notice appear
|
|
|
|
; in all copies.
|
|
|
|
;
|
|
|
|
; There is NO WARRANTY for this software. See license.txt for
|
|
|
|
; details.
|
|
|
|
;
|
|
|
|
; ORIGIN: https://github.com/gkvas/avian/tree/wince
|
|
|
|
|
2013-01-28 15:20:52 +00:00
|
|
|
AREA text, CODE, ARM
|
|
|
|
|
2013-01-29 07:40:29 +00:00
|
|
|
EXPORT vmNativeCall
|
2013-01-28 15:20:52 +00:00
|
|
|
vmNativeCall
|
|
|
|
; arguments:
|
|
|
|
; r0 -> r4 : function
|
|
|
|
; r1 -> r5 : stackTotal
|
|
|
|
; r2 : memoryTable
|
|
|
|
; r3 : memoryCount
|
|
|
|
; [sp, #0] -> r6 : gprTable
|
|
|
|
|
|
|
|
mov ip, sp ; save stack frame
|
|
|
|
stmfd sp!, {r4-r6, lr} ; save clobbered non-volatile regs
|
|
|
|
|
|
|
|
; mv args into non-volatile regs
|
|
|
|
mov r4, r0
|
|
|
|
mov r5, r1
|
|
|
|
ldr r6, [ip]
|
|
|
|
|
|
|
|
; setup stack arguments if necessary
|
|
|
|
sub sp, sp, r5 ; allocate stack
|
|
|
|
mov ip, sp
|
|
|
|
loop
|
|
|
|
tst r3, r3
|
|
|
|
ldrne r0, [r2], #4
|
|
|
|
strne r0, [ip], #4
|
|
|
|
subne r3, r3, #4
|
|
|
|
bne loop
|
|
|
|
|
|
|
|
; setup argument registers if necessary
|
|
|
|
tst r6, r6
|
|
|
|
ldmneia r6, {r0-r3}
|
|
|
|
|
|
|
|
blx r4 ; call function
|
|
|
|
add sp, sp, r5 ; deallocate stack
|
|
|
|
|
|
|
|
ldmfd sp!, {r4-r6, pc} ; restore non-volatile regs and return
|
|
|
|
|
2013-01-29 07:40:29 +00:00
|
|
|
EXPORT vmJump
|
2013-01-28 15:20:52 +00:00
|
|
|
vmJump
|
|
|
|
mov lr, r0
|
|
|
|
ldr r0, [sp]
|
|
|
|
ldr r1, [sp, #4]
|
|
|
|
mov sp, r2
|
|
|
|
mov r8, r3
|
|
|
|
bx lr
|
|
|
|
|
|
|
|
CHECKPOINT_THREAD EQU 4
|
|
|
|
CHECKPOINT_STACK EQU 24
|
|
|
|
|
2013-01-29 07:40:29 +00:00
|
|
|
EXPORT vmRun
|
2013-01-28 15:20:52 +00:00
|
|
|
vmRun
|
|
|
|
; r0: function
|
|
|
|
; r1: arguments
|
|
|
|
; r2: checkpoint
|
|
|
|
stmfd sp!, {r4-r11, lr}
|
|
|
|
; align stack
|
|
|
|
sub sp, sp, #12
|
|
|
|
|
|
|
|
str sp, [r2, #CHECKPOINT_STACK]
|
|
|
|
|
|
|
|
mov r12, r0
|
|
|
|
ldr r0, [r2, #CHECKPOINT_THREAD]
|
|
|
|
|
|
|
|
blx r12
|
|
|
|
|
2013-01-29 07:40:29 +00:00
|
|
|
EXPORT vmRun_returnAddress
|
2013-01-28 15:20:52 +00:00
|
|
|
vmRun_returnAddress
|
|
|
|
add sp, sp, #12
|
|
|
|
ldmfd sp!, {r4-r11, lr}
|
|
|
|
bx lr
|
|
|
|
|
2013-01-29 07:40:29 +00:00
|
|
|
EXPORT vmTrap
|
2013-01-28 15:20:52 +00:00
|
|
|
vmTrap
|
|
|
|
bkpt 3
|
|
|
|
|
|
|
|
END
|