From: Peter Zijlstra <peterz@infradead.org>
To: mingo@kernel.org
Cc: linux-kernel@vger.kernel.org, torvalds@linux-foundation.org,
fweisbec@gmail.com, oleg@redhat.com, umgwanakikbuti@gmail.com,
tglx@linutronix.de, rostedt@goodmis.org,
Peter Zijlstra <peterz@infradead.org>
Subject: [RFC][PATCH 06/11] sched: Fix trace_sched_switch()
Date: Tue, 29 Sep 2015 11:28:31 +0200 [thread overview]
Message-ID: <20150929093520.240883073@infradead.org> (raw)
In-Reply-To: 20150929092825.540553633@infradead.org
[-- Attachment #1: peterz-kill-preempt_active-6.patch --]
[-- Type: text/plain, Size: 3939 bytes --]
__trace_sched_switch_state() is the last remaining PREEMPT_ACTIVE
user, move trace_sched_switch() from prepare_task_switch() to
__schedule() and propagate the @preempt argument.
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
---
include/trace/events/sched.h | 22 +++++++++-------------
kernel/sched/core.c | 2 +-
kernel/trace/ftrace.c | 2 +-
kernel/trace/trace_sched_switch.c | 3 ++-
kernel/trace/trace_sched_wakeup.c | 2 +-
5 files changed, 14 insertions(+), 17 deletions(-)
--- a/include/trace/events/sched.h
+++ b/include/trace/events/sched.h
@@ -104,22 +104,17 @@ DEFINE_EVENT(sched_wakeup_template, sche
TP_ARGS(p));
#ifdef CREATE_TRACE_POINTS
-static inline long __trace_sched_switch_state(struct task_struct *p)
+static inline long __trace_sched_switch_state(bool preempt, struct task_struct *p)
{
- long state = p->state;
-
-#ifdef CONFIG_PREEMPT
#ifdef CONFIG_SCHED_DEBUG
BUG_ON(p != current);
#endif /* CONFIG_SCHED_DEBUG */
+
/*
- * For all intents and purposes a preempted task is a running task.
+ * Preemption ignores task state, therefore preempted tasks are always
+ * RUNNING (we will not have dequeued if state != RUNNING).
*/
- if (preempt_count() & PREEMPT_ACTIVE)
- state = TASK_RUNNING | TASK_STATE_MAX;
-#endif /* CONFIG_PREEMPT */
-
- return state;
+ return preempt ? TASK_RUNNING | TASK_STATE_MAX : p->state;
}
#endif /* CREATE_TRACE_POINTS */
@@ -128,10 +123,11 @@ static inline long __trace_sched_switch_
*/
TRACE_EVENT(sched_switch,
- TP_PROTO(struct task_struct *prev,
+ TP_PROTO(bool preempt,
+ struct task_struct *prev,
struct task_struct *next),
- TP_ARGS(prev, next),
+ TP_ARGS(preempt, prev, next),
TP_STRUCT__entry(
__array( char, prev_comm, TASK_COMM_LEN )
@@ -147,7 +143,7 @@ TRACE_EVENT(sched_switch,
memcpy(__entry->next_comm, next->comm, TASK_COMM_LEN);
__entry->prev_pid = prev->pid;
__entry->prev_prio = prev->prio;
- __entry->prev_state = __trace_sched_switch_state(prev);
+ __entry->prev_state = __trace_sched_switch_state(preempt, prev);
memcpy(__entry->prev_comm, prev->comm, TASK_COMM_LEN);
__entry->next_pid = next->pid;
__entry->next_prio = next->prio;
--- a/kernel/sched/core.c
+++ b/kernel/sched/core.c
@@ -2470,7 +2470,6 @@ static inline void
prepare_task_switch(struct rq *rq, struct task_struct *prev,
struct task_struct *next)
{
- trace_sched_switch(prev, next);
sched_info_switch(rq, prev, next);
perf_event_task_sched_out(prev, next);
fire_sched_out_preempt_notifiers(prev, next);
@@ -3121,6 +3120,7 @@ static void __sched __schedule(bool pree
rq->curr = next;
++*switch_count;
+ trace_sched_switch(preempt, prev, next);
rq = context_switch(rq, prev, next); /* unlocks the rq */
cpu = cpu_of(rq);
} else {
--- a/kernel/trace/ftrace.c
+++ b/kernel/trace/ftrace.c
@@ -5697,7 +5697,7 @@ static int alloc_retstack_tasklist(struc
}
static void
-ftrace_graph_probe_sched_switch(void *ignore,
+ftrace_graph_probe_sched_switch(void *ignore, bool preempt,
struct task_struct *prev, struct task_struct *next)
{
unsigned long long timestamp;
--- a/kernel/trace/trace_sched_switch.c
+++ b/kernel/trace/trace_sched_switch.c
@@ -16,7 +16,8 @@ static int sched_ref;
static DEFINE_MUTEX(sched_register_mutex);
static void
-probe_sched_switch(void *ignore, struct task_struct *prev, struct task_struct *next)
+probe_sched_switch(void *ignore, bool preempt,
+ struct task_struct *prev, struct task_struct *next)
{
if (unlikely(!sched_ref))
return;
--- a/kernel/trace/trace_sched_wakeup.c
+++ b/kernel/trace/trace_sched_wakeup.c
@@ -420,7 +420,7 @@ tracing_sched_wakeup_trace(struct trace_
}
static void notrace
-probe_wakeup_sched_switch(void *ignore,
+probe_wakeup_sched_switch(void *ignore, bool preempt,
struct task_struct *prev, struct task_struct *next)
{
struct trace_array_cpu *data;
next prev parent reply other threads:[~2015-09-29 9:43 UTC|newest]
Thread overview: 61+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-09-29 9:28 [RFC][PATCH 00/11] sched: Killing PREEMPT_ACTIVE Peter Zijlstra
2015-09-29 9:28 ` [RFC][PATCH 01/11] sched: Simplify INIT_PREEMPT_COUNT Peter Zijlstra
2015-09-29 10:30 ` [tip:sched/core] sched/core: " tip-bot for Peter Zijlstra
2015-09-29 13:19 ` [RFC][PATCH 01/11] sched: " Frederic Weisbecker
2015-09-29 14:43 ` Steven Rostedt
2015-09-29 14:47 ` Peter Zijlstra
[not found] ` <20150929103729.00899e69@gandalf.local.home>
[not found] ` <20150929143559.GL3816@twins.programming.kicks-ass.net>
2015-09-29 15:00 ` Steven Rostedt
2015-09-29 15:05 ` Peter Zijlstra
2015-09-29 9:28 ` [RFC][PATCH 02/11] sched: Create preempt_count invariant Peter Zijlstra
2015-09-29 10:30 ` [tip:sched/core] sched/core: " tip-bot for Peter Zijlstra
2015-09-29 12:55 ` [RFC][PATCH 02/11] sched: " Frederic Weisbecker
2015-09-29 13:02 ` Peter Zijlstra
2015-09-29 14:40 ` Steven Rostedt
2015-09-29 13:11 ` Thomas Gleixner
2015-09-29 14:09 ` Peter Zijlstra
2015-09-29 9:28 ` [RFC][PATCH 03/11] sched: Robustify preemption leak checks Peter Zijlstra
2015-09-29 10:31 ` [tip:sched/core] sched/core: " tip-bot for Peter Zijlstra
2015-09-29 13:13 ` [RFC][PATCH 03/11] sched: " Thomas Gleixner
2015-09-29 13:25 ` Frederic Weisbecker
2015-09-29 14:24 ` Peter Zijlstra
2015-09-29 14:32 ` Frederic Weisbecker
2015-09-29 15:07 ` Steven Rostedt
2015-09-29 15:17 ` Peter Zijlstra
2015-09-29 9:28 ` [RFC][PATCH 04/11] sched: Rework TASK_DEAD preemption exception Peter Zijlstra
2015-09-29 13:13 ` Thomas Gleixner
2015-09-29 13:41 ` Frederic Weisbecker
2015-09-29 15:10 ` Steven Rostedt
2015-09-29 9:28 ` [RFC][PATCH 05/11] sched: Add preempt argument to __schedule() Peter Zijlstra
2015-09-29 13:14 ` Thomas Gleixner
2015-09-29 13:18 ` Frederic Weisbecker
2015-09-29 15:28 ` Steven Rostedt
2015-09-29 15:30 ` Steven Rostedt
2015-09-29 15:29 ` Peter Zijlstra
2015-09-29 9:28 ` Peter Zijlstra [this message]
2015-09-29 13:15 ` [RFC][PATCH 06/11] sched: Fix trace_sched_switch() Thomas Gleixner
2015-09-29 15:38 ` Steven Rostedt
2015-09-29 15:48 ` Peter Zijlstra
2015-09-29 16:30 ` Steven Rostedt
2015-09-29 9:28 ` [RFC][PATCH 07/11] sched: Stop setting PREEMPT_ACTIVE Peter Zijlstra
2015-09-29 13:16 ` Thomas Gleixner
2015-09-29 15:41 ` Steven Rostedt
2015-09-29 16:25 ` Peter Zijlstra
2015-09-29 9:28 ` [RFC][PATCH 08/11] sched: Simplify preempt_count tests Peter Zijlstra
2015-09-29 13:17 ` Thomas Gleixner
2015-09-29 15:42 ` Steven Rostedt
2015-09-29 9:28 ` [RFC][PATCH 09/11] sched, x86: Kill saved_preempt_count Peter Zijlstra
2015-09-29 13:18 ` Thomas Gleixner
2015-09-29 15:44 ` Steven Rostedt
2015-09-29 15:46 ` Peter Zijlstra
2015-09-29 9:28 ` [RFC][PATCH 10/11] sched: Kill PREEMPT_ACTIVE Peter Zijlstra
2015-09-29 13:18 ` Thomas Gleixner
2015-09-29 15:45 ` Steven Rostedt
2015-09-29 9:28 ` [RFC][PATCH 11/11] sched: More notrace Peter Zijlstra
2015-09-29 13:19 ` Thomas Gleixner
2015-09-29 15:58 ` Steven Rostedt
2015-09-29 10:27 ` [RFC][PATCH 12/11] sched: Add preempt_count invariant check Peter Zijlstra
2015-09-29 10:32 ` Peter Zijlstra
2015-09-29 10:56 ` [RFC][PATCH v2 " Peter Zijlstra
2015-09-29 11:55 ` Linus Torvalds
2015-09-29 11:55 ` Peter Zijlstra
2015-09-29 10:34 ` [RFC][PATCH 00/11] sched: Killing PREEMPT_ACTIVE Ingo Molnar
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20150929093520.240883073@infradead.org \
--to=peterz@infradead.org \
--cc=fweisbec@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@kernel.org \
--cc=oleg@redhat.com \
--cc=rostedt@goodmis.org \
--cc=tglx@linutronix.de \
--cc=torvalds@linux-foundation.org \
--cc=umgwanakikbuti@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox