LKML Archive on lore.kernel.org help / color / mirror / Atom feed
From: Steven Rostedt <rostedt@goodmis.org> To: linux-kernel@vger.kernel.org Cc: Ingo Molnar <mingo@kernel.org>, Andrew Morton <akpm@linux-foundation.org>, Thomas Gleixner <tglx@linutronix.de>, Peter Zijlstra <peterz@infradead.org>, Masami Hiramatsu <mhiramat@kernel.org>, Josh Poimboeuf <jpoimboe@redhat.com>, Frederic Weisbecker <frederic@kernel.org>, Joel Fernandes <joel@joelfernandes.org>, Andy Lutomirski <luto@kernel.org>, Mark Rutland <mark.rutland@arm.com>, Namhyung Kim <namhyung@kernel.org>, "Frank Ch. Eigler" <fche@redhat.com> Subject: [PATCH 03/16 v3] fgraph: Have the current->ret_stack go down not up Date: Fri, 24 May 2019 23:16:36 -0400 [thread overview] Message-ID: <20190525031745.556089635@goodmis.org> (raw) In-Reply-To: 20190525031633.811342628@goodmis.org From: "Steven Rostedt (VMware)" <rostedt@goodmis.org> Change the direction of the current->ret_stack shadown stack to move the same as most normal arch stacks do. Suggested-by: Peter Zijlstra <peterz@infradead.org> Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org> --- kernel/trace/fgraph.c | 39 ++++++++++++++++++++------------------- 1 file changed, 20 insertions(+), 19 deletions(-) diff --git a/kernel/trace/fgraph.c b/kernel/trace/fgraph.c index 63e701771c20..b0f8ae269351 100644 --- a/kernel/trace/fgraph.c +++ b/kernel/trace/fgraph.c @@ -27,8 +27,9 @@ #define FGRAPH_RET_INDEX (FGRAPH_RET_SIZE / sizeof(long)) #define SHADOW_STACK_SIZE (PAGE_SIZE) #define SHADOW_STACK_INDEX (SHADOW_STACK_SIZE / sizeof(long)) -/* Leave on a buffer at the end */ -#define SHADOW_STACK_MAX_INDEX (SHADOW_STACK_INDEX - FGRAPH_RET_INDEX) +#define SHADOW_STACK_MAX_INDEX SHADOW_STACK_INDEX +/* Leave on a little buffer at the bottom */ +#define SHADOW_STACK_MIN_INDEX FGRAPH_RET_INDEX #define RET_STACK(t, index) ((struct ftrace_ret_stack *)(&(t)->ret_stack[index])) #define RET_STACK_INC(c) ({ c += FGRAPH_RET_INDEX; }) @@ -89,16 +90,16 @@ ftrace_push_return_trace(unsigned long ret, unsigned long func, smp_rmb(); /* The return trace stack is full */ - if (current->curr_ret_stack >= SHADOW_STACK_MAX_INDEX) { + if (current->curr_ret_stack <= SHADOW_STACK_MIN_INDEX) { atomic_inc(¤t->trace_overrun); return -EBUSY; } calltime = trace_clock_local(); - index = current->curr_ret_stack; - RET_STACK_INC(current->curr_ret_stack); - ret_stack = RET_STACK(current, index); + RET_STACK_DEC(current->curr_ret_stack); + ret_stack = RET_STACK(current, current->curr_ret_stack); + /* Make sure interrupts see the current value of curr_ret_stack */ barrier(); ret_stack->ret = ret; ret_stack->func = func; @@ -129,7 +130,7 @@ int function_graph_enter(unsigned long ret, unsigned long func, return 0; out_ret: - RET_STACK_DEC(current->curr_ret_stack); + RET_STACK_INC(current->curr_ret_stack); out: current->curr_ret_depth--; return -EBUSY; @@ -144,9 +145,8 @@ ftrace_pop_return_trace(struct ftrace_graph_ret *trace, unsigned long *ret, int index; index = current->curr_ret_stack; - RET_STACK_DEC(index); - if (unlikely(index < 0 || index > SHADOW_STACK_MAX_INDEX)) { + if (unlikely(index < 0 || index >= SHADOW_STACK_MAX_INDEX)) { ftrace_graph_stop(); WARN_ON(1); /* Might as well panic, otherwise we have no where to go */ @@ -239,7 +239,7 @@ unsigned long ftrace_return_to_handler(unsigned long frame_pointer) * curr_ret_stack is after that. */ barrier(); - RET_STACK_DEC(current->curr_ret_stack); + RET_STACK_INC(current->curr_ret_stack); if (unlikely(!ret)) { ftrace_graph_stop(); @@ -302,9 +302,9 @@ unsigned long ftrace_graph_ret_addr(struct task_struct *task, int *idx, if (ret != (unsigned long)return_to_handler) return ret; - RET_STACK_DEC(index); + RET_STACK_INC(index); - for (i = index; i >= 0; RET_STACK_DEC(i)) { + for (i = index; i < SHADOW_STACK_MAX_INDEX; RET_STACK_INC(i)) { ret_stack = RET_STACK(task, i); if (ret_stack->retp == retp) return ret_stack->ret; @@ -322,13 +322,13 @@ unsigned long ftrace_graph_ret_addr(struct task_struct *task, int *idx, return ret; task_idx = task->curr_ret_stack; - RET_STACK_DEC(task_idx); + RET_STACK_INC(task_idx); - if (!task->ret_stack || task_idx < *idx) + if (!task->ret_stack || task_idx > *idx) return ret; task_idx -= *idx; - RET_STACK_INC(*idx); + RET_STACK_DEC(*idx); return RET_STACK(task, task_idx); } @@ -391,7 +391,7 @@ static int alloc_retstack_tasklist(unsigned long **ret_stack_list) if (t->ret_stack == NULL) { atomic_set(&t->tracing_graph_pause, 0); atomic_set(&t->trace_overrun, 0); - t->curr_ret_stack = 0; + t->curr_ret_stack = SHADOW_STACK_MAX_INDEX; t->curr_ret_depth = -1; /* Make sure the tasks see the 0 first: */ smp_wmb(); @@ -436,10 +436,11 @@ ftrace_graph_probe_sched_switch(void *ignore, bool preempt, */ timestamp -= next->ftrace_timestamp; - for (index = next->curr_ret_stack - FGRAPH_RET_INDEX; index >= 0; ) { + for (index = next->curr_ret_stack + FGRAPH_RET_INDEX; + index < SHADOW_STACK_MAX_INDEX; ) { ret_stack = RET_STACK(next, index); ret_stack->calltime += timestamp; - index -= FGRAPH_RET_INDEX; + index += FGRAPH_RET_INDEX; } } @@ -530,7 +531,7 @@ void ftrace_graph_init_task(struct task_struct *t) { /* Make sure we do not use the parent ret_stack */ t->ret_stack = NULL; - t->curr_ret_stack = 0; + t->curr_ret_stack = SHADOW_STACK_MAX_INDEX; t->curr_ret_depth = -1; if (ftrace_graph_active) { -- 2.20.1
next prev parent reply other threads:[~2019-05-25 3:18 UTC|newest] Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top 2019-05-25 3:16 [PATCH 00/16 v3] function_graph: Rewrite to allow multiple users Steven Rostedt 2019-05-25 3:16 ` [PATCH 01/16 v3] function_graph: Convert ret_stack to a series of longs Steven Rostedt 2019-05-28 9:50 ` Joel Fernandes 2019-05-28 12:58 ` Steven Rostedt 2019-05-28 17:46 ` Joel Fernandes 2019-05-25 3:16 ` [PATCH 02/16 v3] fgraph: Use BUILD_BUG_ON() to make sure we have structures divisible by long Steven Rostedt 2019-05-25 3:16 ` Steven Rostedt [this message] 2019-05-25 3:16 ` [PATCH 04/16 v3] function_graph: Add an array structure that will allow multiple callbacks Steven Rostedt 2019-05-25 3:16 ` [PATCH 05/16 v3] function_graph: Allow multiple users to attach to function graph Steven Rostedt 2019-05-25 3:16 ` [PATCH 06/16 v3] function_graph: Remove logic around ftrace_graph_entry and return Steven Rostedt 2019-05-25 3:16 ` [PATCH 07/16 v3] ftrace/function_graph: Pass fgraph_ops to function graph callbacks Steven Rostedt 2019-05-25 3:16 ` [PATCH 08/16 v3] ftrace: Allow function_graph tracer to be enabled in instances Steven Rostedt 2019-05-25 3:16 ` [PATCH 09/16 v3] ftrace: Allow ftrace startup flags exist without dynamic ftrace Steven Rostedt 2019-05-25 3:16 ` [PATCH 10/16 v3] function_graph: Have the instances use their own ftrace_ops for filtering Steven Rostedt 2019-05-25 3:16 ` [PATCH 11/16 v3] function_graph: Add "task variables" per task for fgraph_ops Steven Rostedt 2019-05-25 3:16 ` [PATCH 12/16 v3] function_graph: Move set_graph_function tests to shadow stack global var Steven Rostedt 2019-05-25 3:16 ` [PATCH 13/16 v3] function_graph: Move graph depth stored data " Steven Rostedt 2019-05-25 3:16 ` [PATCH 14/16 v3] function_graph: Move graph notrace bit " Steven Rostedt 2019-05-25 3:16 ` [PATCH 15/16 v3] function_graph: Implement fgraph_reserve_data() and fgraph_retrieve_data() Steven Rostedt 2019-05-25 3:16 ` [PATCH 16/16 v3] function_graph: Add selftest for passing local variables Steven Rostedt
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=20190525031745.556089635@goodmis.org \ --to=rostedt@goodmis.org \ --cc=akpm@linux-foundation.org \ --cc=fche@redhat.com \ --cc=frederic@kernel.org \ --cc=joel@joelfernandes.org \ --cc=jpoimboe@redhat.com \ --cc=linux-kernel@vger.kernel.org \ --cc=luto@kernel.org \ --cc=mark.rutland@arm.com \ --cc=mhiramat@kernel.org \ --cc=mingo@kernel.org \ --cc=namhyung@kernel.org \ --cc=peterz@infradead.org \ --cc=tglx@linutronix.de \ /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: linkBe 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; as well as URLs for NNTP newsgroup(s).