OSDN Git Service

* gcc/config/i386/i386.h (TARGET_KEEPS_VECTOR_ALIGNED_STACK): New.
[pf3gnuchains/gcc-fork.git] / gcc / config / i386 / darwin.h
1 /* Target definitions for x86 running Darwin.
2    Copyright (C) 2001, 2002, 2004, 2005, 2006 Free Software Foundation, Inc.
3    Contributed by Apple Computer Inc.
4
5 This file is part of GCC.
6
7 GCC is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2, or (at your option)
10 any later version.
11
12 GCC is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING.  If not, write to
19 the Free Software Foundation, 51 Franklin Street, Fifth Floor,
20 Boston, MA 02110-1301, USA.  */
21
22 /* Enable Mach-O bits in generic x86 code.  */
23 #undef TARGET_MACHO
24 #define TARGET_MACHO 1
25
26 #define TARGET_VERSION fprintf (stderr, " (i686 Darwin)");
27
28 #undef  TARGET_64BIT
29 #define TARGET_64BIT (target_flags & MASK_64BIT)
30
31 #ifdef IN_LIBGCC2
32 #undef TARGET_64BIT
33 #ifdef __x86_64__
34 #define TARGET_64BIT 1
35 #else
36 #define TARGET_64BIT 0
37 #endif
38 #endif
39
40 /* Size of the Obj-C jump buffer.  */
41 #define OBJC_JBLEN ((TARGET_64BIT) ? ((9 * 2) + 3 + 16) : (18))
42
43 #undef TARGET_FPMATH_DEFAULT
44 #define TARGET_FPMATH_DEFAULT (TARGET_SSE ? FPMATH_SSE : FPMATH_387)
45
46 #define TARGET_OS_CPP_BUILTINS()                \
47   do                                            \
48     {                                           \
49       builtin_define ("__LITTLE_ENDIAN__");     \
50       darwin_cpp_builtins (pfile);              \
51     }                                           \
52   while (0)
53
54 #undef PTRDIFF_TYPE
55 #define PTRDIFF_TYPE (TARGET_64BIT ? "long int" : "int")
56
57 #undef WCHAR_TYPE
58 #define WCHAR_TYPE "int"
59
60 #undef WCHAR_TYPE_SIZE
61 #define WCHAR_TYPE_SIZE 32
62
63 #undef MAX_BITS_PER_WORD
64 #define MAX_BITS_PER_WORD 64
65
66 #undef FORCE_PREFERRED_STACK_BOUNDARY_IN_MAIN
67 #define FORCE_PREFERRED_STACK_BOUNDARY_IN_MAIN (0)
68
69 #undef TARGET_KEEPS_VECTOR_ALIGNED_STACK
70 #define TARGET_KEEPS_VECTOR_ALIGNED_STACK 1
71
72 /* We want -fPIC by default, unless we're using -static to compile for
73    the kernel or some such.  */
74
75 #undef CC1_SPEC
76 #define CC1_SPEC "%{!mkernel:%{!static:%{!mdynamic-no-pic:-fPIC}}} \
77   %{g: %{!fno-eliminate-unused-debug-symbols: -feliminate-unused-debug-symbols }}"
78
79 #undef ASM_SPEC
80 #define ASM_SPEC "-arch %(darwin_arch) -force_cpusubtype_ALL"
81
82 #define DARWIN_ARCH_SPEC "%{m64:x86_64;:i386}"
83 #define DARWIN_SUBARCH_SPEC DARWIN_ARCH_SPEC
84
85 #undef SUBTARGET_EXTRA_SPECS
86 #define SUBTARGET_EXTRA_SPECS                                   \
87   DARWIN_EXTRA_SPECS                                            \
88   { "darwin_arch", DARWIN_ARCH_SPEC },                          \
89   { "darwin_crt2", "" },                                        \
90   { "darwin_subarch", DARWIN_SUBARCH_SPEC },
91
92 /* Use the following macro for any Darwin/x86-specific command-line option
93    translation.  */
94 #define SUBTARGET_OPTION_TRANSLATE_TABLE \
95   { "", "" }
96
97 /* The Darwin assembler mostly follows AT&T syntax.  */
98 #undef ASSEMBLER_DIALECT
99 #define ASSEMBLER_DIALECT ASM_ATT
100
101 /* Define macro used to output shift-double opcodes when the shift
102    count is in %cl.  Some assemblers require %cl as an argument;
103    some don't.  This macro controls what to do: by default, don't
104    print %cl.  */
105
106 #define SHIFT_DOUBLE_OMITS_COUNT 0
107
108 extern void darwin_x86_file_end (void);
109 #undef TARGET_ASM_FILE_END
110 #define TARGET_ASM_FILE_END darwin_x86_file_end
111
112 /* Define the syntax of pseudo-ops, labels and comments.  */
113
114 /* String containing the assembler's comment-starter.  */
115
116 #define ASM_COMMENT_START "#"
117
118 /* By default, target has a 80387, uses IEEE compatible arithmetic,
119    and returns float values in the 387.  */
120
121 #define TARGET_SUBTARGET_DEFAULT (MASK_80387 | MASK_IEEE_FP | MASK_FLOAT_RETURNS | MASK_128BIT_LONG_DOUBLE)
122
123 /* For now, disable dynamic-no-pic.  We'll need to go through i386.c
124    with a fine-tooth comb looking for refs to flag_pic!  */
125 #define MASK_MACHO_DYNAMIC_NO_PIC 0
126 #define TARGET_DYNAMIC_NO_PIC     (target_flags & MASK_MACHO_DYNAMIC_NO_PIC)
127
128 #undef GOT_SYMBOL_NAME
129 #define GOT_SYMBOL_NAME (machopic_function_base_name ())
130
131 /* Define the syntax of pseudo-ops, labels and comments.  */
132
133 #define LPREFIX "L"
134
135 /* These are used by -fbranch-probabilities */
136 #define HOT_TEXT_SECTION_NAME "__TEXT,__text,regular,pure_instructions"
137 #define UNLIKELY_EXECUTED_TEXT_SECTION_NAME \
138                               "__TEXT,__unlikely,regular,pure_instructions"
139
140 /* Assembler pseudos to introduce constants of various size.  */
141
142 #define ASM_BYTE_OP "\t.byte\t"
143 #define ASM_SHORT "\t.word\t"
144 #define ASM_LONG "\t.long\t"
145 #define ASM_QUAD "\t.quad\t"
146
147 #define SUBTARGET_ENCODE_SECTION_INFO  darwin_encode_section_info
148
149 #undef ASM_OUTPUT_ALIGN
150 #define ASM_OUTPUT_ALIGN(FILE,LOG)      \
151  do { if ((LOG) != 0)                   \
152         {                               \
153           if (in_section == text_section) \
154             fprintf (FILE, "\t%s %d,0x90\n", ALIGN_ASM_OP, (LOG)); \
155           else                          \
156             fprintf (FILE, "\t%s %d\n", ALIGN_ASM_OP, (LOG)); \
157         }                               \
158     } while (0)
159
160 /* This says how to output an assembler line
161    to define a global common symbol.  */
162
163 #define ASM_OUTPUT_COMMON(FILE, NAME, SIZE, ROUNDED)  \
164 ( fputs (".comm ", (FILE)),                     \
165   assemble_name ((FILE), (NAME)),               \
166   fprintf ((FILE), ",%lu\n", (unsigned long)(ROUNDED)))
167
168 /* This says how to output an assembler line
169    to define a local common symbol.  */
170
171 #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE, ROUNDED)  \
172 ( fputs (".lcomm ", (FILE)),                    \
173   assemble_name ((FILE), (NAME)),               \
174   fprintf ((FILE), ","HOST_WIDE_INT_PRINT_UNSIGNED"\n", (ROUNDED)))
175
176 /* Darwin profiling -- call mcount.  */
177 #undef FUNCTION_PROFILER
178 #define FUNCTION_PROFILER(FILE, LABELNO)                                \
179     do {                                                                \
180       if (MACHOPIC_INDIRECT && !TARGET_64BIT)                           \
181         {                                                               \
182           const char *name = machopic_mcount_stub_name ();              \
183           fprintf (FILE, "\tcall %s\n", name+1);  /*  skip '&'  */      \
184           machopic_validate_stub_or_non_lazy_ptr (name);                \
185         }                                                               \
186       else fprintf (FILE, "\tcall mcount\n");                           \
187     } while (0)
188
189 #define C_COMMON_OVERRIDE_OPTIONS                                       \
190   do {                                                                  \
191     SUBTARGET_C_COMMON_OVERRIDE_OPTIONS;                                \
192   } while (0)
193
194 /* Darwin on x86_64 uses dwarf-2 by default.  Pre-darwin9 32-bit
195    compiles default to stabs+.  darwin9+ defaults to dwarf-2.  */
196 #ifndef DARWIN_PREFER_DWARF
197 #undef PREFERRED_DEBUGGING_TYPE
198 #define PREFERRED_DEBUGGING_TYPE (TARGET_64BIT ? DWARF2_DEBUG : DBX_DEBUG)
199 #endif
200
201 /* Darwin uses the standard DWARF register numbers but the default
202    register numbers for STABS.  Fortunately for 64-bit code the
203    default and the standard are the same.  */
204 #undef DBX_REGISTER_NUMBER
205 #define DBX_REGISTER_NUMBER(n)                                  \
206   (TARGET_64BIT ? dbx64_register_map[n]                         \
207    : write_symbols == DWARF2_DEBUG ? svr4_dbx_register_map[n]   \
208    : dbx_register_map[n])
209
210 /* Unfortunately, the 32-bit EH information also doesn't use the standard
211    DWARF register numbers.  */
212 #define DWARF2_FRAME_REG_OUT(n, for_eh)                                 \
213   (! (for_eh) || write_symbols != DWARF2_DEBUG || TARGET_64BIT ? (n)    \
214    : (n) == 5 ? 4                                                       \
215    : (n) == 4 ? 5                                                       \
216    : (n) >= 11 && (n) <= 18 ? (n) + 1                                   \
217    : (n))
218
219 #undef REGISTER_TARGET_PRAGMAS
220 #define REGISTER_TARGET_PRAGMAS() DARWIN_REGISTER_TARGET_PRAGMAS()
221
222 #undef TARGET_SET_DEFAULT_TYPE_ATTRIBUTES
223 #define TARGET_SET_DEFAULT_TYPE_ATTRIBUTES darwin_set_default_type_attributes
224
225 /* For 64-bit, we need to add 4 because @GOTPCREL is relative to the
226    end of the instruction, but without the 4 we'd only have the right
227    address for the start of the instruction.  */
228 #undef ASM_MAYBE_OUTPUT_ENCODED_ADDR_RTX
229 #define ASM_MAYBE_OUTPUT_ENCODED_ADDR_RTX(FILE, ENCODING, SIZE, ADDR, DONE)     \
230   if (TARGET_64BIT)                                                             \
231     {                                                                           \
232       if ((SIZE) == 4 && ((ENCODING) & 0x70) == DW_EH_PE_pcrel)                 \
233         {                                                                       \
234            fputs (ASM_LONG, FILE);                                              \
235            assemble_name (FILE, XSTR (ADDR, 0));                                \
236            fputs ("+4@GOTPCREL", FILE);                                         \
237            goto DONE;                                                           \
238         }                                                                       \
239     }                                                                           \
240   else                                                                          \
241     {                                                                           \
242       if (ENCODING == ASM_PREFERRED_EH_DATA_FORMAT (2, 1))                      \
243         {                                                                       \
244           darwin_non_lazy_pcrel (FILE, ADDR);                                   \
245           goto DONE;                                                            \
246         }                                                                       \
247     }
248
249 /* This needs to move since i386 uses the first flag and other flags are
250    used in Mach-O.  */
251 #undef MACHO_SYMBOL_FLAG_VARIABLE
252 #define MACHO_SYMBOL_FLAG_VARIABLE ((SYMBOL_FLAG_MACH_DEP) << 3)