From 1e8d3393a36a84aab41cf56d6daca029d4ac3f43 Mon Sep 17 00:00:00 2001 From: "\"Steven J. Hill\"" Date: Thu, 12 Jul 2007 00:58:41 +0000 Subject: Fix broken syscall() function since the original patch did not work. --- libc/sysdeps/linux/mips/syscall.S | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) (limited to 'libc/sysdeps/linux/mips/syscall.S') diff --git a/libc/sysdeps/linux/mips/syscall.S b/libc/sysdeps/linux/mips/syscall.S index 965eeac1e..683529596 100644 --- a/libc/sysdeps/linux/mips/syscall.S +++ b/libc/sysdeps/linux/mips/syscall.S @@ -29,6 +29,8 @@ .type syscall,@function .ent syscall syscall: + .set noreorder + .cpload t9; move v0, a0 /* Load system call number from first arg. */ move a0, a1 /* Move the next three args up a register. */ move a1, a2 @@ -55,15 +57,15 @@ syscall: lw v0,7*4(sp) /* for system call restarts */ #endif syscall /* Do the system call. */ + bnez a3, 1f #ifdef __mips64 daddiu sp,sp,16 #else addiu sp,sp,32 #endif - bnez a3, 1f j ra /* Return to caller. */ 1: - move a0,v0 /* Pass return val to C function. */ + move a0,v0 /* Pass return val to C function. */ #ifdef __PIC__ PTR_LA t9, __syscall_error -- cgit v1.2.3