xref: /rk3399_rockchip-uboot/scripts/Makefile.autoconf (revision f32c86493822174e27f4b3c7c9359094406afbd8)
151148790SMasahiro Yamada# This helper makefile is used for creating
251148790SMasahiro Yamada#  - symbolic links (arch/$ARCH/include/asm/arch
351148790SMasahiro Yamada#  - include/autoconf.mk, {spl,tpl}/include/autoconf.mk
451148790SMasahiro Yamada#  - include/config.h
551148790SMasahiro Yamada#
651148790SMasahiro Yamada# When our migration to Kconfig is done
751148790SMasahiro Yamada# (= When we move all CONFIGs from header files to Kconfig)
851148790SMasahiro Yamada# this makefile can be deleted.
9*f32c8649STom Rini#
10*f32c8649STom Rini# SPDX-License-Identifier:	GPL-2.0
11*f32c8649STom Rini#
1251148790SMasahiro Yamada
13e02ee254SMasahiro Yamada__all: include/autoconf.mk include/autoconf.mk.dep
14e02ee254SMasahiro Yamada
15e02ee254SMasahiro Yamadaifeq ($(shell grep -q '^CONFIG_SPL=y' include/config/auto.conf 2>/dev/null && echo y),y)
16e02ee254SMasahiro Yamada__all: spl/include/autoconf.mk
17e02ee254SMasahiro Yamadaendif
18e02ee254SMasahiro Yamada
19e02ee254SMasahiro Yamadaifeq ($(shell grep -q '^CONFIG_TPL=y' include/config/auto.conf 2>/dev/null && echo y),y)
20e02ee254SMasahiro Yamada__all: tpl/include/autoconf.mk
21e02ee254SMasahiro Yamadaendif
22e02ee254SMasahiro Yamada
23e02ee254SMasahiro Yamadainclude include/config/auto.conf
2451148790SMasahiro Yamada
2551148790SMasahiro Yamadainclude scripts/Kbuild.include
2651148790SMasahiro Yamada
2751148790SMasahiro Yamada# Need to define CC and CPP again here in case the top Makefile did not
2851148790SMasahiro Yamada# include config.mk.  Some architectures expect CROSS_COMPILE to be defined
2951148790SMasahiro Yamada# in arch/$(ARCH)/config.mk
3051148790SMasahiro YamadaCC		= $(CROSS_COMPILE)gcc
3151148790SMasahiro YamadaCPP		= $(CC) -E
3251148790SMasahiro Yamada
3351148790SMasahiro Yamadainclude config.mk
3451148790SMasahiro Yamada
3551148790SMasahiro YamadaUBOOTINCLUDE    := \
3651148790SMasahiro Yamada		-Iinclude \
3751148790SMasahiro Yamada		$(if $(KBUILD_SRC), -I$(srctree)/include) \
3851148790SMasahiro Yamada		-I$(srctree)/arch/$(ARCH)/include \
3951148790SMasahiro Yamada		-include $(srctree)/include/linux/kconfig.h
4051148790SMasahiro Yamada
4151148790SMasahiro Yamadac_flags := $(KBUILD_CFLAGS) $(KBUILD_CPPFLAGS) $(PLATFORM_CPPFLAGS) \
4251148790SMasahiro Yamada					$(UBOOTINCLUDE) $(NOSTDINC_FLAGS)
4351148790SMasahiro Yamada
4451148790SMasahiro Yamadaquiet_cmd_autoconf_dep = GEN     $@
4551148790SMasahiro Yamada      cmd_autoconf_dep = $(CC) -x c -DDO_DEPS_ONLY -M -MP $(c_flags) \
4651148790SMasahiro Yamada	-MQ include/config/auto.conf $(srctree)/include/common.h > $@ || {	\
4751148790SMasahiro Yamada		rm $@; false;							\
4851148790SMasahiro Yamada	}
4951148790SMasahiro Yamadainclude/autoconf.mk.dep: FORCE
5051148790SMasahiro Yamada	$(call cmd,autoconf_dep)
5151148790SMasahiro Yamada
5251148790SMasahiro Yamada# We are migrating from board headers to Kconfig little by little.
5351148790SMasahiro Yamada# In the interim, we use both of
5451148790SMasahiro Yamada#  - include/config/auto.conf (generated by Kconfig)
5551148790SMasahiro Yamada#  - include/autoconf.mk      (used in the U-Boot conventional configuration)
5651148790SMasahiro Yamada# The following rule creates autoconf.mk
5751148790SMasahiro Yamada# include/config/auto.conf is grepped in order to avoid duplication of the
5851148790SMasahiro Yamada# same CONFIG macros
5951148790SMasahiro Yamadaquiet_cmd_autoconf = GEN     $@
6051148790SMasahiro Yamada      cmd_autoconf = \
61e02ee254SMasahiro Yamada	$(CPP) $(c_flags) $2 -DDO_DEPS_ONLY -dM $(srctree)/include/common.h > $@.tmp && { \
6251148790SMasahiro Yamada		sed -n -f $(srctree)/tools/scripts/define2mk.sed $@.tmp |		\
6351148790SMasahiro Yamada		while read line; do							\
647740f653SJoe Hershberger			if [ -n "${KCONFIG_IGNORE_DUPLICATES}" ] ||			\
657740f653SJoe Hershberger			   ! grep -q "$${line%=*}=" include/config/auto.conf; then	\
6651148790SMasahiro Yamada				echo "$$line";						\
6751148790SMasahiro Yamada			fi								\
6851148790SMasahiro Yamada		done > $@;								\
6951148790SMasahiro Yamada		rm $@.tmp;								\
7051148790SMasahiro Yamada	} || {										\
7151148790SMasahiro Yamada		rm $@.tmp; false;							\
7251148790SMasahiro Yamada	}
7351148790SMasahiro Yamada
74e02ee254SMasahiro Yamadainclude/autoconf.mk: FORCE
7551148790SMasahiro Yamada	$(call cmd,autoconf)
7651148790SMasahiro Yamada
77e02ee254SMasahiro Yamadaspl/include/autoconf.mk: FORCE
78e02ee254SMasahiro Yamada	$(Q)mkdir -p $(dir $@)
79e02ee254SMasahiro Yamada	$(call cmd,autoconf,-DCONFIG_SPL_BUILD)
80e02ee254SMasahiro Yamada
81e02ee254SMasahiro Yamadatpl/include/autoconf.mk: FORCE
82e02ee254SMasahiro Yamada	$(Q)mkdir -p $(dir $@)
83e02ee254SMasahiro Yamada	$(call cmd,autoconf,-DCONFIG_SPL_BUILD -DCONFIG_TPL_BUILD)
84e02ee254SMasahiro Yamada
85e02ee254SMasahiro Yamadainclude/autoconf.mk include/autoconf.mk.dep \
86e02ee254SMasahiro Yamada	spl/include/autoconf.mk tpl/include/autoconf.mk: include/config.h
8751148790SMasahiro Yamada
8851148790SMasahiro Yamada# include/config.h
8951148790SMasahiro Yamada# Prior to Kconfig, it was generated by mkconfig. Now it is created here.
9051148790SMasahiro Yamadadefine filechk_config_h
9151148790SMasahiro Yamada	(echo "/* Automatically generated - do not edit */";		\
9251148790SMasahiro Yamada	for i in $$(echo $(CONFIG_SYS_EXTRA_OPTIONS) | sed 's/,/ /g'); do \
9351148790SMasahiro Yamada		echo \#define CONFIG_$$i				\
9451148790SMasahiro Yamada		| sed '/=/ {s/=/	/;q; } ; { s/$$/	1/; }'; \
9551148790SMasahiro Yamada	done;								\
9651148790SMasahiro Yamada	echo \#define CONFIG_BOARDDIR board/$(if $(VENDOR),$(VENDOR)/)$(BOARD);\
9751148790SMasahiro Yamada	echo \#include \<config_defaults.h\>;				\
98e02ee254SMasahiro Yamada	echo \#include \<config_uncmd_spl.h\>;				\
9951148790SMasahiro Yamada	echo \#include \<configs/$(CONFIG_SYS_CONFIG_NAME).h\>;		\
10051148790SMasahiro Yamada	echo \#include \<asm/config.h\>;				\
101e02ee254SMasahiro Yamada	echo \#include \<config_fallbacks.h\>;)
10251148790SMasahiro Yamadaendef
10351148790SMasahiro Yamada
10451148790SMasahiro Yamadainclude/config.h: scripts/Makefile.autoconf create_symlink FORCE
10551148790SMasahiro Yamada	$(call filechk,config_h)
10651148790SMasahiro Yamada
10751148790SMasahiro Yamada# symbolic links
1080e7368c6SMasahiro Yamada# If arch/$(ARCH)/mach-$(SOC)/include/mach exists,
1090e7368c6SMasahiro Yamada# make a symbolic link to that directory.
1100e7368c6SMasahiro Yamada# Otherwise, create a symbolic link to arch/$(ARCH)/include/asm/arch-$(SOC).
11151148790SMasahiro YamadaPHONY += create_symlink
11251148790SMasahiro Yamadacreate_symlink:
113a350c6a6SMasahiro Yamadaifdef CONFIG_CREATE_ARCH_SYMLINK
11451148790SMasahiro Yamadaifneq ($(KBUILD_SRC),)
11551148790SMasahiro Yamada	$(Q)mkdir -p include/asm
1160e7368c6SMasahiro Yamada	$(Q)if [ -d $(KBUILD_SRC)/arch/$(ARCH)/mach-$(SOC)/include/mach ]; then	\
1170e7368c6SMasahiro Yamada		dest=arch/$(ARCH)/mach-$(SOC)/include/mach;			\
1180e7368c6SMasahiro Yamada	else									\
1190e7368c6SMasahiro Yamada		dest=arch/$(ARCH)/include/asm/arch-$(if $(SOC),$(SOC),$(CPU));	\
1200e7368c6SMasahiro Yamada	fi;									\
1210e7368c6SMasahiro Yamada	ln -fsn $(KBUILD_SRC)/$$dest include/asm/arch
122ffe29ebcSMasahiro Yamadaelse
1230e7368c6SMasahiro Yamada	$(Q)if [ -d arch/$(ARCH)/mach-$(SOC)/include/mach ]; then	\
1240e7368c6SMasahiro Yamada		dest=../../mach-$(SOC)/include/mach;			\
1250e7368c6SMasahiro Yamada	else								\
1260e7368c6SMasahiro Yamada		dest=arch-$(if $(SOC),$(SOC),$(CPU));			\
1270e7368c6SMasahiro Yamada	fi;								\
1280e7368c6SMasahiro Yamada	ln -fsn $$dest arch/$(ARCH)/include/asm/arch
12951148790SMasahiro Yamadaendif
130a350c6a6SMasahiro Yamadaendif
13151148790SMasahiro Yamada
13251148790SMasahiro YamadaPHONY += FORCE
13351148790SMasahiro YamadaFORCE:
13451148790SMasahiro Yamada
13551148790SMasahiro Yamada.PHONY: $(PHONY)
136