2019-07-13 11:17:51 +02:00
|
|
|
# This is the root Kconfig
|
|
|
|
KCONFIG ?= $(RIOTBASE)/Kconfig
|
|
|
|
|
|
|
|
# Include tools targets
|
|
|
|
include $(RIOTMAKE)/tools/kconfiglib.inc.mk
|
|
|
|
|
2020-07-29 16:22:23 +02:00
|
|
|
# Include fixdep tool
|
|
|
|
include $(RIOTMAKE)/tools/fixdep.inc.mk
|
|
|
|
|
2019-07-13 11:17:51 +02:00
|
|
|
# Generated dir will contain Kconfig generated configurations
|
|
|
|
GENERATED_DIR = $(BINDIR)/generated
|
|
|
|
|
2020-07-28 19:43:09 +02:00
|
|
|
# The sync dir will contain a tree of header files that represent Kconfig symbols
|
2020-07-29 16:22:23 +02:00
|
|
|
export KCONFIG_SYNC_DIR = $(GENERATED_DIR)/deps
|
2020-07-28 19:43:09 +02:00
|
|
|
|
2019-07-13 11:17:51 +02:00
|
|
|
# This file will contain all generated configuration from kconfig
|
|
|
|
export KCONFIG_GENERATED_AUTOCONF_HEADER_C = $(GENERATED_DIR)/autoconf.h
|
|
|
|
|
|
|
|
# Header for the generated header file
|
|
|
|
define KCONFIG_AUTOHEADER_HEADER
|
2020-01-03 13:28:12 +01:00
|
|
|
$(if $(filter MINGW% CYGWIN% MSYS%,$(OS)),/)/* RIOT Configuration File */
|
2019-07-13 11:17:51 +02:00
|
|
|
|
|
|
|
endef
|
|
|
|
export KCONFIG_AUTOHEADER_HEADER
|
|
|
|
|
|
|
|
# This file will contain the calculated dependencies formated in Kconfig
|
|
|
|
export KCONFIG_GENERATED_DEPENDENCIES = $(GENERATED_DIR)/Kconfig.dep
|
|
|
|
|
|
|
|
# This file will contain application default configurations
|
|
|
|
KCONFIG_APP_CONFIG = $(APPDIR)/app.config
|
|
|
|
|
|
|
|
# Default and user overwritten configurations
|
|
|
|
KCONFIG_USER_CONFIG = $(APPDIR)/user.config
|
|
|
|
|
2020-02-18 14:17:12 +01:00
|
|
|
# This is the output of the generated configuration. It always mirrors the
|
|
|
|
# content of KCONFIG_GENERATED_AUTOCONF_HEADER_C, and it is used to load
|
|
|
|
# configuration symbols to the build system.
|
|
|
|
KCONFIG_OUT_CONFIG = $(GENERATED_DIR)/out.config
|
|
|
|
|
2020-08-07 09:28:30 +02:00
|
|
|
# This file is generated by the GENCONFIG tool. It is similar to the .d
|
|
|
|
# files generated by GCC, and the idea is the same. We want to re-trigger the
|
|
|
|
# generation of KCONFIG_OUT_CONFIG and KCONFIG_GENERATED_AUTOCONF_HEADER_C
|
|
|
|
# whenever a change occurs on one of the previously used Kconfig files.
|
|
|
|
KCONFIG_OUT_DEP = $(KCONFIG_OUT_CONFIG).d
|
|
|
|
|
2020-07-30 14:46:01 +02:00
|
|
|
# Include configuration symbols if available. This allows to check for Kconfig
|
|
|
|
# symbols in makefiles. Make tries to 'remake' all included files (see
|
|
|
|
# https://www.gnu.org/software/make/manual/html_node/Remaking-Makefiles.html).
|
|
|
|
-include $(KCONFIG_OUT_CONFIG)
|
2019-12-06 19:40:09 +01:00
|
|
|
|
2019-07-13 11:17:51 +02:00
|
|
|
# Add configurations to merge, in ascendent priority (i.e. a file overrides the
|
2020-07-30 14:35:07 +02:00
|
|
|
# previous ones).
|
2019-07-13 11:17:51 +02:00
|
|
|
MERGE_SOURCES += $(wildcard $(KCONFIG_APP_CONFIG))
|
|
|
|
MERGE_SOURCES += $(wildcard $(KCONFIG_USER_CONFIG))
|
|
|
|
|
|
|
|
# Create directory to place generated files
|
2020-07-30 14:35:07 +02:00
|
|
|
$(GENERATED_DIR): $(if $(MAKE_RESTARTS),,$(CLEAN))
|
2019-07-13 11:17:51 +02:00
|
|
|
$(Q)mkdir -p $@
|
|
|
|
|
2019-12-18 09:39:34 +01:00
|
|
|
# During migration this checks if Kconfig should run. It will run if any of
|
|
|
|
# the following is true:
|
|
|
|
# - A file with '.config' extension is present in the application directory
|
|
|
|
# - A 'Kconfig' file is present in the application directory
|
|
|
|
# - A previous configuration file is present (e.g. from a previous call to
|
|
|
|
# menuconfig)
|
|
|
|
# - menuconfig is being called
|
|
|
|
#
|
|
|
|
# NOTE: This assumes that Kconfig will not generate any default configurations
|
|
|
|
# just from the Kconfig files outside the application folder (i.e. module
|
|
|
|
# configuration via Kconfig is disabled by default). Should this change, the
|
|
|
|
# check would not longer be valid, and Kconfig would have to run on every
|
|
|
|
# build.
|
2020-08-07 09:28:30 +02:00
|
|
|
SHOULD_RUN_KCONFIG ?= $(or $(wildcard $(APPDIR)/*.config), \
|
|
|
|
$(wildcard $(APPDIR)/Kconfig), \
|
|
|
|
$(if $(CLEAN),,$(wildcard $(KCONFIG_OUT_CONFIG))), \
|
|
|
|
$(filter menuconfig, $(MAKECMDGOALS)))
|
2019-12-18 09:39:34 +01:00
|
|
|
|
2020-07-29 16:22:23 +02:00
|
|
|
# export variable to make it visible in other Makefiles
|
|
|
|
export SHOULD_RUN_KCONFIG
|
2020-07-28 19:43:09 +02:00
|
|
|
|
2020-07-29 16:22:23 +02:00
|
|
|
ifneq (,$(SHOULD_RUN_KCONFIG))
|
2020-07-28 19:43:09 +02:00
|
|
|
|
2019-12-18 09:39:34 +01:00
|
|
|
# Add configuration header to build dependencies
|
2020-07-29 16:22:23 +02:00
|
|
|
BUILDDEPS += $(KCONFIG_GENERATED_AUTOCONF_HEADER_C) $(FIXDEP)
|
2019-12-18 09:39:34 +01:00
|
|
|
|
|
|
|
# Include configuration header when building
|
2020-08-07 09:28:30 +02:00
|
|
|
CFLAGS += -imacros '$(KCONFIG_GENERATED_AUTOCONF_HEADER_C)'
|
2019-12-18 09:39:34 +01:00
|
|
|
|
2019-12-13 15:21:16 +01:00
|
|
|
USEMODULE_W_PREFIX = $(addprefix MODULE_,$(USEMODULE))
|
|
|
|
USEPKG_W_PREFIX = $(addprefix PKG_,$(USEPKG))
|
|
|
|
|
2020-08-07 09:28:30 +02:00
|
|
|
.PHONY: menuconfig
|
|
|
|
|
|
|
|
# Opens the menuconfig interface for configuration of modules using the Kconfig
|
|
|
|
# system. It will try to update the autoconf.h, which will update if needed
|
|
|
|
# (i.e. out.config changed).
|
|
|
|
menuconfig: $(MENUCONFIG) $(KCONFIG_OUT_CONFIG)
|
|
|
|
$(Q)KCONFIG_CONFIG=$(KCONFIG_OUT_CONFIG) $(MENUCONFIG) $(KCONFIG)
|
|
|
|
$(MAKE) $(KCONFIG_GENERATED_AUTOCONF_HEADER_C)
|
|
|
|
|
|
|
|
# These rules are not included when only calling `make clean` in
|
|
|
|
# order to keep the $(BINDIR) directory clean.
|
|
|
|
ifneq (clean, $(MAKECMDGOALS))
|
|
|
|
|
2019-12-13 15:21:16 +01:00
|
|
|
# Build a Kconfig file defining all used modules and packages. This is done by
|
|
|
|
# defining symbols like 'MODULE_<MODULE_NAME>' or PKG_<PACKAGE_NAME> which
|
|
|
|
# default to 'y'. Then, every module and package Kconfig menu will depend on
|
|
|
|
# that symbol being set to show its options.
|
2019-07-13 11:17:51 +02:00
|
|
|
$(KCONFIG_GENERATED_DEPENDENCIES): FORCE | $(GENERATED_DIR)
|
2019-12-13 15:21:16 +01:00
|
|
|
$(Q)printf "%s " $(USEMODULE_W_PREFIX) $(USEPKG_W_PREFIX) \
|
2019-07-13 11:17:51 +02:00
|
|
|
| awk 'BEGIN {RS=" "}{ gsub("-", "_", $$0); \
|
2019-12-13 15:21:16 +01:00
|
|
|
printf "config %s\n\tbool\n\tdefault y\n", toupper($$0)}' \
|
2019-07-13 11:17:51 +02:00
|
|
|
| $(LAZYSPONGE) $(LAZYSPONGE_FLAGS) $@
|
|
|
|
|
2020-08-07 09:28:30 +02:00
|
|
|
# Generates a .config file by merging multiple sources specified in
|
|
|
|
# MERGE_SOURCES. This will also generate KCONFIG_OUT_DEP with the list of used
|
|
|
|
# Kconfig files.
|
|
|
|
$(KCONFIG_OUT_CONFIG): $(KCONFIG_GENERATED_DEPENDENCIES) $(GENCONFIG) $(MERGE_SOURCES) | $(GENERATED_DIR)
|
|
|
|
$(Q) $(GENCONFIG) \
|
|
|
|
--config-out=$(KCONFIG_OUT_CONFIG) \
|
|
|
|
--file-list $(KCONFIG_OUT_DEP) \
|
|
|
|
--kconfig-filename $(KCONFIG) \
|
|
|
|
--config-sources $(MERGE_SOURCES) && \
|
|
|
|
touch $(KCONFIG_OUT_CONFIG)
|
2019-07-13 11:17:51 +02:00
|
|
|
|
2020-08-07 09:28:30 +02:00
|
|
|
endif # eq (clean, $(MAKECMDGOALS))
|
2020-07-30 14:35:07 +02:00
|
|
|
|
2020-08-07 09:28:30 +02:00
|
|
|
# Generates the configuration header file which holds the same information
|
|
|
|
# as KCONFIG_OUT_CONFIG, and is used to inject the configurations during
|
|
|
|
# compilation.
|
|
|
|
#
|
2020-07-29 16:22:23 +02:00
|
|
|
# This will generate the 'dummy' header files needed for incremental builds.
|
2020-08-07 09:28:30 +02:00
|
|
|
$(KCONFIG_GENERATED_AUTOCONF_HEADER_C): $(KCONFIG_OUT_CONFIG)
|
|
|
|
$(Q) $(GENCONFIG) \
|
2020-07-28 19:43:09 +02:00
|
|
|
--header-path $(KCONFIG_GENERATED_AUTOCONF_HEADER_C) \
|
2020-07-29 16:22:23 +02:00
|
|
|
--sync-deps $(KCONFIG_SYNC_DIR) \
|
2020-08-07 09:28:30 +02:00
|
|
|
--kconfig-filename $(KCONFIG) \
|
|
|
|
--config-sources $(KCONFIG_OUT_CONFIG) && \
|
|
|
|
touch $(KCONFIG_GENERATED_AUTOCONF_HEADER_C)
|
|
|
|
|
|
|
|
# Try to load the list of Kconfig files used
|
|
|
|
-include $(KCONFIG_OUT_DEP)
|
2020-07-30 14:46:01 +02:00
|
|
|
|
|
|
|
endif
|