summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sys/arm/arm/trap.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/sys/arm/arm/trap.c b/sys/arm/arm/trap.c
index 46595f1..2b2a7687 100644
--- a/sys/arm/arm/trap.c
+++ b/sys/arm/arm/trap.c
@@ -927,9 +927,22 @@ syscall(struct thread *td, trapframe_t *frame, u_int32_t insn)
}
switch (error) {
case 0:
+#ifdef __ARMEB__
+ if ((frame->fixreg[0] == SYS___syscall) &&
+ (code != SYS_lseek)) {
+ /*
+ * 64-bit return, 32-bit syscall. Fixup byte order
+ */
+ tf->tf_r0 = 0;
+ tf->rf_r1 = td->td_retval[0];
+ } else {
+ tf->tf_r0 = td->td_retval[0];
+ tf->tf_r1 = td->td_retval[1];
+ }
+#else
frame->tf_r0 = td->td_retval[0];
frame->tf_r1 = td->td_retval[1];
-
+#endif
frame->tf_spsr &= ~PSR_C_bit; /* carry bit */
break;
OpenPOWER on IntegriCloud