~ubuntu-branches/ubuntu/utopic/eglibc/utopic

« back to all changes in this revision

Viewing changes to sysdeps/unix/sparc/sysdep.h

  • Committer: Package Import Robot
  • Author(s): Adam Conrad
  • Date: 2012-10-26 05:14:58 UTC
  • mfrom: (1.5.1) (4.4.22 experimental)
  • Revision ID: package-import@ubuntu.com-20121026051458-oryotr4i03ob5pab
Tags: 2.16-0ubuntu1
* Merge with unreleased 2.16 in Debian experimental, remaining changes:
  - Drop the Breaks line from libc6, which refers to a Debian transition
  - Remove the libc6 recommends on libc6-i686, which we don't build
  - Enable libc6{,-dev}-armel on armhf and libc6{-dev}-armhf on armel
  - Ship update-locale and validlocale in /usr/sbin in libc-bin
  - Don't build locales or locales-all in Ubuntu, we rely on langpacks
  - Heavily mangle the way we do service restarting on major upgrades
  - Use different MIN_KERNEL_SUPPORTED versions than Debian, due to
    buildd needs.  This should be universally bumped to 3.2.0 once all
    our buildds (including the PPA guests) are running precise kernels
  - Build i386 variants as -march=i686, build amd64 with -O3, and build
    ppc64 variants (both 64-bit and 32-bit) with -O3 -fno-tree-vectorize
  - Re-enable unsubmitted-ldconfig-cache-abi.diff and rebuild the cache
    on upgrades from previous versions that used a different constant
  - debian/patches/any/local-CVE-2012-3406.diff: switch to malloc when
    array grows too large to handle via alloca extension (CVE-2012-3406)
  - Build generic i386/i686 flavour with -mno-tls-direct-seg-refs
* Changes added/dropped with this merge while reducing our delta:
  - Stop building glibc docs from the eglibc source, and instead make
    the glibc-docs stub have a hard dependency on glibc-doc-reference
  - Remove outdated conflicts against ancient versions of ia32-libs
  - Drop the tzdata dependency from libc6, it's in required and minimal
  - Use gcc-4.7/g++-4.7 by default on all our supported architectures
  - Save our historical changelog as changelog.ubuntu in the source
  - Drop nscd's libaudit build-dep for now, as libaudit is in universe
  - Drop the unnecessary Breaks from libc6 to locales and locales-all
  - Ship xen's ld.so.conf.d snippet as /etc/ld.so.conf.d/libc6-xen.conf
* Disable hard failures on the test suite for the first upload to raring

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* Copyright (C) 1993, 1994, 1995, 1997, 2003, 2011
2
 
        Free Software Foundation, Inc.
3
 
   This file is part of the GNU C Library.
4
 
 
5
 
   The GNU C Library is free software; you can redistribute it and/or
6
 
   modify it under the terms of the GNU Lesser General Public
7
 
   License as published by the Free Software Foundation; either
8
 
   version 2.1 of the License, or (at your option) any later version.
9
 
 
10
 
   The GNU C Library is distributed in the hope that it will be useful,
11
 
   but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13
 
   Lesser General Public License for more details.
14
 
 
15
 
   You should have received a copy of the GNU Lesser General Public
16
 
   License along with the GNU C Library; if not, write to the Free
17
 
   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18
 
   02111-1307 USA.  */
19
 
 
20
 
#include <sysdeps/unix/sysdep.h>
21
 
#include <sysdeps/sparc/sysdep.h>
22
 
 
23
 
#ifdef  __ASSEMBLER__
24
 
 
25
 
#ifdef  NO_UNDERSCORES
26
 
/* Since C identifiers are not normally prefixed with an underscore
27
 
   on this system, the asm identifier `syscall_error' intrudes on the
28
 
   C name space.  Make sure we use an innocuous name.  */
29
 
#define syscall_error   C_SYMBOL_NAME(__syscall_error)
30
 
#endif
31
 
 
32
 
#ifdef PIC
33
 
#define SETUP_PIC_REG(reg, tmp)                                         \
34
 
        .ifndef __sparc_get_pc_thunk.reg;                               \
35
 
        .section .text.__sparc_get_pc_thunk.reg,"axG",@progbits,__sparc_get_pc_thunk.reg,comdat; \
36
 
        .align   32;                                                    \
37
 
        .weak    __sparc_get_pc_thunk.reg;                              \
38
 
        .hidden  __sparc_get_pc_thunk.reg;                              \
39
 
        .type    __sparc_get_pc_thunk.reg, #function;                   \
40
 
__sparc_get_pc_thunk.reg:                                               \
41
 
        jmp     %o7 + 8;                                                \
42
 
         add    %o7, %reg, %##reg;                                      \
43
 
        .previous;                                                      \
44
 
        .endif;                                                         \
45
 
        sethi   %hi(_GLOBAL_OFFSET_TABLE_-4), %##reg;                   \
46
 
        mov     %o7, %##tmp;                                            \
47
 
        call    __sparc_get_pc_thunk.reg;                               \
48
 
         or     %##reg, %lo(_GLOBAL_OFFSET_TABLE_+4), %##reg;           \
49
 
        mov     %##tmp, %o7;
50
 
#endif
51
 
 
52
 
#ifdef HAVE_ELF
53
 
#define ENTRY(name)             \
54
 
  .global C_SYMBOL_NAME(name);  \
55
 
  .type name,@function;         \
56
 
  .align 4;                     \
57
 
  C_LABEL(name)
58
 
 
59
 
#else
60
 
#define ENTRY(name)             \
61
 
  .global C_SYMBOL_NAME(name);  \
62
 
  .align 4;                     \
63
 
  C_LABEL(name)
64
 
 
65
 
#endif /* HAVE_ELF */
66
 
 
67
 
#define PSEUDO(name, syscall_name, args)        \
68
 
  .global syscall_error;                        \
69
 
  ENTRY (name)                                  \
70
 
  mov SYS_ify(syscall_name), %g1;               \
71
 
  ta 0;                                         \
72
 
  bcc 1f;                                       \
73
 
  sethi %hi(syscall_error), %g1;                \
74
 
  jmp %g1 + %lo(syscall_error); nop;            \
75
 
1:
76
 
 
77
 
#define PSEUDO_NOERRNO(name, syscall_name, args) \
78
 
  .global syscall_error;                        \
79
 
  ENTRY (name)                                  \
80
 
  mov SYS_ify(syscall_name), %g1;               \
81
 
  ta 0
82
 
 
83
 
#define PSEUDO_ERRVAL(name, syscall_name, args) \
84
 
  .global syscall_error;                        \
85
 
  ENTRY (name)                                  \
86
 
  mov SYS_ify(syscall_name), %g1;               \
87
 
  ta 0
88
 
 
89
 
#define ret             retl; nop
90
 
#define ret_NOERRNO     retl; nop
91
 
#define ret_ERRVAL      retl; nop
92
 
#define r0              %o0
93
 
#define r1              %o1
94
 
#define MOVE(x,y)       mov x, y
95
 
 
96
 
#endif  /* __ASSEMBLER__ */