annotate gcc/config/i386/sol2.h @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents 84e7813d76e9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 /* Target definitions for GCC for Intel 80386 running Solaris 2
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
2 Copyright (C) 1993-2020 Free Software Foundation, Inc.
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 Contributed by Fred Fish (fnf@cygnus.com).
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
4
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 This file is part of GCC.
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
6
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 GCC is free software; you can redistribute it and/or modify
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 it under the terms of the GNU General Public License as published by
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 the Free Software Foundation; either version 3, or (at your option)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 any later version.
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
11
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 GCC is distributed in the hope that it will be useful,
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 GNU General Public License for more details.
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
16
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 along with GCC; see the file COPYING3. If not see
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 <http://www.gnu.org/licenses/>. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
20
111
kono
parents: 67
diff changeset
21 #define SUBTARGET_OPTIMIZATION_OPTIONS \
kono
parents: 67
diff changeset
22 { OPT_LEVELS_1_PLUS, OPT_momit_leaf_frame_pointer, NULL, 1 }
kono
parents: 67
diff changeset
23
kono
parents: 67
diff changeset
24 /* 32-bit Solaris/x86 only guarantees 4-byte stack alignment as required by
kono
parents: 67
diff changeset
25 the i386 psABI, so realign it as necessary for SSE instructions. */
kono
parents: 67
diff changeset
26 #undef STACK_REALIGN_DEFAULT
kono
parents: 67
diff changeset
27 #define STACK_REALIGN_DEFAULT (TARGET_64BIT ? 0 : 1)
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
28
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
29 /* Old versions of the Solaris assembler cannot handle the difference of
111
kono
parents: 67
diff changeset
30 labels in different sections, so force DW_EH_PE_datarel if so. */
kono
parents: 67
diff changeset
31 #ifndef HAVE_AS_IX86_DIFF_SECT_DELTA
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 #undef ASM_PREFERRED_EH_DATA_FORMAT
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 #define ASM_PREFERRED_EH_DATA_FORMAT(CODE,GLOBAL) \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 (flag_pic ? ((GLOBAL ? DW_EH_PE_indirect : 0) \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 | (TARGET_64BIT ? DW_EH_PE_pcrel | DW_EH_PE_sdata4 \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 : DW_EH_PE_datarel)) \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 : DW_EH_PE_absptr)
111
kono
parents: 67
diff changeset
38 #endif
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
39
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 /* The Solaris linker will not merge a read-only .eh_frame section
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 with a read-write .eh_frame section. None of the encodings used
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 with non-PIC code require runtime relocations. In 64-bit mode,
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 since there is no backwards compatibility issue, we use a read-only
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 section for .eh_frame. In 32-bit mode, we use a writable .eh_frame
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 section in order to be compatible with G++ for Solaris x86. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 #undef EH_TABLES_CAN_BE_READ_ONLY
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 #define EH_TABLES_CAN_BE_READ_ONLY (TARGET_64BIT)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
48
111
kono
parents: 67
diff changeset
49 /* Follow Sun requirements for TLS code sequences and use Sun assembler TLS
kono
parents: 67
diff changeset
50 syntax. */
kono
parents: 67
diff changeset
51 #undef TARGET_SUN_TLS
kono
parents: 67
diff changeset
52 #define TARGET_SUN_TLS 1
kono
parents: 67
diff changeset
53
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 #undef CPP_SPEC
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
55 #define CPP_SPEC "%(cpp_subtarget)"
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
56
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
57 #undef CC1_SPEC
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
58 #define CC1_SPEC "%(cc1_cpu) " ASAN_CC1_SPEC \
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
59 " %{mx32:%e-mx32 is not supported on Solaris}"
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
60
111
kono
parents: 67
diff changeset
61 /* GNU as understands --32 and --64, but the native Solaris
kono
parents: 67
diff changeset
62 assembler requires -xarch=generic or -xarch=generic64 instead. */
kono
parents: 67
diff changeset
63 #ifdef USE_GAS
kono
parents: 67
diff changeset
64 #define ASM_CPU32_DEFAULT_SPEC "--32"
kono
parents: 67
diff changeset
65 #define ASM_CPU64_DEFAULT_SPEC "--64"
kono
parents: 67
diff changeset
66 #else
kono
parents: 67
diff changeset
67 #define ASM_CPU32_DEFAULT_SPEC "-xarch=generic"
kono
parents: 67
diff changeset
68 #define ASM_CPU64_DEFAULT_SPEC "-xarch=generic64"
kono
parents: 67
diff changeset
69 #endif
kono
parents: 67
diff changeset
70
kono
parents: 67
diff changeset
71 /* Since Studio 12.6, as needs -xbrace_comment=no so its AVX512 syntax is
kono
parents: 67
diff changeset
72 fully compatible with gas. */
kono
parents: 67
diff changeset
73 #ifdef HAVE_AS_XBRACE_COMMENT_OPTION
kono
parents: 67
diff changeset
74 #define ASM_XBRACE_COMMENT_SPEC "-xbrace_comment=no"
kono
parents: 67
diff changeset
75 #else
kono
parents: 67
diff changeset
76 #define ASM_XBRACE_COMMENT_SPEC ""
kono
parents: 67
diff changeset
77 #endif
kono
parents: 67
diff changeset
78
kono
parents: 67
diff changeset
79 #undef ASM_CPU_SPEC
kono
parents: 67
diff changeset
80 #define ASM_CPU_SPEC "%(asm_cpu_default) " ASM_XBRACE_COMMENT_SPEC
kono
parents: 67
diff changeset
81
kono
parents: 67
diff changeset
82 /* Don't include ASM_PIC_SPEC. While the Solaris 10+ assembler accepts -K PIC,
kono
parents: 67
diff changeset
83 it gives many warnings:
kono
parents: 67
diff changeset
84 Absolute relocation is used for symbol "<symbol>"
kono
parents: 67
diff changeset
85 GNU as doesn't recognize -K at all. */
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
86 #undef ASM_SPEC
111
kono
parents: 67
diff changeset
87 #define ASM_SPEC ASM_SPEC_BASE
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
88
111
kono
parents: 67
diff changeset
89 #define DEFAULT_ARCH32_P !TARGET_64BIT_DEFAULT
kono
parents: 67
diff changeset
90
kono
parents: 67
diff changeset
91 #define ARCH64_SUBDIR "amd64"
kono
parents: 67
diff changeset
92
kono
parents: 67
diff changeset
93 #ifdef USE_GLD
kono
parents: 67
diff changeset
94 /* Since binutils 2.21, GNU ld supports new *_sol2 emulations to strictly
kono
parents: 67
diff changeset
95 follow the Solaris 2 ABI. Prefer them if present. */
kono
parents: 67
diff changeset
96 #ifdef HAVE_LD_SOL2_EMULATION
kono
parents: 67
diff changeset
97 #define ARCH32_EMULATION "elf_i386_sol2"
kono
parents: 67
diff changeset
98 #define ARCH64_EMULATION "elf_x86_64_sol2"
kono
parents: 67
diff changeset
99 #else
kono
parents: 67
diff changeset
100 #define ARCH32_EMULATION "elf_i386"
kono
parents: 67
diff changeset
101 #define ARCH64_EMULATION "elf_x86_64"
kono
parents: 67
diff changeset
102 #endif
kono
parents: 67
diff changeset
103 #endif
kono
parents: 67
diff changeset
104
kono
parents: 67
diff changeset
105 #define ENDFILE_ARCH_SPEC \
kono
parents: 67
diff changeset
106 "%{mpc32:crtprec32.o%s} \
kono
parents: 67
diff changeset
107 %{mpc64:crtprec64.o%s} \
kono
parents: 67
diff changeset
108 %{mpc80:crtprec80.o%s}"
kono
parents: 67
diff changeset
109
kono
parents: 67
diff changeset
110 #define SUBTARGET_CPU_EXTRA_SPECS \
kono
parents: 67
diff changeset
111 { "cpp_subtarget", CPP_SUBTARGET_SPEC }, \
kono
parents: 67
diff changeset
112 { "asm_cpu", ASM_CPU_SPEC }, \
kono
parents: 67
diff changeset
113 { "asm_cpu_default", ASM_CPU_DEFAULT_SPEC }, \
kono
parents: 67
diff changeset
114
kono
parents: 67
diff changeset
115 /* Register the Solaris-specific #pragma directives. */
kono
parents: 67
diff changeset
116 #define REGISTER_SUBTARGET_PRAGMAS() solaris_register_pragmas ()
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
117
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
118 #undef LOCAL_LABEL_PREFIX
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
119 #define LOCAL_LABEL_PREFIX "."
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
120
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
121 /* The 32-bit Solaris assembler does not support .quad. Do not use it. */
63
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
122 #ifndef HAVE_AS_IX86_QUAD
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
123 #undef ASM_QUAD
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
124 #endif
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
125
111
kono
parents: 67
diff changeset
126 /* The native Solaris assembler can't calculate the difference between
kono
parents: 67
diff changeset
127 symbols in different sections, which causes problems for -fPIC jump
kono
parents: 67
diff changeset
128 tables in .rodata. */
kono
parents: 67
diff changeset
129 #ifndef HAVE_AS_IX86_DIFF_SECT_DELTA
kono
parents: 67
diff changeset
130 #undef JUMP_TABLES_IN_TEXT_SECTION
kono
parents: 67
diff changeset
131 #define JUMP_TABLES_IN_TEXT_SECTION 1
kono
parents: 67
diff changeset
132
kono
parents: 67
diff changeset
133 /* The native Solaris assembler cannot handle the SYMBOL-. syntax, but
kono
parents: 67
diff changeset
134 requires SYMBOL@rel/@rel64 instead. */
kono
parents: 67
diff changeset
135 #define ASM_OUTPUT_DWARF_PCREL(FILE, SIZE, LABEL) \
kono
parents: 67
diff changeset
136 do { \
kono
parents: 67
diff changeset
137 fputs (integer_asm_op (SIZE, FALSE), FILE); \
kono
parents: 67
diff changeset
138 assemble_name (FILE, LABEL); \
kono
parents: 67
diff changeset
139 fputs (SIZE == 8 ? "@rel64" : "@rel", FILE); \
kono
parents: 67
diff changeset
140 } while (0)
kono
parents: 67
diff changeset
141 #endif
kono
parents: 67
diff changeset
142
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
143 /* The Solaris assembler wants a .local for non-exported aliases. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
144 #define ASM_OUTPUT_DEF_FROM_DECLS(FILE, DECL, TARGET) \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
145 do { \
111
kono
parents: 67
diff changeset
146 tree id = DECL_ASSEMBLER_NAME (DECL); \
kono
parents: 67
diff changeset
147 ultimate_transparent_alias_target (&id); \
kono
parents: 67
diff changeset
148 const char *declname = IDENTIFIER_POINTER (id); \
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
149 ASM_OUTPUT_DEF ((FILE), declname, \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
150 IDENTIFIER_POINTER (TARGET)); \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
151 if (! TREE_PUBLIC (DECL)) \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
152 { \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
153 fprintf ((FILE), "%s", LOCAL_ASM_OP); \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
154 assemble_name ((FILE), declname); \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
155 fprintf ((FILE), "\n"); \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
156 } \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
157 } while (0)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
158
111
kono
parents: 67
diff changeset
159 #ifndef USE_GAS
63
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
160 /* The Sun assembler uses .tcomm for TLS common sections. */
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
161 #define TLS_COMMON_ASM_OP ".tcomm"
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
162
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
163 /* Similar to the Sun assembler on SPARC, the native assembler requires
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
164 TLS objects to be declared as @tls_obj (not @tls_object). Unlike SPARC,
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
165 gas doesn't understand this variant. */
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
166 #undef ASM_DECLARE_OBJECT_NAME
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
167 #define ASM_DECLARE_OBJECT_NAME(FILE, NAME, DECL) \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
168 do \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
169 { \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
170 HOST_WIDE_INT size; \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
171 \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
172 if (targetm.have_tls && DECL_THREAD_LOCAL_P (DECL)) \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
173 ASM_OUTPUT_TYPE_DIRECTIVE (FILE, NAME, "tls_obj"); \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
174 else \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
175 ASM_OUTPUT_TYPE_DIRECTIVE (FILE, NAME, "object"); \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
176 \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
177 size_directive_output = 0; \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
178 if (!flag_inhibit_size_directive \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
179 && (DECL) && DECL_SIZE (DECL)) \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
180 { \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
181 size_directive_output = 1; \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
182 size = int_size_in_bytes (TREE_TYPE (DECL)); \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
183 ASM_OUTPUT_SIZE_DIRECTIVE (FILE, NAME, size); \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
184 } \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
185 \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
186 ASM_OUTPUT_LABEL (FILE, NAME); \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
187 } \
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
188 while (0)
111
kono
parents: 67
diff changeset
189 #endif /* !USE_GAS */
63
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
190
111
kono
parents: 67
diff changeset
191 /* As in sparc/sol2.h, override the default from i386/x86-64.h to work
kono
parents: 67
diff changeset
192 around Sun as TLS bug. */
kono
parents: 67
diff changeset
193 #undef ASM_OUTPUT_ALIGNED_DECL_COMMON
kono
parents: 67
diff changeset
194 #define ASM_OUTPUT_ALIGNED_DECL_COMMON(FILE, DECL, NAME, SIZE, ALIGN) \
kono
parents: 67
diff changeset
195 do \
kono
parents: 67
diff changeset
196 { \
kono
parents: 67
diff changeset
197 if (TARGET_SUN_TLS \
kono
parents: 67
diff changeset
198 && in_section \
kono
parents: 67
diff changeset
199 && ((in_section->common.flags & SECTION_TLS) == SECTION_TLS)) \
kono
parents: 67
diff changeset
200 switch_to_section (bss_section); \
kono
parents: 67
diff changeset
201 x86_elf_aligned_decl_common (FILE, DECL, NAME, SIZE, ALIGN); \
kono
parents: 67
diff changeset
202 } \
kono
parents: 67
diff changeset
203 while (0)
67
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
204
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
205 /* Output a simple call for .init/.fini. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
206 #define ASM_OUTPUT_CALL(FILE, FN) \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
207 do \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
208 { \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
209 fprintf (FILE, "\tcall\t"); \
67
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
210 ix86_print_operand (FILE, XEXP (DECL_RTL (FN), 0), 'P'); \
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
211 fprintf (FILE, "\n"); \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
212 } \
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
213 while (0)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
214
111
kono
parents: 67
diff changeset
215 #undef TARGET_ASM_NAMED_SECTION
kono
parents: 67
diff changeset
216 #define TARGET_ASM_NAMED_SECTION i386_solaris_elf_named_section
kono
parents: 67
diff changeset
217
kono
parents: 67
diff changeset
218 /* Sun as requires "h" flag for large sections, GNU as can do without, but
kono
parents: 67
diff changeset
219 accepts "l". */
kono
parents: 67
diff changeset
220 #ifdef USE_GAS
kono
parents: 67
diff changeset
221 #define MACH_DEP_SECTION_ASM_FLAG 'l'
kono
parents: 67
diff changeset
222 #else
kono
parents: 67
diff changeset
223 #define MACH_DEP_SECTION_ASM_FLAG 'h'
kono
parents: 67
diff changeset
224 #endif
kono
parents: 67
diff changeset
225
kono
parents: 67
diff changeset
226 #ifndef USE_GAS
kono
parents: 67
diff changeset
227 /* Emit COMDAT group signature symbols for Sun as. */
kono
parents: 67
diff changeset
228 #undef TARGET_ASM_FILE_END
kono
parents: 67
diff changeset
229 #define TARGET_ASM_FILE_END solaris_file_end
kono
parents: 67
diff changeset
230 #endif
kono
parents: 67
diff changeset
231
kono
parents: 67
diff changeset
232 /* Unlike GNU ld, Sun ld doesn't coalesce .ctors.N/.dtors.N sections, so
kono
parents: 67
diff changeset
233 inhibit their creation. Also cf. sparc/sysv4.h. */
kono
parents: 67
diff changeset
234 #ifndef USE_GLD
kono
parents: 67
diff changeset
235 #define CTORS_SECTION_ASM_OP "\t.section\t.ctors, \"aw\""
kono
parents: 67
diff changeset
236 #define DTORS_SECTION_ASM_OP "\t.section\t.dtors, \"aw\""
kono
parents: 67
diff changeset
237 #endif
kono
parents: 67
diff changeset
238
kono
parents: 67
diff changeset
239 #ifndef USE_GAS
kono
parents: 67
diff changeset
240 #define LARGECOMM_SECTION_ASM_OP "\t.lbcomm\t"
kono
parents: 67
diff changeset
241 #endif
kono
parents: 67
diff changeset
242
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
243 /* -fsanitize=address is currently only supported for 32-bit. */
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
244 #define ASAN_REJECT_SPEC \
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
245 DEF_ARCH64_SPEC("%e-fsanitize=address is not supported in this configuration")
111
kono
parents: 67
diff changeset
246
kono
parents: 67
diff changeset
247 #undef NO_PROFILE_COUNTERS
kono
parents: 67
diff changeset
248
kono
parents: 67
diff changeset
249 #undef MCOUNT_NAME
kono
parents: 67
diff changeset
250 #define MCOUNT_NAME "_mcount"
kono
parents: 67
diff changeset
251
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
252 /* We do not need NT_VERSION notes. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
253 #undef X86_FILE_START_VERSION_DIRECTIVE
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
254 #define X86_FILE_START_VERSION_DIRECTIVE false