powerpc: Fix build break due to paca mm_context_t changes
authorMichael Ellerman <mpe@ellerman.id.au>
Fri, 8 Jan 2016 21:25:01 +0000 (08:25 +1100)
committerMichael Ellerman <mpe@ellerman.id.au>
Fri, 8 Jan 2016 21:28:44 +0000 (08:28 +1100)
Commit 2fc251a8dda5 ("powerpc: Copy only required pieces of the
mm_context_t to the paca") broke the build for CONFIG_PPC_STD_MMU_64=y
and CONFIG_PPC_MM_SLICES=n.

That only happens for a kernel built with 4K pages and HUGETLB disabled,
which is why we missed it.

Fix it by adding a mm_ctx_user_psize member to the paca and populating
it in the appropriate places.

Fixes: 2fc251a8dda5 ("powerpc: Copy only required pieces of the mm_context_t to the paca")
Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/include/asm/paca.h
arch/powerpc/mm/hash_utils_64.c

index ef78c288c712cedb623c6bbc2683dc4d6fee6d3e..546540b910959570cc34d8dfa040ee155885ae00 100644 (file)
@@ -138,6 +138,7 @@ struct paca_struct {
        u64 mm_ctx_low_slices_psize;
        unsigned char mm_ctx_high_slices_psize[SLICE_ARRAY_SIZE];
 #else
+       u16 mm_ctx_user_psize;
        u16 mm_ctx_sllp;
 #endif
 #endif
@@ -212,6 +213,7 @@ static inline void copy_mm_to_paca(mm_context_t *context)
        memcpy(&get_paca()->mm_ctx_high_slices_psize,
               &context->high_slices_psize, SLICE_ARRAY_SIZE);
 #else
+       get_paca()->mm_ctx_user_psize = context->user_psize;
        get_paca()->mm_ctx_sllp = context->sllp;
 #endif
 }
index db744576d730ee8ebeca9f9e9c061fd5678c81f7..ba59d5977f3498d4c9c4e42faeff5111f925d2a5 100644 (file)
@@ -866,7 +866,7 @@ static unsigned int get_paca_psize(unsigned long addr)
 #else
 unsigned int get_paca_psize(unsigned long addr)
 {
-       return get_paca()->context.user_psize;
+       return get_paca()->mm_ctx_user_psize;
 }
 #endif