forked from pool/systemtap
Accepting request 61688 from home:jones_tony:branches:devel:tools
Talked to coolo, tested with preload on x86_64 and i586/ OBS-URL: https://build.opensuse.org/request/show/61688 OBS-URL: https://build.opensuse.org/package/show/devel:tools/systemtap?expand=0&rev=22
This commit is contained in:
parent
71b8c4302b
commit
e7efb5386c
13
README-BEFORE-ADDING-PATCHES
Normal file
13
README-BEFORE-ADDING-PATCHES
Normal file
@ -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 <email>
|
||||||
|
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 <email> (same as From: if committer is patch author)
|
||||||
|
|
||||||
|
Short paragraph describing problem/fix.
|
||||||
|
|
||||||
|
References to upstream repo-path/commit-id if applicable.
|
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:548ec4d4d1eaa3a3e8d13f6c5d38b3fd08280a2889f95e71ab36954eb454b652
|
|
||||||
size 1389234
|
|
3
systemtap-1.4.tar.bz2
Normal file
3
systemtap-1.4.tar.bz2
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:773110b3648ce480d6470c10db47b2daeb5988722e7000aa4dbc723c27600dd7
|
||||||
|
size 1530777
|
@ -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
|
Thu Aug 26 02:15:11 UTC 2010 - tonyj@novell.com
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# spec file for package systemtap-docs (Version 1.3)
|
# spec file for package systemtap-docs
|
||||||
#
|
#
|
||||||
# Copyright (c) 2010 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
# Copyright (c) 2011 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
||||||
#
|
#
|
||||||
# All modifications and additions to the file contributed by third parties
|
# All modifications and additions to the file contributed by third parties
|
||||||
# remain the property of their copyright owners, unless otherwise agreed
|
# remain the property of their copyright owners, unless otherwise agreed
|
||||||
@ -26,7 +26,7 @@ BuildRequires: fop
|
|||||||
BuildRequires: latex2html
|
BuildRequires: latex2html
|
||||||
%define use_snapshot 0
|
%define use_snapshot 0
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Version: 1.3
|
Version: 1.4
|
||||||
Release: 1
|
Release: 1
|
||||||
Summary: Documents and examples for systemtap
|
Summary: Documents and examples for systemtap
|
||||||
Group: Development/Tools/Debuggers
|
Group: Development/Tools/Debuggers
|
||||||
@ -37,6 +37,7 @@ Url: http://sourceware.org/systemtap/
|
|||||||
%define package_version %{version}
|
%define package_version %{version}
|
||||||
%endif
|
%endif
|
||||||
Source: ftp://sources.redhat.com/pub/systemtap/snapshots/systemtap-%{package_version}.tar.bz2
|
Source: ftp://sources.redhat.com/pub/systemtap/snapshots/systemtap-%{package_version}.tar.bz2
|
||||||
|
Source2: README-BEFORE-ADDING-PATCHES
|
||||||
Patch1: systemtap-docdir-fix.diff
|
Patch1: systemtap-docdir-fix.diff
|
||||||
Patch2: systemtap-xmlto-fop.diff
|
Patch2: systemtap-xmlto-fop.diff
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||||
|
@ -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 "
|
|
@ -1,57 +0,0 @@
|
|||||||
From 75a48ca31be58a7f2c31d7bda4069a93105f872f Mon Sep 17 00:00:00 2001
|
|
||||||
From: David Smith <dsmith@redhat.com>
|
|
||||||
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
|
|
||||||
|
|
@ -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
|
Fri Jan 14 14:32:11 UTC 2011 - trenn@novell.com
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# spec file for package systemtap (Version 1.3)
|
# spec file for package systemtap
|
||||||
#
|
#
|
||||||
# Copyright (c) 2010 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
# Copyright (c) 2011 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
||||||
#
|
#
|
||||||
# All modifications and additions to the file contributed by third parties
|
# All modifications and additions to the file contributed by third parties
|
||||||
# remain the property of their copyright owners, unless otherwise agreed
|
# remain the property of their copyright owners, unless otherwise agreed
|
||||||
@ -23,7 +23,7 @@ BuildRequires: gcc-c++ glib2-devel libcap-devel libebl-devel pkg-config sqlite-
|
|||||||
BuildRequires: mozilla-nspr-devel mozilla-nss-devel mozilla-nss-tools
|
BuildRequires: mozilla-nspr-devel mozilla-nss-devel mozilla-nss-tools
|
||||||
%define use_snapshot 0
|
%define use_snapshot 0
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Version: 1.3
|
Version: 1.4
|
||||||
Release: 1
|
Release: 1
|
||||||
Summary: Instrumentation System
|
Summary: Instrumentation System
|
||||||
Group: Development/Tools/Debuggers
|
Group: Development/Tools/Debuggers
|
||||||
@ -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
|
# need -docdir patch even though docs are packaged by systemtap-docs.spec
|
||||||
# so that they are installed into directories matching below rm -rf's
|
# so that they are installed into directories matching below rm -rf's
|
||||||
Patch1: systemtap-docdir-fix.diff
|
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: libebl1
|
||||||
Requires: %{name}-runtime = %{version}-%{release}
|
Requires: %{name}-runtime = %{version}-%{release}
|
||||||
@ -104,10 +100,6 @@ This package contains the support tools for static probes.
|
|||||||
%setup -n %{name}-%{package_version} -q
|
%setup -n %{name}-%{package_version} -q
|
||||||
%endif
|
%endif
|
||||||
%patch1 -p1
|
%patch1 -p1
|
||||||
%patch2
|
|
||||||
%patch3 -p1
|
|
||||||
%patch4 -p1
|
|
||||||
%patch5 -p1
|
|
||||||
|
|
||||||
%build
|
%build
|
||||||
autoreconf -fi
|
autoreconf -fi
|
||||||
@ -148,6 +140,7 @@ rm -rf ${RPM_BUILD_ROOT}
|
|||||||
%defattr(-,root,root)
|
%defattr(-,root,root)
|
||||||
%doc %{_docdir}/systemtap
|
%doc %{_docdir}/systemtap
|
||||||
%{_bindir}/staprun
|
%{_bindir}/staprun
|
||||||
|
%{_bindir}/stap-merge
|
||||||
%{_bindir}/stap-report
|
%{_bindir}/stap-report
|
||||||
%{_bindir}/stap-authorize-signing-cert
|
%{_bindir}/stap-authorize-signing-cert
|
||||||
%dir %{_libexecdir}/%{name}
|
%dir %{_libexecdir}/%{name}
|
||||||
|
@ -1,183 +0,0 @@
|
|||||||
From: Frank Ch. Eigler <fche@elastic.org>
|
|
||||||
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 <trenn@suse.de>
|
|
||||||
|
|
||||||
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 <axboe@suse.de>
|
|
||||||
@@ -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)
|
|
@ -1,141 +0,0 @@
|
|||||||
From: Josh Stone <jistone@redhat.com>
|
|
||||||
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 <trenn@suse.de>
|
|
||||||
|
|
||||||
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";
|
|
Loading…
Reference in New Issue
Block a user