This is linuxelf.h in view mode; [Download] [Up]
/* Definitions for Intel 386 running Linux with ELF format Written by Eric Youngdale. */ /* A lie, I guess, but the general idea behind linux/ELF is that we are supposed to be outputting something that will assemble under SVr4. This gets us pretty close. */ #include "i386/i386.h" /* Base i386 target machine definitions */ #include "i386/att.h" /* Use the i386 AT&T assembler syntax */ #include "svr4.h" #undef MD_EXEC_PREFIX #undef MD_STARTFILE_PREFIX #undef TARGET_VERSION #define TARGET_VERSION fprintf (stderr, " (i386 Linux/ELF)"); /* Output at beginning of assembler file. */ /* The .file command should always begin the output. */ #undef ASM_FILE_START #define ASM_FILE_START(FILE) \ do { \ output_file_directive (FILE, main_input_filename); \ fprintf (FILE, "\t.version\t\"01.01\"\n"); \ } while (0) /* The svr4 ABI for the i386 says that records and unions are returned in memory. */ #undef RETURN_IN_MEMORY #define RETURN_IN_MEMORY(TYPE) \ (TYPE_MODE (TYPE) == BLKmode) /* This is how to output an element of a case-vector that is relative. This is only used for PIC code. See comments by the `casesi' insn in i386.md for an explanation of the expression this outputs. */ #undef ASM_OUTPUT_ADDR_DIFF_ELT #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL) \ fprintf (FILE, "\t.long _GLOBAL_OFFSET_TABLE_+[.-%s%d]\n", LPREFIX, VALUE) /* Indicate that jump tables go in the text section. This is necessary when compiling PIC code. */ #define JUMP_TABLES_IN_TEXT_SECTION /* Copy this from the svr4 specifications... */ /* Define the register numbers to be used in Dwarf debugging information. The SVR4 reference port C compiler uses the following register numbers in its Dwarf output code: 0 for %eax (gnu regno = 0) 1 for %ecx (gnu regno = 2) 2 for %edx (gnu regno = 1) 3 for %ebx (gnu regno = 3) 4 for %esp (gnu regno = 7) 5 for %ebp (gnu regno = 6) 6 for %esi (gnu regno = 4) 7 for %edi (gnu regno = 5) The following three DWARF register numbers are never generated by the SVR4 C compiler or by the GNU compilers, but SDB on x86/svr4 believes these numbers have these meanings. 8 for %eip (no gnu equivalent) 9 for %eflags (no gnu equivalent) 10 for %trapno (no gnu equivalent) It is not at all clear how we should number the FP stack registers for the x86 architecture. If the version of SDB on x86/svr4 were a bit less brain dead with respect to floating-point then we would have a precedent to follow with respect to DWARF register numbers for x86 FP registers, but the SDB on x86/svr4 is so completely broken with respect to FP registers that it is hardly worth thinking of it as something to strive for compatibility with. The verison of x86/svr4 SDB I have at the moment does (partially) seem to believe that DWARF register number 11 is associated with the x86 register %st(0), but that's about all. Higher DWARF register numbers don't seem to be associated with anything in particular, and even for DWARF regno 11, SDB only seems to under- stand that it should say that a variable lives in %st(0) (when asked via an `=' command) if we said it was in DWARF regno 11, but SDB still prints garbage when asked for the value of the variable in question (via a `/' command). (Also note that the labels SDB prints for various FP stack regs when doing an `x' command are all wrong.) Note that these problems generally don't affect the native SVR4 C compiler because it doesn't allow the use of -O with -g and because when it is *not* optimizing, it allocates a memory location for each floating-point variable, and the memory location is what gets described in the DWARF AT_location attribute for the variable in question. Regardless of the severe mental illness of the x86/svr4 SDB, we do something sensible here and we use the following DWARF register numbers. Note that these are all stack-top-relative numbers. 11 for %st(0) (gnu regno = 8) 12 for %st(1) (gnu regno = 9) 13 for %st(2) (gnu regno = 10) 14 for %st(3) (gnu regno = 11) 15 for %st(4) (gnu regno = 12) 16 for %st(5) (gnu regno = 13) 17 for %st(6) (gnu regno = 14) 18 for %st(7) (gnu regno = 15) */ #undef DBX_REGISTER_NUMBER #define DBX_REGISTER_NUMBER(n) \ ((n) == 0 ? 0 \ : (n) == 1 ? 2 \ : (n) == 2 ? 1 \ : (n) == 3 ? 3 \ : (n) == 4 ? 6 \ : (n) == 5 ? 7 \ : (n) == 6 ? 5 \ : (n) == 7 ? 4 \ : ((n) >= FIRST_STACK_REG && (n) <= LAST_STACK_REG) ? (n)+3 \ : (-1)) #define LINUX_ELF #include "i386/linux.h" #undef YES_UNDERSCORE #undef DBX_DEBUGGING_INFO #define DWARF_DEBUGGING_INFO
These are the contents of the former NiCE NeXT User Group NeXTSTEP/OpenStep software archive, currently hosted by Netfuture.ch.