blob: 03c2797357842f2ad8cc4d61651c1e110d88ddb5 [file] [log] [blame]
Jeff Diked67b5692005-07-07 17:56:49 -07001#include "uml-config.h"
2
3 .globl syscall_stub
4.section .__syscall_stub, "x"
5syscall_stub:
6 syscall
7 /* We don't have 64-bit constants, so this constructs the address
8 * we need.
9 */
10 movq $(UML_CONFIG_STUB_DATA >> 32), %rbx
11 salq $32, %rbx
12 movq $(UML_CONFIG_STUB_DATA & 0xffffffff), %rcx
13 or %rcx, %rbx
14 movq %rax, (%rbx)
15 int3
Jeff Dikec5600492005-09-03 15:57:36 -070016
17 .globl batch_syscall_stub
18batch_syscall_stub:
Bodo Stroesser07bf7312005-09-03 15:57:50 -070019 mov $(UML_CONFIG_STUB_DATA >> 32), %rbx
20 sal $32, %rbx
21 mov $(UML_CONFIG_STUB_DATA & 0xffffffff), %rax
22 or %rax, %rbx
23 /* load pointer to first operation */
24 mov %rbx, %rsp
25 add $0x10, %rsp
26again:
27 /* load length of additional data */
28 mov 0x0(%rsp), %rax
29
30 /* if(length == 0) : end of list */
31 /* write possible 0 to header */
32 mov %rax, 8(%rbx)
33 cmp $0, %rax
34 jz done
35
36 /* save current pointer */
37 mov %rsp, 8(%rbx)
38
39 /* skip additional data */
40 add %rax, %rsp
41
42 /* load syscall-# */
43 pop %rax
44
45 /* load syscall params */
Jeff Dikec5600492005-09-03 15:57:36 -070046 pop %rdi
47 pop %rsi
48 pop %rdx
49 pop %r10
50 pop %r8
51 pop %r9
Bodo Stroesser07bf7312005-09-03 15:57:50 -070052
53 /* execute syscall */
Jeff Dikec5600492005-09-03 15:57:36 -070054 syscall
Bodo Stroesser07bf7312005-09-03 15:57:50 -070055
56 /* check return value */
57 pop %rcx
58 cmp %rcx, %rax
59 je again
60
61done:
62 /* save return value */
Jeff Dikec5600492005-09-03 15:57:36 -070063 mov %rax, (%rbx)
Bodo Stroesser07bf7312005-09-03 15:57:50 -070064
65 /* stop */
66 int3