[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <63665c54-db44-452f-b321-1162ff6c3fe4@linux.ibm.com>
Date: Thu, 17 Jul 2025 14:20:12 +0200
From: Jens Remus <jremus@...ux.ibm.com>
To: Josh Poimboeuf <jpoimboe@...nel.org>
Cc: linux-kernel@...r.kernel.org, linux-trace-kernel@...r.kernel.org,
bpf@...r.kernel.org, x86@...nel.org,
Steven Rostedt <rostedt@...nel.org>,
Heiko Carstens <hca@...ux.ibm.com>, Vasily Gorbik <gor@...ux.ibm.com>,
Ilya Leoshkevich <iii@...ux.ibm.com>,
Masami Hiramatsu
<mhiramat@...nel.org>,
Mathieu Desnoyers <mathieu.desnoyers@...icios.com>,
Peter Zijlstra <peterz@...radead.org>, Ingo Molnar <mingo@...nel.org>,
Jiri Olsa <jolsa@...nel.org>, Namhyung Kim <namhyung@...nel.org>,
Thomas Gleixner <tglx@...utronix.de>,
Andrii Nakryiko <andrii@...nel.org>,
Indu Bhagat <indu.bhagat@...cle.com>,
"Jose E. Marchesi" <jemarch@....org>,
Beau Belgrave <beaub@...ux.microsoft.com>,
Linus Torvalds <torvalds@...ux-foundation.org>,
Andrew Morton <akpm@...ux-foundation.org>,
Jens Axboe <axboe@...nel.dk>, Florian Weimer <fweimer@...hat.com>,
Sam James <sam@...too.org>
Subject: Re: [RFC PATCH v1 12/16] unwind_user/backchain: Introduce back chain
user space unwinding
On 17.07.2025 04:06, Josh Poimboeuf wrote:
> On Thu, Jul 10, 2025 at 06:35:18PM +0200, Jens Remus wrote:
>> @@ -66,12 +73,20 @@ static int unwind_user_next(struct unwind_user_state *state)
>> /* sframe expects the frame to be local storage */
>> frame = &_frame;
>> if (sframe_find(state->ip, frame, topmost)) {
>> - if (!IS_ENABLED(CONFIG_HAVE_UNWIND_USER_FP))
>> - goto done;
>> - frame = &fp_frame;
>> + if (IS_ENABLED(CONFIG_HAVE_UNWIND_USER_FP)) {
>> + frame = &fp_frame;
>> + } else if (IS_ENABLED(CONFIG_HAVE_UNWIND_USER_BACKCHAIN)) {
>> + if (unwind_user_backchain_next(state))
>> + goto done;
>> + goto done_backchain;
>> + }
>> }
>> } else if (fp_state(state)) {
>> frame = &fp_frame;
>> + } else if (backchain_state(state)) {
>> + if (unwind_user_backchain_next(state))
>> + goto done;
>> + goto done_backchain;
>> } else {
>> goto done;
>> }
>> @@ -153,6 +168,7 @@ static int unwind_user_next(struct unwind_user_state *state)
>>
>> arch_unwind_user_next(state);
>>
>> +done_backchain:
>> state->topmost = false;
>> return 0;
>
> This feels very grafted on, is there not some way to make it more
> generic, i.e., to just work with CONFIG_HAVE_UNWIND_USER_FP?
I agree. It could probably be made to compute the cfa_off and ra.offset
or ra.regnum. Let me explore that, provided there would be any acceptance
for unwind user backchain at all. Note that Power is using backchain as
well, so they may want to build on that as well.
> Also, if distros aren't even compiling with -mbackchain, I wonder if we
> can just not do this altogether :-)
My original intent was to use unwind user's for_each_user_frame() to
replace the exiting stack tracing logic in arch_stack_walk_user_common()
in arch/s390/kernel/stacktrace.c, which currently supports backchain.
Given that for_each_user_frame() was made private in the latest unwind
user series version hinders me. The use was also low, because the
currentl arch_stack_walk_user_common() implementation does not support
page faults, so that the attempt to use unwind user sframe would always
fail and fallback to unwind user backchain. My hope was that somebody
with more Kernel skills could give me a few hints at how it could be
made to support deferred unwind. :-)
Regards,
Jens
--
Jens Remus
Linux on Z Development (D3303)
+49-7031-16-1128 Office
jremus@...ibm.com
IBM
IBM Deutschland Research & Development GmbH; Vorsitzender des Aufsichtsrats: Wolfgang Wendt; Geschäftsführung: David Faller; Sitz der Gesellschaft: Böblingen; Registergericht: Amtsgericht Stuttgart, HRB 243294
IBM Data Privacy Statement: https://www.ibm.com/privacy/
Powered by blists - more mailing lists