From 997a62b0ad4e2a186b9034fd7bf1d4d1a2847a0d Mon Sep 17 00:00:00 2001 From: Stan Cox Date: Fri, 10 Jun 2011 15:09:19 -0400 Subject: [PATCH] Don't process the dtrace -o FILENAME. --- rhbz711427.patch | 103 +++++++++++++++++++++++++++++++++++++++++++++++ systemtap.spec | 9 ++++- 2 files changed, 111 insertions(+), 1 deletion(-) create mode 100644 rhbz711427.patch diff --git a/rhbz711427.patch b/rhbz711427.patch new file mode 100644 index 0000000..b3c1227 --- /dev/null +++ b/rhbz711427.patch @@ -0,0 +1,103 @@ +commit b571f9347c4a54facadb5e948e1430bd2b89158a +Author: Stan Cox +Date: Fri Jun 10 09:42:43 2011 -0400 + + Don't process the dtrace -o FILENAME. + + dtrace.in (main): Use suffix for both -h and -G. Check gcc return code. + dtrace.exp: Massage results accordingly. + +diff --git a/dtrace.in b/dtrace.in +index a64d110..91762bd 100755 +--- a/dtrace.in ++++ b/dtrace.in +@@ -191,7 +191,7 @@ def main(): + add_typedefs = False + keep_temps = False + use_cpp = False +- h_ext = '.h' ++ suffix = "" + filename = "" + s_filename = "" + includes = [] +@@ -209,10 +209,12 @@ def main(): + defines.append(sys.argv[i]) + elif (sys.argv[i] == "-h"): + build_header = True ++ suffix = ".h" + elif (sys.argv[i].startswith("-I")): + includes.append(sys.argv[i]) + elif (sys.argv[i] == "-G"): + build_source = True ++ suffix = ".o" + elif (sys.argv[i] == "-k"): + keep_temps = True + elif (sys.argv[i] == "--types"): +@@ -242,13 +244,10 @@ def main(): + usage() + sys.exit(1) + else: +- if (build_header): +- h_ext = "" +- else: +- (filename,ext) = os.path.splitext(filename) ++ suffix = "" + if (build_header): + providers = _provider() +- providers.generate(s_filename, filename + h_ext, add_typedefs) ++ providers.generate(s_filename, filename + suffix, add_typedefs) + elif (build_source): + (basename,ext) = os.path.splitext(s_filename) + +@@ -269,9 +268,13 @@ def main(): + f.close() + CC = os.environ.get("CC", "gcc") + CFLAGS = "-g " + os.environ.get("CFLAGS", "") +- call([CC, "-fPIC"] + defines + includes + CFLAGS.split() + ++ retcode = call([CC, "-fPIC"] + defines + includes + CFLAGS.split() + + ["-I.", "-I@prefix@/include", "-c", fn, "-o", +- filename + ".o"], shell=False) ++ filename + suffix], shell=False) ++ if (retcode != 0): ++ print "\"gcc " + fn + "\" failed" ++ usage() ++ sys.exit(1) + if (not keep_temps): + os.remove(fn) + else: +diff --git a/testsuite/systemtap.base/dtrace.exp b/testsuite/systemtap.base/dtrace.exp +index b301793..cd97c79 100644 +--- a/testsuite/systemtap.base/dtrace.exp ++++ b/testsuite/systemtap.base/dtrace.exp +@@ -60,12 +60,12 @@ exec rm -f XXX.o + + verbose -log "$dtrace -G -s $dpath -o XXX" + catch {exec $dtrace -G -s $dpath -o XXX} +-if {[file exists XXX.o]} then { ++if {[file exists XXX]} then { + pass "dtrace -G -o XXX" + } else { + fail "dtrace -G -o XXX" + } +-exec rm -f XXX.o ++exec rm -f XXX + + verbose -log "$dtrace -h -s $dpath -o XXX.h" + catch {exec $dtrace -h -s $dpath -o XXX.h} +@@ -96,12 +96,12 @@ exec rm -f /tmp/XXX.o + + verbose -log "$dtrace -G -s $dpath -o /tmp/XXX" + catch {exec $dtrace -G -s $dpath -o /tmp/XXX} +-if {[file exists /tmp/XXX.o]} then { +- pass "dtrace -G -o /tmp/XXX.o" ++if {[file exists /tmp/XXX]} then { ++ pass "dtrace -G -o /tmp/XXX" + } else { +- fail "dtrace -G -o /tmp/XXX.o" ++ fail "dtrace -G -o /tmp/XXX" + } +-exec rm -f /tmp/XXX.o ++exec rm -f /tmp/XXX + + verbose -log "$dtrace -h -s $dpath -o /tmp/XXX.h" + catch {exec $dtrace -h -s $dpath -o /tmp/XXX.h} diff --git a/systemtap.spec b/systemtap.spec index 0e3481a..4ac2006 100644 --- a/systemtap.spec +++ b/systemtap.spec @@ -16,7 +16,7 @@ Name: systemtap Version: 1.5 -Release: 2%{?dist} +Release: 3%{?dist} # for version, see also configure.ac Summary: Instrumentation System Group: Development/System @@ -64,6 +64,8 @@ BuildRequires: m4 BuildRequires: elfutils-devel >= %{elfutils_version} %endif +Patch2: rhbz711427.patch + %if %{with_docs} BuildRequires: /usr/bin/latex /usr/bin/dvips /usr/bin/ps2pdf latex2html # On F10, xmlto's pdf support was broken off into a sub-package, @@ -184,6 +186,8 @@ find . \( -name configure -o -name config.h.in \) -print | xargs touch cd .. %endif +%patch2 -p1 + %build %if %{with_bundled_elfutils} @@ -499,6 +503,9 @@ exit 0 %changelog +* Fri Jun 10 2011 Stan Cox - 1.5-3 +- Don't massage dtrace -o FILENAME arg + * Thu Jun 2 2011 Stan Cox - 1.5-2 - Add explicit 'Requires python' dependency