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

« back to all changes in this revision

Viewing changes to ports/sysdeps/m68k/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
1
/* Assembler macros for m68k.
2
 
   Copyright (C) 1998, 2003, 2010 Free Software Foundation, Inc.
 
2
   Copyright (C) 1998, 2003, 2010, 2012 Free Software Foundation, Inc.
3
3
   This file is part of the GNU C Library.
4
4
 
5
5
   The GNU C Library is free software; you can redistribute it and/or
13
13
   Lesser General Public License for more details.
14
14
 
15
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.  */
 
16
   License along with the GNU C Library.  If not, see
 
17
   <http://www.gnu.org/licenses/>.  */
19
18
 
20
19
#include <sysdeps/generic/sysdep.h>
21
20
 
23
22
 
24
23
/* Syntactic details of assembler.  */
25
24
 
26
 
# ifdef HAVE_ELF
27
 
 
28
25
/* ELF uses byte-counts for .align, most others use log2 of count of bytes.  */
29
 
#  define ALIGNARG(log2) 1<<log2
 
26
# define ALIGNARG(log2) 1<<log2
30
27
/* For ELF we need the `.type' directive to make shared libs work right.  */
31
 
#  define ASM_TYPE_DIRECTIVE(name,typearg) .type name,typearg
32
 
#  define ASM_SIZE_DIRECTIVE(name) .size name,.-name
33
 
 
34
 
/* In ELF C symbols are asm symbols.  */
35
 
#  undef NO_UNDERSCORES
36
 
#  define NO_UNDERSCORES
37
 
 
38
 
# else
39
 
 
40
 
#  define ALIGNARG(log2) log2
41
 
#  define ASM_TYPE_DIRECTIVE(name,type) /* Nothing is specified.  */
42
 
#  define ASM_SIZE_DIRECTIVE(name)      /* Nothing is specified.  */
43
 
 
44
 
# endif
45
 
 
 
28
# define ASM_TYPE_DIRECTIVE(name,typearg) .type name,typearg
 
29
# define ASM_SIZE_DIRECTIVE(name) .size name,.-name
46
30
 
47
31
/* Define an entry point visible from C.
48
32
 
54
38
  ASM_TYPE_DIRECTIVE (C_SYMBOL_NAME(name),@function);                         \
55
39
  .align ALIGNARG(2);                                                         \
56
40
  C_LABEL(name)                                                               \
 
41
  cfi_startproc;                                                              \
57
42
  CALL_MCOUNT
58
43
 
59
44
# undef END
60
 
# define END(name) ASM_SIZE_DIRECTIVE(name)
 
45
# define END(name)                                                            \
 
46
  cfi_endproc;                                                                \
 
47
  ASM_SIZE_DIRECTIVE(name)
61
48
 
62
49
 
63
50
/* If compiled for profiling, call `_mcount' at the start of each function.  */
65
52
/* The mcount code relies on a normal frame pointer being on the stack
66
53
   to locate our caller, so push one just for its benefit.  */
67
54
#  define CALL_MCOUNT \
68
 
  move.l %fp, -(%sp); move.l %sp, %fp;                                        \
69
 
  jbsr JUMPTARGET (mcount);                                                   \
70
 
  move.l (%sp)+, %fp;
 
55
  move.l %fp, -(%sp);                                                         \
 
56
  cfi_adjust_cfa_offset (4);  cfi_rel_offset (%fp, 0);                        \
 
57
  move.l %sp, %fp;                                                            \
 
58
  jbsr JUMPTARGET (_mcount);                                                  \
 
59
  move.l (%sp)+, %fp;                                                         \
 
60
  cfi_adjust_cfa_offset (-4); cfi_restore (%fp);
71
61
# else
72
62
#  define CALL_MCOUNT           /* Do nothing.  */
73
63
# endif
74
64
 
75
 
# ifdef NO_UNDERSCORES
76
 
/* Since C identifiers are not normally prefixed with an underscore
77
 
   on this system, the asm identifier `syscall_error' intrudes on the
78
 
   C name space.  Make sure we use an innocuous name.  */
79
 
#  define syscall_error __syscall_error
80
 
#  define mcount        _mcount
81
 
# endif
82
 
 
83
65
# define PSEUDO(name, syscall_name, args)                                     \
84
 
  .globl syscall_error;                                                       \
 
66
  .globl __syscall_error;                                                     \
85
67
  ENTRY (name)                                                                \
86
68
    DO_CALL (syscall_name, args);                                             \
87
 
    jcc JUMPTARGET(syscall_error)
 
69
    jcc JUMPTARGET(__syscall_error)
88
70
 
89
71
# undef PSEUDO_END
90
72
# define PSEUDO_END(name)                                                     \