Make ALIGN(x) behave as ALIGN(.,x)
authorAlan Modra <amodra@gmail.com>
Wed, 8 Jul 2015 12:48:34 +0000 (22:18 +0930)
committerAlan Modra <amodra@gmail.com>
Fri, 10 Jul 2015 10:38:55 +0000 (20:08 +0930)
Inside output sections, ALIGN(.,x) uses a section-relative value for
dot.  The unary ALIGN always used the absolute value of dot.

* ldexp.c (align_dot_val): New function.
(fold_unary <ALIGN_K, NEXT>): Use it.

ld/ChangeLog
ld/ldexp.c

index 9228ead9ebf17affd3f1027e7b1f523a2476e83f..aec6288a80a871b8065fa600207fd270d230129b 100644 (file)
@@ -1,3 +1,8 @@
+2015-07-10  Alan Modra  <amodra@gmail.com>
+
+       * ldexp.c (align_dot_val): New function.
+       (fold_unary <ALIGN_K, NEXT>): Use it.
+
 2015-07-03   Kai Tietz  <ktietz@redhat.com>
 
        PR ld/11539
index a5192b1eaad6c361ec96d363f090043c0d6a7015..2c0fe5a16fdebd3a2b6d60f02c82e33650ee52a1 100644 (file)
@@ -257,6 +257,14 @@ new_rel_from_abs (bfd_vma value)
   expld.result.section = s;
 }
 
+static void
+align_dot_val (bfd_vma align)
+{
+  bfd_vma base = expld.section->vma;
+
+  new_rel_from_abs (base + align_n (expld.dot - base, align));
+}
+
 /* New-function for the definedness hash table.  */
 
 static struct bfd_hash_entry *
@@ -335,7 +343,7 @@ fold_unary (etree_type *tree)
        {
        case ALIGN_K:
          if (expld.phase != lang_first_phase_enum)
-           new_rel_from_abs (align_n (expld.dot, expld.result.value));
+           align_dot_val (expld.result.value);
          else
            expld.result.valid_p = FALSE;
          break;
@@ -365,7 +373,7 @@ fold_unary (etree_type *tree)
          if (expld.phase != lang_first_phase_enum)
            {
              make_abs ();
-             expld.result.value = align_n (expld.dot, expld.result.value);
+             align_dot_val (expld.result.value);
            }
          else
            expld.result.valid_p = FALSE;