* configure.in: Add mips64* support.
[jlayton/glibc.git] / sysdeps / unix / mips / mips64 / n32 / sysdep.h
1 /* Copyright (C) 1992, 1995, 1997, 1999, 2000, 2002, 2003
2         Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
4    Contributed by Alexandre Oliva <aoliva@redhat.com>.
5
6    The GNU C Library is free software; you can redistribute it and/or
7    modify it under the terms of the GNU Lesser General Public
8    License as published by the Free Software Foundation; either
9    version 2.1 of the License, or (at your option) any later version.
10
11    The GNU C Library is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14    Lesser General Public License for more details.
15
16    You should have received a copy of the GNU Lesser General Public
17    License along with the GNU C Library; if not, write to the Free
18    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
19    02111-1307 USA.  */
20
21 #include <sysdeps/unix/mips/sysdep.h>
22
23 #ifdef __ASSEMBLER__
24
25 /* Note that while it's better structurally, going back to call __syscall_error
26    can make things confusing if you're debugging---it looks like it's jumping
27    backwards into the previous fn.  */
28 #ifdef __PIC__
29 #define PSEUDO(name, syscall_name, args) \
30   .align 2;                                                                   \
31   99:;                                                                        \
32   .set noat;                                                                  \
33   .cpsetup t9, $1, name;                                                      \
34   .set at;                                                                    \
35   la t9,__syscall_error;                                                      \
36   .cpreturn;                                                                  \
37   jr t9;                                                                      \
38   ENTRY(name)                                                                 \
39   li v0, SYS_ify(syscall_name);                                               \
40   syscall;                                                                    \
41   bne a3, zero, 99b;                                                          \
42 L(syse1):
43 #else
44 #define PSEUDO(name, syscall_name, args) \
45   .set noreorder;                                                             \
46   .align 2;                                                                   \
47   99: j __syscall_error;                                                      \
48   ENTRY(name)                                                                 \
49   .set noreorder;                                                             \
50   li v0, SYS_ify(syscall_name);                                               \
51   syscall;                                                                    \
52   .set reorder;                                                               \
53   bne a3, zero, 99b;                                                          \
54 L(syse1):
55 #endif
56
57 #endif