glibc/sysdeps/unix/mips/sysdep.S
Roland McGrath 3e9a97580a 2003-03-13 Alexandre Oliva <aoliva@redhat.com>
* sysdeps/mips/add_n.S: Use L macro for local labels.
	* sysdeps/mips/addmul_1.S: Likewise.
	* sysdeps/mips/lshift.S: Likewise.
	* sysdeps/mips/memcpy.S: Likewise.
	* sysdeps/mips/memset.S: Likewise.
	* sysdeps/mips/mul_1.S: Likewise.
	* sysdeps/mips/rshift.S: Likewise.
	* sysdeps/mips/sub_n.S: Likewise.
	* sysdeps/mips/submul_1.S: Likewise.
	* sysdeps/mips/mips64/add_n.S: Likewise.
	* sysdeps/mips/mips64/addmul_1.S: Likewise.
	* sysdeps/mips/mips64/lshift.S: Likewise.
	* sysdeps/mips/mips64/mul_1.S: Likewise.
	* sysdeps/mips/mips64/rshift.S: Likewise.
	* sysdeps/mips/mips64/sub_n.S: Likewise.
	* sysdeps/mips/mips64/submul_1.S: Likewise.
	* sysdeps/unix/mips/sysdep.h: Define L() according to ABI
	conventions.  Define END as in sys/asm.h.
	* sysdeps/unix/mips/sysdep.S: Likewise.
	* sysdeps/unix/mips/wait.S: Likewise.
	* sysdeps/unix/sysv/linux/mips/clone.S: Likewise.
2003-03-14 03:59:37 +00:00

100 lines
2.4 KiB
ArmAsm

/* Copyright (C) 1992, 1993, 1994, 1997, 1998, 1999, 2000, 2002, 2003
Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Brendan Kehoe (brendan@zen.org).
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with the GNU C Library; if not, write to the Free
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
02111-1307 USA. */
#include <sysdep.h>
#define _ERRNO_H
#include <bits/errno.h>
#ifdef _LIBC_REENTRANT
ENTRY(__syscall_error)
#ifdef __PIC__
.set noreorder
.set noat
move AT, ra
bltzal zero, 0f
nop
0: .cpload ra
move ra, AT
.set at
.set reorder
#endif
subu sp, 32
#ifdef __PIC__
.cprestore 16
#endif
sw v0, 20(sp)
sw ra, 24(sp)
#if defined (EWOULDBLOCK_sys) && EWOULDBLOCK_sys != EAGAIN
/* We translate the system's EWOULDBLOCK error into EAGAIN.
The GNU C library always defines EWOULDBLOCK==EAGAIN.
EWOULDBLOCK_sys is the original number. */
bne v0, EWOULDBLOCK_sys, L(skip)
nop
li v0, EAGAIN
L(skip):
#endif
/* Find our per-thread errno address */
jal __errno_location
/* Store the error value. */
lw t0, 20(sp)
sw t0, 0(v0)
/* And just kick back a -1. */
lw ra, 24(sp)
addiu sp, 32
li v0, -1
j ra
END(__syscall_error)
#else /* _LIBC_REENTRANT */
ENTRY(__syscall_error)
#ifdef __PIC__
.set noreorder
.set noat
move AT, ra
bltzal zero, 0f
nop
0: .cpload ra
move ra, AT
.set at
.set reorder
#endif
#if defined (EWOULDBLOCK_sys) && EWOULDBLOCK_sys != EAGAIN
/* We translate the system's EWOULDBLOCK error into EAGAIN.
The GNU C library always defines EWOULDBLOCK==EAGAIN.
EWOULDBLOCK_sys is the original number. */
bne v0, EWOULDBLOCK_sys, L(skip)
li v0, EAGAIN
L(skip):
#endif
/* Store it in errno... */
sw v0, errno
/* And just kick back a -1. */
li v0, -1
j ra
END(__syscall_error)
#endif /* _LIBC_REENTRANT */