annotate gcc/config/powerpcspe/linux.h @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Definitions of target machine for GNU compiler,
kono
parents:
diff changeset
2 for PowerPC machines running Linux.
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
3 Copyright (C) 1996-2018 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
4 Contributed by Michael Meissner (meissner@cygnus.com).
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 This file is part of GCC.
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 GCC is free software; you can redistribute it and/or modify it
kono
parents:
diff changeset
9 under the terms of the GNU General Public License as published
kono
parents:
diff changeset
10 by the Free Software Foundation; either version 3, or (at your
kono
parents:
diff changeset
11 option) any later version.
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 GCC is distributed in the hope that it will be useful, but WITHOUT
kono
parents:
diff changeset
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
kono
parents:
diff changeset
15 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
kono
parents:
diff changeset
16 License for more details.
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
19 along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
20 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 /* Linux doesn't support saving and restoring 64-bit regs in a 32-bit
kono
parents:
diff changeset
23 process. */
kono
parents:
diff changeset
24 #define OS_MISSING_POWERPC64 1
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 /* We use glibc _mcount for profiling. */
kono
parents:
diff changeset
27 #define NO_PROFILE_COUNTERS 1
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 #ifdef SINGLE_LIBC
kono
parents:
diff changeset
30 #define OPTION_GLIBC (DEFAULT_LIBC == LIBC_GLIBC)
kono
parents:
diff changeset
31 #define OPTION_UCLIBC (DEFAULT_LIBC == LIBC_UCLIBC)
kono
parents:
diff changeset
32 #define OPTION_BIONIC (DEFAULT_LIBC == LIBC_BIONIC)
kono
parents:
diff changeset
33 #undef OPTION_MUSL
kono
parents:
diff changeset
34 #define OPTION_MUSL (DEFAULT_LIBC == LIBC_MUSL)
kono
parents:
diff changeset
35 #else
kono
parents:
diff changeset
36 #define OPTION_GLIBC (linux_libc == LIBC_GLIBC)
kono
parents:
diff changeset
37 #define OPTION_UCLIBC (linux_libc == LIBC_UCLIBC)
kono
parents:
diff changeset
38 #define OPTION_BIONIC (linux_libc == LIBC_BIONIC)
kono
parents:
diff changeset
39 #undef OPTION_MUSL
kono
parents:
diff changeset
40 #define OPTION_MUSL (linux_libc == LIBC_MUSL)
kono
parents:
diff changeset
41 #endif
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 /* Determine what functions are present at the runtime;
kono
parents:
diff changeset
44 this includes full c99 runtime and sincos. */
kono
parents:
diff changeset
45 #undef TARGET_LIBC_HAS_FUNCTION
kono
parents:
diff changeset
46 #define TARGET_LIBC_HAS_FUNCTION linux_libc_has_function
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 #undef TARGET_OS_CPP_BUILTINS
kono
parents:
diff changeset
49 #define TARGET_OS_CPP_BUILTINS() \
kono
parents:
diff changeset
50 do \
kono
parents:
diff changeset
51 { \
kono
parents:
diff changeset
52 builtin_define_std ("PPC"); \
kono
parents:
diff changeset
53 builtin_define_std ("powerpc"); \
kono
parents:
diff changeset
54 builtin_assert ("cpu=powerpc"); \
kono
parents:
diff changeset
55 builtin_assert ("machine=powerpc"); \
kono
parents:
diff changeset
56 TARGET_OS_SYSV_CPP_BUILTINS (); \
kono
parents:
diff changeset
57 } \
kono
parents:
diff changeset
58 while (0)
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 #undef CPP_OS_DEFAULT_SPEC
kono
parents:
diff changeset
61 #define CPP_OS_DEFAULT_SPEC "%(cpp_os_linux)"
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 #undef LINK_SHLIB_SPEC
kono
parents:
diff changeset
64 #define LINK_SHLIB_SPEC "%{shared:-shared} %{!shared: %{static:-static}}"
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 #undef LIB_DEFAULT_SPEC
kono
parents:
diff changeset
67 #define LIB_DEFAULT_SPEC "%(lib_linux)"
kono
parents:
diff changeset
68
kono
parents:
diff changeset
69 #undef STARTFILE_DEFAULT_SPEC
kono
parents:
diff changeset
70 #define STARTFILE_DEFAULT_SPEC "%(startfile_linux)"
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 #undef ENDFILE_DEFAULT_SPEC
kono
parents:
diff changeset
73 #define ENDFILE_DEFAULT_SPEC "%(endfile_linux)"
kono
parents:
diff changeset
74
kono
parents:
diff changeset
75 #undef LINK_START_DEFAULT_SPEC
kono
parents:
diff changeset
76 #define LINK_START_DEFAULT_SPEC "%(link_start_linux)"
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78 #undef LINK_OS_DEFAULT_SPEC
kono
parents:
diff changeset
79 #define LINK_OS_DEFAULT_SPEC "%(link_os_linux)"
kono
parents:
diff changeset
80
kono
parents:
diff changeset
81 #undef DEFAULT_ASM_ENDIAN
kono
parents:
diff changeset
82 #if (TARGET_DEFAULT & MASK_LITTLE_ENDIAN)
kono
parents:
diff changeset
83 #define DEFAULT_ASM_ENDIAN " -mlittle"
kono
parents:
diff changeset
84 #define LINK_OS_LINUX_EMUL ENDIAN_SELECT(" -m elf32ppclinux", \
kono
parents:
diff changeset
85 " -m elf32lppclinux", \
kono
parents:
diff changeset
86 " -m elf32lppclinux")
kono
parents:
diff changeset
87 #else
kono
parents:
diff changeset
88 #define DEFAULT_ASM_ENDIAN " -mbig"
kono
parents:
diff changeset
89 #define LINK_OS_LINUX_EMUL ENDIAN_SELECT(" -m elf32ppclinux", \
kono
parents:
diff changeset
90 " -m elf32lppclinux", \
kono
parents:
diff changeset
91 " -m elf32ppclinux")
kono
parents:
diff changeset
92 #endif
kono
parents:
diff changeset
93
kono
parents:
diff changeset
94 #undef LINK_OS_LINUX_SPEC
kono
parents:
diff changeset
95 #define LINK_OS_LINUX_SPEC LINK_OS_LINUX_EMUL " %{!shared: %{!static: \
kono
parents:
diff changeset
96 %{rdynamic:-export-dynamic} \
kono
parents:
diff changeset
97 -dynamic-linker " GNU_USER_DYNAMIC_LINKER "}}"
kono
parents:
diff changeset
98
kono
parents:
diff changeset
99 /* For backward compatibility, we must continue to use the AIX
kono
parents:
diff changeset
100 structure return convention. */
kono
parents:
diff changeset
101 #undef DRAFT_V4_STRUCT_RET
kono
parents:
diff changeset
102 #define DRAFT_V4_STRUCT_RET 1
kono
parents:
diff changeset
103
kono
parents:
diff changeset
104 /* We are 32-bit all the time, so optimize a little. */
kono
parents:
diff changeset
105 #undef TARGET_64BIT
kono
parents:
diff changeset
106 #define TARGET_64BIT 0
kono
parents:
diff changeset
107
kono
parents:
diff changeset
108 /* We don't need to generate entries in .fixup, except when
kono
parents:
diff changeset
109 -mrelocatable or -mrelocatable-lib is given. */
kono
parents:
diff changeset
110 #undef RELOCATABLE_NEEDS_FIXUP
kono
parents:
diff changeset
111 #define RELOCATABLE_NEEDS_FIXUP \
kono
parents:
diff changeset
112 (rs6000_isa_flags & rs6000_isa_flags_explicit & OPTION_MASK_RELOCATABLE)
kono
parents:
diff changeset
113
kono
parents:
diff changeset
114 #ifdef TARGET_LIBC_PROVIDES_SSP
kono
parents:
diff changeset
115 /* ppc32 glibc provides __stack_chk_guard in -0x7008(2). */
kono
parents:
diff changeset
116 #define TARGET_THREAD_SSP_OFFSET -0x7008
kono
parents:
diff changeset
117 #endif
kono
parents:
diff changeset
118
kono
parents:
diff changeset
119 #define POWERPC_LINUX
kono
parents:
diff changeset
120
kono
parents:
diff changeset
121 /* ppc linux has 128-bit long double support in glibc 2.4 and later. */
kono
parents:
diff changeset
122 #ifdef TARGET_DEFAULT_LONG_DOUBLE_128
kono
parents:
diff changeset
123 #define RS6000_DEFAULT_LONG_DOUBLE_SIZE 128
kono
parents:
diff changeset
124 #endif
kono
parents:
diff changeset
125
kono
parents:
diff changeset
126 /* Static stack checking is supported by means of probes. */
kono
parents:
diff changeset
127 #define STACK_CHECK_STATIC_BUILTIN 1
kono
parents:
diff changeset
128
kono
parents:
diff changeset
129 /* Software floating point support for exceptions and rounding modes
kono
parents:
diff changeset
130 depends on the C library in use. */
kono
parents:
diff changeset
131 #undef TARGET_FLOAT_EXCEPTIONS_ROUNDING_SUPPORTED_P
kono
parents:
diff changeset
132 #define TARGET_FLOAT_EXCEPTIONS_ROUNDING_SUPPORTED_P \
kono
parents:
diff changeset
133 rs6000_linux_float_exceptions_rounding_supported_p
kono
parents:
diff changeset
134
kono
parents:
diff changeset
135 /* Support for TARGET_ATOMIC_ASSIGN_EXPAND_FENV without FPRs depends
kono
parents:
diff changeset
136 on glibc 2.19 or greater. */
kono
parents:
diff changeset
137 #if TARGET_GLIBC_MAJOR > 2 \
kono
parents:
diff changeset
138 || (TARGET_GLIBC_MAJOR == 2 && TARGET_GLIBC_MINOR >= 19)
kono
parents:
diff changeset
139 #define RS6000_GLIBC_ATOMIC_FENV 1
kono
parents:
diff changeset
140 #endif