Excessive TLB flush ranges
Thomas Gleixner
tglx at linutronix.de
Tue May 16 01:18:36 PDT 2023
On Tue, May 16 2023 at 08:37, Thomas Gleixner wrote:
> On Mon, May 15 2023 at 22:31, Russell King wrote:
>>> + list_for_each_entry(va, list, list) {
>>> + /* flush range by one by one 'invlpg' */
>>> + for (addr = va->va_start; addr < va->va_end; addr += PAGE_SIZE)
>>> + flush_tlb_one_kernel(addr);
>>
>> Isn't this just the same as:
>> flush_tlb_kernel_range(va->va_start, va->va_end);
>
> Indeed.
Actually not. At least not on x86 where it'd end up with 3 IPIs for that
case again, instead of having one which walks the list on each CPU.
Thanks,
tglx
More information about the linux-arm-kernel
mailing list