On Mon, 2014-11-03 at 20:21 +0530, Aneesh Kumar K.V wrote:
> upatepp get called for a nohpte fault, when we find from the linux
> page table that the translation was hashed before. In that case
> we are sure that there is no existing translation, hence we could
> avoid doing tlbie.

We are sure there *was* no existing translation. It's possible that since the
nohpte fault occurred the translation has been loaded into the tlb.

Ben says that's OK, because updatepp is only ever relaxing permissions. But
please add some explanation of that to the changelog - it's not obvious.

> @@ -322,8 +322,15 @@ static long native_hpte_updatepp(unsigned long slot, 
> unsigned long newpp,
>               }
>               native_unlock_hpte(hptep);
>       }
> -     /* Ensure it is out of the tlb too. */
> -     tlbie(vpn, bpsize, apsize, ssize, local);
> +
> +     if (flags & HPTE_LOCAL_UPDATE)
> +             local = 1;
> +     /*
> +      * Ensure it is out of the tlb too if it is not a nohpte fault
> +      */
> +     if (!(flags & HPTE_NOHPTE_UPDATE))
> +             tlbie(vpn, bpsize, apsize, ssize, local);
> +
>       return ret;
>  }

The context preceeding this hunk includes this comment:

        /*
         * We need to invalidate the TLB always because hpte_remove doesn't do
         * a tlb invalidate. If a hash bucket gets full, we "evict" a more/less
         * random entry from it. When we do that we don't invalidate the TLB
         * (hpte_remove) because we assume the old translation is still
         * technically "valid".
         */

Which seems out of sync with the code now.

cheers



_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to