aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gas/ChangeLog6
-rw-r--r--gas/config/tc-mips.c21
2 files changed, 24 insertions, 3 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index fbbeb57..9da20de 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,3 +1,9 @@
+Fri Jun 19 13:57:06 1998 Ian Lance Taylor <ian@cygnus.com>
+
+ * write.c (adjust_reloc_syms): Never adjust relocs against weak
+ symbols.
+ * config/tc-mips.c (md_apply_fix): Adjust accordingly.
+
Fri Jun 19 09:50:17 1998 Jeffrey A Law (law@cygnus.com)
start-sanitize-am33
diff --git a/gas/config/tc-mips.c b/gas/config/tc-mips.c
index d26b4fd..cfe6292 100644
--- a/gas/config/tc-mips.c
+++ b/gas/config/tc-mips.c
@@ -140,7 +140,11 @@ mips_target_format ()
/* This is the set of options which may be modified by the .set
pseudo-op. We use a struct so that .set push and .set pop are more
- reliable. */
+ reliable.
+
+ FIXME: The CPU specific variables (mips_4010, et. al.) should
+ probably be in here as well, and there should probably be some way
+ to set them. */
struct mips_set_options
{
@@ -234,7 +238,17 @@ static int mips_4900 = -1;
/* Whether the processor uses hardware interlocks to protect
reads from the HI and LO registers, and thus does not
- require nops to be inserted. */
+ require nops to be inserted.
+
+ FIXME: We really should not be checking mips_cpu here. The -mcpu=
+ option is documented to not do anything special. In gcc, the
+ -mcpu= option only affects scheduling, and does not affect code
+ generation. Each test of -mcpu= here should actually be testing a
+ specific variable, such as mips_4010, and each such variable should
+ have a command line option to set it. The -mcpu= option may be
+ used to set the default value of these options, as is the case for
+ mips_4010. */
+
#define hilo_interlocks (mips_4010 || mips_3900 \
/* start-sanitize-tx49 */ \
|| mips_cpu == 4900 || mips_4900 \
@@ -9911,7 +9925,8 @@ md_apply_fix (fixP, valueP)
#ifdef OBJ_ELF
if (fixP->fx_addsy != NULL
&& OUTPUT_FLAVOR == bfd_target_elf_flavour
- && S_GET_OTHER (fixP->fx_addsy) == STO_MIPS16)
+ && (S_GET_OTHER (fixP->fx_addsy) == STO_MIPS16
+ || S_IS_WEAK (fixP->fx_addsy)))
{
value -= S_GET_VALUE (fixP->fx_addsy);
if (value != 0 && ! fixP->fx_pcrel)