yann@402: From http://sources.redhat.com/cgi-bin/cvsweb.cgi/src/gas/config/tc-arm.c.diff?r1=1.168&r2=1.169&cvsroot=src yann@402: See also http://lists.arm.linux.org.uk/pipermail/linux-arm-kernel/2004-July/023128.html, yann@402: "[CRITICAL PATCH] 2.6: fix silent build error]" yann@402: yann@402: Revision 1.169, Fri Jul 2 11:12:29 2004 UTC (19 hours, 4 minutes ago) by nickc yann@402: Branch: MAIN yann@402: CVS Tags: binutils_latest_snapshot, HEAD yann@402: Changes since 1.168: +14 -1 lines yann@402: yann@402: (md_apply_fix3:BFD_RELOC_ARM_IMMEDIATE): Do not allow values which have come yann@402: from undefined symbols. yann@402: Always consider this fixup to have been processed as a reloc cannot be yann@402: generated for it. yann@402: yann@402: yann@402: =================================================================== yann@402: RCS file: /cvs/src/src/gas/config/tc-arm.c,v yann@402: retrieving revision 1.168 yann@402: retrieving revision 1.169 yann@402: diff -u -r1.168 -r1.169 yann@402: --- src/gas/config/tc-arm.c 2004/04/30 10:51:12 1.168 yann@402: +++ src/gas/config/tc-arm.c 2004/07/02 11:12:29 1.169 yann@402: @@ -12186,6 +12186,20 @@ yann@402: switch (fixP->fx_r_type) yann@402: { yann@402: case BFD_RELOC_ARM_IMMEDIATE: yann@402: + /* We claim that this fixup has been processed here, yann@402: + even if in fact we generate an error because we do yann@402: + not have a reloc for it, so tc_gen_reloc will reject it. */ yann@402: + fixP->fx_done = 1; yann@402: + yann@402: + if (fixP->fx_addsy yann@402: + && ! S_IS_DEFINED (fixP->fx_addsy)) yann@402: + { yann@402: + as_bad_where (fixP->fx_file, fixP->fx_line, yann@402: + _("undefined symbol %s used as an immediate value"), yann@402: + S_GET_NAME (fixP->fx_addsy)); yann@402: + break; yann@402: + } yann@402: + yann@402: newimm = validate_immediate (value); yann@402: temp = md_chars_to_number (buf, INSN_SIZE); yann@402: yann@402: @@ -12202,7 +12216,6 @@ yann@402: yann@402: newimm |= (temp & 0xfffff000); yann@402: md_number_to_chars (buf, (valueT) newimm, INSN_SIZE); yann@402: - fixP->fx_done = 1; yann@402: break; yann@402: yann@402: case BFD_RELOC_ARM_ADRL_IMMEDIATE: