linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v1 0/3] Initial BBML2 support for contpte_convert()
@ 2025-02-19 14:38 Mikołaj Lenczewski
  2025-02-19 14:38 ` [PATCH v1 1/3] arm64: Add BBM Level 2 cpu feature Mikołaj Lenczewski
                   ` (2 more replies)
  0 siblings, 3 replies; 14+ messages in thread
From: Mikołaj Lenczewski @ 2025-02-19 14:38 UTC (permalink / raw)
  To: ryan.roberts, yang, catalin.marinas, will, joey.gouly, broonie,
	mark.rutland, james.morse, yangyicong, robin.murphy,
	anshuman.khandual, maz, liaochang1, akpm, david, baohua,
	ioworker0, oliver.upton, linux-arm-kernel, linux-kernel
  Cc: Mikołaj Lenczewski

Hi All,

This patch series adds adding initial support for eliding
break-before-make requirements on systems that support BBML2 and
additionally guarantee to never raise a conflict abort.

This support reorders and optionally elides a TLB invalidation in
contpte_convert(). The elision of said invalidation leads to a 12%
improvement when executing a microbenchmark designed to force the
pathological path where contpte_convert() gets called. This
represents an 80% reduction in the cost of calling contpte_convert().

However, even without the elision, the reodering represents a
performance improvement due to reducing thread contention, as there is
a smaller time window for racing threads to see an invalid pagetable
entry (especially if they already have a cached entry in their TLB
that they are working off of).

This series is based on v6.14-rc3 (0ad2507d5d93).

Patch 1 implements an allow-list of cpus that support BBML2, but with
the additional constraint of never causing TLB conflict aborts. We
settled on this constraint because we will use the feature for kernel
mappings in the future, for which we cannot handle conflict aborts
safely.

Yang Shi has a series at [1] that aims to use BBML2 to enable splitting
the linear map at runtime. This series partially overlaps with it to add
the cpu feature. We beleive this series is fully compatible with Yang's
requirements and could go first, given there is still a lot of discussion
around the best way to manage the mechanics of splitting/collapsing the
linear map.

[1]:
  https://lore.kernel.org/linux-arm-kernel/20250103011822.1257189-1-yang@os.amperecomputing.com/

Mikołaj Lenczewski (3):
  arm64: Add BBM Level 2 cpu feature
  arm64/mm: Delay tlbi in contpte_convert() under BBML2
  arm64/mm: Elide tlbi in contpte_convert() under BBML2

 arch/arm64/Kconfig                  |  9 ++++++++
 arch/arm64/include/asm/cpufeature.h |  5 +++++
 arch/arm64/kernel/cpufeature.c      | 32 +++++++++++++++++++++++++++++
 arch/arm64/mm/contpte.c             |  3 ++-
 arch/arm64/tools/cpucaps            |  1 +
 5 files changed, 49 insertions(+), 1 deletion(-)

-- 
2.45.3



^ permalink raw reply	[flat|nested] 14+ messages in thread

end of thread, other threads:[~2025-02-20 20:03 UTC | newest]

Thread overview: 14+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-02-19 14:38 [PATCH v1 0/3] Initial BBML2 support for contpte_convert() Mikołaj Lenczewski
2025-02-19 14:38 ` [PATCH v1 1/3] arm64: Add BBM Level 2 cpu feature Mikołaj Lenczewski
2025-02-19 15:39   ` Robin Murphy
2025-02-19 15:43     ` Ryan Roberts
2025-02-19 16:25       ` Robin Murphy
2025-02-20  9:33         ` Mikołaj Lenczewski
2025-02-19 23:34   ` Oliver Upton
2025-02-19 23:57     ` Oliver Upton
2025-02-20  9:37       ` Mikołaj Lenczewski
2025-02-20  1:25   ` Yang Shi
2025-02-20 10:34     ` Mikołaj Lenczewski
2025-02-20 20:01       ` Yang Shi
2025-02-19 14:38 ` [PATCH v1 2/3] arm64/mm: Delay tlbi in contpte_convert() under BBML2 Mikołaj Lenczewski
2025-02-19 14:38 ` [PATCH v1 3/3] arm64/mm: Elide " Mikołaj Lenczewski

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).