On 18/12/2015 11:37, Mauro Carvalho Chehab wrote: > Em Thu, 17 Dec 2015 17:48:57 +0100 > Mason <slash.tmp@xxxxxxx> escreveu: > >> On 17/12/2015 17:09, Mauro Carvalho Chehab wrote: >>> Em Thu, 17 Dec 2015 16:32:54 +0100 >>> Mason <slash.tmp@xxxxxxx> escreveu: >>> >>>> I wanted to fix the NEED_WRITEL_RELAXED warning, but I don't know Perl. >>>> >>>> v4l/scripts/make_config_compat.pl >>>> >>>> check_files_for_func("writel_relaxed", "NEED_WRITEL_RELAXED", "include/asm-generic/io.h"); >>>> incorrectly outputs >>>> #define NEED_WRITEL_RELAXED 1 >>>> >>>> >>>> In file included from <command-line>:0:0: >>>> /tmp/sandbox/media_build/v4l/compat.h:1568:0: warning: "writel_relaxed" redefined >>>> #define writel_relaxed writel >>>> ^ >>>> In file included from include/linux/scatterlist.h:10:0, >>>> from /tmp/sandbox/media_build/v4l/compat.h:1255, >>>> from <command-line>:0: >>>> /tmp/sandbox/custom-linux-3.4/arch/arm/include/asm/io.h:235:0: note: this is the location of the previous definition >>>> #define writel_relaxed(v,c) ((void)__raw_writel((__force u32) \ >>>> ^ >>>> >>>> Shouldn't the script examine arch/$ARCH/include/asm/io.h instead of >>>> include/asm-generic/io.h ? (Or perhaps both?) >>>> >>>> Does make_config_compat.pl know about ARCH? >>> >>> No to both. When you do a "make init" on the Kernel repository, it >>> will evaluate the ARCH vars. >>> >>> This is also needed for the media build to work, as it needs to >>> check what CONFIG vars are enabled on the targeted Kernel. >> >> I downloaded the vanilla version of my custom kernel: linux-3.4.39.tar.xz >> >> Even then, NEED_WRITEL_RELAXED is incorrectly defined. > > did you run a: > make allmodconfig > make init > > for the vanilla version? Without that, the symlinks won't appear. /tmp/sandbox/linux-3.4.39$ make allmodconfig scripts/kconfig/conf --allmodconfig Kconfig # # configuration written to .config # /tmp/sandbox/linux-3.4.39$ make menuconfig scripts/kconfig/mconf Kconfig .config:25:warning: symbol value '' invalid for PHYS_OFFSET # # configuration written to .config # *** End of the configuration. *** Execute 'make' to start the build or try 'make help'. /tmp/sandbox/linux-3.4.39$ make init scripts/kconfig/conf --silentoldconfig Kconfig CHK include/linux/version.h CHK include/generated/utsrelease.h make[1]: `include/generated/mach-types.h' is up to date. CC kernel/bounds.s GEN include/generated/bounds.h CC arch/arm/kernel/asm-offsets.s GEN include/generated/asm-offsets.h CALL scripts/checksyscalls.sh CC scripts/mod/empty.o MKELF scripts/mod/elfconfig.h HOSTCC scripts/mod/file2alias.o HOSTCC scripts/mod/modpost.o HOSTCC scripts/mod/sumversion.o HOSTLD scripts/mod/modpost HOSTCC scripts/selinux/genheaders/genheaders HOSTCC scripts/selinux/mdp/mdp CC init/main.o CHK include/generated/compile.h UPD include/generated/compile.h CC init/version.o CC init/do_mounts.o CC init/do_mounts_initrd.o LD init/mounts.o CC init/initramfs.o CC init/calibrate.o LD init/built-in.o cd ../media_build/linux make tar DIR=/tmp/sandbox/media_tree make untar cd .. make release DIR=/tmp/sandbox/linux-3.4.39 make make -C ../linux apply_patches make[2]: Entering directory `/tmp/sandbox/media_build/linux' Patches for 3.4.39. already applied. make[2]: Leaving directory `/tmp/sandbox/media_build/linux' make -C /tmp/sandbox/linux-3.4.39 SUBDIRS=/tmp/sandbox/media_build/v4l modules make[2]: Entering directory `/tmp/sandbox/linux-3.4.39' CC [M] /tmp/sandbox/media_build/v4l/altera-lpt.o In file included from <command-line>:0:0: /tmp/sandbox/media_build/v4l/compat.h:1568:0: warning: "writel_relaxed" redefined #define writel_relaxed writel ^ In file included from include/linux/scatterlist.h:10:0, from /tmp/sandbox/media_build/v4l/compat.h:1255, from <command-line>:0: /tmp/sandbox/linux-3.4.39/arch/arm/include/asm/io.h:235:0: note: this is the location of the previous definition #define writel_relaxed(v,c) ((void)__raw_writel((__force u32) \ ^ $ grep -rn NEED_WRITEL_RELAXED v4l/compat.h:1567:#ifdef NEED_WRITEL_RELAXED v4l/scripts/make_config_compat.pl:667: check_files_for_func("writel_relaxed", "NEED_WRITEL_RELAXED", "include/asm-generic/io.h"); v4l/config-compat.h:1888:#define NEED_WRITEL_RELAXED 1 -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html