aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEric Christopher <echristo@gmail.com>2000-11-01 00:54:00 +0000
committerEric Christopher <echristo@gmail.com>2000-11-01 00:54:00 +0000
commitc51ce5f0646879e7a1070673df888435204dcb1a (patch)
tree839279fd52d5c5d31e6b9b420890349bc95e86f5
parent7947af930573d349a6201482ed4fa6ad88b2cc21 (diff)
downloadgdb-c51ce5f0646879e7a1070673df888435204dcb1a.zip
gdb-c51ce5f0646879e7a1070673df888435204dcb1a.tar.gz
gdb-c51ce5f0646879e7a1070673df888435204dcb1a.tar.bz2
2000-10-31 Eric Christopher <echristo@cygnus.com>
* config/tc-mn10300.c (md_apply_fix3): Use valuep if fully resolved or pc-relative, else use fx_offset.
-rw-r--r--gas/ChangeLog15
-rw-r--r--gas/config/tc-mn10300.c22
2 files changed, 30 insertions, 7 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index 9be1453..881bd1f 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,3 +1,8 @@
+2000-10-31 Eric Christopher <echristo@redhat.com>
+
+ * config/tc-mn10300.c (md_apply_fix3): Use valuep if fully resolved
+ or pc-relative, else use fx_offset.
+
2000-10-31 Jim Wilson <wilson@redhat.com>
* config/tc-ia64.c (struct md): New field tag_fixups.
@@ -10,7 +15,7 @@
(ia64_unrecognized_line, case '['): Parse tags.
(ia64_frob_label): Create tag_fixups.
(md_assemble): Reset md.qp.X_op after using it.
-
+
2000-10-31 Kaz Kojima <kkojima@rr.iij4u.or.jp>
* config/tc-sh.c (md_apply_fix [BFD_RELOC_SH_PCDISP12BY2]): Allow 4094.
@@ -41,7 +46,7 @@
* configure.in (emulations): Add m68hc12.
* configure: Regenerate.
* po/gas.pot: Regenerate.
-
+
2000-10-27 Aldy Hernandez <aldyh@redhat.com>
* config/tc-arm.c (psrs): Remove lowercase versions of spsr* and
@@ -61,10 +66,10 @@
* doc/as.texinfo: Note that --gdwarf2 only works on some targets,
not all.
-
+
* config/tc-arm.h (md_end): Define.
(DWARF2_LINE_MIN_INSN_LENGTH): Define.
-
+
* config/tc-arm.c (output_inst): Call dwarf2_generate_asm_lineno
if generating DWARF2 line numbers.
(arm_end_of_source): New function. Call dwarf2_finish if
@@ -73,7 +78,7 @@
* config/tc-hppa.c (md_assemble): Use dwarf2_generate_asm_lineno.
* config/tc-m68hc11.c (m68hc11_new_insn): Use dwarf2_generate_asm_lineno.
* config/tc-sh.c (md_assemble): Use dwarf2_generate_asm_lineno.
-
+
2000-10-25 Diego Novillo <dnovillo@cygnus.com>
* tc-i386.c: Fix prototype declarations for functions taking no
diff --git a/gas/config/tc-mn10300.c b/gas/config/tc-mn10300.c
index 301a42b..5137bf4 100644
--- a/gas/config/tc-mn10300.c
+++ b/gas/config/tc-mn10300.c
@@ -1912,11 +1912,12 @@ md_pcrel_from (fixp)
int
md_apply_fix3 (fixp, valuep, seg)
fixS *fixp;
- valueT *valuep ATTRIBUTE_UNUSED;
+ valueT *valuep;
segT seg;
{
char *fixpos = fixp->fx_where + fixp->fx_frag->fr_literal;
int size = 0;
+ int value;
assert (fixp->fx_r_type < BFD_RELOC_UNUSED);
@@ -1924,6 +1925,23 @@ md_apply_fix3 (fixp, valuep, seg)
if (seg->flags & SEC_ALLOC)
abort ();
+ /* The value we are passed in *valuep includes the symbol values.
+ Since we are using BFD_ASSEMBLER, if we are doing this relocation
+ the code in write.c is going to call bfd_install_relocation, which
+ is also going to use the symbol value. That means that if the
+ reloc is fully resolved we want to use *valuep since
+ bfd_install_relocation is not being used.
+
+ However, if the reloc is not fully resolved we do not want to use
+ *valuep, and must use fx_offset instead. However, if the reloc
+ is PC relative, we do want to use *valuep since it includes the
+ result of md_pcrel_from. */
+ if (fixp->fx_addsy == (symbolS *) NULL || fixp->fx_pcrel)
+ value = *valuep;
+ else
+ value = fixp->fx_offset;
+
+
/* If the fix is relative to a symbol which is not defined, or not
in the same segment as the fix, we cannot resolve it here. */
if (fixp->fx_addsy != NULL
@@ -1959,7 +1977,7 @@ md_apply_fix3 (fixp, valuep, seg)
_("Bad relocation fixup type (%d)"), fixp->fx_r_type);
}
- md_number_to_chars (fixpos, fixp->fx_offset, size);
+ md_number_to_chars (fixpos, value, size);
fixp->fx_done = 1;
return 0;