52 lines
		
	
	
		
			764 B
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			764 B
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
#include "as-layout.h"
 | 
						|
 | 
						|
	.globl syscall_stub
 | 
						|
.section .__syscall_stub, "ax"
 | 
						|
 | 
						|
	.globl batch_syscall_stub
 | 
						|
batch_syscall_stub:
 | 
						|
	/* load pointer to first operation */
 | 
						|
	mov	$(STUB_DATA+8), %esp
 | 
						|
 | 
						|
again:
 | 
						|
	/* load length of additional data */
 | 
						|
	mov	0x0(%esp), %eax
 | 
						|
 | 
						|
	/* if(length == 0) : end of list */
 | 
						|
	/* write possible 0 to header */
 | 
						|
	mov	%eax, STUB_DATA+4
 | 
						|
	cmpl	$0, %eax
 | 
						|
	jz	done
 | 
						|
 | 
						|
	/* save current pointer */
 | 
						|
	mov	%esp, STUB_DATA+4
 | 
						|
 | 
						|
	/* skip additional data */
 | 
						|
	add	%eax, %esp
 | 
						|
 | 
						|
	/* load syscall-# */
 | 
						|
	pop	%eax
 | 
						|
 | 
						|
	/* load syscall params */
 | 
						|
	pop	%ebx
 | 
						|
	pop	%ecx
 | 
						|
	pop	%edx
 | 
						|
	pop	%esi
 | 
						|
 	pop	%edi
 | 
						|
	pop	%ebp
 | 
						|
 | 
						|
	/* execute syscall */
 | 
						|
	int	$0x80
 | 
						|
 | 
						|
	/* check return value */
 | 
						|
	pop	%ebx
 | 
						|
	cmp	%ebx, %eax
 | 
						|
	je	again
 | 
						|
 | 
						|
done:
 | 
						|
	/* save return value */
 | 
						|
	mov	%eax, STUB_DATA
 | 
						|
 | 
						|
	/* stop */
 | 
						|
	int3
 |