|
|
1.1 root 1: /* Definitions for Intel 386 running Linux with ELF format
2: Written by Eric Youngdale. */
3:
4: /* A lie, I guess, but the general idea behind linux/ELF is that we are
5: supposed to be outputting something that will assemble under SVr4.
6: This gets us pretty close. */
7: #include "i386/i386.h" /* Base i386 target machine definitions */
8: #include "i386/att.h" /* Use the i386 AT&T assembler syntax */
9: #include "svr4.h"
10: #undef MD_EXEC_PREFIX
11: #undef MD_STARTFILE_PREFIX
12: #undef TARGET_VERSION
13: #define TARGET_VERSION fprintf (stderr, " (i386 Linux/ELF)");
14: /* Output at beginning of assembler file. */
15: /* The .file command should always begin the output. */
16: #undef ASM_FILE_START
17: #define ASM_FILE_START(FILE) \
18: do { \
19: output_file_directive (FILE, main_input_filename); \
20: fprintf (FILE, "\t.version\t\"01.01\"\n"); \
21: } while (0)
22: /* The svr4 ABI for the i386 says that records and unions are returned
23: in memory. */
24: #undef RETURN_IN_MEMORY
25: #define RETURN_IN_MEMORY(TYPE) \
26: (TYPE_MODE (TYPE) == BLKmode)
27: /* This is how to output an element of a case-vector that is relative.
28: This is only used for PIC code. See comments by the `casesi' insn in
29: i386.md for an explanation of the expression this outputs. */
30: #undef ASM_OUTPUT_ADDR_DIFF_ELT
31: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL) \
32: fprintf (FILE, "\t.long _GLOBAL_OFFSET_TABLE_+[.-%s%d]\n", LPREFIX, VALUE)
33: /* Indicate that jump tables go in the text section. This is
34: necessary when compiling PIC code. */
35: #define JUMP_TABLES_IN_TEXT_SECTION
36: /* Copy this from the svr4 specifications... */
37: /* Define the register numbers to be used in Dwarf debugging information.
38: The SVR4 reference port C compiler uses the following register numbers
39: in its Dwarf output code:
40: 0 for %eax (gnu regno = 0)
41: 1 for %ecx (gnu regno = 2)
42: 2 for %edx (gnu regno = 1)
43: 3 for %ebx (gnu regno = 3)
44: 4 for %esp (gnu regno = 7)
45: 5 for %ebp (gnu regno = 6)
46: 6 for %esi (gnu regno = 4)
47: 7 for %edi (gnu regno = 5)
48: The following three DWARF register numbers are never generated by
49: the SVR4 C compiler or by the GNU compilers, but SDB on x86/svr4
50: believes these numbers have these meanings.
51: 8 for %eip (no gnu equivalent)
52: 9 for %eflags (no gnu equivalent)
53: 10 for %trapno (no gnu equivalent)
54: It is not at all clear how we should number the FP stack registers
55: for the x86 architecture. If the version of SDB on x86/svr4 were
56: a bit less brain dead with respect to floating-point then we would
57: have a precedent to follow with respect to DWARF register numbers
58: for x86 FP registers, but the SDB on x86/svr4 is so completely
59: broken with respect to FP registers that it is hardly worth thinking
60: of it as something to strive for compatibility with.
61: The verison of x86/svr4 SDB I have at the moment does (partially)
62: seem to believe that DWARF register number 11 is associated with
63: the x86 register %st(0), but that's about all. Higher DWARF
64: register numbers don't seem to be associated with anything in
65: particular, and even for DWARF regno 11, SDB only seems to under-
66: stand that it should say that a variable lives in %st(0) (when
67: asked via an `=' command) if we said it was in DWARF regno 11,
68: but SDB still prints garbage when asked for the value of the
69: variable in question (via a `/' command).
70: (Also note that the labels SDB prints for various FP stack regs
71: when doing an `x' command are all wrong.)
72: Note that these problems generally don't affect the native SVR4
73: C compiler because it doesn't allow the use of -O with -g and
74: because when it is *not* optimizing, it allocates a memory
75: location for each floating-point variable, and the memory
76: location is what gets described in the DWARF AT_location
77: attribute for the variable in question.
78: Regardless of the severe mental illness of the x86/svr4 SDB, we
79: do something sensible here and we use the following DWARF
80: register numbers. Note that these are all stack-top-relative
81: numbers.
82: 11 for %st(0) (gnu regno = 8)
83: 12 for %st(1) (gnu regno = 9)
84: 13 for %st(2) (gnu regno = 10)
85: 14 for %st(3) (gnu regno = 11)
86: 15 for %st(4) (gnu regno = 12)
87: 16 for %st(5) (gnu regno = 13)
88: 17 for %st(6) (gnu regno = 14)
89: 18 for %st(7) (gnu regno = 15)
90: */
91: #undef DBX_REGISTER_NUMBER
92: #define DBX_REGISTER_NUMBER(n) \
93: ((n) == 0 ? 0 \
94: : (n) == 1 ? 2 \
95: : (n) == 2 ? 1 \
96: : (n) == 3 ? 3 \
97: : (n) == 4 ? 6 \
98: : (n) == 5 ? 7 \
99: : (n) == 6 ? 5 \
100: : (n) == 7 ? 4 \
101: : ((n) >= FIRST_STACK_REG && (n) <= LAST_STACK_REG) ? (n)+3 \
102: : (-1))
103: #define LINUX_ELF
104: #include "i386/linux.h"
105:
106: #undef YES_UNDERSCORE
107: #undef DBX_DEBUGGING_INFO
108: #define DWARF_DEBUGGING_INFO
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.