summaryrefslogtreecommitdiff
path: root/sys/arch/mips64
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/mips64')
-rw-r--r--sys/arch/mips64/include/exec.h5
-rw-r--r--sys/arch/mips64/include/proc.h4
-rw-r--r--sys/arch/mips64/mips64/trap.c76
3 files changed, 18 insertions, 67 deletions
diff --git a/sys/arch/mips64/include/exec.h b/sys/arch/mips64/include/exec.h
index 3c63f743523..bf91f90dcb3 100644
--- a/sys/arch/mips64/include/exec.h
+++ b/sys/arch/mips64/include/exec.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: exec.h,v 1.1 2004/10/18 19:05:36 grange Exp $ */
+/* $OpenBSD: exec.h,v 1.2 2009/11/19 20:13:51 miod Exp $ */
/*
* Copyright (c) 1996-2004 Per Fogelstrom, Opsycon AB
@@ -62,9 +62,6 @@
#if defined(_LP64)
#define _KERN_DO_ELF64
-#if defined(COMPAT_O32)
-#define _KERN_DO_ELF
-#endif
#else
#define _KERN_DO_ELF
#endif
diff --git a/sys/arch/mips64/include/proc.h b/sys/arch/mips64/include/proc.h
index bbdd8f4a1af..587ee4be25f 100644
--- a/sys/arch/mips64/include/proc.h
+++ b/sys/arch/mips64/include/proc.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: proc.h,v 1.3 2009/06/10 18:05:30 miod Exp $ */
+/* $OpenBSD: proc.h,v 1.4 2009/11/19 20:13:51 miod Exp $ */
/*
* Copyright (c) 1992, 1993
@@ -57,8 +57,6 @@ struct mdproc {
/* md_flags */
#define MDP_FPUSED 0x00000001 /* floating point coprocessor used */
-#define MDP_O32 0x00000002 /* Uses 32 bit syscall interface */
-#define MDP_64 0x00000004 /* Uses new 64 bit syscall interface */
#define MDP_PERF 0x00010000 /* Performance counter used */
#define MDP_WATCH1 0x00020000 /* Watch register 1 used */
#define MDP_WATCH2 0x00040000 /* Watch register 1 used */
diff --git a/sys/arch/mips64/mips64/trap.c b/sys/arch/mips64/mips64/trap.c
index 95ee0ca4638..c39409c9279 100644
--- a/sys/arch/mips64/mips64/trap.c
+++ b/sys/arch/mips64/mips64/trap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: trap.c,v 1.47 2009/11/18 20:58:52 miod Exp $ */
+/* $OpenBSD: trap.c,v 1.48 2009/11/19 20:13:52 miod Exp $ */
/*
* Copyright (c) 1988 University of Utah.
@@ -447,24 +447,12 @@ printf("SIG-BUSB @%p pc %p, ra %p\n", trapframe->badvaddr, trapframe->pc, trapfr
args.i[1] = locr0->a2;
args.i[2] = locr0->a3;
if (i > 3) {
- if (p->p_md.md_flags & MDP_O32) {
- int32_t p[5];
-
- i = copyin((int32_t *)locr0->sp + 4,
- p, 5 * sizeof(int32_t));
- args.i[3] = p[0];
- args.i[4] = p[1];
- args.i[5] = p[2];
- args.i[6] = p[3];
- args.i[7] = p[4];
- } else {
- args.i[3] = locr0->a4;
- args.i[4] = locr0->a5;
- args.i[5] = locr0->a6;
- args.i[6] = locr0->a7;
- i = copyin((void *)locr0->sp,
- &args.i[7], sizeof(register_t));
- }
+ args.i[3] = locr0->a4;
+ args.i[4] = locr0->a5;
+ args.i[5] = locr0->a6;
+ args.i[6] = locr0->a7;
+ i = copyin((void *)locr0->sp,
+ &args.i[7], sizeof(register_t));
}
break;
@@ -473,38 +461,17 @@ printf("SIG-BUSB @%p pc %p, ra %p\n", trapframe->badvaddr, trapframe->pc, trapfr
* Like syscall, but code is a quad, so as to maintain
* quad alignment for the rest of the arguments.
*/
- if (p->p_md.md_flags & MDP_O32) {
- if (_QUAD_LOWWORD == 0) {
- code = locr0->a0;
- } else {
- code = locr0->a1;
- }
- args.i[0] = locr0->a2;
- args.i[1] = locr0->a3;
- } else {
- code = locr0->a0;
- args.i[0] = locr0->a1;
- args.i[1] = locr0->a2;
- args.i[2] = locr0->a3;
- }
+ code = locr0->a0;
+ args.i[0] = locr0->a1;
+ args.i[1] = locr0->a2;
+ args.i[2] = locr0->a3;
if (code >= numsys)
callp += p->p_emul->e_nosys; /* (illegal) */
else
callp += code;
i = callp->sy_argsize / sizeof(int);
- if (i > 2 && p->p_md.md_flags & MDP_O32) {
- int32_t p[6];
-
- i = copyin((int32_t *)locr0->sp + 4,
- p, 6 * sizeof(int32_t));
- args.i[2] = p[0];
- args.i[3] = p[1];
- args.i[4] = p[2];
- args.i[5] = p[3];
- args.i[6] = p[4];
- args.i[7] = p[5];
- } else if (i > 3) {
+ if (i > 3) {
args.i[3] = locr0->a4;
args.i[4] = locr0->a5;
args.i[5] = locr0->a6;
@@ -526,21 +493,10 @@ printf("SIG-BUSB @%p pc %p, ra %p\n", trapframe->badvaddr, trapframe->pc, trapfr
args.i[2] = locr0->a2;
args.i[3] = locr0->a3;
if (i > 4) {
- if (p->p_md.md_flags & MDP_O32) {
- int32_t p[4];
-
- i = copyin((int32_t *)locr0->sp + 4,
- p, 4 * sizeof(int32_t));
- args.i[4] = p[0];
- args.i[5] = p[1];
- args.i[6] = p[2];
- args.i[7] = p[3];
- } else {
- args.i[4] = locr0->a4;
- args.i[5] = locr0->a5;
- args.i[6] = locr0->a6;
- args.i[7] = locr0->a7;
- }
+ args.i[4] = locr0->a4;
+ args.i[5] = locr0->a5;
+ args.i[6] = locr0->a6;
+ args.i[7] = locr0->a7;
}
}
#ifdef SYSCALL_DEBUG