summaryrefslogtreecommitdiff
path: root/mit-pthreads/machdep/syscall-ip22-irix-5.2.S
blob: ded0fc55e3886c311cb6c9e01a75571be8a47585 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#include <sys.s>
#include <sys/regdef.h>

/*
 	Kernel syscall interface:
   	Input:
		v0		syscall	number
   	Output:

   	This macro is similar to SYSCALL in sys/syscall.h, but not completely.
   	There's room for optimization, if we assume this will continue to
   	be assembled as one file.

	Compile with -DPIC for pic code.
*/

#ifdef PIC
#define PICOPT  .option pic2
#else
#define PICOPT
#endif


#define YSYSCALL(x) 					\
	PICOPT;								\
	.globl 		machdep_sys_##x;		\
	.ent		machdep_sys_##x, 0;		\
machdep_sys_##x:;						\
	.frame  sp,0,ra;					\
	.set	noreorder;					\
	li	v0, SYS_##x;					\
	syscall;							\
	bne a3, zero, 1b;					\
	nop;								\
	j ra;								\
	nop;								\
	.end 		machdep_sys_##x

/* ==========================================================================
 * error code for all syscalls. The error value is returned as the negative
 * of the errno value.
 */

1:
	subu v0,zero,v0;
	j ra;

/* ==========================================================================
 * lstat
 */
	PICOPT;							
	.globl 		machdep_sys_lstat;		
	.ent		machdep_sys_lstat, 0;		
machdep_sys_lstat:;						
	.frame  sp,0,ra;					
	.set	noreorder;					
	move a2, a1
	move a1, a0
	li   a0, 2
	li	v0, SYS_lxstat;					
	syscall;							
	bne a3, zero, 1b;					
	nop;								
	j ra;							
	nop;								
	.end 		machdep_sys_lstat

/* ==========================================================================
 * fstat
 */
	PICOPT;							
	.globl 		machdep_sys_fstat;		
	.ent		machdep_sys_fstat, 0;		
machdep_sys_fstat:;						
	.frame  sp,0,ra;					
	.set	noreorder;					
	move a2, a1
	move a1, a0
	li   a0, 2
	li	v0, SYS_fxstat;					
	syscall;							
	bne a3, zero, 1b;					
	nop;								
	j ra;							
	nop;								
	.end 		machdep_sys_fstat

/* ==========================================================================
 * stat
 */
	PICOPT;							
	.globl 		machdep_sys_stat;		
	.ent		machdep_sys_stat, 0;		
machdep_sys_stat:;						
	.frame  sp,0,ra;					
	.set	noreorder;					
	move a2, a1
	move a1, a0
	li   a0, 2
	li	v0, SYS_xstat;					
	syscall;							
	bne a3, zero, 1b;					
	nop;								
	j ra;							
	nop;								
	.end 		machdep_sys_stat