aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIan Lance Taylor <ian@airs.com>1996-04-15 16:28:19 +0000
committerIan Lance Taylor <ian@airs.com>1996-04-15 16:28:19 +0000
commit7a15a226ada5d390e119d5b4e8eb376e2d5c3d8d (patch)
treefd3980e9390f2305c61dd673f8c23ca090591432
parent449abd890017f4db4e9842a492e5be44610ecfaa (diff)
downloadgdb-7a15a226ada5d390e119d5b4e8eb376e2d5c3d8d.zip
gdb-7a15a226ada5d390e119d5b4e8eb376e2d5c3d8d.tar.gz
gdb-7a15a226ada5d390e119d5b4e8eb376e2d5c3d8d.tar.bz2
* config/tc-mips.c (load_address): Cast X_add_number to valueT
before comparing against MAX_GPREL_OFFSET, so that negative numbers are handled correctly. (macro): Likewise.
-rw-r--r--gas/ChangeLog7
-rw-r--r--gas/config/tc-mips.c11
2 files changed, 13 insertions, 5 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index 520ea70..d6f0815 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,3 +1,10 @@
+Mon Apr 15 12:26:33 1996 Ian Lance Taylor <ian@cygnus.com>
+
+ * config/tc-mips.c (load_address): Cast X_add_number to valueT
+ before comparing against MAX_GPREL_OFFSET, so that negative
+ numbers are handled correctly.
+ (macro): Likewise.
+
Thu Apr 11 12:39:02 1996 Ian Lance Taylor <ian@cygnus.com>
* config/tc-sparc.c (last_insn): New static variable.
diff --git a/gas/config/tc-mips.c b/gas/config/tc-mips.c
index 19b271d..61f38dc 100644
--- a/gas/config/tc-mips.c
+++ b/gas/config/tc-mips.c
@@ -1993,7 +1993,8 @@ load_address (counter, reg, ep)
lui $reg,<sym> (BFD_RELOC_HI16_S)
addiu $reg,$reg,<sym> (BFD_RELOC_LO16)
If we have an addend, we always use the latter form. */
- if (ep->X_add_number != 0 || nopic_need_relax (ep->X_add_symbol))
+ if ((valueT) ep->X_add_number >= MAX_GPREL_OFFSET
+ || nopic_need_relax (ep->X_add_symbol))
p = NULL;
else
{
@@ -2860,7 +2861,7 @@ macro (ip)
addiu $tempreg,$tempreg,<sym> (BFD_RELOC_LO16)
If we have a constant, we need two instructions anyhow,
so we may as well always use the latter form. */
- if (offset_expr.X_add_number != 0
+ if ((valueT) offset_expr.X_add_number >= MAX_GPREL_OFFSET
|| nopic_need_relax (offset_expr.X_add_symbol))
p = NULL;
else
@@ -3571,7 +3572,7 @@ macro (ip)
With a constant we always use the latter case. */
if (breg == 0)
{
- if (offset_expr.X_add_number != 0
+ if ((valueT) offset_expr.X_add_number >= MAX_GPREL_OFFSET
|| nopic_need_relax (offset_expr.X_add_symbol))
p = NULL;
else
@@ -3595,7 +3596,7 @@ macro (ip)
}
else
{
- if (offset_expr.X_add_number != 0
+ if ((valueT) offset_expr.X_add_number >= MAX_GPREL_OFFSET
|| nopic_need_relax (offset_expr.X_add_symbol))
p = NULL;
else
@@ -4000,7 +4001,7 @@ macro (ip)
If there is a base register, we add it to $at after the
lui instruction. If there is a constant, we always use
the last case. */
- if (offset_expr.X_add_number != 0
+ if ((valueT) offset_expr.X_add_number >= MAX_GPREL_OFFSET
|| nopic_need_relax (offset_expr.X_add_symbol))
{
p = NULL;