diff --git a/README-BEFORE-ADDING-PATCHES b/README-BEFORE-ADDING-PATCHES new file mode 100644 index 0000000..a3d989f --- /dev/null +++ b/README-BEFORE-ADDING-PATCHES @@ -0,0 +1,13 @@ +All patches need to have a patch description header similar to what is used in +SuSE kernel git tree. Patches added without this will be reverted. Thanks. + +From: Name +Subject: Summary of fix +Date: date +References: bnc#xxxxxx (bugzilla reference if applicable) +Upstream: yes (provide repo/commit-id in description) or no (provide reason) +Signed-Off-by: Name (same as From: if committer is patch author) + +Short paragraph describing problem/fix. + +References to upstream repo-path/commit-id if applicable. diff --git a/systemtap-1.3.tar.bz2 b/systemtap-1.3.tar.bz2 deleted file mode 100644 index daf080b..0000000 --- a/systemtap-1.3.tar.bz2 +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:548ec4d4d1eaa3a3e8d13f6c5d38b3fd08280a2889f95e71ab36954eb454b652 -size 1389234 diff --git a/systemtap-1.4.tar.bz2 b/systemtap-1.4.tar.bz2 new file mode 100644 index 0000000..98fdfe2 --- /dev/null +++ b/systemtap-1.4.tar.bz2 @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:773110b3648ce480d6470c10db47b2daeb5988722e7000aa4dbc723c27600dd7 +size 1530777 diff --git a/systemtap-docs.changes b/systemtap-docs.changes index c114884..53bdf02 100644 --- a/systemtap-docs.changes +++ b/systemtap-docs.changes @@ -1,3 +1,8 @@ +------------------------------------------------------------------- +Fri Jan 21 18:45:18 UTC 2011 - tonyj@novell.com + +- Update to version 1.4. See systemtap.changes for full changelog. + ------------------------------------------------------------------- Thu Aug 26 02:15:11 UTC 2010 - tonyj@novell.com diff --git a/systemtap-docs.spec b/systemtap-docs.spec index ea20536..bfc934c 100644 --- a/systemtap-docs.spec +++ b/systemtap-docs.spec @@ -26,8 +26,8 @@ BuildRequires: fop BuildRequires: latex2html %define use_snapshot 0 License: GPLv2+ -Version: 1.3 -Release: 2 +Version: 1.4 +Release: 1 Summary: Documents and examples for systemtap Group: Development/Tools/Debuggers Url: http://sourceware.org/systemtap/ @@ -37,6 +37,7 @@ Url: http://sourceware.org/systemtap/ %define package_version %{version} %endif Source: ftp://sources.redhat.com/pub/systemtap/snapshots/systemtap-%{package_version}.tar.bz2 +Source2: README-BEFORE-ADDING-PATCHES Patch1: systemtap-docdir-fix.diff Patch2: systemtap-xmlto-fop.diff BuildRoot: %{_tmppath}/%{name}-%{version}-build diff --git a/systemtap-hppa.diff b/systemtap-hppa.diff deleted file mode 100644 index 5d453f1..0000000 --- a/systemtap-hppa.diff +++ /dev/null @@ -1,11 +0,0 @@ ---- includes/sys/sdt.h.orig 2010-07-21 22:46:07.000000000 +0200 -+++ includes/sys/sdt.h 2010-09-05 20:47:20.686243029 +0200 -@@ -129,7 +129,7 @@ - #endif - - --#if defined __x86_64__ || defined __i386__ || defined __powerpc__ || defined __arm__ || defined __sparc__ -+#if defined __x86_64__ || defined __i386__ || defined __powerpc__ || defined __arm__ || defined __sparc__ || defined __hppa - #define STAP_NOP "\tnop " - #else - #define STAP_NOP "\tnop 0 " diff --git a/systemtap-support-2.6.36.diff b/systemtap-support-2.6.36.diff deleted file mode 100644 index 04f208e..0000000 --- a/systemtap-support-2.6.36.diff +++ /dev/null @@ -1,57 +0,0 @@ -From 75a48ca31be58a7f2c31d7bda4069a93105f872f Mon Sep 17 00:00:00 2001 -From: David Smith -Date: Mon, 23 Aug 2010 13:05:33 -0500 -Subject: [PATCH] Fixed PR11940 by getting scripts w/global variables to compile on 2.6.36. - -* runtime/runtime.h: Updated module parameter get/set functions with new - interface for 2.6.36. ---- - runtime/runtime.h | 17 ++++++++++++++--- - 1 files changed, 14 insertions(+), 3 deletions(-) - -diff --git a/runtime/runtime.h b/runtime/runtime.h -index 497137d..388216c 100644 ---- a/runtime/runtime.h -+++ b/runtime/runtime.h -@@ -142,10 +142,14 @@ static struct - #endif - #include "addr-map.c" - -- -+#ifdef module_param_cb /* kernels >= 2.6.36 */ -+#define _STP_KERNEL_PARAM_ARG const struct kernel_param -+#else -+#define _STP_KERNEL_PARAM_ARG struct kernel_param -+#endif - - /* Support functions for int64_t module parameters. */ --static int param_set_int64_t(const char *val, struct kernel_param *kp) -+static int param_set_int64_t(const char *val, _STP_KERNEL_PARAM_ARG *kp) - { - char *endp; - long long ll; -@@ -166,13 +170,20 @@ static int param_set_int64_t(const char *val, struct kernel_param *kp) - return 0; - } - --static int param_get_int64_t(char *buffer, struct kernel_param *kp) -+static int param_get_int64_t(char *buffer, _STP_KERNEL_PARAM_ARG *kp) - { - return sprintf(buffer, "%lli", (long long)*((int64_t *)kp->arg)); - } - - #define param_check_int64_t(name, p) __param_check(name, p, int64_t) - -+#ifdef module_param_cb /* kernels >= 2.6.36 */ -+static struct kernel_param_ops param_ops_int64_t = { -+ .set = param_set_int64_t, -+ .get = param_get_int64_t, -+}; -+#endif -+#undef _STP_KERNEL_PARAM_ARG - - /************* Module Stuff ********************/ - --- -1.7.2 - diff --git a/systemtap-xmlto-fop.diff b/systemtap-xmlto-fop.diff index 3558809..e544cdf 100644 --- a/systemtap-xmlto-fop.diff +++ b/systemtap-xmlto-fop.diff @@ -8,8 +8,8 @@ # bump up the allocated space so "xmlto pdf" works tapsets.pdf: tapsets.xml -- env pool_size=2000000 hash_extra=2000000 xmlto $(XMLTOPDFPARAMS) pdf tapsets.xml >/dev/null 2>&1 -+# env pool_size=2000000 hash_extra=2000000 xmlto $(XMLTOPDFPARAMS) pdf tapsets.xml >/dev/null 2>&1 +- env pool_size=3000000 hash_extra=3000000 xmlto $(XMLTOPDFPARAMS) pdf tapsets.xml >/dev/null 2>&1 ++# env pool_size=3000000 hash_extra=3000000 xmlto $(XMLTOPDFPARAMS) pdf tapsets.xml >/dev/null 2>&1 + xmlto fo tapsets.xml + fop tapsets.fo tapsets.pdf diff --git a/systemtap.changes b/systemtap.changes index 7961396..1822e93 100644 --- a/systemtap.changes +++ b/systemtap.changes @@ -1,3 +1,14 @@ +------------------------------------------------------------------- +Fri Jan 21 18:46:18 UTC 2011 - tonyj@novell.com + +- Update to version 1.4 + Changes in this release: https://lkml.org/lkml/2011/1/17/101 + Drop patches: + systemtap-hppa.diff + systemtap-support-2.6.36.diff + systemtap_fix_mod_vs_del_timer_race.patch + systemtap_improve_gettimeofday_stability.patch + ------------------------------------------------------------------- Fri Jan 14 14:32:11 UTC 2011 - trenn@novell.com diff --git a/systemtap.spec b/systemtap.spec index aa87af1..ea98c32 100644 --- a/systemtap.spec +++ b/systemtap.spec @@ -23,8 +23,8 @@ BuildRequires: gcc-c++ glib2-devel libcap-devel libebl-devel pkg-config sqlite- BuildRequires: mozilla-nspr-devel mozilla-nss-devel mozilla-nss-tools %define use_snapshot 0 License: GPLv2+ -Version: 1.3 -Release: 2 +Version: 1.4 +Release: 1 Summary: Instrumentation System Group: Development/Tools/Debuggers Url: http://sourceware.org/systemtap/ @@ -39,10 +39,6 @@ Source: ftp://sources.redhat.com/pub/systemtap/snapshots/systemtap-%{pac # need -docdir patch even though docs are packaged by systemtap-docs.spec # so that they are installed into directories matching below rm -rf's Patch1: systemtap-docdir-fix.diff -Patch2: systemtap-hppa.diff -Patch3: systemtap-support-2.6.36.diff -Patch4: systemtap_improve_gettimeofday_stability.patch -Patch5: systemtap_fix_mod_vs_del_timer_race.patch Requires: libebl1 Requires: %{name}-runtime = %{version}-%{release} @@ -104,10 +100,6 @@ This package contains the support tools for static probes. %setup -n %{name}-%{package_version} -q %endif %patch1 -p1 -%patch2 -%patch3 -p1 -%patch4 -p1 -%patch5 -p1 %build autoreconf -fi @@ -148,6 +140,7 @@ rm -rf ${RPM_BUILD_ROOT} %defattr(-,root,root) %doc %{_docdir}/systemtap %{_bindir}/staprun +%{_bindir}/stap-merge %{_bindir}/stap-report %{_bindir}/stap-authorize-signing-cert %dir %{_libexecdir}/%{name} diff --git a/systemtap_fix_mod_vs_del_timer_race.patch b/systemtap_fix_mod_vs_del_timer_race.patch deleted file mode 100644 index 0d52871..0000000 --- a/systemtap_fix_mod_vs_del_timer_race.patch +++ /dev/null @@ -1,183 +0,0 @@ -From: Frank Ch. Eigler -Subject: PR10651 / RHBZ653286: mod_timer vs. del_timer_sync races -References: bnc#664105 -Patch-Mainline: yes -Git-commit: f2b610b6295628ae1fef744421c293883f1e4298 -Git-repo: git://sources.redhat.com/git/systemtap.git - -Signed-off-by: Thomas Renninger - -It appears possible for del_timer_sync (from outside) and mod_timer -(from within a timer callback) to race. Defeat this race by ensuring -that the timer callback checks an atomic_t flag before rescheduling -itself with mod_timer. - -* runtime/transport/relay_v2.c (transport_state): Turn into an atomic_t. - Update users. - (__stp_relay_wakeup_timer): Observe flag. - (_stp_transport_data_fs_{start,stop}): Update flag before timer manipulations. -* runtime/transport/ring_buffer.c: Ditto for corresponding functions. - -diff --git a/runtime/transport/relay_v2.c b/runtime/transport/relay_v2.c -index 974941d..33e198e 100644 ---- a/runtime/transport/relay_v2.c -+++ b/runtime/transport/relay_v2.c -@@ -4,7 +4,7 @@ - * code started as a proposed relayfs interface called 'utt'. It has - * been modified and simplified for systemtap. - * -- * Changes Copyright (C) 2009 Red Hat Inc. -+ * Changes Copyright (C) 2009-2010 Red Hat Inc. - * - * Original utt code by: - * Copyright (C) 2006 Jens Axboe -@@ -42,7 +42,7 @@ - * to be changed. */ - struct _stp_relay_data_type { - struct rchan *rchan; -- enum _stp_transport_state transport_state; -+ atomic_t /* enum _stp_transport_state */ transport_state; - struct dentry *dropped_file; - atomic_t dropped; - atomic_t wakeup; -@@ -133,7 +133,10 @@ static void __stp_relay_wakeup_timer(unsigned long val) - #endif - } - -- mod_timer(&_stp_relay_data.timer, jiffies + STP_RELAY_TIMER_INTERVAL); -+ if (atomic_read(&_stp_relay_data.transport_state) == STP_TRANSPORT_RUNNING) -+ mod_timer(&_stp_relay_data.timer, jiffies + STP_RELAY_TIMER_INTERVAL); -+ else -+ dbug_trans(0, "relay_v2 wakeup timer expiry\n"); - } - - static void __stp_relay_timer_init(void) -@@ -149,7 +152,7 @@ static void __stp_relay_timer_init(void) - - static enum _stp_transport_state _stp_transport_get_state(void) - { -- return _stp_relay_data.transport_state; -+ return atomic_read (&_stp_relay_data.transport_state); - } - - static void _stp_transport_data_fs_overwrite(int overwrite) -@@ -242,19 +245,19 @@ static struct rchan_callbacks __stp_relay_callbacks = { - - static void _stp_transport_data_fs_start(void) - { -- if (_stp_relay_data.transport_state == STP_TRANSPORT_INITIALIZED) { -+ if (atomic_read (&_stp_relay_data.transport_state) == STP_TRANSPORT_INITIALIZED) { -+ atomic_set (&_stp_relay_data.transport_state, STP_TRANSPORT_RUNNING); - /* We're initialized. Now start the timer. */ - __stp_relay_timer_init(); -- _stp_relay_data.transport_state = STP_TRANSPORT_RUNNING; - } - } - - static void _stp_transport_data_fs_stop(void) - { -- if (_stp_relay_data.transport_state == STP_TRANSPORT_RUNNING) { -+ if (atomic_read (&_stp_relay_data.transport_state) == STP_TRANSPORT_RUNNING) { -+ atomic_set (&_stp_relay_data.transport_state, STP_TRANSPORT_STOPPED); - del_timer_sync(&_stp_relay_data.timer); - dbug_trans(0, "flushing...\n"); -- _stp_relay_data.transport_state = STP_TRANSPORT_STOPPED; - if (_stp_relay_data.rchan) - relay_flush(_stp_relay_data.rchan); - } -@@ -277,7 +280,7 @@ static int _stp_transport_data_fs_init(void) - u64 npages; - struct sysinfo si; - -- _stp_relay_data.transport_state = STP_TRANSPORT_STOPPED; -+ atomic_set(&_stp_relay_data.transport_state, STP_TRANSPORT_STOPPED); - _stp_relay_data.overwrite_flag = 0; - atomic_set(&_stp_relay_data.dropped, 0); - _stp_relay_data.dropped_file = NULL; -@@ -337,7 +340,7 @@ static int _stp_transport_data_fs_init(void) - goto err; - } - dbug_trans(1, "returning 0...\n"); -- _stp_relay_data.transport_state = STP_TRANSPORT_INITIALIZED; -+ atomic_set (&_stp_relay_data.transport_state, STP_TRANSPORT_INITIALIZED); - - return 0; - -diff --git a/runtime/transport/ring_buffer.c b/runtime/transport/ring_buffer.c -index 6c327c0..232f099 100644 ---- a/runtime/transport/ring_buffer.c -+++ b/runtime/transport/ring_buffer.c -@@ -55,7 +55,7 @@ struct _stp_iterator { - #endif - - struct _stp_relay_data_type { -- enum _stp_transport_state transport_state; -+ atomic_t /* enum _stp_transport_state */ transport_state; - struct ring_buffer *rb; - struct _stp_iterator iter[NR_ITERS]; - cpumask_var_t trace_reader_cpumask; -@@ -649,10 +649,12 @@ static int _stp_data_write_commit(void *entry) - - static void __stp_relay_wakeup_timer(unsigned long val) - { -- if (waitqueue_active(&_stp_poll_wait) -- && ! _stp_ring_buffer_empty()) -+ if (waitqueue_active(&_stp_poll_wait) && ! _stp_ring_buffer_empty()) - wake_up_interruptible(&_stp_poll_wait); -- mod_timer(&_stp_relay_data.timer, jiffies + STP_RELAY_TIMER_INTERVAL); -+ if (atomic_read(&_stp_relay_data.transport_state) == STP_TRANSPORT_RUNNING) -+ mod_timer(&_stp_relay_data.timer, jiffies + STP_RELAY_TIMER_INTERVAL); -+ else -+ dbug_trans(0, "ring_buffer wakeup timer expiry\n"); - } - - static void __stp_relay_timer_start(void) -@@ -677,7 +679,7 @@ static int _stp_transport_data_fs_init(void) - int rc; - int cpu, cpu2; - -- _stp_relay_data.transport_state = STP_TRANSPORT_STOPPED; -+ atomic_set (&_stp_relay_data.transport_state, STP_TRANSPORT_STOPPED); - _stp_relay_data.rb = NULL; - - // allocate buffer -@@ -738,23 +740,23 @@ static int _stp_transport_data_fs_init(void) - } - - dbug_trans(1, "returning 0...\n"); -- _stp_relay_data.transport_state = STP_TRANSPORT_INITIALIZED; -+ atomic_set (&_stp_relay_data.transport_state, STP_TRANSPORT_INITIALIZED); - return 0; - } - - static void _stp_transport_data_fs_start(void) - { -- if (_stp_relay_data.transport_state == STP_TRANSPORT_INITIALIZED) { -- __stp_relay_timer_start(); -- _stp_relay_data.transport_state = STP_TRANSPORT_RUNNING; -+ if (atomic_read(&_stp_relay_data.transport_state) == STP_TRANSPORT_INITIALIZED) { -+ atomic_set(&_stp_relay_data.transport_state, STP_TRANSPORT_RUNNING); -+ __stp_relay_timer_start(); - } - } - - static void _stp_transport_data_fs_stop(void) - { -- if (_stp_relay_data.transport_state == STP_TRANSPORT_RUNNING) { -- __stp_relay_timer_stop(); -- _stp_relay_data.transport_state = STP_TRANSPORT_STOPPED; -+ if (atomic_read(&_stp_relay_data.transport_state) == STP_TRANSPORT_RUNNING) { -+ atomic_set(&_stp_relay_data.transport_state, STP_TRANSPORT_STOPPED); -+ __stp_relay_timer_stop(); - } - } - -@@ -773,7 +775,7 @@ static void _stp_transport_data_fs_close(void) - - static enum _stp_transport_state _stp_transport_get_state(void) - { -- return _stp_relay_data.transport_state; -+ return atomic_read (&_stp_relay_data.transport_state); - } - - static void _stp_transport_data_fs_overwrite(int overwrite) diff --git a/systemtap_improve_gettimeofday_stability.patch b/systemtap_improve_gettimeofday_stability.patch deleted file mode 100644 index c49b141..0000000 --- a/systemtap_improve_gettimeofday_stability.patch +++ /dev/null @@ -1,141 +0,0 @@ -From: Josh Stone -Subject: Improve gettimeofday stability -References: bnc#664105 -Patch-Mainline: yes -Git-commit: 3fd1c4901e81e5f6b550bb988d612281e0fc231b -Git-repo: git://sources.redhat.com/git/systemtap.git - -Signed-off-by: Thomas Renninger - -These are a few tweaks to improve the stability of our gettimeofday -startup and shutdown. Hopefully this helps with PR10651 and PR12182, -but that's not been confirmed yet. - -* runtime/runtime.h: Don't include time.c here. -* translate.cxx (c_unparser::emit_common_header): Include time.c here, - only if NEEDed (so we also ensure init/kill_time will be called). - (c_unparser::emit_module_init): Change to STAP_SESSION_STOPPED for the - final cleanup efforts, especially for time.c to wrap up. - (c_unparser::emit_module_exit): Ditto. -* runtime/time.c (__stp_time_timer_callback): Use the session_state - instead of stp_timer_reregister, and continue until STOPPED. - (__stp_init_time): Don't add_timer from the IPI. - (_stp_init_time): Instead, add_timer_on each cpu here. - -diff --git a/runtime/runtime.h b/runtime/runtime.h -index d4f41db..814d8ad 100644 ---- a/runtime/runtime.h -+++ b/runtime/runtime.h -@@ -132,7 +132,6 @@ static struct - #include "copy.c" - #include "regs.c" - #include "regs-ia64.c" --#include "time.c" - - #include "task_finder.c" - -diff --git a/runtime/time.c b/runtime/time.c -index 0d13487..38a808a 100644 ---- a/runtime/time.c -+++ b/runtime/time.c -@@ -56,9 +56,6 @@ typedef struct __stp_time_t { - - static void *stp_time = NULL; - --/* Flag to tell the timer callback whether to reregister */ --static int stp_timer_reregister = 0; -- - /* Try to estimate the number of CPU cycles in a millisecond - i.e. kHz. This - * relies heavily on the accuracy of udelay. By calling udelay twice, we - * attempt to account for overhead in the call. -@@ -134,7 +131,7 @@ __stp_time_timer_callback(unsigned long val) - XXX: The worst that can probably happen is that we get - two consecutive timer resets. */ - -- if (likely(stp_timer_reregister)) -+ if (likely(atomic_read(&session_state) != STAP_SESSION_STOPPED)) - mod_timer(&time->timer, jiffies + 1); - } - -@@ -154,7 +151,6 @@ __stp_init_time(void *info) - init_timer(&time->timer); - time->timer.expires = jiffies + 1; - time->timer.function = __stp_time_timer_callback; -- add_timer(&time->timer); - } - - #ifdef CONFIG_CPU_FREQ -@@ -208,7 +204,6 @@ _stp_kill_time(void) - { - if (stp_time) { - int cpu; -- stp_timer_reregister = 0; - for_each_online_cpu(cpu) { - stp_time_t *time = per_cpu_ptr(stp_time, cpu); - del_timer_sync(&time->timer); -@@ -229,20 +224,23 @@ _stp_kill_time(void) - static int - _stp_init_time(void) - { -- int ret = 0; -+ int cpu, ret = 0; - - _stp_kill_time(); - - stp_time = _stp_alloc_percpu(sizeof(stp_time_t)); - if (unlikely(stp_time == 0)) - return -1; -- -- stp_timer_reregister = 1; -+ - #ifdef STAPCONF_ONEACHCPU_RETRY - ret = on_each_cpu(__stp_init_time, NULL, 0, 1); - #else - ret = on_each_cpu(__stp_init_time, NULL, 1); - #endif -+ for_each_online_cpu(cpu) { -+ stp_time_t *time = per_cpu_ptr(stp_time, cpu); -+ add_timer_on(&time->timer, cpu); -+ } - - #ifdef CONFIG_CPU_FREQ - if (!ret && !__stp_constant_freq()) { -@@ -250,7 +248,6 @@ _stp_init_time(void) - CPUFREQ_TRANSITION_NOTIFIER); - - if (!ret) { -- int cpu; - for_each_online_cpu(cpu) { - unsigned long flags; - int freq_khz = cpufreq_get(cpu); -diff --git a/translate.cxx b/translate.cxx -index f360940..4447a24 100644 ---- a/translate.cxx -+++ b/translate.cxx -@@ -1085,6 +1085,10 @@ c_unparser::emit_common_header () - if (!session->stat_decls.empty()) - o->newline() << "#include \"stat.c\"\n"; - -+ o->newline() << "#ifdef STAP_NEED_GETTIMEOFDAY"; -+ o->newline() << "#include \"time.c\""; // Don't we all need more? -+ o->newline() << "#endif"; -+ - o->newline(); - } - -@@ -1327,6 +1331,7 @@ c_unparser::emit_module_init () - } - - // For any partially registered/unregistered kernel facilities. -+ o->newline() << "atomic_set (&session_state, STAP_SESSION_STOPPED);"; - o->newline() << "#ifdef STAPCONF_SYNCHRONIZE_SCHED"; - o->newline() << "synchronize_sched();"; - o->newline() << "#endif"; -@@ -1409,6 +1414,7 @@ c_unparser::emit_module_exit () - o->newline(-2) << "} while (holdon);"; - - // cargo cult epilogue -+ o->newline() << "atomic_set (&session_state, STAP_SESSION_STOPPED);"; - o->newline() << "#ifdef STAPCONF_SYNCHRONIZE_SCHED"; - o->newline() << "synchronize_sched();"; - o->newline() << "#endif";