diff options
author | Ralf Corsepius <ralf.corsepius@rtems.org> | 2011-01-07 07:58:01 +0000 |
---|---|---|
committer | Ralf Corsepius <ralf.corsepius@rtems.org> | 2011-01-07 07:58:01 +0000 |
commit | 9f1ab2356a2910ecb47031d354018e62dd5a32e7 (patch) | |
tree | a88e0d23d55136f495cfdc0d973d5abd5a4b1c34 /contrib | |
parent | Housekeeping. (diff) | |
download | rtems-9f1ab2356a2910ecb47031d354018e62dd5a32e7.tar.bz2 |
New.
Diffstat (limited to 'contrib')
-rw-r--r-- | contrib/crossrpms/patches/binutils-2.21-rtems4.11-20110107.diff | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/contrib/crossrpms/patches/binutils-2.21-rtems4.11-20110107.diff b/contrib/crossrpms/patches/binutils-2.21-rtems4.11-20110107.diff new file mode 100644 index 0000000000..771e4f3035 --- /dev/null +++ b/contrib/crossrpms/patches/binutils-2.21-rtems4.11-20110107.diff @@ -0,0 +1,75 @@ +diff -Naur binutils-2.21.orig/ld/ChangeLog binutils-2.21/ld/ChangeLog +--- binutils-2.21.orig/ld/ChangeLog 2010-12-01 12:03:47.000000000 +0100 ++++ binutils-2.21/ld/ChangeLog 2011-01-07 08:40:32.459885370 +0100 +@@ -1,3 +1,8 @@ ++2010-12-04 Alan Modra <amodra@gmail.com> ++ ++ * ldlang.c (lang_size_sections_1): Align lma using same alignment ++ as for vma. ++ + 2010-11-30 Joel Sherrill <joel.sherrill@oarcorp.com> + + * configure.tgt: Add sparc64-rtems. +diff -Naur binutils-2.21.orig/ld/ldlang.c binutils-2.21/ld/ldlang.c +--- binutils-2.21.orig/ld/ldlang.c 2010-11-05 06:56:53.000000000 +0100 ++++ binutils-2.21/ld/ldlang.c 2011-01-07 08:40:32.461885415 +0100 +@@ -4788,6 +4788,7 @@ + bfd_vma newdot, after; + lang_output_section_statement_type *os; + lang_memory_region_type *r; ++ int section_alignment = 0; + + os = &s->output_section_statement; + if (os->constraint == -1) +@@ -4857,8 +4858,6 @@ + } + else + { +- int align; +- + if (os->addr_tree == NULL) + { + /* No address specified for this section, get one +@@ -4909,16 +4908,16 @@ + } + + newdot = os->region->current; +- align = os->bfd_section->alignment_power; ++ section_alignment = os->bfd_section->alignment_power; + } + else +- align = os->section_alignment; ++ section_alignment = os->section_alignment; + + /* Align to what the section needs. */ +- if (align > 0) ++ if (section_alignment > 0) + { + bfd_vma savedot = newdot; +- newdot = align_power (newdot, align); ++ newdot = align_power (newdot, section_alignment); + + if (newdot != savedot + && (config.warn_section_align +@@ -4974,8 +4973,8 @@ + { + bfd_vma lma = os->lma_region->current; + +- if (os->section_alignment != -1) +- lma = align_power (lma, os->section_alignment); ++ if (section_alignment > 0) ++ lma = align_power (lma, section_alignment); + os->bfd_section->lma = lma; + } + else if (r->last_os != NULL +@@ -5016,8 +5015,8 @@ + else + lma = dot + last->lma - last->vma; + +- if (os->section_alignment != -1) +- lma = align_power (lma, os->section_alignment); ++ if (section_alignment > 0) ++ lma = align_power (lma, section_alignment); + os->bfd_section->lma = lma; + } + } |