[compiler-rt] 15d5db2 - [DFSan] build-libc-list.py no longer provides a list of default files.

Andrew Browne via llvm-commits llvm-commits at lists.llvm.org
Tue May 31 11:27:05 PDT 2022


Author: Andrew Browne
Date: 2022-05-31T11:25:56-07:00
New Revision: 15d5db276c9ba0add984d07696f11a33079f42bc

URL: https://github.com/llvm/llvm-project/commit/15d5db276c9ba0add984d07696f11a33079f42bc
DIFF: https://github.com/llvm/llvm-project/commit/15d5db276c9ba0add984d07696f11a33079f42bc.diff

LOG: [DFSan] build-libc-list.py no longer provides a list of default files.

Reviewed By: vitalybuka

Differential Revision: https://reviews.llvm.org/D126430

Added: 
    

Modified: 
    compiler-rt/lib/dfsan/scripts/build-libc-list.py

Removed: 
    


################################################################################
diff  --git a/compiler-rt/lib/dfsan/scripts/build-libc-list.py b/compiler-rt/lib/dfsan/scripts/build-libc-list.py
index daa6248b82a9..ce6f542ea634 100755
--- a/compiler-rt/lib/dfsan/scripts/build-libc-list.py
+++ b/compiler-rt/lib/dfsan/scripts/build-libc-list.py
@@ -11,6 +11,30 @@
 # uninstrumented, thus allowing the instrumentation pass to treat calls to those
 # functions correctly.
 
+# Typical usage will list runtime libraries which are not instrumented by dfsan.
+# This would include libc, and compiler builtins.
+#
+# ./build-libc-list.py \
+#    --lib-file=/lib/x86_64-linux-gnu/ld-linux-x86-64.so.2 \
+#    --lib-file=/lib/x86_64-linux-gnu/libanl.so.1 \
+#    --lib-file=/lib/x86_64-linux-gnu/libBrokenLocale.so.1 \
+#    --lib-file=/lib/x86_64-linux-gnu/libcidn.so.1 \
+#    --lib-file=/lib/x86_64-linux-gnu/libcrypt.so.1 \
+#    --lib-file=/lib/x86_64-linux-gnu/libc.so.6 \
+#    --lib-file=/lib/x86_64-linux-gnu/libdl.so.2 \
+#    --lib-file=/lib/x86_64-linux-gnu/libm.so.6 \
+#    --lib-file=/lib/x86_64-linux-gnu/libnsl.so.1 \
+#    --lib-file=/lib/x86_64-linux-gnu/libpthread.so.0 \
+#    --lib-file=/lib/x86_64-linux-gnu/libresolv.so.2 \
+#    --lib-file=/lib/x86_64-linux-gnu/librt.so.1 \
+#    --lib-file=/lib/x86_64-linux-gnu/libthread_db.so.1 \
+#    --lib-file=/lib/x86_64-linux-gnu/libutil.so.1 \
+#    --lib-file=/usr/lib/x86_64-linux-gnu/libc_nonshared.a \
+#    --lib-file=/usr/lib/x86_64-linux-gnu/libpthread_nonshared.a \
+#    --lib-file=/lib/x86_64-linux-gnu/libgcc_s.so.1 \
+#    --lib-file=/usr/lib/gcc/x86_64-linux-gnu/4.6/libgcc.a \
+#    --error-missing-lib
+
 import os
 import subprocess
 import sys
@@ -33,30 +57,10 @@ def defined_function_list(object):
 
 p = OptionParser()
 
-p.add_option('--libc-dso-path', metavar='PATH',
-             help='path to libc DSO directory',
-             default='/lib/x86_64-linux-gnu')
-p.add_option('--libc-archive-path', metavar='PATH',
-             help='path to libc archive directory',
-             default='/usr/lib/x86_64-linux-gnu')
-
-p.add_option('--libgcc-dso-path', metavar='PATH',
-             help='path to libgcc DSO directory',
-             default='/lib/x86_64-linux-gnu')
-p.add_option('--libgcc-archive-path', metavar='PATH',
-             help='path to libgcc archive directory',
-             default='/usr/lib/gcc/x86_64-linux-gnu/4.6')
-
-p.add_option('--with-libstdcxx', action='store_true',
-             dest='with_libstdcxx',
-             help='include libstdc++ in the list (inadvisable)')
-p.add_option('--libstdcxx-dso-path', metavar='PATH',
-             help='path to libstdc++ DSO directory',
-             default='/usr/lib/x86_64-linux-gnu')
-
 p.add_option('--only-explicit-files', action='store_true',
-             dest='only_explicit_files', default=False,
-             help='Only process --lib-file, not the default libc libraries.')
+             dest='only_explicit_files', default=True,
+             help='[DEPRECATED] Only process --lib-file, not the default libc libraries.')
+
 p.add_option('--lib-file', action='append', metavar='PATH',
              help='Specific library files to add.',
              default=[])
@@ -67,43 +71,10 @@ def defined_function_list(object):
 
 (options, args) = p.parse_args()
 
-def build_libs_list():
-    libs = [os.path.join(options.libc_dso_path, name) for name in
-            ['ld-linux-x86-64.so.2',
-             'libanl.so.1',
-             'libBrokenLocale.so.1',
-             'libcidn.so.1',
-             'libcrypt.so.1',
-             'libc.so.6',
-             'libdl.so.2',
-             'libm.so.6',
-             'libnsl.so.1',
-             'libpthread.so.0',
-             'libresolv.so.2',
-             'librt.so.1',
-             'libthread_db.so.1',
-             'libutil.so.1']]
-    libs += [os.path.join(options.libc_archive_path, name) for name in
-             ['libc_nonshared.a',
-              'libpthread_nonshared.a']]
-
-    libs.append(os.path.join(options.libgcc_dso_path, 'libgcc_s.so.1'))
-    libs.append(os.path.join(options.libgcc_archive_path, 'libgcc.a'))
-
-    if options.with_libstdcxx:
-      libs.append(os.path.join(options.libstdcxx_dso_path, 'libstdc++.so.6'))
-
-    return libs
-
-libs = []
-if options.only_explicit_files:
-    libs = options.lib_file
-    if not libs:
-        print >> sys.stderr, 'No libraries provided.'
-        exit(1)
-else:
-    libs = build_libs_list()
-    libs.extend(options.lib_file)
+libs = options.lib_file
+if not libs:
+    print >> sys.stderr, 'No libraries provided.'
+    exit(1)
 
 missing_lib = False
 functions = []


        


More information about the llvm-commits mailing list