📄 coff.h
字号:
/* Definitions of target machine for GNU compiler, for ARM with COFF obj format. Copyright (C) 1995, 1996, 1997, 1998 Free Software Foundation, Inc. Contributed by Doug Evans (dje@cygnus.com). This file is part of GNU CC.GNU CC is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe Free Software Foundation; either version 2, or (at your option)any later version.GNU CC is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with GNU CC; see the file COPYING. If not, write tothe Free Software Foundation, 59 Temple Place - Suite 330,Boston, MA 02111-1307, USA. */#include "arm/semi.h"#include "arm/aout.h"#undef USER_LABEL_PREFIX#define USER_LABEL_PREFIX "_"/* Run-time Target Specification. */#undef TARGET_VERSION#define TARGET_VERSION fputs (" (ARM/coff)", stderr)#undef TARGET_DEFAULT#define TARGET_DEFAULT (ARM_FLAG_SOFT_FLOAT | ARM_FLAG_APCS_32)#define MULTILIB_DEFAULTS { "mlittle-endian", "msoft-float", "mapcs-32" }/* Setting this to 32 produces more efficient code, but the value set in previous versions of this toolchain was 8, which produces more compact structures. The command line option -mstructure_size_boundary=<n> can be used to change this value. */#undef STRUCTURE_SIZE_BOUNDARY#define STRUCTURE_SIZE_BOUNDARY arm_structure_size_boundaryextern int arm_structure_size_boundary;/* A C expression whose value is nonzero if IDENTIFIER with arguments ARGS is a valid machine specific attribute for DECL. The attributes in ATTRIBUTES have previously been assigned to DECL. */#define VALID_MACHINE_DECL_ATTRIBUTE(DECL, ATTRIBUTES, IDENTIFIER, ARGS) \arm_valid_machine_decl_attribute (DECL, IDENTIFIER, ARGS)/* This is COFF, but prefer stabs. */#define SDB_DEBUGGING_INFO#define PREFERRED_DEBUGGING_TYPE DBX_DEBUG#include "dbxcoff.h"/* A C statement to output assembler commands which will identify the object file as having been compiled with GNU CC (or another GNU compiler). *//* Define this to NULL so we don't get anything. We have ASM_IDENTIFY_LANGUAGE. Also, when using stabs, gcc2_compiled must be a stabs entry, not an ordinary symbol, or gdb won't see it. The stabs entry must be before the N_SO in order for gdb to find it. */#define ASM_IDENTIFY_GCC(STREAM) \ fprintf (STREAM, "%sgcc2_compiled.:\n", LOCAL_LABEL_PREFIX )/* This outputs a lot of .req's to define alias for various registers. Let's try to avoid this. */#undef ASM_FILE_START#define ASM_FILE_START(STREAM) \do { \ extern char *version_string; \ fprintf (STREAM, "%s Generated by gcc %s for ARM/coff\n", \ ASM_COMMENT_START, version_string); \} while (0)/* A C statement to output something to the assembler file to switch to section NAME for object DECL which is either a FUNCTION_DECL, a VAR_DECL or NULL_TREE. Some target formats do not support arbitrary sections. Do not define this macro in such cases. */#define ASM_OUTPUT_SECTION_NAME(STREAM, DECL, NAME, RELOC) \do { \ if ((DECL) && TREE_CODE (DECL) == FUNCTION_DECL) \ fprintf (STREAM, "\t.section %s,\"x\"\n", (NAME)); \ else if ((DECL) && DECL_READONLY_SECTION (DECL, RELOC)) \ fprintf (STREAM, "\t.section %s,\"\"\n", (NAME)); \ else \ fprintf (STREAM, "\t.section %s,\"w\"\n", (NAME)); \} while (0)/* Support the ctors/dtors and other sections. */#undef INIT_SECTION_ASM_OP/* Define this macro if jump tables (for `tablejump' insns) should be output in the text section, along with the assembler instructions. Otherwise, the readonly data section is used. */#define JUMP_TABLES_IN_TEXT_SECTION 1#undef READONLY_DATA_SECTION#define READONLY_DATA_SECTION rdata_section#undef RDATA_SECTION_ASM_OP#define RDATA_SECTION_ASM_OP "\t.section .rdata"#undef CTORS_SECTION_ASM_OP#define CTORS_SECTION_ASM_OP "\t.section .ctors,\"x\""#undef DTORS_SECTION_ASM_OP#define DTORS_SECTION_ASM_OP "\t.section .dtors,\"x\""/* A list of other sections which the compiler might be "in" at any given time. */#undef EXTRA_SECTIONS#define EXTRA_SECTIONS SUBTARGET_EXTRA_SECTIONS in_rdata, in_ctors, in_dtors#define SUBTARGET_EXTRA_SECTIONS/* A list of extra section function definitions. */#undef EXTRA_SECTION_FUNCTIONS#define EXTRA_SECTION_FUNCTIONS \ RDATA_SECTION_FUNCTION \ CTORS_SECTION_FUNCTION \ DTORS_SECTION_FUNCTION \ SUBTARGET_EXTRA_SECTION_FUNCTIONS#define SUBTARGET_EXTRA_SECTION_FUNCTIONS#define RDATA_SECTION_FUNCTION \void \rdata_section () \{ \ if (in_section != in_rdata) \ { \ fprintf (asm_out_file, "%s\n", RDATA_SECTION_ASM_OP); \ in_section = in_rdata; \ } \}#define CTORS_SECTION_FUNCTION \void \ctors_section () \{ \ if (in_section != in_ctors) \ { \ fprintf (asm_out_file, "%s\n", CTORS_SECTION_ASM_OP); \ in_section = in_ctors; \ } \}#define DTORS_SECTION_FUNCTION \void \dtors_section () \{ \ if (in_section != in_dtors) \ { \ fprintf (asm_out_file, "%s\n", DTORS_SECTION_ASM_OP); \ in_section = in_dtors; \ } \}/* Support the ctors/dtors sections for g++. */#define INT_ASM_OP ".word"/* A C statement (sans semicolon) to output an element in the table of global constructors. */#undef ASM_OUTPUT_CONSTRUCTOR#define ASM_OUTPUT_CONSTRUCTOR(STREAM,NAME) \do { \ ctors_section (); \ fprintf (STREAM, "\t%s\t ", INT_ASM_OP); \ assemble_name (STREAM, NAME); \ fprintf (STREAM, "\n"); \} while (0)/* A C statement (sans semicolon) to output an element in the table of global destructors. */#undef ASM_OUTPUT_DESTRUCTOR#define ASM_OUTPUT_DESTRUCTOR(STREAM,NAME) \do { \ dtors_section (); \ fprintf (STREAM, "\t%s\t ", INT_ASM_OP); \ assemble_name (STREAM, NAME); \ fprintf (STREAM, "\n"); \} while (0)/* __CTOR_LIST__ and __DTOR_LIST__ must be defined by the linker script. */#define CTOR_LISTS_DEFINED_EXTERNALLY#undef DO_GLOBAL_CTORS_BODY#undef DO_GLOBAL_DTORS_BODY/* If you don't define HAVE_ATEXIT, and the object file format/OS/whatever does not support constructors/destructors, then gcc implements destructors by defining its own exit function, which calls the destructors. This gcc exit function overrides the C library's exit function, and this can cause all kinds of havoc if the C library has a non-trivial exit function. You really don't want to use the exit function in libgcc2.c. */#define HAVE_ATEXIT/* The ARM development system defines __main. */#define NAME__MAIN "__gccmain"#define SYMBOL__MAIN __gccmain
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -