32 lines
		
	
	
		
			650 B
		
	
	
	
		
			ArmAsm
		
	
	
	
			
		
		
	
	
			32 lines
		
	
	
		
			650 B
		
	
	
	
		
			ArmAsm
		
	
	
	
/
 | 
						|
/ our buffer looks like:
 | 
						|
/  eax,ebx,ecx,edx,esi,edi,esp,ebp,pc
 | 
						|
/
 | 
						|
/ _longjmp is called with two parameters:  jmp_buf*,int
 | 
						|
/ jmp_buf* is at 4(%esp), int is at 8(%esp)
 | 
						|
/ retaddr is, of course, at (%esp)
 | 
						|
 | 
						|
	.globl	_longjmp
 | 
						|
	.globl	longjmp
 | 
						|
_longjmp:
 | 
						|
longjmp:
 | 
						|
	movl	4(%esp), %ebx	/ address of buf
 | 
						|
	movl	8(%esp), %eax	/ store return value
 | 
						|
 | 
						|
	movl	24(%ebx), %esp	/ restore stack
 | 
						|
	movl	32(%ebx), %edi
 | 
						|
/ Next line sets up return address.
 | 
						|
	movl	%edi, 0(%esp)	
 | 
						|
	movl	8(%ebx), %ecx
 | 
						|
	movl	12(%ebx), %edx
 | 
						|
	movl	16(%ebx), %esi
 | 
						|
	movl	20(%ebx), %edi
 | 
						|
	movl	28(%ebx), %ebp
 | 
						|
	movl	4(%ebx), %ebx
 | 
						|
	testl	%eax,%eax
 | 
						|
	jne	bye
 | 
						|
	incl	%eax		/ eax hold 0 if we are here
 | 
						|
bye:
 | 
						|
	ret
 | 
						|
 |