From 9c2d52014c95cef4aa0cf7e39ed47a42643c9568 Mon Sep 17 00:00:00 2001 From: James Y Knight Date: Sat, 2 Jun 2018 02:44:10 +0000 Subject: Fix support for distinguishing archive members by timestamp on Darwin. On Darwin, the binary's symbol table points to debug info in object files -- potentially object files within a static library. Such a library may have multiple entries with the same name, distinguished only by timestamp. The code was already _attempting_ to handle this case (see the code in ObjectContainerBSDArchive::Archive::FindObject which disambiguates via timestamp). But, unfortunately, while the timestamp was taken into account on the _first_ lookup, the result was then cached in a map keyed only off of the path. Added the timestamp to the cache, and added a test case. Differential Revision: https://reviews.llvm.org/D47660 llvm-svn: 333813 --- .../test/macosx/duplicate-archive-members/Makefile | 22 ++++++++ .../TestDuplicateMembers.py | 62 ++++++++++++++++++++++ .../test/macosx/duplicate-archive-members/a.c | 14 +++++ .../test/macosx/duplicate-archive-members/main.c | 17 ++++++ .../test/macosx/duplicate-archive-members/sub1/a.c | 14 +++++ 5 files changed, 129 insertions(+) create mode 100644 lldb/packages/Python/lldbsuite/test/macosx/duplicate-archive-members/Makefile create mode 100644 lldb/packages/Python/lldbsuite/test/macosx/duplicate-archive-members/TestDuplicateMembers.py create mode 100644 lldb/packages/Python/lldbsuite/test/macosx/duplicate-archive-members/a.c create mode 100644 lldb/packages/Python/lldbsuite/test/macosx/duplicate-archive-members/main.c create mode 100644 lldb/packages/Python/lldbsuite/test/macosx/duplicate-archive-members/sub1/a.c (limited to 'lldb/packages/Python/lldbsuite/test/macosx') diff --git a/lldb/packages/Python/lldbsuite/test/macosx/duplicate-archive-members/Makefile b/lldb/packages/Python/lldbsuite/test/macosx/duplicate-archive-members/Makefile new file mode 100644 index 00000000000..5bb3a3ce3f1 --- /dev/null +++ b/lldb/packages/Python/lldbsuite/test/macosx/duplicate-archive-members/Makefile @@ -0,0 +1,22 @@ +LEVEL = ../../make + +C_SOURCES := main.c + +# Make an archive that has two object files with the same name, but +# different timestamps. Do it all in one rule so that the timestamps +# can be controlled without confusing Make. +libfoo.a: a.c sub1/a.c + $(CC) $(CFLAGS) -c $( + +extern int a(int); +extern int b(int); +int main (int argc, char const *argv[]) +{ + printf ("a(1) returns %d\n", a(1)); + printf ("b(2) returns %d\n", b(2)); +} diff --git a/lldb/packages/Python/lldbsuite/test/macosx/duplicate-archive-members/sub1/a.c b/lldb/packages/Python/lldbsuite/test/macosx/duplicate-archive-members/sub1/a.c new file mode 100644 index 00000000000..814d4e8b44e --- /dev/null +++ b/lldb/packages/Python/lldbsuite/test/macosx/duplicate-archive-members/sub1/a.c @@ -0,0 +1,14 @@ +//===-- a.c -----------------------------------------------------*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +static int __b_global = 2; + +int b(int arg) { + int result = arg + __b_global; + return result; +} -- cgit v1.2.3