1 /* Return -1 on error or 1 on success (never 0!). */
2 static int
get_syscall_args(struct tcb * tcp)3 get_syscall_args(struct tcb *tcp)
4 {
5 	if (!ia64_ia32mode) {
6 		unsigned long *rbs_end =
7 			(unsigned long *) ia64_regs.ar[PT_AUR_BSP];
8 		unsigned long sof = (ia64_regs.cfm >> 0) & 0x7f;
9 		unsigned long sol = (ia64_regs.cfm >> 7) & 0x7f;
10 		unsigned long *out0 = ia64_rse_skip_regs(rbs_end, -sof + sol);
11 		unsigned int i;
12 
13 		for (i = 0; i < tcp->s_ent->nargs; ++i) {
14 			if (umoven(tcp,
15 				   (unsigned long) ia64_rse_skip_regs(out0, i),
16 				   sizeof(long), &tcp->u_arg[i]) < 0)
17 				return -1;
18 		}
19 	} else {
20 		/* truncate away IVE sign-extension */
21 		tcp->u_arg[0] = 0xffffffff & ia64_regs.gr[11]; /* EBX */
22 		tcp->u_arg[1] = 0xffffffff & ia64_regs.gr[ 9]; /* ECX */
23 		tcp->u_arg[2] = 0xffffffff & ia64_regs.gr[10]; /* EDX */
24 		tcp->u_arg[3] = 0xffffffff & ia64_regs.gr[14]; /* ESI */
25 		tcp->u_arg[4] = 0xffffffff & ia64_regs.gr[15]; /* EDI */
26 		tcp->u_arg[5] = 0xffffffff & ia64_regs.gr[13]; /* EBP */
27 	}
28 	return 1;
29 }
30