From: Ian Lance Taylor Date: Thu, 5 Dec 1996 16:06:14 +0000 (+0000) Subject: * write.c (fixup_segment): Don't discard the symbol for a PC X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=00a69b895a5ff0836c14a1d7c799963e9f0e10a6;p=binutils-gdb.git * write.c (fixup_segment): Don't discard the symbol for a PC relative fixup to an absolute symbol. PR 11204. --- diff --git a/gas/ChangeLog b/gas/ChangeLog index 03d606f48b4..5733d0ed41f 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,8 @@ +Thu Dec 5 11:03:31 1996 Ian Lance Taylor + + * write.c (fixup_segment): Don't discard the symbol for a PC + relative fixup to an absolute symbol. + start-sanitize-d10v Wed Dec 4 15:42:41 1996 Martin M. Hunt diff --git a/gas/write.c b/gas/write.c index 736e1509ad8..b85ffa7e4b3 100644 --- a/gas/write.c +++ b/gas/write.c @@ -297,7 +297,8 @@ fix_new_exp (frag, where, size, exp, pcrel, r_type) break; default: - as_bad ("expression too complex for fixup"); + add = make_expr_symbol (exp); + break; } return fix_new_internal (frag, where, size, add, sub, off, @@ -2429,7 +2430,8 @@ fixup_segment (fixP, this_segment_type) } else { - if (add_symbol_segment == absolute_section) + if (add_symbol_segment == absolute_section + && ! pcrel) { #ifdef TC_I960 /* See comment about reloc_callj() above. */ @@ -2480,9 +2482,15 @@ fixup_segment (fixP, this_segment_type) else { seg_reloc_count++; +/* start-sanitize-v850 */ +#if !(defined (TC_V850) && defined (OBJ_ELF)) +/* end-sanitize-v850 */ #if !(defined (TC_M68K) && defined (OBJ_ELF)) #if !defined (TC_I386) || !(defined (OBJ_ELF) || defined (OBJ_COFF)) add_number += S_GET_VALUE (add_symbolP); +/* start-sanitize-v850 */ +#endif +/* end-sanitize-v850 */ #endif #endif }