[PATCH v3 0/3] arm64: entry: Convert to generic entry
Jinjie Ruan
ruanjinjie at huawei.com
Mon Oct 21 01:30:51 PDT 2024
On 2024/10/17 23:25, Mark Rutland wrote:
> Hi,
>
> On Sat, Jun 29, 2024 at 04:55:58PM +0800, Jinjie Ruan wrote:
>> Currently, x86, Riscv, Loongarch use the generic entry. Convert arm64
>> to use the generic entry infrastructure from kernel/entry/*. The generic
>> entry makes maintainers' work easier and codes more elegant, which aslo
>> removed a lot of duplicate code.
>
>> arch/arm64/Kconfig | 1 +
>> arch/arm64/include/asm/entry-common.h | 172 ++++++++++++
>> arch/arm64/include/asm/ptrace.h | 5 +
>> arch/arm64/include/asm/stacktrace.h | 5 +-
>> arch/arm64/include/asm/syscall.h | 6 +-
>> arch/arm64/include/asm/thread_info.h | 23 +-
>> arch/arm64/kernel/entry-common.c | 368 +++++---------------------
>> arch/arm64/kernel/ptrace.c | 90 -------
>> arch/arm64/kernel/signal.c | 3 +-
>> arch/arm64/kernel/syscall.c | 18 +-
>> include/linux/entry-common.h | 90 +++++++
>> include/linux/thread_info.h | 13 +
>> kernel/entry/common.c | 37 +--
>> 13 files changed, 395 insertions(+), 436 deletions(-)
>> create mode 100644 arch/arm64/include/asm/entry-common.h
>
> Looking at this I have a few concerns, which I've tried to explain
> below.
>
> Firstly, this is difficult to review (and will be difficult to test,
> queue. and debug in future) because lots of independent changes are made
> all at once. I think that needs to be split out more.
>
> It would be good if preparatory rework/cleanup could be split into a few
> patches that we could consider queueing before the rest of the series,
> or even if we decide to not pick the rest of the series. For example,
> patch 2 should be split into:
>
> * One patch that replaces arm64's interrupts_enabled() with
> regs_irqs_disabled(), removing interrupts_enabled() entirely rather
> than implementing regs_irqs_disabled() using interrupts_enabled().
Yes, only the new version is needed, another interrupts_enabled() should
be removed.
>
> That'll require updating existing users, but the end result will be
> more consistent and have fewer lines of code.
>
> * One patch that changes on_thread_stack() from a macro to a function.
> The commit message for patch 2 currently says:
>
> > Make on_thread_stack() compatible with generic entry.
>
> ... but it's not clear to me *what* that incompatibility is, and that
> should be explained in the commit message.
This change is not needed, I'll remove it.
>
> * One patch that splits report_syscall() into report_syscall_enter() and
> report_syscall_exit(). This should have no functional change.
Yes, that will be more clear.
>
> Patch 3 in particular is very hard to follow because several unrelated
> complex systems are updated simultaneously. It would be really nice if
> we could move to the generic sycall code separately from moving the rest
> of the entry code, as the sycall handling code is a particularly
> important ABI concern, and it's difficult to see whether we're making
> ABI changes (accidentaly or knowingly).
>
> Can we split that up (e.g. splitting the generic code first into
> separate entry and syscall files), or are those too tightly coupled for
> that to be possible?
It will be hard, but I will try to split it, they are surely tightly
coupled which make the 3th patch too big when I try to switch to generic
entry.
>
> At the end of the series, pt_regs::{lockdep_hardirqs,exit_rcu} still
> exist, though they're unused. It would be nicer if we could get rid of
> those in a preparatory patch, e.g. have enter_from_kernel_mode() and
> exit_to_kernel_mode() use an irqentry_state_t (or a temporary
> arm64-specific version). That would make the subsequent changes clearer
> since we'd already have the same structure.
You are totally right, when I do as you said, the third switch patch is
more smoother and more comprehensible.
>
> In the end result, there's a lot of bouncing between noinstr functions
> where things are inlined today. For example, el0_da() calls
> irqentry_enter_from_user_mode(), which is an out-of-line noinstr wrapper
> for enter_from_user_mode(), which is an __always_inline function in a
> header. It would be nice to avoid unnecessary bouncing through
> out-of-line functions. I see s390 and x86 use enter_from_user_mode()
> directly.Yes, the enter_from_user_mode() is enough, there is no need to use the
wrapper irqentry_enter_from_user_mode().
>
> There's also some indirection that I don't think is necessary *and*
> hides important ordering concerns and results in mistakes. In
> particular, note that before this series, enter_from_kernel_mode() calls
> the (instrumentable) MTE checks *after* all the necessary lockdep+RCU
> management is performed by __enter_from_kernel_mode():
>
> static void noinstr enter_from_kernel_mode(struct pt_regs *regs)
> {
> __enter_from_kernel_mode(regs);
> mte_check_tfsr_entry();
> mte_disable_tco_entry(current);
> }
>
> ... whereas after this series is applied, those MTE checks are placed in
> arch_enter_from_kernel_mode(), which irqentry_enter() calls *before* the
> necessary lockdep+RCU management. That is broken.
Yes, these MTE checks can be wrapped in arm64 version
enter_from_kernel_mode() code, and the new defined arch functions can be
removed.
>
> It would be better to keep that explicit in the arm64 entry code with
> arm64-specific wrappers, e.g.
>
> static noinstr irqentry_state_t enter_from_kernel_mode(struct pt_regs *regs)
> {
> irqentry_state_t state = irqentry_enter(regs);
> mte_check_tfsr_entry();
> mte_disable_tco_entry(current);
>
> return state;
> }
>
> ... which would avoid the need for arch_enter_from_kernel_mode(), make
> that ordering obvious, and would remove the need to modify all the
> callers.
>
> Likewise for the user entry/exit paths, which would avoid the visual
> imbalance of:
>
> irqentry_enter_from_user_mode();
> ...
> exit_to_user_mode_wrapper()
>
Yes, it is not clear, we can eliminate this sense of imbalance by
renaming them and wrap them.
> Thanks,
> Mark.
>
More information about the linux-arm-kernel
mailing list