PowerPC fixes 5.1-3: CONFIG_SPARSEMEM doesn't exist in the kernel source code
Christian Zigotzky
chzigotzky at xenosoft.de
Mon Mar 25 23:23:26 AEDT 2019
I was able to activate CONFIG_SPARSEMEM in the kernel configuration. But
does the P.A. Semi Nemo board need this option?
-- Christian
On 25 March 2019 at 12:00PM, Christian Zigotzky wrote:
> Hi All,
>
> I wasn't able to compile the RC2 today because of the following error
> messages:
>
> CC arch/powerpc/mm/slb.o
> In file included from ./arch/powerpc/include/asm/book3s/64/mmu.h:39:0,
> from ./arch/powerpc/include/asm/mmu.h:360,
> from ./arch/powerpc/include/asm/lppaca.h:36,
> from ./arch/powerpc/include/asm/paca.h:21,
> from ./arch/powerpc/include/asm/current.h:16,
> from ./include/linux/thread_info.h:21,
> from ./include/asm-generic/preempt.h:5,
> from ./arch/powerpc/include/generated/asm/preempt.h:1,
> from ./include/linux/preempt.h:78,
> from ./include/linux/spinlock.h:51,
> from ./include/linux/mmzone.h:8,
> from ./include/linux/gfp.h:6,
> from ./include/linux/mm.h:10,
> from ./arch/powerpc/include/asm/cacheflush.h:12,
> from ./arch/powerpc/include/asm/asm-prototypes.h:16,
> from arch/powerpc/mm/slb.c:17:
> ./arch/powerpc/include/asm/book3s/64/mmu-hash.h:584:6: warning:
> "MAX_PHYSMEM_BITS" is not defined [-Wundef]
> #if (MAX_PHYSMEM_BITS > MAX_EA_BITS_PER_CONTEXT)
> ^
> arch/powerpc/mm/slb.c: In function 'slb_allocate_kernel':
> arch/powerpc/mm/slb.c:697:37: error: 'MAX_PHYSMEM_BITS' undeclared
> (first use in this function)
> if ((ea & ~REGION_MASK) > (1UL << MAX_PHYSMEM_BITS))
> ^
> arch/powerpc/mm/slb.c:697:37: note: each undeclared identifier is
> reported only once for each function it appears in
> scripts/Makefile.build:278: recipe for target 'arch/powerpc/mm/slb.o'
> failed
> make[3]: *** [arch/powerpc/mm/slb.o] Error 1
> scripts/Makefile.build:489: recipe for target 'arch/powerpc/mm' failed
> make[2]: *** [arch/powerpc/mm] Error 2
> /home/christian/Downloads/a/Makefile:1046: recipe for target
> 'arch/powerpc' failed
> make[1]: *** [arch/powerpc] Error 2
> Makefile:170: recipe for target 'sub-make' failed
> make: *** [sub-make] Error 2
>
> -----
>
> The variable MAX_PHYSMEM_BITS isn't defined. The problem is in the
> last PowerPC fixes 5.1-3:
> https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?h=v5.1-rc2&id=a5ed1e96cafde5ba48638f486bfca0685dc6ddc9
>
> Commit log: powerpc/mm: Only define MAX_PHYSMEM_BITS in SPARSEMEM
> configurations
>
> Problematic fix:
>
> diff --git a/arch/powerpc/include/asm/mmu.h
> b/arch/powerpc/include/asm/mmu.h
> index d34ad1657d7b..598cdcdd1355 100644
> --- a/arch/powerpc/include/asm/mmu.h
> +++ b/arch/powerpc/include/asm/mmu.h
> @@ -352,7 +352,7 @@ static inline bool strict_kernel_rwx_enabled(void)
> #if defined(CONFIG_SPARSEMEM_VMEMMAP) &&
> defined(CONFIG_SPARSEMEM_EXTREME) && \
> defined (CONFIG_PPC_64K_PAGES)
> #define MAX_PHYSMEM_BITS 51
> -#else
> +#elif defined(CONFIG_SPARSEMEM)
> #define MAX_PHYSMEM_BITS 46
> #endif
>
> The first if statement isn't successfull because the variables
> CONFIG_SPARSEMEM_EXTREME and CONFIG_PPC_64K_PAGES aren't activated in
> our kernel configuration. Therefore we need MAX_PHYSMEM_BITS 46 for
> our Nemo board. Unfortunately CONFIG_SPARSEMEM doesn't exist in the
> kernel source code so we can't activate it in the kernel config.
>
> I replaced '#elif defined(CONFIG_SPARSEMEM)' with '#else' and after
> that the compiling of the RC2 works again.
>
> Please check if CONFIG_SPARSEMEM exists.
>
> Thanks,
> Christian
More information about the Linuxppc-dev
mailing list