/* Copyright (C) 1992-2016 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, see
. */
#include
#define _ERRNO_H
#include
#include
.set nomips16
#ifdef _LIBC_REENTRANT
LOCALSZ= 3
FRAMESZ= (((NARGSAVE+LOCALSZ)*SZREG)+ALSZ)&ALMASK
RAOFF= FRAMESZ-(1*SZREG)
GPOFF= FRAMESZ-(2*SZREG)
V0OFF= FRAMESZ-(3*SZREG)
ENTRY(__syscall_error)
#ifdef __PIC__
.set noat
SETUP_GPX (AT)
.set at
#endif
PTR_SUBU sp, FRAMESZ
.set noat
SETUP_GPX64(GPOFF,AT)
.set at
#ifdef __PIC__
SAVE_GP(GPOFF)
#endif
REG_S v0, V0OFF(sp)
REG_S ra, RAOFF(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. */
REG_L t0, V0OFF(sp)
sw t0, 0(v0)
/* And just kick back a -1. */
REG_L ra, RAOFF(sp)
RESTORE_GP64
PTR_ADDU sp, FRAMESZ
li v0, -1
j ra
END(__syscall_error)
#else /* _LIBC_REENTRANT */
ENTRY(__syscall_error)
#ifdef __PIC__
SETUP_GPX (AT)
#endif
SETUP_GPX64 (t9, AT)
#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
RESTORE_GP64
j ra
END(__syscall_error)
#endif /* _LIBC_REENTRANT */