aboutsummaryrefslogtreecommitdiff
path: root/gas
diff options
context:
space:
mode:
authorNick Clifton <nickc@redhat.com>2005-01-04 10:20:36 +0000
committerNick Clifton <nickc@redhat.com>2005-01-04 10:20:36 +0000
commit18af0b39e6429361f1e3a93e63f045d5db1bed72 (patch)
tree034656a9e5b5e7777019eef4d41a87f29c3aa5ad /gas
parentc9bc3b3d292e520e750db3fd2214481712d29d9c (diff)
downloadgdb-18af0b39e6429361f1e3a93e63f045d5db1bed72.zip
gdb-18af0b39e6429361f1e3a93e63f045d5db1bed72.tar.gz
gdb-18af0b39e6429361f1e3a93e63f045d5db1bed72.tar.bz2
(md_apply_fix3): Fix offset calculation for global label.
Diffstat (limited to 'gas')
-rw-r--r--gas/ChangeLog5
-rw-r--r--gas/config/tc-msp430.c16
2 files changed, 19 insertions, 2 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index c412689..e7ad1de 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,3 +1,8 @@
+2005-01-04 Dmitry Diky <diwil@spec.ru>
+
+ * config/tc-msp430.c (md_apply_fix3): Fix offset calculation for
+ global label.
+
2005-01-03 David Mosberger <davidm@hpl.hp.com>
* config/tc-ia64.c (md): Add member "loc_directive_seen".
diff --git a/gas/config/tc-msp430.c b/gas/config/tc-msp430.c
index d836578..d7a2082 100644
--- a/gas/config/tc-msp430.c
+++ b/gas/config/tc-msp430.c
@@ -1,6 +1,6 @@
/* tc-msp430.c -- Assembler code for the Texas Instruments MSP430
- Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc.
+ Copyright (C) 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
Contributed by Dmitry Diky <diwil@mail.ru>
This file is part of GAS, the GNU Assembler.
@@ -1851,7 +1851,19 @@ md_apply_fix3 (fixS * fixp, valueT * valuep, segT seg)
if (fixp->fx_addsy && (s == seg || s == absolute_section))
{
- value = S_GET_VALUE (fixp->fx_addsy) + *valuep;
+ /* FIXME: We can appear here only in case if we perform a pc
+ relative jump to the label which is i) global, ii) locally
+ defined or this is a jump to an absolute symbol.
+ If this is an absolute symbol -- everything is OK.
+ If this is a global label, we've got a symbol value defined
+ twice:
+ 1. S_GET_VALUE (fixp->fx_addsy) will contain a symbol offset
+ from this section start
+ 2. *valuep will contain the real offset from jump insn to the
+ label
+ So, the result of S_GET_VALUE (fixp->fx_addsy) + (* valuep);
+ will be incorrect. Therefore remove s_get_value. */
+ value = /* S_GET_VALUE (fixp->fx_addsy) + */ * valuep;
fixp->fx_done = 1;
}
else