Nicholas Piggin <npig...@gmail.com> writes:
> Excerpts from Aneesh Kumar K.V's message of May 13, 2020 1:06 pm:
>> With a 64K page size flush with start and end value as below
>> (start, end) = (721f680d0000, 721f680e0000) results in
>> (hstart, hend) = (721f68200000, 721f68000000)
>> 
>> Avoid doing a __tlbie_va_range with the wrong hstart and hend value in this
>> case.
>> 
>> __tlbie_va_range will skip the actual tlbie operation for start > end.
>> But we still end up doing the tlbie fixup.
>
> Hm, good catch.
>
>> Reported-by: Bharata B Rao <bhar...@linux.ibm.com>
>> Signed-off-by: Aneesh Kumar K.V <aneesh.ku...@linux.ibm.com>
>> ---
>>  arch/powerpc/mm/book3s64/radix_tlb.c | 6 +++---
>>  1 file changed, 3 insertions(+), 3 deletions(-)
>> 
>> diff --git a/arch/powerpc/mm/book3s64/radix_tlb.c 
>> b/arch/powerpc/mm/book3s64/radix_tlb.c
>> index 758ade2c2b6e..d592f9e1c037 100644
>> --- a/arch/powerpc/mm/book3s64/radix_tlb.c
>> +++ b/arch/powerpc/mm/book3s64/radix_tlb.c
>> @@ -884,10 +884,10 @@ static inline void __radix__flush_tlb_range(struct 
>> mm_struct *mm,
>>              if (IS_ENABLED(CONFIG_TRANSPARENT_HUGEPAGE)) {
>>                      hstart = (start + PMD_SIZE - 1) & PMD_MASK;
>>                      hend = end & PMD_MASK;
>> -                    if (hstart == hend)
>> -                            hflush = false;
>> -                    else
>> +                    if (hstart < hend)
>>                              hflush = true;
>> +                    else
>> +                            hflush = false;
>
> We can probably get rid of the else part since it is already false.

Yeah I can do that when applying.

cheers

Reply via email to