aboutsummaryrefslogtreecommitdiff
path: root/gas/config/tc-i386.c
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2003-05-20 07:58:07 +0000
committerAlan Modra <amodra@gmail.com>2003-05-20 07:58:07 +0000
commit54cfded08ec4835361d381d602fe3f845a45c118 (patch)
tree74ca96db0684fe552779ec353d72fe7b4e37c9e2 /gas/config/tc-i386.c
parent58da2eb2121a5931361d4f1df6888799ff6affc3 (diff)
downloadgdb-54cfded08ec4835361d381d602fe3f845a45c118.zip
gdb-54cfded08ec4835361d381d602fe3f845a45c118.tar.gz
gdb-54cfded08ec4835361d381d602fe3f845a45c118.tar.bz2
* dw2gencfi.c, dw2gencfi.h: New files.
* config/tc-i386.c (tc_x86_cfi_init): New function. * config/tc-i386.h (TARGET_USE_CFIPOP, tc_cfi_init): New defines. * as.c (parse_args): Set verbose flag on --verbose. (main): Call tc_cfi_init()/cfi_finish(). * as.h (verbose): New external variable. * read.c (pobegin): Insert CFI pops to the list. * symbols.c (local_symbol_make): Make symbol external. * symbols.h (local_symbol_make): New prototype. * Makefile.am: Add dw2gencfi.[ch] files. Run "make dep-am". * Makefile.in: Regenerate. * doc/as.texinfo: Added node "CFI directives" with description of all implemented .cfi_* directives. * doc/Makefile.in: Regenerate. * po/POTFILES.in: Regenerate.
Diffstat (limited to 'gas/config/tc-i386.c')
-rw-r--r--gas/config/tc-i386.c83
1 files changed, 83 insertions, 0 deletions
diff --git a/gas/config/tc-i386.c b/gas/config/tc-i386.c
index 92540ad..9a3bbbb 100644
--- a/gas/config/tc-i386.c
+++ b/gas/config/tc-i386.c
@@ -30,6 +30,7 @@
#include "safe-ctype.h"
#include "subsegs.h"
#include "dwarf2dbg.h"
+#include "dw2gencfi.h"
#include "opcode/i386.h"
#ifndef REGISTER_WARNINGS
@@ -6299,3 +6300,85 @@ intel_putback_token ()
prev_token.reg = NULL;
prev_token.str = NULL;
}
+
+void
+tc_x86_cfi_init (void)
+{
+ struct cfi_config cfi_config;
+
+ if (flag_code == CODE_64BIT)
+ {
+ cfi_config.addr_length = 8;
+ cfi_config.eh_align = 8;
+ cfi_config.code_align = 1;
+ cfi_config.data_align = -8;
+ cfi_config.ra_column = 0x10;
+ cfi_config.reloc_type = BFD_RELOC_64;
+ }
+ else
+ {
+ cfi_config.addr_length = 4;
+ cfi_config.eh_align = 4;
+ cfi_config.code_align = 1;
+ cfi_config.data_align = -4;
+ cfi_config.ra_column = 0x08;
+ cfi_config.reloc_type = BFD_RELOC_32;
+ }
+
+ cfi_set_config (&cfi_config);
+}
+
+unsigned long
+tc_x86_regname_to_dw2regnum (const char *regname)
+{
+ unsigned int regnum;
+ unsigned int regnames_count;
+ char *regnames_32[] =
+ {
+ "eax", "ebx", "ecx", "edx",
+ "edi", "esi", "ebp", "esp",
+ "eip"
+ };
+ char *regnames_64[] =
+ {
+ "rax", "rbx", "rcx", "rdx",
+ "rdi", "rsi", "rbp", "rsp",
+ "r8", "r9", "r10", "r11",
+ "r12", "r13", "r14", "r15",
+ "rip"
+ };
+ char **regnames;
+
+ if (flag_code == CODE_64BIT)
+ {
+ regnames = regnames_64;
+ regnames_count = sizeof (regnames_64);
+ }
+ else
+ {
+ regnames = regnames_32;
+ regnames_count = sizeof (regnames_32);
+ }
+
+ for (regnum = 0; regnum < regnames_count; regnum++)
+ if (strcmp (regname, regnames[regnum]) == 0)
+ return regnum;
+
+ as_bad (_("unknown register name '%s'"), regname);
+ return -1;
+}
+
+void
+tc_x86_frame_initial_instructions (void)
+{
+ if (flag_code == CODE_64BIT)
+ {
+ cfi_add_insn (CFA_def_cfa, tc_x86_regname_to_dw2regnum ("rsp"), 8);
+ cfi_add_insn (CFA_offset, tc_x86_regname_to_dw2regnum ("rip"), -8);
+ }
+ else
+ {
+ cfi_add_insn (CFA_def_cfa, tc_x86_regname_to_dw2regnum ("esp"), 4);
+ cfi_add_insn (CFA_offset, tc_x86_regname_to_dw2regnum ("eip"), -4);
+ }
+}