[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <87o9755jy2.fsf@concordia.ellerman.id.au>
Date: Fri, 22 Feb 2019 00:51:01 +1100
From: Michael Ellerman <mpe@...erman.id.au>
To: Christophe Leroy <christophe.leroy@....fr>,
Benjamin Herrenschmidt <benh@...nel.crashing.org>,
Paul Mackerras <paulus@...ba.org>, j.neuschaefer@....net
Cc: linux-kernel@...r.kernel.org, linuxppc-dev@...ts.ozlabs.org
Subject: Re: [PATCH v4 04/16] powerpc/mm/32s: use generic mmu_mapin_ram() for all blocks.
Christophe Leroy <christophe.leroy@....fr> writes:
> Now that mmu_mapin_ram() is able to handle other blocks
> than the one starting at 0, the WII can use it for all
> its blocks.
>
> Signed-off-by: Christophe Leroy <christophe.leroy@....fr>
> ---
> arch/powerpc/mm/pgtable_32.c | 27 +++++++++------------------
> 1 file changed, 9 insertions(+), 18 deletions(-)
>
> diff --git a/arch/powerpc/mm/pgtable_32.c b/arch/powerpc/mm/pgtable_32.c
> index b4858818523f..2bf9bf8867d4 100644
> --- a/arch/powerpc/mm/pgtable_32.c
> +++ b/arch/powerpc/mm/pgtable_32.c
> @@ -254,26 +254,17 @@ static void __init __mapin_ram_chunk(unsigned long offset, unsigned long top)
>
> void __init mapin_ram(void)
> {
> - unsigned long s, top;
> -
> -#ifndef CONFIG_WII
> - top = total_lowmem;
> - s = mmu_mapin_ram(0, top);
> - __mapin_ram_chunk(s, top);
> -#else
> - if (!wii_hole_size) {
> - s = mmu_mapin_ram(0, total_lowmem);
> - __mapin_ram_chunk(s, total_lowmem);
> - } else {
> - top = wii_hole_start;
> - s = mmu_mapin_ram(0, top);
> - __mapin_ram_chunk(s, top);
> + struct memblock_region *reg;
> +
> + for_each_memblock(memory, reg) {
> + unsigned long base = reg->base;
> + unsigned long top = min(base + reg->size, (unsigned long)total_lowmem);
This gives me:
In file included from ../arch/powerpc/mm/pgtable_32.c:22:
../arch/powerpc/mm/pgtable_32.c: In function ‘mapin_ram’:
../include/linux/kernel.h:846:29: error: comparison of distinct pointer types lacks a cast [-Werror]
(!!(sizeof((typeof(x) *)1 == (typeof(y) *)1)))
^~
../include/linux/kernel.h:860:4: note: in expansion of macro ‘__typecheck’
(__typecheck(x, y) && __no_side_effects(x, y))
^~~~~~~~~~~
../include/linux/kernel.h:870:24: note: in expansion of macro ‘__safe_cmp’
__builtin_choose_expr(__safe_cmp(x, y), \
^~~~~~~~~~
../include/linux/kernel.h:879:19: note: in expansion of macro ‘__careful_cmp’
#define min(x, y) __careful_cmp(x, y, <)
^~~~~~~~~~~~~
../arch/powerpc/mm/pgtable_32.c:261:23: note: in expansion of macro ‘min’
unsigned long top = min(base + reg->size, (unsigned long)total_lowmem);
^~~
cc1: all warnings being treated as errors
../scripts/Makefile.build:276: recipe for target 'arch/powerpc/mm/pgtable_32.o' failed
For 44x/bamboo_defconfig.
cheers
Powered by blists - more mailing lists