From: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
To: "Maciej W. Rozycki" <macro@orcam.me.uk>
Cc: Nick Bowler <nbowler@draconx.ca>,
Jiaxun Yang <jiaxun.yang@flygoat.com>,
linux-mips@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH] MIPS: mm: Prevent a TLB shutdown on initial uniquification
Date: Tue, 11 Nov 2025 13:27:06 +0100 [thread overview]
Message-ID: <aRMrmjJcLJYR8QO-@alpha.franken.de> (raw)
In-Reply-To: <alpine.DEB.2.21.2511110547430.25436@angie.orcam.me.uk>
On Tue, Nov 11, 2025 at 06:21:46AM +0000, Maciej W. Rozycki wrote:
> Depending on the particular CPU implementation a TLB shutdown may occur
> if multiple matching entries are detected upon the execution of a TLBP
> or the TLBWI/TLBWR instructions. Given that we don't know what entries
> we have been handed we need to be very careful with the initial TLB
> setup and avoid all these instructions.
>
> Therefore read all the TLB entries one by one with the TLBR instruction,
> bypassing the content addressing logic, and preinitialize the TLB using
> addresses outside our usual unique range and avoiding clashes with any
> incoming contents before making the usual call to local_flush_tlb_all().
>
> This fixes (at least) R4x00 cores if TLBP hits multiple matching TLB
> entries (SGI IP22 PROM for examples sets up all TLBs to the same virtual
> address).
>
> Signed-off-by: Maciej W. Rozycki <macro@orcam.me.uk>
> Fixes: 35ad7e181541 ("MIPS: mm: tlb-r4k: Uniquify TLB entries on init")
> Cc: stable@vger.kernel.org # v6.17+
> ---
> Hi,
>
> I have verified this lightly, also with some diagnostics added so as to
> make sure things get set up correctly, with my Malta/74Kf system for a
> 32-bit configuration and with my SWARM/BCM1250 system for a 64-bit one.
> Sadly the latter box does not finish booting either way, but it's to be
> bisected separately.
>
> Can you please give it a try with your systems?
it's booting on my R4400 SGI Indy, but I see a lot of segmentation
faults during system start. If I comment out r4k_tlb_uniquify() every-
thing boots fine, which is kind of strange as there is a local_flush_tlb_all(),
which should leave the TLB in the same stage.... No idea why, yet.
> arch/mips/mm/tlb-r4k.c | 92 +++++++++++++++++++++++++++++--------------------
> 1 file changed, 55 insertions(+), 37 deletions(-)
>
> linux-mips-tlb-r4k-uniquify-fix.diff
> Index: linux-macro/arch/mips/mm/tlb-r4k.c
> ===================================================================
> --- linux-macro.orig/arch/mips/mm/tlb-r4k.c
> +++ linux-macro/arch/mips/mm/tlb-r4k.c
> @@ -15,6 +15,7 @@
> #include <linux/mm.h>
> #include <linux/hugetlb.h>
> #include <linux/export.h>
> +#include <linux/sort.h>
>
> #include <asm/cpu.h>
> #include <asm/cpu-type.h>
> @@ -508,54 +509,70 @@ static int __init set_ntlb(char *str)
>
> __setup("ntlb=", set_ntlb);
>
> -/* Initialise all TLB entries with unique values */
> +
> +/* Comparison function for EntryHi VPN fields. */
> +static int r4k_vpn_cmp(const void *a, const void *b)
> +{
> + return ((*(unsigned long *)a - *(unsigned long *)b) >>
> + (sizeof(unsigned long) - sizeof(int)) * 8);
> +}
> +
> +/*
> + * Initialise all TLB entries with unique values that do not clash with
> + * what we have been handed over and what we'll be using ourselves.
> + */
> static void r4k_tlb_uniquify(void)
> {
> - int entry = num_wired_entries();
> + unsigned long tlb_vpns[1 << MIPS_CONF1_TLBS_SIZE];
> + int tlbsize = current_cpu_data.tlbsize;
> + int start = num_wired_entries();
> + unsigned long vpn_mask;
> + int cnt, ent, idx, i;
> +
> + vpn_mask = GENMASK(cpu_vmbits - 1, 13);
> + vpn_mask |= IS_ENABLED(CONFIG_64BIT) ? 3ULL << 62 : 1 << 31;
>
> htw_stop();
> +
> + for (i = start, cnt = 0; i < tlbsize; i++, cnt++) {
shouldn't we read all TLB entries here ?
Thomas.
--
Crap can work. Given enough thrust pigs will fly, but it's not necessarily a
good idea. [ RFC1925, 2.3 ]
next prev parent reply other threads:[~2025-11-11 12:27 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-11-11 6:21 [PATCH] MIPS: mm: Prevent a TLB shutdown on initial uniquification Maciej W. Rozycki
2025-11-11 12:27 ` Thomas Bogendoerfer [this message]
2025-11-11 15:41 ` Maciej W. Rozycki
2025-11-11 22:53 ` Thomas Bogendoerfer
2025-11-12 9:56 ` Thomas Bogendoerfer
2025-11-12 12:16 ` Maciej W. Rozycki
2025-11-12 14:20 ` Thomas Bogendoerfer
2025-11-12 23:47 ` Maciej W. Rozycki
2025-11-11 22:17 ` Nick Bowler
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=aRMrmjJcLJYR8QO-@alpha.franken.de \
--to=tsbogend@alpha.franken.de \
--cc=jiaxun.yang@flygoat.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mips@vger.kernel.org \
--cc=macro@orcam.me.uk \
--cc=nbowler@draconx.ca \
/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: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.