* config/i386/netbsd-elf.h (TARGET_OS_CPP_BUILTINS): Define.
[official-gcc.git] / gcc / config / i386 / sco5.h
blobb520159f79ca5beab45fff9576281f250134be2d
1 /* Definitions for Intel 386 running SCO Unix System V 3.2 Version 5.
2 Copyright (C) 1992, 1995, 1996, 1997, 1998, 1999, 2000, 2002
3 Free Software Foundation, Inc.
4 Contributed by Kean Johnston (hug@netcom.com)
6 This file is part of GNU CC.
8 GNU CC is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2, or (at your option)
11 any later version.
13 GNU CC is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with GNU CC; see the file COPYING. If not, write to
20 the Free Software Foundation, 59 Temple Place - Suite 330,
21 Boston, MA 02111-1307, USA. */
23 #define TARGET_VERSION fprintf (stderr, " (i386, SCO OpenServer 5 Syntax)");
25 #undef LPREFIX
26 #define LPREFIX ".L"
28 #undef ALIGN_ASM_OP
29 #define ALIGN_ASM_OP "\t.align\t"
31 #undef ASCII_DATA_ASM_OP
32 #define ASCII_DATA_ASM_OP "\t.ascii\t"
34 #undef IDENT_ASM_OP
35 #define IDENT_ASM_OP "\t.ident\t"
37 #undef COMMON_ASM_OP
38 #define COMMON_ASM_OP "\t.comm\t"
40 #undef SET_ASM_OP
41 #define SET_ASM_OP "\t.set\t"
43 #undef LOCAL_ASM_OP
44 #define LOCAL_ASM_OP "\t.local\t"
46 #undef ASM_SHORT
47 #define ASM_SHORT "\t.value\t"
49 #undef ASM_LONG
50 #define ASM_LONG "\t.long\t"
52 #undef ASM_QUAD
54 #undef TYPE_ASM_OP
55 #define TYPE_ASM_OP "\t.type\t"
57 #undef SIZE_ASM_OP
58 #define SIZE_ASM_OP "\t.size\t"
60 #undef STRING_ASM_OP
61 #define STRING_ASM_OP "\t.string\t"
63 #undef SKIP_ASM_OP
64 #define SKIP_ASM_OP "\t.zero\t"
66 #undef GLOBAL_ASM_OP
67 #define GLOBAL_ASM_OP "\t.globl\t"
69 #undef EH_FRAME_SECTION_ASM_OP
70 #define EH_FRAME_SECTION_NAME_COFF ".ehfram"
71 #define EH_FRAME_SECTION_NAME_ELF ".eh_frame"
72 #define EH_FRAME_SECTION_NAME \
73 ((TARGET_ELF) ? EH_FRAME_SECTION_NAME_ELF : EH_FRAME_SECTION_NAME_COFF)
75 /* Avoid problems (long sectino names, forward assembler refs) with DWARF
76 exception unwinding when we're generating COFF */
77 #define DWARF2_UNWIND_INFO \
78 ((TARGET_ELF) ? 1 : 0 )
80 #undef READONLY_DATA_SECTION_ASM_OP
81 #define READONLY_DATA_SECTION_ASM_OP_COFF "\t.section\t.rodata, \"x\""
82 #define READONLY_DATA_SECTION_ASM_OP_ELF "\t.section\t.rodata"
83 #define READONLY_DATA_SECTION_ASM_OP \
84 ((TARGET_ELF) \
85 ? READONLY_DATA_SECTION_ASM_OP_ELF \
86 : READONLY_DATA_SECTION_ASM_OP_COFF)
88 #undef INIT_SECTION_ASM_OP
89 #define INIT_SECTION_ASM_OP_ELF "\t.section\t.init"
90 /* Rename these for COFF because crt1.o will try to run them. */
91 #define INIT_SECTION_ASM_OP_COFF "\t.section\t.ctor ,\"x\""
92 #define INIT_SECTION_ASM_OP \
93 ((TARGET_ELF) ? INIT_SECTION_ASM_OP_ELF : INIT_SECTION_ASM_OP_COFF)
95 #undef CTORS_SECTION_ASM_OP
96 #define CTORS_SECTION_ASM_OP_ELF "\t.section\t.ctors,\"aw\""
97 #define CTORS_SECTION_ASM_OP_COFF INIT_SECTION_ASM_OP_COFF
98 #define CTORS_SECTION_ASM_OP \
99 ((TARGET_ELF) ? CTORS_SECTION_ASM_OP_ELF : CTORS_SECTION_ASM_OP_COFF)
101 #undef DTORS_SECTION_ASM_OP
102 #define DTORS_SECTION_ASM_OP_ELF "\t.section\t.dtors, \"aw\""
103 #define DTORS_SECTION_ASM_OP_COFF FINI_SECTION_ASM_OP_COFF
104 #define DTORS_SECTION_ASM_OP \
105 ((TARGET_ELF) ? DTORS_SECTION_ASM_OP_ELF : DTORS_SECTION_ASM_OP_COFF)
107 #undef FINI_SECTION_ASM_OP
108 #define FINI_SECTION_ASM_OP_ELF "\t.section\t.fini"
109 #define FINI_SECTION_ASM_OP_COFF "\t.section\t.dtor, \"x\""
110 #define FINI_SECTION_ASM_OP \
111 ((TARGET_ELF) ? FINI_SECTION_ASM_OP_ELF : FINI_SECTION_ASM_OP_COFF)
113 #undef BSS_SECTION_ASM_OP
114 #define BSS_SECTION_ASM_OP "\t.data"
116 #undef TEXT_SECTION_ASM_OP
117 #define TEXT_SECTION_ASM_OP "\t.text"
119 #undef DATA_SECTION_ASM_OP
120 #define DATA_SECTION_ASM_OP "\t.data"
122 #undef TYPE_OPERAND_FMT
123 #define TYPE_OPERAND_FMT "@%s"
125 #undef APPLY_RESULT_SIZE
126 #define APPLY_RESULT_SIZE \
127 (TARGET_ELF) ? size : 116
129 #ifndef ASM_DECLARE_RESULT
130 #define ASM_DECLARE_RESULT(FILE, RESULT)
131 #endif
133 #define SCO_DEFAULT_ASM_COFF(FILE,NAME) \
134 do { \
135 ASM_OUTPUT_LABEL (FILE, NAME); \
136 } while (0)
138 #undef ASM_DECLARE_FUNCTION_NAME
139 #define ASM_DECLARE_FUNCTION_NAME(FILE, NAME, DECL) \
140 do { \
141 if (TARGET_ELF) { \
142 fprintf (FILE, "%s", TYPE_ASM_OP); \
143 assemble_name (FILE, NAME); \
144 putc (',', FILE); \
145 fprintf (FILE, TYPE_OPERAND_FMT, "function"); \
146 putc ('\n', FILE); \
147 ASM_DECLARE_RESULT (FILE, DECL_RESULT (DECL)); \
148 ASM_OUTPUT_LABEL(FILE, NAME); \
149 } else \
150 SCO_DEFAULT_ASM_COFF(FILE, NAME); \
151 } while (0)
153 #undef ASM_DECLARE_FUNCTION_SIZE
154 #define ASM_DECLARE_FUNCTION_SIZE(FILE, FNAME, DECL) \
155 do { \
156 if (TARGET_ELF) { if (!flag_inhibit_size_directive) \
158 fprintf (FILE, "%s", SIZE_ASM_OP); \
159 assemble_name (FILE, (FNAME)); \
160 fprintf (FILE, ",.-"); \
161 assemble_name (FILE, (FNAME)); \
162 putc ('\n', FILE); \
163 } } \
164 } while (0)
166 #undef ASM_DECLARE_OBJECT_NAME
167 #define ASM_DECLARE_OBJECT_NAME(FILE, NAME, DECL) \
168 do { \
169 if (TARGET_ELF) { \
170 fprintf (FILE, "%s", TYPE_ASM_OP); \
171 assemble_name (FILE, NAME); \
172 putc (',', FILE); \
173 fprintf (FILE, TYPE_OPERAND_FMT, "object"); \
174 putc ('\n', FILE); \
175 size_directive_output = 0; \
176 if (!flag_inhibit_size_directive && DECL_SIZE (DECL)) \
178 size_directive_output = 1; \
179 fprintf (FILE, "%s", SIZE_ASM_OP); \
180 assemble_name (FILE, NAME); \
181 fprintf (FILE, ",%d\n", int_size_in_bytes (TREE_TYPE (DECL))); \
183 ASM_OUTPUT_LABEL(FILE, NAME); \
184 } else \
185 SCO_DEFAULT_ASM_COFF(FILE, NAME); \
186 } while (0)
188 #undef ASM_FILE_START_1
189 #define ASM_FILE_START_1(FILE)
191 #undef ASM_FILE_START
192 #define ASM_FILE_START(FILE) \
193 do { \
194 output_file_directive((FILE),main_input_filename); \
195 fprintf ((FILE), "\t.version\t\"01.01\"\n"); \
196 } while (0)
198 #undef ASM_FINISH_DECLARE_OBJECT
199 #define ASM_FINISH_DECLARE_OBJECT(FILE, DECL, TOP_LEVEL, AT_END) \
200 do { \
201 if (TARGET_ELF) { \
202 const char *name = XSTR (XEXP (DECL_RTL (DECL), 0), 0); \
203 if (!flag_inhibit_size_directive && DECL_SIZE (DECL) \
204 && ! AT_END && TOP_LEVEL \
205 && DECL_INITIAL (DECL) == error_mark_node \
206 && !size_directive_output) \
208 size_directive_output = 1; \
209 fprintf (FILE, "%s", SIZE_ASM_OP); \
210 assemble_name (FILE, name); \
211 fprintf (FILE, ",%d\n", int_size_in_bytes (TREE_TYPE (DECL))); \
214 } while (0)
216 #undef ASM_GENERATE_INTERNAL_LABEL
217 #define ASM_GENERATE_INTERNAL_LABEL(LABEL, PREFIX, NUM) \
218 do { \
219 if (TARGET_ELF) \
220 sprintf (LABEL, "*.%s%ld", (PREFIX), (long)(NUM)); \
221 else \
222 sprintf (LABEL, ".%s%ld", (PREFIX), (long)(NUM)); \
223 } while (0)
225 #undef ASM_OUTPUT_ALIGNED_COMMON
226 #define ASM_OUTPUT_ALIGNED_COMMON(FILE, NAME, SIZE, ALIGN) \
227 do { \
228 fprintf ((FILE), "%s", COMMON_ASM_OP); \
229 assemble_name ((FILE), (NAME)); \
230 if (TARGET_ELF) \
231 fprintf ((FILE), ",%u,%u\n", (SIZE), (ALIGN) / BITS_PER_UNIT); \
232 else \
233 fprintf ((FILE), ",%u\n", (SIZE)); \
234 } while (0)
236 #undef ASM_OUTPUT_ALIGNED_LOCAL
237 #define ASM_OUTPUT_ALIGNED_LOCAL(FILE, NAME, SIZE, ALIGN) \
238 do { \
239 if (TARGET_ELF) { \
240 fprintf ((FILE), "%s", LOCAL_ASM_OP); \
241 assemble_name ((FILE), (NAME)); \
242 fprintf ((FILE), "\n"); \
243 ASM_OUTPUT_ALIGNED_COMMON (FILE, NAME, SIZE, ALIGN); \
244 } else { \
245 int align = exact_log2 (ALIGN); \
246 if (align > 2) align = 2; \
247 if (TARGET_SVR3_SHLIB) \
248 data_section (); \
249 else \
250 bss_section (); \
251 ASM_OUTPUT_ALIGN ((FILE), align == -1 ? 2 : align); \
252 fprintf ((FILE), "%s\t", "\t.lcomm"); \
253 assemble_name ((FILE), (NAME)); \
254 fprintf ((FILE), ",%u\n", (SIZE)); \
256 } while (0)
258 /* A C statement (sans semicolon) to output to the stdio stream
259 FILE the assembler definition of uninitialized global DECL named
260 NAME whose size is SIZE bytes and alignment is ALIGN bytes.
261 Try to use asm_output_aligned_bss to implement this macro. */
263 #define ASM_OUTPUT_ALIGNED_BSS(FILE, DECL, NAME, SIZE, ALIGN) \
264 asm_output_aligned_bss (FILE, DECL, NAME, SIZE, ALIGN)
266 #undef ESCAPES
267 #define ESCAPES \
268 "\1\1\1\1\1\1\1\1btn\1fr\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\
269 \0\0\"\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\
270 \0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\\\0\0\0\
271 \0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\1\
272 \1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\
273 \1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\
274 \1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\
275 \1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1"
277 #undef STRING_LIMIT
278 #define STRING_LIMIT ((unsigned) 256)
280 #undef ASM_OUTPUT_LIMITED_STRING
281 #define ASM_OUTPUT_LIMITED_STRING(FILE, STR) \
282 do \
284 register const unsigned char *_limited_str = \
285 (const unsigned char *) (STR); \
286 register unsigned ch; \
287 fprintf ((FILE), "%s\"", STRING_ASM_OP); \
288 for (; (ch = *_limited_str); _limited_str++) \
290 register int escape; \
291 switch (escape = ESCAPES[ch]) \
293 case 0: \
294 putc (ch, (FILE)); \
295 break; \
296 case 1: \
297 fprintf ((FILE), "\\%03o", ch); \
298 break; \
299 default: \
300 putc ('\\', (FILE)); \
301 putc (escape, (FILE)); \
302 break; \
305 fprintf ((FILE), "\"\n"); \
307 while (0)
310 #undef ASM_OUTPUT_ASCII
311 #define ASM_OUTPUT_ASCII(FILE, STR, LENGTH) \
312 do { \
313 register const unsigned char *_ascii_bytes = \
314 (const unsigned char *) (STR); \
315 register const unsigned char *limit = _ascii_bytes + (LENGTH); \
316 register unsigned bytes_in_chunk = 0; \
317 for (; _ascii_bytes < limit; _ascii_bytes++) \
319 register unsigned const char *p; \
320 if (bytes_in_chunk >= 64) \
322 fputc ('\n', (FILE)); \
323 bytes_in_chunk = 0; \
325 for (p = _ascii_bytes; p < limit && *p != '\0'; p++) \
326 continue; \
327 if (p < limit && (p - _ascii_bytes) <= (long) STRING_LIMIT) \
329 if (bytes_in_chunk > 0) \
331 fputc ('\n', (FILE)); \
332 bytes_in_chunk = 0; \
334 ASM_OUTPUT_LIMITED_STRING ((FILE), _ascii_bytes); \
335 _ascii_bytes = p; \
337 else \
339 if (bytes_in_chunk == 0) \
340 fputs ("\t.byte\t", (FILE)); \
341 else \
342 fputc (',', (FILE)); \
343 fprintf ((FILE), "0x%02x", *_ascii_bytes); \
344 bytes_in_chunk += 5; \
347 if (bytes_in_chunk > 0) \
348 fprintf ((FILE), "\n"); \
349 } while (0)
351 #undef ASM_OUTPUT_CASE_LABEL
352 #define ASM_OUTPUT_CASE_LABEL(FILE,PREFIX,NUM,JUMPTABLE) \
353 do { \
354 if (TARGET_ELF) \
355 ASM_OUTPUT_ALIGN ((FILE), 2); \
356 ASM_OUTPUT_INTERNAL_LABEL((FILE),(PREFIX),(NUM)); \
357 } while (0)
359 #undef ASM_OUTPUT_IDENT
360 #define ASM_OUTPUT_IDENT(FILE, NAME) \
361 fprintf (FILE, "%s\"%s\"\n", IDENT_ASM_OP, NAME);
363 #undef ASM_GLOBALIZE_LABEL
364 #define ASM_GLOBALIZE_LABEL(FILE,NAME) \
365 (fprintf ((FILE), "%s", GLOBAL_ASM_OP), assemble_name (FILE, NAME), fputs ("\n", FILE))
367 #undef ASM_OUTPUT_EXTERNAL_LIBCALL
368 #define ASM_OUTPUT_EXTERNAL_LIBCALL(FILE, FUN) \
369 if (TARGET_ELF) ASM_GLOBALIZE_LABEL (FILE, XSTR (FUN, 0))
371 #undef ASM_OUTPUT_INTERNAL_LABEL
372 #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM) \
373 fprintf (FILE, ".%s%d:\n", PREFIX, NUM)
375 /* The prefix to add to user-visible assembler symbols. */
377 #undef USER_LABEL_PREFIX
378 #define USER_LABEL_PREFIX ""
381 * We rename 'gcc_except_table' to the shorter name in preparation
382 * for the day when we're ready to do DWARF2 eh unwinding under COFF.
384 /* #define EXCEPTION_SECTION() named_section (NULL, ".gccexc", 1) */
386 /* Switch into a generic section. */
387 #define TARGET_ASM_NAMED_SECTION default_elf_asm_named_section
389 #undef ASM_OUTPUT_SKIP
390 #define ASM_OUTPUT_SKIP(FILE,SIZE) \
391 do { \
392 if (TARGET_ELF) \
393 fprintf (FILE, "%s%u\n", SKIP_ASM_OP, (SIZE)); \
394 else \
395 fprintf ((FILE), "%s.,.+%u\n", SET_ASM_OP, (SIZE)); \
396 } while (0)
399 #undef CTOR_LIST_BEGIN
400 #define CTOR_LIST_BEGIN \
401 do { \
402 asm (CTORS_SECTION_ASM_OP); \
403 if (TARGET_ELF) \
404 STATIC func_ptr __CTOR_LIST__[1] = { (func_ptr) (-1) }; \
405 else \
406 asm ("pushl $0"); \
407 } while (0)
409 #undef CTOR_LIST_END
410 #define CTOR_LIST_END \
411 do { \
412 if (TARGET_ELF) { \
413 asm (CTORS_SECTION_ASM_OP); \
414 STATIC func_ptr __CTOR_LIST__[1] = { (func_ptr) (0) }; \
415 } else { \
416 CTOR_LIST_BEGIN; \
418 } while (0)
420 #undef DBX_BLOCKS_FUNCTION_RELATIVE
421 #define DBX_BLOCKS_FUNCTION_RELATIVE 1
423 #undef DBX_FUNCTION_FIRST
424 #define DBX_FUNCTION_FIRST 1
426 #undef DBX_REGISTER_NUMBER
427 #define DBX_REGISTER_NUMBER(n) \
428 ((TARGET_ELF) ? svr4_dbx_register_map[n] : dbx_register_map[n])
430 #undef DWARF2_DEBUGGING_INFO
431 #undef DWARF_DEBUGGING_INFO
432 #undef SDB_DEBUGGING_INFO
433 #undef DBX_DEBUGGING_INFO
434 #undef PREFERRED_DEBUGGING_TYPE
436 #define DWARF2_DEBUGGING_INFO 1
437 #define DWARF_DEBUGGING_INFO 1
438 #define SDB_DEBUGGING_INFO 1
439 #define DBX_DEBUGGING_INFO 1
440 #define PREFERRED_DEBUGGING_TYPE \
441 ((TARGET_ELF) ? DWARF2_DEBUG: SDB_DEBUG)
443 #undef EXTRA_SECTIONS
444 #define EXTRA_SECTIONS in_init, in_fini
446 #undef EXTRA_SECTION_FUNCTIONS
447 #define EXTRA_SECTION_FUNCTIONS \
448 INIT_SECTION_FUNCTION \
449 FINI_SECTION_FUNCTION
451 #undef FINI_SECTION_FUNCTION
452 #define FINI_SECTION_FUNCTION \
453 void \
454 fini_section () \
456 if ((!TARGET_ELF) && in_section != in_fini) \
458 fprintf (asm_out_file, "%s\n", FINI_SECTION_ASM_OP); \
459 in_section = in_fini; \
463 #undef INIT_SECTION_FUNCTION
464 #define INIT_SECTION_FUNCTION \
465 void \
466 init_section () \
468 if ((!TARGET_ELF) && in_section != in_init) \
470 fprintf (asm_out_file, "%s\n", INIT_SECTION_ASM_OP); \
471 in_section = in_init; \
475 #undef SUBTARGET_FRAME_POINTER_REQUIRED
476 #define SUBTARGET_FRAME_POINTER_REQUIRED \
477 ((TARGET_ELF) ? 0 : \
478 (current_function_calls_setjmp || current_function_calls_longjmp))
480 #undef LOCAL_LABEL_PREFIX
481 #define LOCAL_LABEL_PREFIX \
482 ((TARGET_ELF) ? "" : ".")
484 #undef MD_EXEC_PREFIX
485 #undef MD_STARTFILE_PREFIX
486 #define MD_EXEC_PREFIX "/usr/ccs/bin/"
487 #define MD_STARTFILE_PREFIX "/usr/ccs/lib/"
489 #undef NON_SAVING_SETJMP
490 #define NON_SAVING_SETJMP \
491 ((TARGET_ELF) ? 0 : \
492 (current_function_calls_setjmp && current_function_calls_longjmp))
494 #undef NO_IMPLICIT_EXTERN_C
495 #define NO_IMPLICIT_EXTERN_C 1
497 /* JKJ FIXME - examine the ramifications of RETURN_IN_MEMORY and
498 RETURN_POPS_ARGS */
500 #undef RETURN_POPS_ARGS
501 #define RETURN_POPS_ARGS(FUNDECL,FUNTYPE,SIZE) \
502 ((TARGET_ELF) ? \
503 (ix86_return_pops_args (FUNDECL, FUNTYPE, SIZE)) : \
504 (((FUNDECL) && (TREE_CODE (FUNDECL) == IDENTIFIER_NODE)) ? 0 \
505 : (TARGET_RTD \
506 && (TYPE_ARG_TYPES (FUNTYPE) == 0 \
507 || (TREE_VALUE (tree_last (TYPE_ARG_TYPES (FUNTYPE))) \
508 == void_type_node))) ? (SIZE) \
509 : 0))
511 /* ??? Ignore coff. */
512 #undef TARGET_ASM_SELECT_SECTION
513 #define TARGET_ASM_SELECT_SECTION default_elf_select_section
515 #undef SWITCH_TAKES_ARG
516 #define SWITCH_TAKES_ARG(CHAR) \
517 (DEFAULT_SWITCH_TAKES_ARG(CHAR) \
518 || (CHAR) == 'h' \
519 || (CHAR) == 'R' \
520 || (CHAR) == 'Y' \
521 || (CHAR) == 'z')
523 #undef WORD_SWITCH_TAKES_ARG
524 #define WORD_SWITCH_TAKES_ARG(STR) \
525 (DEFAULT_WORD_SWITCH_TAKES_ARG (STR) \
526 && strcmp (STR, "Tdata") && strcmp (STR, "Ttext") \
527 && strcmp (STR, "Tbss"))
529 #undef TARGET_SUBTARGET_DEFAULT
530 #define TARGET_SUBTARGET_DEFAULT (MASK_80387 | MASK_IEEE_FP | MASK_FLOAT_RETURNS)
532 #undef HANDLE_SYSV_PRAGMA
533 #define HANDLE_SYSV_PRAGMA 1
535 /* Though OpenServer supports .weak in COFF, we don't use it.
536 * G++ will frequently emit a symol as .weak and then (in the same .s
537 * file) declare it global. The COFF assembler finds this unamusing.
539 #define SUPPORTS_WEAK (TARGET_ELF)
540 #define ASM_WEAKEN_LABEL(FILE,NAME) \
541 do { fputs ("\t.weak\t", FILE); assemble_name (FILE, NAME); \
542 fputc ('\n', FILE); } while (0)
544 #undef SCCS_DIRECTIVE
545 #define SCCS_DIRECTIVE 1
548 * Define sizes and types
550 #undef SIZE_TYPE
551 #undef PTRDIFF_TYPE
552 #undef WCHAR_TYPE
553 #undef WCHAR_TYPE_SIZE
554 #undef LONG_DOUBLE_TYPE_SIZE
555 #define LONG_DOUBLE_TYPE_SIZE 96
556 #define SIZE_TYPE "unsigned int"
557 #define PTRDIFF_TYPE "int"
558 #define WCHAR_TYPE "long int"
559 #define WCHAR_TYPE_SIZE BITS_PER_WORD
562 * New for multilib support. Set the default switches for multilib,
563 * which is -melf.
565 #define MULTILIB_DEFAULTS { "melf" }
568 /* Please note that these specs may look messy but they are required in
569 order to emulate the SCO Development system as closely as possible.
570 With SCO Open Server 5.0, you now get the linker and assembler free,
571 so that is what these specs are targeted for. These utilities are
572 very argument sensitive: a space in the wrong place breaks everything.
573 So RMS, please forgive this mess. It works.
575 Parameters which can be passed to gcc, and their SCO equivalents:
576 GCC Parameter SCO Equivalent
577 -ansi -a ansi
578 -posix -a posix
579 -Xpg4 -a xpg4
580 -Xpg4plus -a xpg4plus
581 -Xods30 -a ods30
583 As with SCO, the default is XPG4 plus mode. SCO also allows you to
584 specify a C dialect with -Xt, -Xa, -Xc, -Xk and -Xm. These are passed
585 on to the assembler and linker in the same way that the SCO compiler
586 does.
588 SCO also allows you to compile, link and generate either ELF or COFF
589 binaries. With gcc, unlike the SCO compiler, the default is ELF.
590 Specify -mcoff to gcc to produce COFF binaries. -fpic will get the
591 assembler and linker to produce PIC code.
594 /* Set up assembler flags for PIC and ELF compilations */
595 #undef ASM_SPEC
597 #if USE_GAS
598 /* Leave ASM_SPEC undefined so we pick up the master copy from gcc.c
599 * Undef MD_EXEC_PREFIX because we don't know where GAS is, but it's not
600 * likely in /usr/ccs/bin/
602 #undef MD_EXEC_PREFIX
603 #else
605 #define ASM_SPEC \
606 "-b %{!mcoff:elf}%{mcoff:coff \
607 %{static:%e-static not valid with -mcoff} \
608 %{shared:%e-shared not valid with -mcoff} \
609 %{symbolic:%e-symbolic not valid with -mcoff}} \
610 %{Ym,*} %{Yd,*} %{Wa,*:%*} \
611 %{!mcoff:-E%{Xa:a}%{!Xa:%{Xc:c}%{!Xc:%{Xk:k}%{!Xk:%{Xt:t}%{!Xt:a}}}},%{ansi:ansi}%{!ansi:%{posix:posix}%{!posix:%{Xpg4:xpg4}%{!Xpg4:%{Xpg4plus:XPG4PLUS}%{!Xpg4plus:%{Xods30:ods30}%{!Xods30:XPG4PLUS}}}}},ELF %{Qn:} %{!Qy:-Qn}}"
612 #endif
614 /* Use crt1.o as a startup file and crtn.o as a closing file. */
616 #undef STARTFILE_SPEC
617 #define STARTFILE_SPEC \
618 "%{shared: %{!mcoff: crti.o%s}} \
619 %{!shared:\
620 %{!symbolic: \
621 %{pg:gcrt.o%s}%{!pg:%{p:mcrt1.o%s}%{!p:crt1.o%s}}}} \
622 %{ansi:values-Xc.o%s} \
623 %{!ansi: \
624 %{Xa:values-Xa.o%s} \
625 %{!Xa:%{Xc:values-Xc.o%s} \
626 %{!Xc:%{Xk:values-Xk.o%s} \
627 %{!Xk:%{Xt:values-Xt.o%s} \
628 %{!Xt:values-Xa.o%s}}}}} \
629 %{mcoff:crtbeginS.o%s} %{!mcoff:crtbegin.o%s}"
631 #undef ENDFILE_SPEC
632 #define ENDFILE_SPEC \
633 "%{!mcoff:crtend.o%s} \
634 %{mcoff:crtendS.o%s} \
635 %{pg:gcrtn.o%s}%{!pg:crtn.o%s}"
637 #undef CPP_PREDEFINES
638 #define CPP_PREDEFINES \
639 "-Asystem=svr3"
641 /* You are in a maze of GCC specs ... all alike */
643 #undef CPP_SPEC
644 #define CPP_SPEC "%(cpp_cpu) \
645 %{fpic:%{mcoff:%e-fpic is not valid with -mcoff}} \
646 %{fPIC:%{mcoff:%e-fPIC is not valid with -mcoff}} \
647 -D__i386 -D__unix -D_SCO_DS=1 -D_M_I386 -D_M_XENIX -D_M_UNIX \
648 %{!Xods30:-D_STRICT_NAMES} \
649 %{!ansi:%{!posix:%{!Xods30:-D_SCO_XPG_VERS=4}}} \
650 %{ansi:-isystem include/ansi%s -isystem /usr/include/ansi -D_STRICT_ANSI} \
651 %{!ansi: \
652 %{posix:-isystem include/posix%s -isystem /usr/include/posix \
653 -D_POSIX_C_SOURCE=2 -D_POSIX_SOURCE=1} \
654 %{!posix:%{Xpg4:-isystem include/xpg4%s -isystem /usr/include/xpg4 \
655 -D_XOPEN_SOURCE=1} \
656 %{!Xpg4:-D_M_I86 -D_M_I86SM -D_M_INTERNAT -D_M_SDATA -D_M_STEXT \
657 -D_M_BITFIELDS -D_M_SYS5 -D_M_SYSV -D_M_SYSIII \
658 -D_M_WORDSWAP -Dunix -DM_I386 -DM_UNIX -DM_XENIX \
659 %{Xods30:-isystem include/ods_30_compat%s \
660 -isystem /usr/include/ods_30_compat \
661 -D_SCO_ODS_30 -DM_I86 -DM_I86SM -DM_SDATA -DM_STEXT \
662 -DM_BITFIELDS -DM_SYS5 -DM_SYSV -DM_INTERNAT -DM_SYSIII \
663 -DM_WORDSWAP}}}} \
664 %{scointl:-DM_INTERNAT -D_M_INTERNAT} \
665 %{!mcoff:-D_SCO_ELF} \
666 %{mcoff:-D_M_COFF -D_SCO_COFF} \
667 %{!mcoff:%{fpic:-D__PIC__ -D__pic__} \
668 %{fPIC:%{!fpic:-D__PIC__ -D__pic__}}} \
669 %{Xa:-D_SCO_C_DIALECT=1} \
670 %{!Xa:%{Xc:-D_SCO_C_DIALECT=3} \
671 %{!Xc:%{Xk:-D_SCO_C_DIALECT=4} \
672 %{!Xk:%{Xt:-D_SCO_C_DIALECT=2} \
673 %{!Xt:-D_SCO_C_DIALECT=1}}}}"
675 #undef LINK_SPEC
676 #define LINK_SPEC \
677 "-b %{!mcoff:elf}%{mcoff:coff \
678 %{static:%e-static not valid with -mcoff} \
679 %{shared:%e-shared not valid with -mcoff} \
680 %{symbolic:%e-symbolic not valid with -mcoff} \
681 %{fpic:%e-fpic not valid with -mcoff} \
682 %{fPIC:%e-fPIC not valid with -mcoff}} \
683 -R%{Xa:a}%{!Xa:%{Xc:c}%{!Xc:%{Xk:k}%{!Xk:%{Xt:t}%{!Xt:a}}}},%{ansi:ansi}%{!ansi:%{posix:posix}%{!posix:%{Xpg4:xpg4}%{!Xpg4:%{Xpg4plus:XPG4PLUS}%{!Xpg4plus:%{Xods30:ods30}%{!Xods30:XPG4PLUS}}}}},%{mcoff:COFF}%{!mcoff:ELF} \
684 %{Wl,*%*} %{YP,*} %{YL,*} %{YU,*} \
685 %{!YP,*:%{p:-YP,/usr/ccs/libp:/lib/libp:/usr/lib/libp:/usr/ccs/lib:/lib:/usr/lib} \
686 %{!p:-YP,/usr/ccs/lib:/lib:/usr/lib}} \
687 %{h*} %{static:-dn -Bstatic} %{shared:-G -dy %{!z*:-z text}} \
688 %{symbolic:-Bsymbolic -G -dy %{!z*:-z text}} %{z*} %{R*} %{Y*} \
689 %{G:-G} %{!mcoff:%{Qn:} %{!Qy:-Qn}}"
691 /* The SCO COFF linker gets confused on the difference between "-ofoo"
692 and "-o foo". So we just always force a single space. */
694 #define SWITCHES_NEED_SPACES "o"
696 /* Library spec. If we are not building a shared library, provide the
697 standard libraries, as per the SCO compiler. */
699 #undef LIB_SPEC
700 #define LIB_SPEC \
701 "%{shared:pic/libgcc.a%s}%{!shared:%{!symbolic:-lcrypt -lgen -lc}}"
703 #undef LIBGCC_SPEC
704 #define LIBGCC_SPEC \
705 "%{!shared:-lgcc}"
707 #define MASK_COFF 010000000000 /* Mask for elf generation */
708 #define TARGET_ELF (1) /* (!(target_flags & MASK_COFF)) */
710 #undef SUBTARGET_SWITCHES
711 #define SUBTARGET_SWITCHES \
712 { "elf", -MASK_COFF, N_("Generate ELF output") },
714 #define NO_DOLLAR_IN_LABEL
716 /* Implicit library calls should use memcpy, not bcopy, etc. They are
717 faster on OpenServer libraries. */
719 #define TARGET_MEM_FUNCTIONS
721 /* Biggest alignment supported by the object file format of this
722 machine. Use this macro to limit the alignment which can be
723 specified using the `__attribute__ ((aligned (N)))' construct. If
724 not defined, the default value is `BIGGEST_ALIGNMENT'. */
726 #define MAX_OFILE_ALIGNMENT (32768*8)
728 /* Define the `__builtin_va_list' type for the ABI. On OpenServer, this
729 type is `char *'. */
730 #undef BUILD_VA_LIST_TYPE
731 #define BUILD_VA_LIST_TYPE(VALIST) \
732 (VALIST) = build_pointer_type (char_type_node)
736 Here comes some major hackery to get the crt stuff to compile properly.
737 Since we can (and do) compile for both COFF and ELF environments, we
738 set things up accordingly, based on the pre-processor defines for ELF
739 and COFF. This is insane, but then I guess having one compiler with a
740 single back-end supporting two vastly different file format types is
741 a little insane too. But it is not impossible and we get a useful
742 compiler at the end of the day. Onward we go ...
745 #if defined(CRT_BEGIN) || defined(CRT_END) || defined(IN_LIBGCC2)
746 # undef OBJECT_FORMAT_ELF
747 # undef INIT_SECTION_ASM_OP
748 # undef FINI_SECTION_ASM_OP
749 # undef CTORS_SECTION_ASM_OP
750 # undef DTORS_SECTION_ASM_OP
751 # undef EH_FRAME_SECTION_NAME
752 # undef CTOR_LIST_BEGIN
753 # undef CTOR_LIST_END
754 # undef DO_GLOBAL_CTORS_BODY
756 # if defined (_SCO_ELF)
757 # define OBJECT_FORMAT_ELF
758 # define INIT_SECTION_ASM_OP INIT_SECTION_ASM_OP_ELF
759 # define FINI_SECTION_ASM_OP FINI_SECTION_ASM_OP_ELF
760 # define DTORS_SECTION_ASM_OP DTORS_SECTION_ASM_OP_ELF
761 # define CTORS_SECTION_ASM_OP CTORS_SECTION_ASM_OP_ELF
762 # define EH_FRAME_SECTION_NAME EH_FRAME_SECTION_NAME_ELF
763 # else /* ! _SCO_ELF */
764 # define INIT_SECTION_ASM_OP INIT_SECTION_ASM_OP_COFF
765 # define FINI_SECTION_ASM_OP FINI_SECTION_ASM_OP_COFF
766 # define DTORS_SECTION_ASM_OP DTORS_SECTION_ASM_OP_COFF
767 # define CTORS_SECTION_ASM_OP CTORS_SECTION_ASM_OP_COFF
768 # define EH_FRAME_SECTION_NAME EH_FRAME_SECTION_NAME_COFF
769 # define CTOR_LIST_BEGIN asm (INIT_SECTION_ASM_OP); asm ("pushl $0")
770 # define CTOR_LIST_END CTOR_LIST_BEGIN
771 # define DO_GLOBAL_CTORS_BODY \
772 do { \
773 func_ptr *p, *beg = alloca(0); \
774 for (p = beg; *p;) \
775 (*p++) (); \
776 } while (0)
777 # endif /* ! _SCO_ELF */
778 #endif /* CRT_BEGIN !! CRT_END */
780 /* Handle special EH pointer encodings. Absolute, pc-relative, and
781 indirect are handled automatically. */
782 #define ASM_MAYBE_OUTPUT_ENCODED_ADDR_RTX(FILE, ENCODING, SIZE, ADDR, DONE) \
783 do { \
784 if ((SIZE) == 4 && ((ENCODING) & 0x70) == DW_EH_PE_datarel) \
786 fputs (ASM_LONG, FILE); \
787 assemble_name (FILE, XSTR (ADDR, 0)); \
788 fputs (((ENCODING) & DW_EH_PE_indirect ? "@GOT" : "@GOTOFF"), FILE); \
789 goto DONE; \
791 } while (0)
793 /* Used by crtstuff.c to initialize the base of data-relative relocations.
794 These are GOT relative on x86, so return the pic register. */
795 #ifdef __PIC__
796 #define CRT_GET_RFIB_DATA(BASE) \
798 register void *ebx_ __asm__("ebx"); \
799 BASE = ebx_; \
801 #else
802 #define CRT_GET_RFIB_DATA(BASE) \
803 __asm__ ("call\t.LPR%=\n" \
804 ".LPR%=:\n\t" \
805 "popl\t%0\n\t" \
806 /* Due to a GAS bug, this cannot use EAX. That encodes \
807 smaller than the traditional EBX, which results in the \
808 offset being off by one. */ \
809 "addl\t$_GLOBAL_OFFSET_TABLE_+[.-.LPR%=],%0" \
810 : "=d"(BASE))
811 #endif
813 /* Select a format to encode pointers in exception handling data. CODE
814 is 0 for data, 1 for code labels, 2 for function pointers. GLOBAL is
815 true if the symbol may be affected by dynamic relocations. */
816 #undef ASM_PREFERRED_EH_DATA_FORMAT
817 #define ASM_PREFERRED_EH_DATA_FORMAT(CODE,GLOBAL) \
818 (flag_pic ? (GLOBAL ? DW_EH_PE_indirect : 0) | DW_EH_PE_datarel \
819 : DW_EH_PE_absptr)