OSDN Git Service

PR 10450
authorian <ian>
Thu, 31 Dec 2009 04:29:20 +0000 (04:29 +0000)
committerian <ian>
Thu, 31 Dec 2009 04:29:20 +0000 (04:29 +0000)
* output.cc (Output_segment::Output_segment): If PT_TLS, set the
flags to PF_R.
(Output_segment::add_output_section): Don't change the flags if
the type is PT_TLS.

gold/ChangeLog
gold/output.cc

index 8acaf87..12dc7f0 100644 (file)
@@ -1,6 +1,12 @@
 2009-12-30  Ian Lance Taylor  <iant@google.com>
 
        PR 10450
+       * output.cc (Output_segment::Output_segment): If PT_TLS, set the
+       flags to PF_R.
+       (Output_segment::add_output_section): Don't change the flags if
+       the type is PT_TLS.
+
+       PR 10450
        * dynobj.cc (Dynobj::create_gnu_hash_table): Add symbols to the
        GNU hash table if they need a dynamic value.  Otherwise, don't add
        them if they are defined in a dynamic object or are forced local.
index e643fb7..8f1060e 100644 (file)
@@ -3063,6 +3063,10 @@ Output_segment::Output_segment(elfcpp::Elf_Word type, elfcpp::Elf_Word flags)
     are_addresses_set_(false),
     is_large_data_segment_(false)
 {
+  // The ELF ABI specifies that a PT_TLS segment always has PF_R as
+  // the flags.
+  if (type == elfcpp::PT_TLS)
+    this->flags_ = elfcpp::PF_R;
 }
 
 // Add an Output_section to an Output_segment.
@@ -3077,8 +3081,11 @@ Output_segment::add_output_section(Output_section* os,
   gold_assert(os->is_large_data_section() == this->is_large_data_segment());
   gold_assert(this->type() == elfcpp::PT_LOAD || !do_sort);
 
-  // Update the segment flags.
-  this->flags_ |= seg_flags;
+  // Update the segment flags.  The ELF ABI specifies that a PT_TLS
+  // segment should always have PF_R as the flags, regardless of the
+  // associated sections.
+  if (this->type() != elfcpp::PT_TLS)
+    this->flags_ |= seg_flags;
 
   Output_segment::Output_data_list* pdl;
   if (os->type() == elfcpp::SHT_NOBITS)