diff --git a/ld/ChangeLog b/ld/ChangeLog index 50adaee6199668d4d26bca65f6ab90a0c68b6240..c1b7f45c03d798059edaeebed1663f917dcd7406 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,11 @@ +2016-06-27 Nick Clifton <nickc@redhat.com> + + PR ld/20302 + * lexsup.c (set_segment_start): If resetting the start address of + a section, remember to generate a new script element as well. + * testsuite/ld-scripts/pr20302.d: New test. + * testsuite/ld-scripts/scripts.exp: Run the new test. + 2016-06-24 Alan Modra <amodra@gmail.com> * testsuite/ld-aarch64/aarch64-elf.exp (aarch64_choose_ilp32_emul): diff --git a/ld/lexsup.c b/ld/lexsup.c index 7f8146ca357d1174d02906dd9badea0e37d2d363..6d28e9142b090814dd9dd0637e4a44da5732a91a 100644 --- a/ld/lexsup.c +++ b/ld/lexsup.c @@ -1686,6 +1686,7 @@ set_segment_start (const char *section, char *valstr) if (strcmp (seg->name, name) == 0) { seg->value = val; + lang_section_start (section, exp_intop (val), seg); return; } /* There was no existing value so we must create a new segment diff --git a/ld/testsuite/ld-scripts/pr20302.d b/ld/testsuite/ld-scripts/pr20302.d new file mode 100644 index 0000000000000000000000000000000000000000..ec655dd2b19b5bb15380d06919bf88e3681ec105 --- /dev/null +++ b/ld/testsuite/ld-scripts/pr20302.d @@ -0,0 +1,12 @@ +#ld: -Tdata=0x1000 -Tdata=0x2000 -Tcross2.t +#source: align2a.s +#objdump: -h +#notarget: rx-*-* *-*-aout *-*-netbsd x86_64-*-cygwin *-*-vms +# RX uses non standard section names. +# AOUT and NETBSD have fixed address for the data section. +# x86_64 Cygwin biases all start addresses to be > 2Gb. +# VMS targets need extra libraries. + +#... + . \.data[ ]+0+[0-9a-f]+[ ]+0+02000[ ]+0+02000.* +#pass diff --git a/ld/testsuite/ld-scripts/script.exp b/ld/testsuite/ld-scripts/script.exp index b178cb3d2ea3d3cebef1032e7616b18126536bbd..1b19202818f948cd8d114027a311d13ac14001cf 100644 --- a/ld/testsuite/ld-scripts/script.exp +++ b/ld/testsuite/ld-scripts/script.exp @@ -230,3 +230,4 @@ foreach test_script $test_script_list { } run_dump_test "align-with-input" +run_dump_test "pr20302"