|
|
e7106e |
From 1c468a7ce030c9a1528414d63c94530da6b61538 Mon Sep 17 00:00:00 2001
|
|
|
e7106e |
From: Petr Machata <pmachata@redhat.com>
|
|
|
e7106e |
Date: Tue, 3 Mar 2015 11:57:01 +0100
|
|
|
e7106e |
Subject: [PATCH] Do not assume prefix of /usr/share in system_call_params.exp
|
|
|
e7106e |
|
|
|
e7106e |
---
|
|
|
e7106e |
testsuite/Makefile.am | 2 ++
|
|
|
e7106e |
testsuite/ltrace.main/system_call_params.exp | 14 ++++++++------
|
|
|
e7106e |
2 files changed, 10 insertions(+), 6 deletions(-)
|
|
|
e7106e |
|
|
|
e7106e |
diff -up ltrace-0.7.91/testsuite/Makefile.in\~ ltrace-0.7.91/testsuite/Makefile.in
|
|
|
e7106e |
--- ltrace-0.7.91/testsuite/Makefile.in~ 2013-11-05 02:22:47.000000000 +0100
|
|
|
e7106e |
+++ ltrace-0.7.91/testsuite/Makefile.in 2015-03-06 00:13:20.164533852 +0100
|
|
|
e7106e |
@@ -648,6 +648,7 @@
|
|
|
e7106e |
rm -f env.exp
|
|
|
e7106e |
echo set libelf_LD_LIBRARY_PATH '"$(libelf_LD_LIBRARY_PATH)"' >> $@
|
|
|
e7106e |
echo set libunwind_LD_LIBRARY_PATH '"$(libunwind_LD_LIBRARY_PATH)"' >> $@
|
|
|
e7106e |
+ echo set PREFIX '"$(prefix)"' >> $@
|
|
|
e7106e |
|
|
|
e7106e |
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
|
|
e7106e |
# Otherwise a system limit (for SysV at least) may be exceeded.
|
|
|
e7106e |
diff --git a/testsuite/ltrace.main/system_call_params.exp b/testsuite/ltrace.main/system_call_params.exp
|
|
|
e7106e |
index 4eade10..90d2c86 100644
|
|
|
e7106e |
--- a/testsuite/ltrace.main/system_call_params.exp
|
|
|
e7106e |
+++ b/testsuite/ltrace.main/system_call_params.exp
|
|
|
e7106e |
@@ -67,7 +67,8 @@ set conf [ltraceNamedSource "$dir/syscalls.conf" {
|
|
|
e7106e |
# system with the right prefix. So first compile a wrapper that we
|
|
|
e7106e |
# use to redirect fopen calls.
|
|
|
e7106e |
|
|
|
e7106e |
-set libfopen_so [ltraceCompile libfopen.so -ldl [ltraceSource c {
|
|
|
e7106e |
+set libfopen_so [ltraceCompile libfopen.so -ldl \
|
|
|
e7106e |
+ [ltraceSource c [string map [list "@PREFIX@" "$PREFIX"] {
|
|
|
e7106e |
#define _GNU_SOURCE
|
|
|
e7106e |
#include <dlfcn.h>
|
|
|
e7106e |
#include <stdio.h>
|
|
|
e7106e |
@@ -76,13 +77,14 @@ set libfopen_so [ltraceCompile libfopen.so -ldl [ltraceSource c {
|
|
|
e7106e |
FILE *
|
|
|
e7106e |
fopen(const char *path, const char *mode)
|
|
|
e7106e |
{
|
|
|
e7106e |
- if (strncmp(path, "/usr/share", 10) == 0)
|
|
|
e7106e |
- path = "/dev/null";
|
|
|
e7106e |
+ #define PATH "@PREFIX@/share"
|
|
|
e7106e |
+ if (strncmp(path, PATH, sizeof(PATH) - 1) == 0)
|
|
|
e7106e |
+ path = "/dev/null";
|
|
|
e7106e |
|
|
|
e7106e |
- return ((FILE *(*)(const char *, const char *))
|
|
|
e7106e |
- dlsym(RTLD_NEXT, "fopen")) (path, mode);
|
|
|
e7106e |
+ return ((FILE *(*)(const char *, const char *))
|
|
|
e7106e |
+ dlsym(RTLD_NEXT, "fopen")) (path, mode);
|
|
|
e7106e |
}
|
|
|
e7106e |
-}]]
|
|
|
e7106e |
+}]]]
|
|
|
e7106e |
|
|
|
e7106e |
setenv LD_PRELOAD $libfopen_so
|
|
|
e7106e |
ltraceMatch1 [ltraceRun -L -S -F $conf -- $bin] {^open@SYS\("/some/path"} == 0
|
|
|
e7106e |
--
|
|
|
e7106e |
2.1.0
|
|
|
e7106e |
|