From: Mark Rutland <mark.rutland@arm•com>
To: Will Deacon <will@kernel•org>
Cc: linux-arm-kernel@lists•infradead.org, linux-arch@vger•kernel.org,
linux-kernel@vger•kernel.org,
Catalin Marinas <catalin.marinas@arm•com>,
Marc Zyngier <maz@kernel•org>,
Greg Kroah-Hartman <gregkh@linuxfoundation•org>,
Peter Zijlstra <peterz@infradead•org>,
Morten Rasmussen <morten.rasmussen@arm•com>,
Qais Yousef <qais.yousef@arm•com>,
Suren Baghdasaryan <surenb@google•com>,
Quentin Perret <qperret@google•com>, Tejun Heo <tj@kernel•org>,
Johannes Weiner <hannes@cmpxchg•org>,
Ingo Molnar <mingo@redhat•com>,
Juri Lelli <juri.lelli@redhat•com>,
Vincent Guittot <vincent.guittot@linaro•org>,
"Rafael J. Wysocki" <rjw@rjwysocki•net>,
Dietmar Eggemann <dietmar.eggemann@arm•com>,
Daniel Bristot de Oliveira <bristot@redhat•com>,
Valentin Schneider <valentin.schneider@arm•com>,
kernel-team@android•com
Subject: Re: [PATCH v8 02/19] arm64: Allow mismatched 32-bit EL0 support
Date: Fri, 4 Jun 2021 10:38:08 +0100 [thread overview]
Message-ID: <20210604093808.GA64162@C02TD0UTHF1T.local> (raw)
In-Reply-To: <20210603174413.GC1170@willie-the-truck>
On Thu, Jun 03, 2021 at 06:44:14PM +0100, Will Deacon wrote:
> On Thu, Jun 03, 2021 at 01:37:15PM +0100, Mark Rutland wrote:
> > On Wed, Jun 02, 2021 at 05:47:02PM +0100, Will Deacon wrote:
> > > When confronted with a mixture of CPUs, some of which support 32-bit
> > > applications and others which don't, we quite sensibly treat the system
> > > as 64-bit only for userspace and prevent execve() of 32-bit binaries.
> > >
> > > Unfortunately, some crazy folks have decided to build systems like this
> > > with the intention of running 32-bit applications, so relax our
> > > sanitisation logic to continue to advertise 32-bit support to userspace
> > > on these systems and track the real 32-bit capable cores in a cpumask
> > > instead. For now, the default behaviour remains but will be tied to
> > > a command-line option in a later patch.
> > >
> > > Reviewed-by: Catalin Marinas <catalin.marinas@arm•com>
> > > Signed-off-by: Will Deacon <will@kernel•org>
> > > ---
> > > arch/arm64/include/asm/cpufeature.h | 8 +-
> > > arch/arm64/kernel/cpufeature.c | 114 ++++++++++++++++++++++++----
> > > arch/arm64/tools/cpucaps | 3 +-
> > > 3 files changed, 110 insertions(+), 15 deletions(-)
> > >
> > > diff --git a/arch/arm64/include/asm/cpufeature.h b/arch/arm64/include/asm/cpufeature.h
> > > index 338840c00e8e..603bf4160cd6 100644
> > > --- a/arch/arm64/include/asm/cpufeature.h
> > > +++ b/arch/arm64/include/asm/cpufeature.h
> > > @@ -630,9 +630,15 @@ static inline bool cpu_supports_mixed_endian_el0(void)
> > > return id_aa64mmfr0_mixed_endian_el0(read_cpuid(ID_AA64MMFR0_EL1));
> > > }
> > >
> > > +const struct cpumask *system_32bit_el0_cpumask(void);
> > > +DECLARE_STATIC_KEY_FALSE(arm64_mismatched_32bit_el0);
> > > +
> > > static inline bool system_supports_32bit_el0(void)
> > > {
> > > - return cpus_have_const_cap(ARM64_HAS_32BIT_EL0);
> > > + u64 pfr0 = read_sanitised_ftr_reg(SYS_ID_AA64PFR0_EL1);
> > > +
> > > + return static_branch_unlikely(&arm64_mismatched_32bit_el0) ||
> > > + id_aa64pfr0_32bit_el0(pfr0);
> > > }
> >
> > Note that read_sanitised_ftr_reg() has to do a bsearch() to find the
> > arm64_ftr_reg, so this will make system_32bit_el0_cpumask() a fair
> > amount more expensive than it needs to be.
>
> I seriously doubt that it matters, but it did come up before and I proposed
> a potential solution if it's actually a concern:
>
> https://lore.kernel.org/r/20201202172727.GC29813@willie-the-truck
>
> so if you can show that it's a problem, we can resurrect something like
> that.
I'm happy to leave that for future. I raised this because elsewhere this
is an issue when we need to avoid instrumentation; if that's not a
concern here on any path then I am not aware of a functional issue.
> > Can we follow the pattern we have for arm64_ftr_reg_ctrel0, and have a
> > arm64_ftr_reg_id_aa64pfr0_el1 that we can address directly here?
>
> I mean, clearly its possible, but based on what data?
>
> > That said. I reckon this could be much cleaner if we maintained separate
> > caps:
> >
> > ARM64_ALL_CPUS_HAVE_32BIT_EL0
> > ARM64_SOME_CPUS_HAVE_32BIT_EL0
> >
> > ... and allow arm64_mismatched_32bit_el0 to be set dependent on
> > ARM64_SOME_CPUS_HAVE_32BIT_EL0. With that, this can be simplified to:
> >
> > static inline bool system_supports_32bit_el0(void)
> > {
> > return (cpus_have_const_cap(ARM64_ALL_CPUS_HAVE_32BIT_EL0)) ||
> > static_branch_unlikely(&arm64_mismatched_32bit_el0))
>
> Something similar was discussed in November last year but this falls
> apart with late onlining because its not generally possible to tell whether
> you've seen all the CPUs or not.
Ah; is that for when your boot CPU set is all AArch32-capable, but a
late-onlined CPU is not?
I assume that we require at least one of the set of boot CPUs to be
AArch32 cpable, and don't settle the compat hwcaps after userspace has
started.
> I'm mostly reluctant to make significant changes based on cosmetic
> preferences because testing and debugging this with all the system
> combinations is really difficult.
Fair enough.
> > > +{
> > > + static bool boot_cpu_32bit_regs_overridden = false;
> > > +
> > > + if (!allow_mismatched_32bit_el0 || boot_cpu_32bit_regs_overridden)
> > > + return;
> > > +
> > > + if (id_aa64pfr0_32bit_el0(boot->reg_id_aa64pfr0))
> > > + return;
> > > +
> > > + boot->aarch32 = info->aarch32;
> > > + init_32bit_cpu_features(&boot->aarch32);
> > > + boot_cpu_32bit_regs_overridden = true;
> > > +}
> >
> > Can't we share this with the boot CPU path if we do:
> >
> > /*
> > * Initialize the common AArch32 features on the first CPU with AArch32.
> > */
> > static void lazy_init_32bit_el0_cpu_features(struct cpuinfo_arm64 *info,
> > struct cpuinfo_arm64 *boot)
> > {
> > static bool initialised = false;
> > if (initialised || !id_aa64pfr0_32bit_el0(info->reg_id_aa64pfr0))
> > return;
> >
> > boot->aarch32 = info->aarch32;
> > init_32bit_cpu_features(&boot->aarch32);
> > initiaised = true;
> > }
> >
> > ... or is the allow_mismatched_32bit_el0 check necessary for late
> > hotplug?
>
> Interesting. I think this works, but I'm wary that it results in the
> 32-bit features of a 64-bit-only boot CPU being populated using the first
> 32-bit-capable CPU even if we're not running with allow_mismatched_32bit_el0
> enabled. That feels like setting ourselves up for future bugs. For example,
> compat_has_neon() would unexpectedly return true even though 32-bit execve()
> would be forbidden.
Sure; I had not considered that case.
Thanks,
Mark.
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists•infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
next prev parent reply other threads:[~2021-06-04 9:40 UTC|newest]
Thread overview: 48+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-06-02 16:47 [PATCH v8 00/19] Add support for 32-bit tasks on asymmetric AArch32 systems Will Deacon
2021-06-02 16:47 ` [PATCH v8 01/19] arm64: cpuinfo: Split AArch32 registers out into a separate struct Will Deacon
2021-06-03 12:38 ` Mark Rutland
2021-06-03 17:24 ` Will Deacon
2021-06-02 16:47 ` [PATCH v8 02/19] arm64: Allow mismatched 32-bit EL0 support Will Deacon
2021-06-03 12:37 ` Mark Rutland
2021-06-03 17:44 ` Will Deacon
2021-06-04 9:38 ` Mark Rutland [this message]
2021-06-04 11:05 ` Will Deacon
2021-06-04 12:04 ` Mark Rutland
2021-06-04 13:50 ` Will Deacon
2021-06-02 16:47 ` [PATCH v8 03/19] KVM: arm64: Kill 32-bit vCPUs on systems with mismatched " Will Deacon
2021-06-02 16:47 ` [PATCH v8 04/19] arm64: Kill 32-bit applications scheduled on 64-bit-only CPUs Will Deacon
2021-06-02 16:47 ` [PATCH v8 05/19] sched: Introduce task_cpu_possible_mask() to limit fallback rq selection Will Deacon
2021-06-04 17:10 ` Valentin Schneider
2021-06-07 17:04 ` Will Deacon
2021-06-02 16:47 ` [PATCH v8 06/19] cpuset: Don't use the cpu_possible_mask as a last resort for cgroup v1 Will Deacon
2021-06-04 17:11 ` Valentin Schneider
2021-06-07 17:20 ` Will Deacon
2021-06-10 10:20 ` Valentin Schneider
2021-06-02 16:47 ` [PATCH v8 07/19] cpuset: Honour task_cpu_possible_mask() in guarantee_online_cpus() Will Deacon
2021-06-04 17:11 ` Valentin Schneider
2021-06-02 16:47 ` [PATCH v8 08/19] sched: Reject CPU affinity changes based on task_cpu_possible_mask() Will Deacon
2021-06-04 17:11 ` Valentin Schneider
2021-06-07 22:43 ` Will Deacon
2021-06-02 16:47 ` [PATCH v8 09/19] sched: Introduce task_struct::user_cpus_ptr to track requested affinity Will Deacon
2021-06-04 17:12 ` Valentin Schneider
2021-06-02 16:47 ` [PATCH v8 10/19] sched: Split the guts of sched_setaffinity() into a helper function Will Deacon
2021-06-04 17:12 ` Valentin Schneider
2021-06-02 16:47 ` [PATCH v8 11/19] sched: Allow task CPU affinity to be restricted on asymmetric systems Will Deacon
2021-06-04 17:12 ` Valentin Schneider
2021-06-07 22:52 ` Will Deacon
2021-06-10 10:20 ` Valentin Schneider
2021-06-02 16:47 ` [PATCH v8 12/19] sched: Introduce task_cpus_dl_admissible() to check proposed affinity Will Deacon
2021-06-03 9:43 ` Daniel Bristot de Oliveira
2021-06-03 9:52 ` Will Deacon
2021-06-02 16:47 ` [PATCH v8 13/19] arm64: Implement task_cpu_possible_mask() Will Deacon
2021-06-02 16:47 ` [PATCH v8 14/19] arm64: exec: Adjust affinity for compat tasks with mismatched 32-bit EL0 Will Deacon
2021-06-03 9:45 ` Daniel Bristot de Oliveira
2021-06-02 16:47 ` [PATCH v8 15/19] arm64: Prevent offlining first CPU with 32-bit EL0 on mismatched system Will Deacon
2021-06-03 12:58 ` Mark Rutland
2021-06-03 17:40 ` Will Deacon
2021-06-04 9:49 ` Mark Rutland
2021-06-04 12:14 ` Qais Yousef
2021-06-02 16:47 ` [PATCH v8 16/19] arm64: Advertise CPUs capable of running 32-bit applications in sysfs Will Deacon
2021-06-02 16:47 ` [PATCH v8 17/19] arm64: Hook up cmdline parameter to allow mismatched 32-bit EL0 Will Deacon
2021-06-02 16:47 ` [PATCH v8 18/19] arm64: Remove logic to kill 32-bit tasks on 64-bit-only cores Will Deacon
2021-06-02 16:47 ` [PATCH v8 19/19] Documentation: arm64: describe asymmetric 32-bit support Will Deacon
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=20210604093808.GA64162@C02TD0UTHF1T.local \
--to=mark.rutland@arm$(echo .)com \
--cc=bristot@redhat$(echo .)com \
--cc=catalin.marinas@arm$(echo .)com \
--cc=dietmar.eggemann@arm$(echo .)com \
--cc=gregkh@linuxfoundation$(echo .)org \
--cc=hannes@cmpxchg$(echo .)org \
--cc=juri.lelli@redhat$(echo .)com \
--cc=kernel-team@android$(echo .)com \
--cc=linux-arch@vger$(echo .)kernel.org \
--cc=linux-arm-kernel@lists$(echo .)infradead.org \
--cc=linux-kernel@vger$(echo .)kernel.org \
--cc=maz@kernel$(echo .)org \
--cc=mingo@redhat$(echo .)com \
--cc=morten.rasmussen@arm$(echo .)com \
--cc=peterz@infradead$(echo .)org \
--cc=qais.yousef@arm$(echo .)com \
--cc=qperret@google$(echo .)com \
--cc=rjw@rjwysocki$(echo .)net \
--cc=surenb@google$(echo .)com \
--cc=tj@kernel$(echo .)org \
--cc=valentin.schneider@arm$(echo .)com \
--cc=vincent.guittot@linaro$(echo .)org \
--cc=will@kernel$(echo .)org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
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