Excessive TLB flush ranges
Thomas Gleixner
tglx at linutronix.de
Tue May 16 01:20:37 PDT 2023
On Tue, May 16 2023 at 10:18, Thomas Gleixner wrote:
> 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.
ARM32 has the same problem when tlb_ops_need_broadcast() is true.
Thanks,
tglx
More information about the linux-arm-kernel
mailing list