URL
https://opencores.org/ocsvn/or1k/or1k/trunk
Subversion Repositories or1k
[/] [or1k/] [trunk/] [linux/] [uClibc/] [libc/] [sysdeps/] [linux/] [v850/] [syscall.c] - Rev 1325
Go to most recent revision | Compare with Previous | Blame | View Log
/* * libc/sysdeps/linux/v850/syscall.c -- generic syscall function for linux/v850 * * Copyright (C) 2002 NEC Corporation * Copyright (C) 2002 Miles Bader <miles@gnu.org> * * This file is subject to the terms and conditions of the GNU Lesser * General Public License. See the file COPYING.LIB in the main * directory of this archive for more details. * * Written by Miles Bader <miles@gnu.org> */ #include <errno.h> #include <sys/syscall.h> typedef unsigned long arg_t; /* Invoke `system call' NUM, passing it the remaining arguments. This is completely system-dependent, and not often useful. */ long syscall (long num, arg_t a1, arg_t a2, arg_t a3, arg_t a4, arg_t a5, arg_t a6) { /* We don't know how many arguments are valid, so A5 and A6 are fetched off the stack even for (the majority of) system calls with fewer arguments; hopefully this won't cause any problems. A1-A4 are in registers, so they're OK. */ register arg_t a asm (SYSCALL_ARG0) = a1; register arg_t b asm (SYSCALL_ARG1) = a2; register arg_t c asm (SYSCALL_ARG2) = a3; register arg_t d asm (SYSCALL_ARG3) = a4; register arg_t e asm (SYSCALL_ARG4) = a5; register arg_t f asm (SYSCALL_ARG5) = a6; register unsigned long syscall asm (SYSCALL_NUM) = num; register unsigned long ret asm (SYSCALL_RET); asm ("trap " SYSCALL_LONG_TRAP : "=r" (ret) : "r" (syscall), "r" (a), "r" (b), "r" (c), "r" (d), "r" (e), "r" (f) : SYSCALL_CLOBBERS); __syscall_return (long, ret); }
Go to most recent revision | Compare with Previous | Blame | View Log