/* Copyright (C) 2001-2020 Free Software Foundation, Inc.
This file is part of the GNU C Library.
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
#include
/* Usage:
long int syscall (syscall_number, arg1, arg2, arg3, arg4, arg5, arg6, arg7)
We need to do some arg shifting, syscall_number will be in v0. */
.text
NESTED (syscall, SZREG, ra)
.mask 0x00010000, -SZREG
.fmask 0x00000000, 0
PTR_ADDIU sp, -SZREG
cfi_adjust_cfa_offset (SZREG)
REG_S s0, (sp)
cfi_rel_offset (s0, 0)
move s0, a0
move a0, a1 /* shift arg1 - arg7. */
move a1, a2
move a2, a3
move a3, a4
move a4, a5
move a5, a6
move a6, a7
move v0, s0 /* Syscall number -> v0 */
syscall /* Do the system call. */
REG_L s0, (sp)
cfi_restore (s0)
PTR_ADDIU sp, SZREG
cfi_adjust_cfa_offset (-SZREG)
bne a3, zero, L(error)
ret
L(error):
SETUP_GP64_REG (a0, syscall)
PTR_LA t9, __syscall_error
RESTORE_GP64_REG
jr t9
END (syscall)