~ubuntu-branches/ubuntu/natty/eglibc/natty-security

« back to all changes in this revision

Viewing changes to ports/sysdeps/unix/mips/mips64/n32/sysdep.h

  • Committer: Bazaar Package Importer
  • Author(s): Aurelien Jarno
  • Date: 2009-05-05 09:54:14 UTC
  • Revision ID: james.westby@ubuntu.com-20090505095414-c45qsg9ixjheohru
ImportĀ upstreamĀ versionĀ 2.9

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
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