Reza Arbab <ar...@linux.vnet.ibm.com> writes:

> When setting a 2M pte, radix__map_kernel_page() is using the address
>
>       ptep = (pte_t *)pudp;
>
> Fix this conversion to use pmdp instead. Use pmdp_ptep() to do this
> instead of casting the pointer.
>

Reviewed-by: Aneesh Kumar K.V <aneesh.ku...@linux.vnet.ibm.com>

> Signed-off-by: Reza Arbab <ar...@linux.vnet.ibm.com>
> ---
>  arch/powerpc/mm/pgtable-radix.c | 4 ++--
>  1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/arch/powerpc/mm/pgtable-radix.c b/arch/powerpc/mm/pgtable-radix.c
> index cfa53cc..34f1a0d 100644
> --- a/arch/powerpc/mm/pgtable-radix.c
> +++ b/arch/powerpc/mm/pgtable-radix.c
> @@ -65,7 +65,7 @@ int radix__map_kernel_page(unsigned long ea, unsigned long 
> pa,
>               if (!pmdp)
>                       return -ENOMEM;
>               if (map_page_size == PMD_SIZE) {
> -                     ptep = (pte_t *)pudp;
> +                     ptep = pmdp_ptep(pmdp);
>                       goto set_the_pte;
>               }
>               ptep = pte_alloc_kernel(pmdp, ea);
> @@ -90,7 +90,7 @@ int radix__map_kernel_page(unsigned long ea, unsigned long 
> pa,
>               }
>               pmdp = pmd_offset(pudp, ea);
>               if (map_page_size == PMD_SIZE) {
> -                     ptep = (pte_t *)pudp;
> +                     ptep = pmdp_ptep(pmdp);
>                       goto set_the_pte;
>               }
>               if (!pmd_present(*pmdp)) {
> -- 
> 1.8.3.1

Reply via email to