summaryrefslogtreecommitdiffstats
path: root/sys/arm
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arm')
-rw-r--r--sys/arm/arm/trap.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/sys/arm/arm/trap.c b/sys/arm/arm/trap.c
index 2b2a7687..bcb703d 100644
--- a/sys/arm/arm/trap.c
+++ b/sys/arm/arm/trap.c
@@ -928,16 +928,16 @@ syscall(struct thread *td, trapframe_t *frame, u_int32_t insn)
switch (error) {
case 0:
#ifdef __ARMEB__
- if ((frame->fixreg[0] == SYS___syscall) &&
+ if ((insn & 0x000fffff) &&
(code != SYS_lseek)) {
/*
* 64-bit return, 32-bit syscall. Fixup byte order
*/
- tf->tf_r0 = 0;
- tf->rf_r1 = td->td_retval[0];
+ frame->tf_r0 = 0;
+ frame->tf_r1 = td->td_retval[0];
} else {
- tf->tf_r0 = td->td_retval[0];
- tf->tf_r1 = td->td_retval[1];
+ frame->tf_r0 = td->td_retval[0];
+ frame->tf_r1 = td->td_retval[1];
}
#else
frame->tf_r0 = td->td_retval[0];
OpenPOWER on IntegriCloud