1 /* Definitions for Intel 386 running SCO Unix System V 3.2 Version 5.
2 Copyright (C) 1992, 95-98, 1999 Free Software Foundation, Inc.
3 Contributed by Kean Johnston (hug@netcom.com)
5 This file is part of GNU CC.
7 GNU CC 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)
12 GNU CC 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.
17 You should have received a copy of the GNU General Public License
18 along with GNU CC; see the file COPYING. If not, write to
19 the Free Software Foundation, 59 Temple Place - Suite 330,
20 Boston, MA 02111-1307, USA. */
22 #include "i386/i386.h" /* Base i386 target definitions */
23 #include "i386/att.h" /* Use AT&T i386 assembler syntax */
26 #define TARGET_VERSION fprintf (stderr, " (i386, SCO OpenServer 5 Syntax)");
32 #define ALIGN_ASM_OP "\t.align"
34 #undef ASCII_DATA_ASM_OP
35 #define ASCII_DATA_ASM_OP "\t.ascii"
38 #define ASM_BYTE_OP "\t.byte"
41 #define IDENT_ASM_OP "\t.ident"
44 #define COMMON_ASM_OP "\t.comm"
47 #define SET_ASM_OP "\t.set"
50 #define LOCAL_ASM_OP "\t.local"
53 #define INT_ASM_OP "\t.long"
56 #define ASM_SHORT "\t.value"
59 #define ASM_LONG "\t.long"
62 #define ASM_DOUBLE "\t.double"
65 #define TYPE_ASM_OP "\t.type"
68 #define SIZE_ASM_OP "\t.size"
71 #define STRING_ASM_OP "\t.string"
74 #define SKIP_ASM_OP "\t.zero"
77 #define GLOBAL_ASM_OP "\t.globl"
79 #undef EH_FRAME_SECTION_ASM_OP
80 #define EH_FRAME_SECTION_ASM_OP_COFF "\t.section\t.ehfram, \"x\""
81 #define EH_FRAME_SECTION_ASM_OP_ELF "\t.section\t.eh_frame, \"aw\""
82 #define EH_FRAME_SECTION_ASM_OP \
83 ((TARGET_ELF) ? EH_FRAME_SECTION_ASM_OP_ELF : EH_FRAME_SECTION_ASM_OP_COFF)
85 /* Avoid problems (long sectino names, forward assembler refs) with DWARF
86 exception unwinding when we're generating COFF */
87 #define DWARF2_UNWIND_INFO \
88 ((TARGET_ELF) ? 1 : 0 )
90 #undef CONST_SECTION_ASM_OP
91 #define CONST_SECTION_ASM_OP_COFF "\t.section\t.rodata, \"x\""
92 #define CONST_SECTION_ASM_OP_ELF "\t.section\t.rodata"
93 #define CONST_SECTION_ASM_OP \
94 ((TARGET_ELF) ? CONST_SECTION_ASM_OP_ELF : CONST_SECTION_ASM_OP_COFF)
96 #undef USE_CONST_SECTION
97 #define USE_CONST_SECTION_ELF 1
98 #define USE_CONST_SECTION_COFF 0
99 #define USE_CONST_SECTION \
100 ((TARGET_ELF) ? USE_CONST_SECTION_ELF : USE_CONST_SECTION_COFF)
102 #undef INIT_SECTION_ASM_OP
103 #define INIT_SECTION_ASM_OP_ELF "\t.section\t.init"
104 #define INIT_SECTION_ASM_OP_COFF "\t.section\t.init ,\"x\""
105 #define INIT_SECTION_ASM_OP \
106 ((TARGET_ELF) ? INIT_SECTION_ASM_OP_ELF : INIT_SECTION_ASM_OP_COFF)
108 #undef CTORS_SECTION_ASM_OP
109 #define CTORS_SECTION_ASM_OP_ELF "\t.section\t.ctors,\"aw\""
110 #define CTORS_SECTION_ASM_OP_COFF INIT_SECTION_ASM_OP_COFF
111 #define CTORS_SECTION_ASM_OP \
112 ((TARGET_ELF) ? CTORS_SECTION_ASM_OP_ELF : CTORS_SECTION_ASM_OP_COFF)
114 #undef DTORS_SECTION_ASM_OP
115 #define DTORS_SECTION_ASM_OP_ELF "\t.section\t.dtors, \"aw\""
116 #define DTORS_SECTION_ASM_OP_COFF FINI_SECTION_ASM_OP_COFF
117 #define DTORS_SECTION_ASM_OP \
118 ((TARGET_ELF) ? DTORS_SECTION_ASM_OP_ELF : DTORS_SECTION_ASM_OP_COFF)
120 #undef FINI_SECTION_ASM_OP
121 #define FINI_SECTION_ASM_OP_ELF "\t.section\t.fini"
122 #define FINI_SECTION_ASM_OP_COFF "\t.section\t.fini, \"x\""
123 #define FINI_SECTION_ASM_OP \
124 ((TARGET_ELF) ? FINI_SECTION_ASM_OP_ELF : FINI_SECTION_ASM_OP_COFF)
126 #undef BSS_SECTION_ASM_OP
127 #define BSS_SECTION_ASM_OP "\t.data"
129 #undef TEXT_SECTION_ASM_OP
130 #define TEXT_SECTION_ASM_OP "\t.text"
132 #undef DATA_SECTION_ASM_OP
133 #define DATA_SECTION_ASM_OP "\t.data"
135 #undef TYPE_OPERAND_FMT
136 #define TYPE_OPERAND_FMT "@%s"
138 #undef APPLY_RESULT_SIZE
139 #define APPLY_RESULT_SIZE \
140 (TARGET_ELF) ? size : 116
142 #ifndef ASM_DECLARE_RESULT
143 #define ASM_DECLARE_RESULT(FILE, RESULT)
146 #define SCO_DEFAULT_ASM_COFF(FILE,NAME) \
148 ASM_OUTPUT_LABEL (FILE, NAME); \
151 #undef ASM_DECLARE_FUNCTION_NAME
152 #define ASM_DECLARE_FUNCTION_NAME(FILE, NAME, DECL) \
155 fprintf (FILE, "%s\t ", TYPE_ASM_OP); \
156 assemble_name (FILE, NAME); \
158 fprintf (FILE, TYPE_OPERAND_FMT, "function"); \
160 ASM_DECLARE_RESULT (FILE, DECL_RESULT (DECL)); \
161 ASM_OUTPUT_LABEL(FILE, NAME); \
163 SCO_DEFAULT_ASM_COFF(FILE, NAME); \
166 #undef ASM_DECLARE_FUNCTION_SIZE
167 #define ASM_DECLARE_FUNCTION_SIZE(FILE, FNAME, DECL) \
169 if (TARGET_ELF) { if (!flag_inhibit_size_directive) \
171 fprintf (FILE, "%s\t ", SIZE_ASM_OP); \
172 assemble_name (FILE, (FNAME)); \
173 fprintf (FILE, ",.-"); \
174 assemble_name (FILE, (FNAME)); \
179 #undef ASM_DECLARE_OBJECT_NAME
180 #define ASM_DECLARE_OBJECT_NAME(FILE, NAME, DECL) \
183 fprintf (FILE, "%s\t ", TYPE_ASM_OP); \
184 assemble_name (FILE, NAME); \
186 fprintf (FILE, TYPE_OPERAND_FMT, "object"); \
188 size_directive_output = 0; \
189 if (!flag_inhibit_size_directive && DECL_SIZE (DECL)) \
191 size_directive_output = 1; \
192 fprintf (FILE, "%s\t ", SIZE_ASM_OP); \
193 assemble_name (FILE, NAME); \
194 fprintf (FILE, ",%d\n", int_size_in_bytes (TREE_TYPE (DECL))); \
196 ASM_OUTPUT_LABEL(FILE, NAME); \
198 SCO_DEFAULT_ASM_COFF(FILE, NAME); \
201 #undef ASM_FILE_START_1
202 #define ASM_FILE_START_1(FILE)
204 #undef ASM_FILE_START
205 #define ASM_FILE_START(FILE) \
207 output_file_directive((FILE),main_input_filename); \
208 fprintf ((FILE), "\t.version\t\"01.01\"\n"); \
212 #define ASM_FILE_END(FILE) \
214 if (!flag_no_ident) \
215 fprintf ((FILE), "%s\t\"GCC: (GNU) %s\"\n", \
216 IDENT_ASM_OP, version_string); \
219 #undef ASM_FINISH_DECLARE_OBJECT
220 #define ASM_FINISH_DECLARE_OBJECT(FILE, DECL, TOP_LEVEL, AT_END) \
223 char *name = XSTR (XEXP (DECL_RTL (DECL), 0), 0); \
224 if (!flag_inhibit_size_directive && DECL_SIZE (DECL) \
225 && ! AT_END && TOP_LEVEL \
226 && DECL_INITIAL (DECL) == error_mark_node \
227 && !size_directive_output) \
229 size_directive_output = 1; \
230 fprintf (FILE, "%s\t ", SIZE_ASM_OP); \
231 assemble_name (FILE, name); \
232 fprintf (FILE, ",%d\n", int_size_in_bytes (TREE_TYPE (DECL))); \
237 #undef ASM_GENERATE_INTERNAL_LABEL
238 #define ASM_GENERATE_INTERNAL_LABEL(LABEL, PREFIX, NUM) \
241 sprintf (LABEL, "*.%s%d", (PREFIX), (NUM)); \
243 sprintf (LABEL, ".%s%d", (PREFIX), (NUM)); \
246 #undef ASM_OUTPUT_ADDR_DIFF_ELT
247 #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, BODY, VALUE, REL) \
250 fprintf (FILE, "%s _GLOBAL_OFFSET_TABLE_+[.-%s%d]\n", ASM_LONG, LPREFIX, VALUE); \
252 fprintf (FILE, "\t.word %s%d-%s%d\n", LPREFIX,VALUE,LPREFIX,REL); \
255 #undef ASM_OUTPUT_ALIGNED_COMMON
256 #define ASM_OUTPUT_ALIGNED_COMMON(FILE, NAME, SIZE, ALIGN) \
258 fprintf ((FILE), "%s\t", COMMON_ASM_OP); \
259 assemble_name ((FILE), (NAME)); \
261 fprintf ((FILE), ",%u,%u\n", (SIZE), (ALIGN) / BITS_PER_UNIT); \
263 fprintf ((FILE), ",%u\n", (SIZE)); \
266 #undef ASM_OUTPUT_ALIGNED_LOCAL
267 #define ASM_OUTPUT_ALIGNED_LOCAL(FILE, NAME, SIZE, ALIGN) \
270 fprintf ((FILE), "%s\t", LOCAL_ASM_OP); \
271 assemble_name ((FILE), (NAME)); \
272 fprintf ((FILE), "\n"); \
273 ASM_OUTPUT_ALIGNED_COMMON (FILE, NAME, SIZE, ALIGN); \
275 int align = exact_log2 (ALIGN); \
276 if (align > 2) align = 2; \
277 if (TARGET_SVR3_SHLIB) \
281 ASM_OUTPUT_ALIGN ((FILE), align == -1 ? 2 : align); \
282 fprintf ((FILE), "%s\t", "\t.lcomm"); \
283 assemble_name ((FILE), (NAME)); \
284 fprintf ((FILE), ",%u\n", (SIZE)); \
288 /* A C statement (sans semicolon) to output to the stdio stream
289 FILE the assembler definition of uninitialized global DECL named
290 NAME whose size is SIZE bytes and alignment is ALIGN bytes.
291 Try to use asm_output_aligned_bss to implement this macro. */
293 #define ASM_OUTPUT_ALIGNED_BSS(FILE, DECL, NAME, SIZE, ALIGN) \
294 asm_output_aligned_bss (FILE, DECL, NAME, SIZE, ALIGN)
298 "\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\
299 \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\
300 \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\
301 \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\
302 \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\
303 \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\
304 \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\
305 \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"
308 #define STRING_LIMIT ((unsigned) 256)
310 #undef ASM_OUTPUT_LIMITED_STRING
311 #define ASM_OUTPUT_LIMITED_STRING(FILE, STR) \
314 register unsigned char *_limited_str = (unsigned char *) (STR); \
315 register unsigned ch; \
316 fprintf ((FILE), "%s\t\"", STRING_ASM_OP); \
317 for (; (ch = *_limited_str); _limited_str++) \
319 register int escape; \
320 switch (escape = ESCAPES[ch]) \
326 fprintf ((FILE), "\\%03o", ch); \
329 putc ('\\', (FILE)); \
330 putc (escape, (FILE)); \
334 fprintf ((FILE), "\"\n"); \
339 #undef ASM_OUTPUT_ASCII
340 #define ASM_OUTPUT_ASCII(FILE, STR, LENGTH) \
342 register unsigned char *_ascii_bytes = (unsigned char *) (STR); \
343 register unsigned char *limit = _ascii_bytes + (LENGTH); \
344 register unsigned bytes_in_chunk = 0; \
345 for (; _ascii_bytes < limit; _ascii_bytes++) \
347 register unsigned char *p; \
348 if (bytes_in_chunk >= 64) \
350 fputc ('\n', (FILE)); \
351 bytes_in_chunk = 0; \
353 for (p = _ascii_bytes; p < limit && *p != '\0'; p++) \
355 if (p < limit && (p - _ascii_bytes) <= STRING_LIMIT) \
357 if (bytes_in_chunk > 0) \
359 fputc ('\n', (FILE)); \
360 bytes_in_chunk = 0; \
362 ASM_OUTPUT_LIMITED_STRING ((FILE), _ascii_bytes); \
367 if (bytes_in_chunk == 0) \
368 fprintf ((FILE), "%s\t", ASM_BYTE_OP); \
370 fputc (',', (FILE)); \
371 fprintf ((FILE), "0x%02x", *_ascii_bytes); \
372 bytes_in_chunk += 5; \
375 if (bytes_in_chunk > 0) \
376 fprintf ((FILE), "\n"); \
379 /* Must use data section for relocatable constants when pic. */
380 #undef SELECT_RTX_SECTION
381 #define SELECT_RTX_SECTION(MODE,RTX) \
384 if (flag_pic && symbolic_operand (RTX)) \
389 readonly_data_section(); \
392 #undef ASM_OUTPUT_CASE_LABEL
393 #define ASM_OUTPUT_CASE_LABEL(FILE,PREFIX,NUM,JUMPTABLE) \
396 ASM_OUTPUT_ALIGN ((FILE), 2); \
397 ASM_OUTPUT_INTERNAL_LABEL((FILE),(PREFIX),(NUM)); \
401 #undef ASM_OUTPUT_CONSTRUCTOR
402 #define ASM_OUTPUT_CONSTRUCTOR(FILE,NAME) \
406 fprintf (FILE, "%s\t ", INT_ASM_OP); \
407 assemble_name (FILE, NAME); \
408 fprintf (FILE, "\n"); \
411 fprintf (FILE, "\tpushl $"); \
412 assemble_name (FILE, NAME); \
413 fprintf (FILE, "\n"); } \
416 #undef ASM_OUTPUT_DESTRUCTOR
417 #define ASM_OUTPUT_DESTRUCTOR(FILE,NAME) \
421 fprintf (FILE, "%s\t ", INT_ASM_OP); \
422 assemble_name (FILE, NAME); \
423 fprintf (FILE, "\n"); \
426 fprintf (FILE, "%s\t ", ASM_LONG); \
427 assemble_name (FILE, NAME); \
428 fprintf (FILE, "\n"); } \
432 #undef ASM_OUTPUT_IDENT
433 #define ASM_OUTPUT_IDENT(FILE, NAME) \
434 fprintf (FILE, "%s\t\"%s\"\n", IDENT_ASM_OP, NAME);
436 #undef ASM_GLOBALIZE_LABEL
437 #define ASM_GLOBALIZE_LABEL(FILE,NAME) \
438 (fprintf ((FILE), "%s ", GLOBAL_ASM_OP), assemble_name (FILE, NAME), fputs ("\n", FILE))
440 #undef ASM_OUTPUT_EXTERNAL_LIBCALL
441 #define ASM_OUTPUT_EXTERNAL_LIBCALL(FILE, FUN) \
442 if (TARGET_ELF) ASM_GLOBALIZE_LABEL (FILE, XSTR (FUN, 0))
444 #undef ASM_OUTPUT_INTERNAL_LABEL
445 #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM) \
446 fprintf (FILE, ".%s%d:\n", PREFIX, NUM)
448 /* The prefix to add to user-visible assembler symbols. */
450 #undef USER_LABEL_PREFIX
451 #define USER_LABEL_PREFIX ""
454 * Compensate for the difference between ELF and COFF assembler syntax.
455 * Otherwise, this is cribbed from ../svr4.h.
456 * We rename 'gcc_except_table' to the shorter name in preparation
457 * for the day when we're ready to do DWARF2 eh unwinding under COFF
459 #undef ASM_OUTPUT_SECTION_NAME
460 #define ASM_OUTPUT_SECTION_NAME(FILE, DECL, NAME, RELOC) \
462 static struct section_info \
464 struct section_info *next; \
466 enum sect_enum {SECT_RW, SECT_RO, SECT_EXEC} type; \
468 struct section_info *s; \
470 enum sect_enum type; \
471 char *sname = NAME ; \
472 if (strcmp(NAME, ".gcc_except_table") == 0) sname = ".gccexc" ; \
474 for (s = sections; s; s = s->next) \
475 if (!strcmp (NAME, s->name)) \
478 if (DECL && TREE_CODE (DECL) == FUNCTION_DECL) \
479 type = SECT_EXEC, mode = (TARGET_ELF) ? "ax" : "x" ; \
480 else if (DECL && DECL_READONLY_SECTION (DECL, RELOC)) \
481 type = SECT_RO, mode = "a"; \
483 type = SECT_RW, mode = (TARGET_ELF) ? "aw" : "w" ; \
487 s = (struct section_info *) xmalloc (sizeof (struct section_info)); \
488 s->name = xmalloc ((strlen (NAME) + 1) * sizeof (*NAME)); \
489 strcpy (s->name, NAME); \
491 s->next = sections; \
493 fprintf (FILE, ".section\t%s,\"%s\"%s\n", sname, mode, \
494 (TARGET_ELF) ? ",@progbits" : "" ); \
498 if (DECL && s->type != type) \
499 error_with_decl (DECL, "%s causes a section type conflict"); \
501 fprintf (FILE, ".section\t%s\n", sname); \
505 #undef ASM_OUTPUT_SKIP
506 #define ASM_OUTPUT_SKIP(FILE,SIZE) \
509 fprintf (FILE, "%s\t%u\n", SKIP_ASM_OP, (SIZE)); \
511 fprintf ((FILE), "%s\t.,.+%u\n", SET_ASM_OP, (SIZE)); \
515 #undef CTOR_LIST_BEGIN
516 #define CTOR_LIST_BEGIN \
518 asm (CTORS_SECTION_ASM_OP); \
520 STATIC func_ptr __CTOR_LIST__[1] = { (func_ptr) (-1) }; \
526 #define CTOR_LIST_END \
529 asm (CTORS_SECTION_ASM_OP); \
530 STATIC func_ptr __CTOR_LIST__[1] = { (func_ptr) (0) }; \
536 #undef DBX_BLOCKS_FUNCTION_RELATIVE
537 #define DBX_BLOCKS_FUNCTION_RELATIVE 1
539 #undef DBX_FUNCTION_FIRST
540 #define DBX_FUNCTION_FIRST 1
542 #undef DBX_REGISTER_NUMBER
543 #define DBX_REGISTER_NUMBER(n) \
553 : ((n) >= FIRST_STACK_REG && (n) <= LAST_STACK_REG) ? (n)+3 \
566 #undef DWARF_DEBUGGING_INFO
567 #undef SDB_DEBUGGING_INFO
568 #undef DBX_DEBUGGING_INFO
569 #undef PREFERRED_DEBUGGING_TYPE
571 #define DWARF_DEBUGGING_INFO 1
572 #define SDB_DEBUGGING_INFO 1
573 #define DBX_DEBUGGING_INFO 1
574 #define PREFERRED_DEBUGGING_TYPE \
575 ((TARGET_ELF) ? DWARF_DEBUG: SDB_DEBUG)
577 #undef EXTRA_SECTIONS
578 #define EXTRA_SECTIONS in_const, in_init, in_fini, in_ctors, in_dtors
580 #undef EXTRA_SECTION_FUNCTIONS
581 #define EXTRA_SECTION_FUNCTIONS \
582 CONST_SECTION_FUNCTION \
583 INIT_SECTION_FUNCTION \
584 FINI_SECTION_FUNCTION \
585 CTORS_SECTION_FUNCTION \
586 DTORS_SECTION_FUNCTION
588 #undef CONST_SECTION_FUNCTION
589 #define CONST_SECTION_FUNCTION \
593 extern void text_section(); \
594 if (!USE_CONST_SECTION) \
596 else if (in_section != in_const) \
598 fprintf (asm_out_file, "%s\n", CONST_SECTION_ASM_OP); \
599 in_section = in_const; \
603 #undef FINI_SECTION_FUNCTION
604 #define FINI_SECTION_FUNCTION \
608 if ((!TARGET_ELF) && in_section != in_fini) \
610 fprintf (asm_out_file, "%s\n", FINI_SECTION_ASM_OP); \
611 in_section = in_fini; \
615 #undef INIT_SECTION_FUNCTION
616 #define INIT_SECTION_FUNCTION \
620 if ((!TARGET_ELF) && in_section != in_init) \
622 fprintf (asm_out_file, "%s\n", INIT_SECTION_ASM_OP); \
623 in_section = in_init; \
627 #undef CTORS_SECTION_FUNCTION
628 #define CTORS_SECTION_FUNCTION \
632 if (in_section != in_ctors) \
634 fprintf (asm_out_file, "%s\n", CTORS_SECTION_ASM_OP); \
635 in_section = in_ctors; \
639 #undef DTORS_SECTION_FUNCTION
640 #define DTORS_SECTION_FUNCTION \
644 if (in_section != in_dtors) \
646 fprintf (asm_out_file, "%s\n", DTORS_SECTION_ASM_OP); \
647 in_section = in_dtors; \
651 #undef FRAME_POINTER_REQUIRED
652 #define FRAME_POINTER_REQUIRED \
653 ((TARGET_ELF) ? 0 : \
654 (current_function_calls_setjmp || current_function_calls_longjmp))
656 #undef JUMP_TABLES_IN_TEXT_SECTION
657 #define JUMP_TABLES_IN_TEXT_SECTION (TARGET_ELF && flag_pic)
659 #undef LOCAL_LABEL_PREFIX
660 #define LOCAL_LABEL_PREFIX \
661 ((TARGET_ELF) ? "" : ".")
663 #undef MD_EXEC_PREFIX
664 #undef MD_STARTFILE_PREFIX
665 #define MD_EXEC_PREFIX "/usr/ccs/bin/"
666 #define MD_STARTFILE_PREFIX "/usr/ccs/lib/"
668 #undef NON_SAVING_SETJMP
669 #define NON_SAVING_SETJMP \
670 ((TARGET_ELF) ? 0 : \
671 (current_function_calls_setjmp && current_function_calls_longjmp))
673 #undef NO_IMPLICIT_EXTERN_C
674 #define NO_IMPLICIT_EXTERN_C 1
676 /* JKJ FIXME - examine the ramifications of RETURN_IN_MEMORY and
679 #undef RETURN_POPS_ARGS
680 #define RETURN_POPS_ARGS(FUNDECL,FUNTYPE,SIZE) \
682 (i386_return_pops_args (FUNDECL, FUNTYPE, SIZE)) : \
683 (((FUNDECL) && (TREE_CODE (FUNDECL) == IDENTIFIER_NODE)) ? 0 \
685 && (TYPE_ARG_TYPES (FUNTYPE) == 0 \
686 || (TREE_VALUE (tree_last (TYPE_ARG_TYPES (FUNTYPE))) \
687 == void_type_node))) ? (SIZE) \
690 #undef SELECT_SECTION
691 #define SELECT_SECTION(DECL,RELOC) \
693 if (TARGET_ELF && flag_pic && RELOC) \
695 else if (TREE_CODE (DECL) == STRING_CST) \
697 if (! flag_writable_strings) \
702 else if (TREE_CODE (DECL) == VAR_DECL) \
704 if (! DECL_READONLY_SECTION (DECL, RELOC)) \
713 #undef SWITCH_TAKES_ARG
714 #define SWITCH_TAKES_ARG(CHAR) \
715 (DEFAULT_SWITCH_TAKES_ARG(CHAR) \
721 #undef WORD_SWITCH_TAKES_ARG
722 #define WORD_SWITCH_TAKES_ARG(STR) \
723 (DEFAULT_WORD_SWITCH_TAKES_ARG (STR) \
724 && strcmp (STR, "Tdata") && strcmp (STR, "Ttext") \
725 && strcmp (STR, "Tbss"))
727 #undef TARGET_DEFAULT
728 #define TARGET_DEFAULT (MASK_80387 | MASK_IEEE_FP | MASK_FLOAT_RETURNS)
730 #undef HANDLE_SYSV_PRAGMA
731 #define HANDLE_SYSV_PRAGMA 1
733 /* Though OpenServer support .weak in COFF, g++ doesn't play nice with it
734 * so we'll punt on it for now
736 #define SUPPORTS_WEAK (TARGET_ELF)
737 #define ASM_WEAKEN_LABEL(FILE,NAME) \
738 do { fputs ("\t.weak\t", FILE); assemble_name (FILE, NAME); \
739 fputc ('\n', FILE); } while (0)
741 #undef SCCS_DIRECTIVE
742 #define SCCS_DIRECTIVE 1
745 * Define sizes and types
750 #undef WCHAR_TYPE_SIZE
751 #undef LONG_DOUBLE_TYPE_SIZE
752 #define LONG_DOUBLE_TYPE_SIZE 96
753 #define SIZE_TYPE "unsigned int"
754 #define PTRDIFF_TYPE "int"
755 #define WCHAR_TYPE "long int"
756 #define WCHAR_TYPE_SIZE BITS_PER_WORD
759 * New for multilib support. Set the default switches for multilib,
762 #define MULTILIB_DEFAULTS { "melf" }
765 /* Please note that these specs may look messy but they are required in
766 order to emulate the SCO Development system as closely as possible.
767 With SCO Open Server 5.0, you now get the linker and assembler free,
768 so that is what these specs are targeted for. These utilities are
769 very argument sensitive: a space in the wrong place breaks everything.
770 So RMS, please forgive this mess. It works.
772 Parameters which can be passed to gcc, and their SCO equivalents:
773 GCC Parameter SCO Equivalent
777 -Xpg4plus -a xpg4plus
780 As with SCO, the default is XPG4 plus mode. SCO also allows you to
781 specify a C dialect with -Xt, -Xa, -Xc, -Xk and -Xm. These are passed
782 on to the assembler and linker in the same way that the SCO compiler
785 SCO also allows you to compile, link and generate either ELF or COFF
786 binaries. With gcc, unlike the SCO compiler, the default is ELF.
787 Specify -mcoff to gcc to produce COFF binaries. -fpic will get the
788 assembler and linker to produce PIC code.
791 /* Set up assembler flags for PIC and ELF compilations */
795 /* Leave ASM_SPEC undefined so we pick up the master copy from gcc.c
796 * Undef MD_EXEC_PREFIX becuase we don't know where GAS is, but it's not
797 * likely in /usr/ccs/bin/
799 #undef MD_EXEC_PREFIX
803 "-b %{!mcoff:elf}%{mcoff:coff \
804 %{static:%e-static not valid with -mcoff} \
805 %{shared:%e-shared not valid with -mcoff} \
806 %{symbolic:%e-symbolic not valid with -mcoff}} \
807 %{Ym,*} %{Yd,*} %{Wa,*:%*} \
808 %{!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}}"
811 /* Use crt1.o as a startup file and crtn.o as a closing file. */
813 #undef STARTFILE_SPEC
814 #define STARTFILE_SPEC \
815 "%{shared: %{!mcoff: crti.o%s}} \
818 %{pg:gcrt.o%s}%{!pg:%{p:mcrt1.o%s}%{!p:crt1.o%s}}}} \
819 %{ansi:values-Xc.o%s} \
821 %{traditional:values-Xt.o%s} \
823 %{Xa:values-Xa.o%s} \
824 %{!Xa:%{Xc:values-Xc.o%s} \
825 %{!Xc:%{Xk:values-Xk.o%s} \
826 %{!Xk:%{Xt:values-Xt.o%s} \
827 %{!Xt:values-Xa.o%s}}}}}} \
828 %{mcoff:crtbeginS.o%s} %{!mcoff:crtbegin.o%s}"
831 #define ENDFILE_SPEC \
832 "%{!mcoff:crtend.o%s} \
833 %{mcoff:crtendS.o%s} \
834 %{pg:gcrtn.o%s}%{!pg:crtn.o%s}"
836 #undef CPP_PREDEFINES
837 #define CPP_PREDEFINES \
840 /* You are in a maze of GCC specs ... all alike */
843 #define CPP_SPEC "%(cpp_cpu) \
844 %{fpic:%{mcoff:%e-fpic is not valid with -mcoff}} \
845 %{fPIC:%{mcoff:%e-fPIC is not valid with -mcoff}} \
846 -D__i386 -D__unix -D_SCO_DS=1 -D_M_I386 -D_M_XENIX -D_M_UNIX \
847 %{!Xods30:-D_STRICT_NAMES} \
848 %{!ansi:%{!posix:%{!Xods30:-D_SCO_XPG_VERS=4}}} \
849 %{ansi:-isystem include/ansi%s -isystem /usr/include/ansi -D_STRICT_ANSI} \
851 %{posix:-isystem include/posix%s -isystem /usr/include/posix \
852 -D_POSIX_C_SOURCE=2 -D_POSIX_SOURCE=1} \
853 %{!posix:%{Xpg4:-isystem include/xpg4%s -isystem /usr/include/xpg4 \
855 %{!Xpg4:-D_M_I86 -D_M_I86SM -D_M_INTERNAT -D_M_SDATA -D_M_STEXT \
856 -D_M_BITFIELDS -D_M_SYS5 -D_M_SYSV -D_M_SYSIII \
857 -D_M_WORDSWAP -Dunix -DM_I386 -DM_UNIX -DM_XENIX \
858 %{Xods30:-isystem include/ods_30_compat%s \
859 -isystem /usr/include/ods_30_compat \
860 -D_SCO_ODS_30 -DM_I86 -DM_I86SM -DM_SDATA -DM_STEXT \
861 -DM_BITFIELDS -DM_SYS5 -DM_SYSV -DM_INTERNAT -DM_SYSIII \
863 %{scointl:-DM_INTERNAT -D_M_INTERNAT} \
864 %{traditional:-D_KR -D_SVID -D_NO_PROTOTYPE} \
865 %{!mcoff:-D_SCO_ELF} \
866 %{mcoff:-D_M_COFF -D_SCO_COFF} \
867 %{!mcoff:%{fpic:-D__PIC__ -D__pic__} \
868 %{fPIC:%{!fpic:-D__PIC__ -D__pic__}}} \
869 %{Xa:-D_SCO_C_DIALECT=1} \
870 %{!Xa:%{Xc:-D_SCO_C_DIALECT=3} \
871 %{!Xc:%{Xk:-D_SCO_C_DIALECT=4} \
872 %{!Xk:%{Xt:-D_SCO_C_DIALECT=2} \
873 %{!Xt:-D_SCO_C_DIALECT=1}}}} \
874 %{traditional:-traditional -D_KR -D_NO_PROTOTYPE}"
878 "-b %{!mcoff:elf}%{mcoff:coff \
879 %{static:%e-static not valid with -mcoff} \
880 %{shared:%e-shared not valid with -mcoff} \
881 %{symbolic:%e-symbolic not valid with -mcoff} \
882 %{fpic:%e-fpic not valid with -mcoff} \
883 %{fPIC:%e-fPIC not valid with -mcoff}} \
884 -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} \
885 %{Wl,*%*} %{YP,*} %{YL,*} %{YU,*} \
886 %{!YP,*:%{p:-YP,/usr/ccs/libp:/lib/libp:/usr/lib/libp:/usr/ccs/lib:/lib:/usr/lib} \
887 %{!p:-YP,/usr/ccs/lib:/lib:/usr/lib}} \
888 %{h*} %{static:-dn -Bstatic} %{shared:-G -dy %{!z*:-z text}} \
889 %{symbolic:-Bsymbolic -G -dy %{!z*:-z text}} %{z*} %{R*} %{Y*} \
890 %{G:-G} %{!mcoff:%{Qn:} %{!Qy:-Qn}}"
892 /* The SCO COFF linker gets confused on the difference between "-ofoo"
893 and "-o foo". So we just always force a single space. */
895 #define SWITCHES_NEED_SPACES "o"
897 /* Library spec. If we are not building a shared library, provide the
898 standard libraries, as per the SCO compiler. */
902 "%{shared:pic/libgcc.a%s}%{!shared:%{!symbolic:-lcrypt -lgen -lc}}"
905 #define LIBGCC_SPEC \
908 #define MASK_COFF 010000000000 /* Mask for elf generation */
909 #define TARGET_COFF (target_flags & MASK_COFF)
910 #define TARGET_ELF (!(target_flags & MASK_COFF))
912 #undef SUBTARGET_SWITCHES
913 #define SUBTARGET_SWITCHES \
914 { "coff", MASK_COFF, "Generate COFF output" }, \
915 { "elf", -MASK_COFF, "Generate ELF output" },
917 #define NO_DOLLAR_IN_LABEL
919 /* Implicit library calls should use memcpy, not bcopy, etc. They are
920 faster on OpenServer libraries. */
922 #define TARGET_MEM_FUNCTIONS
924 /* Biggest alignment supported by the object file format of this
925 machine. Use this macro to limit the alignment which can be
926 specified using the `__attribute__ ((aligned (N)))' construct. If
927 not defined, the default value is `BIGGEST_ALIGNMENT'. */
929 #define MAX_OFILE_ALIGNMENT (32768*8)
932 Here comes some major hackery to get the crt stuff to compile properly.
933 Since we can (and do) compile for both COFF and ELF environments, we
934 set things up accordingly, based on the pre-processor defines for ELF
935 and COFF. This is insane, but then I guess having one compiler with a
936 single back-end supporting two vastly different file format types is
937 a little insane too. But it is not impossible and we get a useful
938 compiler at the end of the day. Onward we go ...
941 #if defined(CRT_BEGIN) || defined(CRT_END) || defined(IN_LIBGCC2)
942 # undef OBJECT_FORMAT_ELF
944 # undef INIT_SECTION_ASM_OP
945 # undef FINI_SECTION_ASM_OP
946 # undef CTORS_SECTION_ASM_OP
947 # undef DTORS_SECTION_ASM_OP
948 # undef EH_FRAME_SECTION_ASM_OP
949 # undef CTOR_LIST_BEGIN
950 # undef CTOR_LIST_END
951 # undef DO_GLOBAL_CTORS_BODY
953 # if defined (_SCO_ELF)
954 # define OBJECT_FORMAT_ELF
955 # define HAVE_ATEXIT 1
956 # define INIT_SECTION_ASM_OP INIT_SECTION_ASM_OP_ELF
957 # define FINI_SECTION_ASM_OP FINI_SECTION_ASM_OP_ELF
958 # define DTORS_SECTION_ASM_OP DTORS_SECTION_ASM_OP_ELF
959 # define CTORS_SECTION_ASM_OP CTORS_SECTION_ASM_OP_ELF
960 # define EH_FRAME_SECTION_ASM_OP EH_FRAME_SECTION_ASM_OP_ELF
961 # else /* ! _SCO_ELF */
962 # define INIT_SECTION_ASM_OP INIT_SECTION_ASM_OP_COFF
963 # define FINI_SECTION_ASM_OP FINI_SECTION_ASM_OP_COFF
964 # define DTORS_SECTION_ASM_OP DTORS_SECTION_ASM_OP_COFF
965 # define CTORS_SECTION_ASM_OP CTORS_SECTION_ASM_OP_COFF
966 # define EH_FRAME_SECTION_ASM_OP ""
967 # define CTOR_LIST_BEGIN asm (INIT_SECTION_ASM_OP); asm ("pushl $0")
968 # define CTOR_LIST_END CTOR_LIST_BEGIN
969 # define DO_GLOBAL_CTORS_BODY \
971 func_ptr *p, *beg = alloca(0); \
975 # endif /* ! _SCO_ELF */
976 #endif /* CRT_BEGIN !! CRT_END */