hpux.h revision 132718
1/* Definitions of target machine GNU compiler.  IA-64 version.
2   Copyright (C) 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
3   Contributed by Steve Ellcey <sje@cup.hp.com> and
4                  Reva Cuthbertson <reva@cup.hp.com>
5
6This file is part of GCC.
7
8GCC is free software; you can redistribute it and/or modify
9it under the terms of the GNU General Public License as published by
10the Free Software Foundation; either version 2, or (at your option)
11any later version.
12
13GCC is distributed in the hope that it will be useful,
14but WITHOUT ANY WARRANTY; without even the implied warranty of
15MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16GNU General Public License for more details.
17
18You should have received a copy of the GNU General Public License
19along with GCC; see the file COPYING.  If not, write to
20the Free Software Foundation, 59 Temple Place - Suite 330,
21Boston, MA 02111-1307, USA.  */
22
23/* This macro is a C statement to print on `stderr' a string describing the
24   particular machine description choice.  */
25
26#define TARGET_VERSION fprintf (stderr, " (IA-64) HP-UX");
27
28/* Enable HPUX ABI quirks.  */
29#undef  TARGET_HPUX
30#define TARGET_HPUX 1
31
32/* Target OS builtins.  */
33#define TARGET_OS_CPP_BUILTINS()			\
34do {							\
35	builtin_assert("system=hpux");			\
36	builtin_assert("system=posix");			\
37	builtin_assert("system=unix");			\
38	builtin_define_std("hpux");			\
39	builtin_define_std("unix");			\
40	builtin_define("__IA64__");			\
41	builtin_define("_LONGLONG");			\
42	builtin_define("_INCLUDE_LONGLONG");		\
43	builtin_define("_UINT128_T");			\
44	if (c_dialect_cxx () || !flag_iso)		\
45	  {						\
46	    builtin_define("_HPUX_SOURCE");		\
47	    builtin_define("__STDC_EXT__");		\
48	    builtin_define("__STDCPP__");		\
49	  }						\
50	if (TARGET_ILP32)				\
51	  builtin_define("_ILP32");			\
52} while (0)
53
54#undef CPP_SPEC
55#define CPP_SPEC \
56  "%{mt|pthread:-D_REENTRANT -D_THREAD_SAFE -D_POSIX_C_SOURCE=199506L}"
57/* aCC defines also -DRWSTD_MULTI_THREAD, -DRW_MULTI_THREAD.  These
58   affect only aCC's C++ library (Rogue Wave-derived) which we do not
59   use, and they violate the user's name space.  */
60
61#undef  ASM_EXTRA_SPEC
62#define ASM_EXTRA_SPEC "%{milp32:-milp32} %{mlp64:-mlp64}"
63
64#undef ENDFILE_SPEC
65
66#undef STARTFILE_SPEC
67#define STARTFILE_SPEC "%{!shared:%{static:crt0%O%s}}"
68
69#undef LINK_SPEC
70#define LINK_SPEC \
71  "+Accept TypeMismatch \
72   %{shared:-b} \
73   %{!shared: \
74     -u main \
75     %{static:-noshared}}"
76
77#undef  LIB_SPEC
78#define LIB_SPEC \
79  "%{!shared: \
80     %{mt|pthread:-lpthread} \
81     %{p:%{!mlp64:-L/usr/lib/hpux32/libp} \
82	 %{mlp64:-L/usr/lib/hpux64/libp} -lprof} \
83     %{pg:%{!mlp64:-L/usr/lib/hpux32/libp} \
84	  %{mlp64:-L/usr/lib/hpux64/libp} -lgprof} \
85     %{!symbolic:-lc}}"
86
87#ifndef CROSS_COMPILE
88#undef LIBGCC_SPEC
89#define LIBGCC_SPEC \
90  "%{shared-libgcc:%{!mlp64:-lgcc_s}%{mlp64:-lgcc_s_hpux64} -lgcc} \
91   %{!shared-libgcc:-lgcc}"
92#endif
93
94#undef SUBTARGET_SWITCHES
95#define SUBTARGET_SWITCHES \
96  { "ilp32",    MASK_ILP32,     "Generate ILP32 code" }, \
97  { "lp64",    -MASK_ILP32,     "Generate LP64 code" },
98
99#define MULTILIB_DEFAULTS { "milp32" }
100
101/* A C expression whose value is zero if pointers that need to be extended
102   from being `POINTER_SIZE' bits wide to `Pmode' are sign-extended and
103   greater then zero if they are zero-extended and less then zero if the
104   ptr_extend instruction should be used.  */
105
106#define POINTERS_EXTEND_UNSIGNED -1
107
108#define JMP_BUF_SIZE  (8 * 76)
109
110#undef TARGET_DEFAULT
111#define TARGET_DEFAULT (MASK_DWARF2_ASM | MASK_BIG_ENDIAN | MASK_ILP32)
112
113/* This needs to be set to force structure arguments with a single
114   integer field to be treated as structures and not as the type of
115   their field.  Without this a structure with a single char will be
116   returned just like a char variable, instead of being returned at the
117   top of the register as specified for big-endian IA64.  */
118
119#define MEMBER_TYPE_FORCES_BLK(FIELD, MODE) \
120  (!FLOAT_MODE_P (MODE) || (MODE) == TFmode)
121
122/* ASM_OUTPUT_EXTERNAL_LIBCALL defaults to just a globalize_label call,
123   but that doesn't put out the @function type information which causes
124   shared library problems.  */
125
126#undef ASM_OUTPUT_EXTERNAL_LIBCALL
127#define ASM_OUTPUT_EXTERNAL_LIBCALL(FILE, FUN)			\
128do {								\
129  (*targetm.asm_out.globalize_label) (FILE, XSTR (FUN, 0));	\
130  ASM_OUTPUT_TYPE_DIRECTIVE (FILE, XSTR (FUN, 0), "function");	\
131} while (0)
132
133#undef FUNCTION_ARG_PADDING
134#define FUNCTION_ARG_PADDING(MODE, TYPE) \
135	ia64_hpux_function_arg_padding ((MODE), (TYPE))
136
137#undef PAD_VARARGS_DOWN
138#define PAD_VARARGS_DOWN (!AGGREGATE_TYPE_P (type))
139
140#define REGISTER_TARGET_PRAGMAS() \
141  c_register_pragma (0, "builtin", ia64_hpux_handle_builtin_pragma)
142
143/* Tell ia64.c that we are using the HP linker and we should delay output of
144   function extern declarations so that we don't output them for functions
145   which are never used (and may not be defined).  */
146
147#undef TARGET_HPUX_LD
148#define TARGET_HPUX_LD	1
149
150/* The HPUX dynamic linker objects to weak symbols with no
151   definitions, so do not use them in gthr-posix.h.  */
152#define GTHREAD_USE_WEAK 0
153
154/* Put out the needed function declarations at the end.  */
155
156#define TARGET_ASM_FILE_END ia64_hpux_file_end
157
158#undef CTORS_SECTION_ASM_OP
159#define CTORS_SECTION_ASM_OP  "\t.section\t.init_array,\t\"aw\",\"init_array\""
160
161#undef DTORS_SECTION_ASM_OP
162#define DTORS_SECTION_ASM_OP  "\t.section\t.fini_array,\t\"aw\",\"fini_array\""
163
164/* The init_array/fini_array technique does not permit the use of
165   initialization priorities.  */
166#define SUPPORTS_INIT_PRIORITY 0
167
168#undef READONLY_DATA_SECTION_ASM_OP
169#define READONLY_DATA_SECTION_ASM_OP "\t.section\t.rodata,\t\"a\",\t\"progbits\""
170
171#undef DATA_SECTION_ASM_OP
172#define DATA_SECTION_ASM_OP "\t.section\t.data,\t\"aw\",\t\"progbits\""
173
174#undef SDATA_SECTION_ASM_OP
175#define SDATA_SECTION_ASM_OP "\t.section\t.sdata,\t\"asw\",\t\"progbits\""
176
177#undef BSS_SECTION_ASM_OP
178#define BSS_SECTION_ASM_OP "\t.section\t.bss,\t\"aw\",\t\"nobits\""
179
180#undef SBSS_SECTION_ASM_OP
181#define SBSS_SECTION_ASM_OP "\t.section\t.sbss,\t\"asw\",\t\"nobits\""
182
183#undef TEXT_SECTION_ASM_OP
184#define TEXT_SECTION_ASM_OP "\t.section\t.text,\t\"ax\",\t\"progbits\""
185
186/* It is illegal to have relocations in shared segments on HPUX.
187   Pretend flag_pic is always set.  */
188#undef  TARGET_ASM_SELECT_SECTION
189#define TARGET_ASM_SELECT_SECTION  ia64_rwreloc_select_section
190#undef  TARGET_ASM_UNIQUE_SECTION
191#define TARGET_ASM_UNIQUE_SECTION  ia64_rwreloc_unique_section
192#undef  TARGET_ASM_SELECT_RTX_SECTION
193#define TARGET_ASM_SELECT_RTX_SECTION  ia64_rwreloc_select_rtx_section
194#undef  TARGET_SECTION_TYPE_FLAGS
195#define TARGET_SECTION_TYPE_FLAGS  ia64_rwreloc_section_type_flags
196
197/* ia64 HPUX has the float and long double forms of math functions.  */
198#undef TARGET_C99_FUNCTIONS
199#define TARGET_C99_FUNCTIONS  1
200
201#define TARGET_INIT_LIBFUNCS ia64_hpux_init_libfuncs
202
203#define FLOAT_LIB_COMPARE_RETURNS_BOOL(MODE, COMPARISON) ((MODE) == TFmode)
204