# git rev-parse -q --verify 6a86fe746e2f69e49328b9ad8ad0f840c467ee59^{commit} 6a86fe746e2f69e49328b9ad8ad0f840c467ee59 already have revision, skipping fetch # git checkout -q -f -B kisskb 6a86fe746e2f69e49328b9ad8ad0f840c467ee59 # git clean -qxdf # < git log -1 # commit 6a86fe746e2f69e49328b9ad8ad0f840c467ee59 # Author: Michael Ellerman # Date: Thu Feb 18 23:30:58 2021 +1100 # # powerpc/4xx: Fix build errors from mfdcr() # # lkp reported a build error in fsp2.o: # # CC arch/powerpc/platforms/44x/fsp2.o # {standard input}:577: Error: unsupported relocation against base # # Which comes from: # # pr_err("GESR0: 0x%08x\n", mfdcr(base + PLB4OPB_GESR0)); # # Where our mfdcr() macro is stringifying "base + PLB4OPB_GESR0", and # passing that to the assembler, which obviously doesn't work. # # The mfdcr() macro already checks that the argument is constant using # __builtin_constant_p(), and if not calls the out-of-line version of # mfdcr(). But in this case GCC is smart enough to notice that "base + # PLB4OPB_GESR0" will be constant, even though it's not something we can # immediately stringify into a register number. # # Segher pointed out that passing the register number to the inline asm # as a constant would be better, and in fact it fixes the build error, # presumably because it gives GCC a chance to resolve the value. # # While we're at it, change mtdcr() similarly. # # Reported-by: kernel test robot # Suggested-by: Segher Boessenkool # Signed-off-by: Michael Ellerman # Acked-by: Feng Tang # Link: https://lore.kernel.org/r/20210218123058.748882-1-mpe@ellerman.id.au # < /opt/cross/kisskb/korg/gcc-4.9.4-nolibc/powerpc64-linux/bin/powerpc64-linux-gcc --version # < /opt/cross/kisskb/korg/gcc-4.9.4-nolibc/powerpc64-linux/bin/powerpc64-linux-ld --version # < git log --format=%s --max-count=1 6a86fe746e2f69e49328b9ad8ad0f840c467ee59 # < make -s -j 24 ARCH=powerpc O=/kisskb/build/powerpc-fixes_mpc85xx_defconfig_powerpc-gcc4.9 CROSS_COMPILE=/opt/cross/kisskb/korg/gcc-4.9.4-nolibc/powerpc64-linux/bin/powerpc64-linux- mpc85xx_defconfig # < make -s -j 24 ARCH=powerpc O=/kisskb/build/powerpc-fixes_mpc85xx_defconfig_powerpc-gcc4.9 CROSS_COMPILE=/opt/cross/kisskb/korg/gcc-4.9.4-nolibc/powerpc64-linux/bin/powerpc64-linux- help # make -s -j 24 ARCH=powerpc O=/kisskb/build/powerpc-fixes_mpc85xx_defconfig_powerpc-gcc4.9 CROSS_COMPILE=/opt/cross/kisskb/korg/gcc-4.9.4-nolibc/powerpc64-linux/bin/powerpc64-linux- olddefconfig # make -s -j 24 ARCH=powerpc O=/kisskb/build/powerpc-fixes_mpc85xx_defconfig_powerpc-gcc4.9 CROSS_COMPILE=/opt/cross/kisskb/korg/gcc-4.9.4-nolibc/powerpc64-linux/bin/powerpc64-linux- In file included from /kisskb/src/include/linux/kernel.h:10:0, from /kisskb/src/include/linux/list.h:9, from /kisskb/src/include/linux/module.h:12, from /kisskb/src/drivers/net/ethernet/freescale/fs_enet/mac-scc.c:15: /kisskb/src/drivers/net/ethernet/freescale/fs_enet/mac-scc.c: In function 'allocate_bd': /kisskb/src/include/linux/err.h:22:49: warning: cast to pointer from integer of different size [-Wint-to-pointer-cast] #define IS_ERR_VALUE(x) unlikely((unsigned long)(void *)(x) >= (unsigned long)-MAX_ERRNO) ^ /kisskb/src/include/linux/compiler.h:78:42: note: in definition of macro 'unlikely' # define unlikely(x) __builtin_expect(!!(x), 0) ^ /kisskb/src/drivers/net/ethernet/freescale/fs_enet/mac-scc.c:139:6: note: in expansion of macro 'IS_ERR_VALUE' if (IS_ERR_VALUE(fep->ring_mem_addr)) ^ /kisskb/src/arch/powerpc/boot/dts/fsl/mpc8541cds.dts:330.3-21: Warning (pci_device_bus_num): /pci@e0008000/i8259@19000:bus-range: PCI bus number 1 out of range, expected (0 - 0) /kisskb/src/arch/powerpc/boot/dts/fsl/mpc8555cds.dts:330.3-21: Warning (pci_device_bus_num): /pci@e0008000/i8259@19000:bus-range: PCI bus number 1 out of range, expected (0 - 0) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd59a64) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) INFO: Uncompressed kernel (size 0xd49338) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0xe00000) Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:34 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6490917 Bytes = 6338.79 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e002a4 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:34 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6489280 Bytes = 6337.19 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e00314 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:34 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6458428 Bytes = 6307.06 KiB = 6.16 MiB Load Address: 00000000 Entry Point: 00000000 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:34 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6489206 Bytes = 6337.12 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e00314 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:35 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6489207 Bytes = 6337.12 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e00314 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:35 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6489341 Bytes = 6337.25 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e002a4 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:35 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6489202 Bytes = 6337.11 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e002a4 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:35 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6489242 Bytes = 6337.15 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e00314 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:35 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6492681 Bytes = 6340.51 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e002a4 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:35 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6489266 Bytes = 6337.17 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e002a4 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:35 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6489352 Bytes = 6337.26 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e00314 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:35 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6489145 Bytes = 6337.06 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e002a4 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:35 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6490497 Bytes = 6338.38 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e002a4 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:36 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6492281 Bytes = 6340.12 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e002a4 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:36 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6489266 Bytes = 6337.17 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e002a4 Image Name: Linux-5.11.0-g6a86fe746e2f Created: Tue Feb 23 17:10:36 2021 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 6489262 Bytes = 6337.17 KiB = 6.19 MiB Load Address: 00e00000 Entry Point: 00e002a4 Completed OK # rm -rf /kisskb/build/powerpc-fixes_mpc85xx_defconfig_powerpc-gcc4.9 # Build took: 0:02:39.698328