aboutsummaryrefslogtreecommitdiff
path: root/gold
diff options
context:
space:
mode:
authorIan Lance Taylor <ian@airs.com>2010-07-13 07:56:08 +0000
committerIan Lance Taylor <ian@airs.com>2010-07-13 07:56:08 +0000
commitf2d707b5bbca6893f38094b9be1e6346118a6d0e (patch)
tree52444aede92c82a0cc8f71a160bda27725d15353 /gold
parent2ef36331d2904194948f22ec75f99281240acad7 (diff)
downloadgdb-f2d707b5bbca6893f38094b9be1e6346118a6d0e.zip
gdb-f2d707b5bbca6893f38094b9be1e6346118a6d0e.tar.gz
gdb-f2d707b5bbca6893f38094b9be1e6346118a6d0e.tar.bz2
* archive.cc (Archive::include_member): Unlock an external member
of a thin archive. Don't bother to delete an object we know is NULL.
Diffstat (limited to 'gold')
-rw-r--r--gold/ChangeLog6
-rw-r--r--gold/archive.cc14
2 files changed, 14 insertions, 6 deletions
diff --git a/gold/ChangeLog b/gold/ChangeLog
index 14c5386..d62547e 100644
--- a/gold/ChangeLog
+++ b/gold/ChangeLog
@@ -1,3 +1,9 @@
+2010-07-13 Ian Lance Taylor <iant@google.com>
+
+ * archive.cc (Archive::include_member): Unlock an external member
+ of a thin archive. Don't bother to delete an object we know is
+ NULL.
+
2010-07-12 Cary Coutant <ccoutant@google.com>
* compressed_output.cc (zlib_decompress): New function.
diff --git a/gold/archive.cc b/gold/archive.cc
index 36e4862..202fc2c8e 100644
--- a/gold/archive.cc
+++ b/gold/archive.cc
@@ -853,11 +853,7 @@ Archive::include_member(Symbol_table* symtab, Layout* layout,
&& this->searched_for()
&& obj == NULL
&& unconfigured)
- {
- if (obj != NULL)
- delete obj;
- return false;
- }
+ return false;
if (obj == NULL)
return true;
@@ -874,7 +870,13 @@ Archive::include_member(Symbol_table* symtab, Layout* layout,
}
if (!input_objects->add_object(obj))
- delete obj;
+ {
+ // If this is an external member of a thin archive, unlock the
+ // file.
+ if (obj->offset() == 0)
+ obj->unlock(this->task_);
+ delete obj;
+ }
else
{
{