* ldlang.c (lang_map): Increment lang_statement_iteration so that DEFINED() expressio...
authorNick Clifton <nickc@redhat.com>
Fri, 31 Aug 2007 14:46:55 +0000 (14:46 +0000)
committerNick Clifton <nickc@redhat.com>
Fri, 31 Aug 2007 14:46:55 +0000 (14:46 +0000)
* testsuite/ld-script/map-address.d,
* testsuite/ld-script/map-address.t: Add a test for testing DEFINED in map output.

ld/ChangeLog
ld/ldlang.c
ld/testsuite/ChangeLog
ld/testsuite/ld-scripts/map-address.d
ld/testsuite/ld-scripts/map-address.t

index 8a94b2e1e56f0810e1599047993427bcb2c7fbfd..1579bec8b68d59a4567095e5ac3a7111989e2c8f 100644 (file)
@@ -1,3 +1,8 @@
+2007-08-31  Tristan Gingold  <gingold@adacore.com>
+
+       * ldlang.c (lang_map): Increment lang_statement_iteration so that
+       DEFINED() expressions are correctly computed.
+
 2007-08-31  Alan Modra  <amodra@bigpond.net.au>
 
        * ldlang.c (lang_record_phdrs): Give a fatal error if no sections
index f247a173315fcc8f0ffbb464c802eb458dc6968c..7ecd477468540f2dfbf20d7237815fca15c5e285 100644 (file)
@@ -1811,6 +1811,7 @@ lang_map (void)
        bfd_map_over_sections (p, init_map_userdata, 0);
       bfd_link_hash_traverse (link_info.hash, sort_def_symbol, 0);
     }
+  lang_statement_iteration ++;
   print_statements ();
 }
 
@@ -3539,7 +3540,7 @@ print_assignment (lang_assignment_statement_type *assignment,
              value = h->u.def.value;
 
              if (expld.result.section)
-             value += expld.result.section->vma;
+               value += expld.result.section->vma;
 
              minfo ("[0x%V]", value);
            }
index ec3cf044ea96c7942f961b4573eaead2a516e0de..5b0ce3225ef2f6a4ce59336e824d8cdb31633111 100644 (file)
@@ -1,3 +1,9 @@
+2007-08-31  Tristan Gingold  <gingold@adacore.com>
+
+       * ld-script/map-address.t: Add a test for testing DEFINED in map
+       output.
+       * ld-script/map-address.d: Update expected output.
+
 2007-08-28  Mark Shinwell  <shinwell@codesourcery.com>
             Joseph Myers  <joseph@codesourcery.com>
 
index 289b685041658d3d8bdc38eede819185c3ab4414..7877ca4de5c6ba30f9055aae4bdeada603ad8610 100644 (file)
@@ -1,6 +1,8 @@
 #...
 Linker script and memory map
 #...
+ *0x0*000020 *def1 = .*
+ *0x0*000020 *def2 = def1
  *0x0*010001 *\. = 0x10001
  *0x0*010001 *foo = \.
  *0x0*010201 *\. = \(\. \+ 0x200\)
index 8f2dfebe2058ac1e0a25ad8ea5701142059ab8fd..e077ed1cb4c97993b258d5d2c2f88dffbc3eb8d1 100644 (file)
@@ -1,5 +1,7 @@
 SECTIONS
 {
+  def1 = DEFINED(foo) ? 0x10 : 0x20;
+  def2 = def1;
   . = 0x10001;
   foo = .;
   . += 0x200;