Fixed bug where first call had wrong stack alignment
Tiny optimizations
This commit is contained in:
parent
85b7ac740b
commit
9eb36bd2bb
Binary file not shown.
Binary file not shown.
@ -221,12 +221,12 @@
|
|||||||
; #define PUSH(v) ( stk-=sizeof(cell), *(cell *)(data+(int)stk)=v )
|
; #define PUSH(v) ( stk-=sizeof(cell), *(cell *)(data+(int)stk)=v )
|
||||||
;
|
;
|
||||||
%macro _PUSH 1
|
%macro _PUSH 1
|
||||||
sub esi, 4
|
lea esi,[esi-4]
|
||||||
mov dword [esi], %1
|
mov dword [esi], %1
|
||||||
%endmacro
|
%endmacro
|
||||||
|
|
||||||
%macro _PUSHMEM 1
|
%macro _PUSHMEM 1
|
||||||
sub esi, 4
|
lea esi,[esi-4]
|
||||||
mov ebp, dword %1
|
mov ebp, dword %1
|
||||||
mov dword [esi], ebp
|
mov dword [esi], ebp
|
||||||
%endmacro
|
%endmacro
|
||||||
@ -236,7 +236,7 @@
|
|||||||
;
|
;
|
||||||
%macro _POP 1
|
%macro _POP 1
|
||||||
mov %1, dword [esi]
|
mov %1, dword [esi]
|
||||||
add esi, 4
|
lea esi,[esi+4]
|
||||||
%endmacro
|
%endmacro
|
||||||
|
|
||||||
|
|
||||||
@ -1021,7 +1021,7 @@ OP_RET:
|
|||||||
|
|
||||||
j_ret:
|
j_ret:
|
||||||
_POP ebx ; pop frame
|
_POP ebx ; pop frame
|
||||||
add esi,4 ; pop extra param
|
lea esi,[esi+4]
|
||||||
mov frm,ebx
|
mov frm,ebx
|
||||||
add ebx,edi
|
add ebx,edi
|
||||||
ret
|
ret
|
||||||
@ -1934,9 +1934,10 @@ _amx_exec_jit:
|
|||||||
|
|
||||||
add esi,edi ; ESP will contain DAT+STK
|
add esi,edi ; ESP will contain DAT+STK
|
||||||
|
|
||||||
add [esp+8],edi ; make STP absolute address for run-time checks
|
add [esp+8],edi ; make STP absolute address for run-time checks
|
||||||
|
|
||||||
_POP ecx ; AMX pseudo-return address, ignored
|
mov dword [esi], 0 ; zero this out, but we need to keep it so
|
||||||
|
; the stack frame is in tact
|
||||||
mov ecx,esp ; copy stack pointer
|
mov ecx,esp ; copy stack pointer
|
||||||
; Call compiled code via CALL NEAR <address>
|
; Call compiled code via CALL NEAR <address>
|
||||||
call ebp
|
call ebp
|
||||||
|
Loading…
Reference in New Issue
Block a user