summaryrefslogtreecommitdiff
path: root/lib/dfsan/scripts/build-libc-list.py
diff options
context:
space:
mode:
Diffstat (limited to 'lib/dfsan/scripts/build-libc-list.py')
-rwxr-xr-xlib/dfsan/scripts/build-libc-list.py36
1 files changed, 24 insertions, 12 deletions
diff --git a/lib/dfsan/scripts/build-libc-list.py b/lib/dfsan/scripts/build-libc-list.py
index 8f6b8d5136317..eddb6c07e99d8 100755
--- a/lib/dfsan/scripts/build-libc-list.py
+++ b/lib/dfsan/scripts/build-libc-list.py
@@ -26,27 +26,38 @@ def defined_function_list(object):
raise subprocess.CalledProcessError(readelf_proc.returncode, 'readelf')
for line in readelf:
if (line[31:35] == 'FUNC' or line[31:36] == 'IFUNC') and \
+ line[39:44] != 'LOCAL' and \
line[55:58] != 'UND':
function_name = line[59:].split('@')[0]
functions.append(function_name)
return functions
p = OptionParser()
-p.add_option('--lib', metavar='PATH',
- help='path to lib directory to use',
+
+p.add_option('--libc-dso-path', metavar='PATH',
+ help='path to libc DSO directory',
default='/lib/x86_64-linux-gnu')
-p.add_option('--usrlib', metavar='PATH',
- help='path to usr/lib directory to use',
+p.add_option('--libc-archive-path', metavar='PATH',
+ help='path to libc archive directory',
default='/usr/lib/x86_64-linux-gnu')
-p.add_option('--gcclib', metavar='PATH',
- help='path to gcc lib directory to use',
+
+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')
+
(options, args) = p.parse_args()
-libs = [os.path.join(options.lib, name) for name in
+libs = [os.path.join(options.libc_dso_path, name) for name in
['ld-linux-x86-64.so.2',
'libanl.so.1',
'libBrokenLocale.so.1',
@@ -61,14 +72,15 @@ libs = [os.path.join(options.lib, name) for name in
'librt.so.1',
'libthread_db.so.1',
'libutil.so.1']]
-libs += [os.path.join(options.usrlib, name) for name in
+libs += [os.path.join(options.libc_archive_path, name) for name in
['libc_nonshared.a',
'libpthread_nonshared.a']]
-gcclibs = ['libgcc.a',
- 'libgcc_s.so']
+
+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:
- gcclibs += ['libstdc++.so']
-libs += [os.path.join(options.gcclib, name) for name in gcclibs]
+ libs.append(os.path.join(options.libstdcxx_dso_path, 'libstdc++.so.6'))
functions = []
for l in libs: