mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
707ad8d083
If the generated configuration file is present include it. That way one can check if certain symbols are being configured using Kconfig.
105 lines
4.1 KiB
Makefile
105 lines
4.1 KiB
Makefile
# This is the root Kconfig
|
|
KCONFIG ?= $(RIOTBASE)/Kconfig
|
|
|
|
# Include tools targets
|
|
include $(RIOTMAKE)/tools/kconfiglib.inc.mk
|
|
|
|
# Generated dir will contain Kconfig generated configurations
|
|
GENERATED_DIR = $(BINDIR)/generated
|
|
|
|
# This file will contain all generated configuration from kconfig
|
|
export KCONFIG_GENERATED_AUTOCONF_HEADER_C = $(GENERATED_DIR)/autoconf.h
|
|
|
|
# Add configuration header to build dependencies
|
|
BUILDDEPS += $(KCONFIG_GENERATED_AUTOCONF_HEADER_C)
|
|
|
|
# Include configuration header when building
|
|
CFLAGS += -include '$(KCONFIG_GENERATED_AUTOCONF_HEADER_C)'
|
|
|
|
# Header for the generated header file
|
|
define KCONFIG_AUTOHEADER_HEADER
|
|
/* RIOT Configuration File */
|
|
|
|
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
|
|
|
|
# This file will contain merged configurations from MERGE_SOURCES and is the
|
|
# one that is used to generate the 'riotconf.h' header
|
|
KCONFIG_MERGED_CONFIG = $(GENERATED_DIR)/merged.config
|
|
|
|
# Include configuration symbols if available, only when not cleaning. 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).
|
|
# So if this file was included even when 'clean' is called, make would enter a
|
|
# loop, as it always is out-of-date.
|
|
# This has the side effect of requiring a Kconfig user to run 'clean' on a
|
|
# separate call (e.g. 'make clean && make all'), to get the symbols correctly.
|
|
ifneq ($(CLEAN),clean)
|
|
-include $(KCONFIG_MERGED_CONFIG)
|
|
endif
|
|
|
|
# Flag that indicates that the configuration has been edited
|
|
KCONFIG_EDITED_CONFIG = $(GENERATED_DIR)/.editedconfig
|
|
|
|
# Add configurations to merge, in ascendent priority (i.e. a file overrides the
|
|
# previous ones)
|
|
MERGE_SOURCES += $(wildcard $(KCONFIG_APP_CONFIG))
|
|
MERGE_SOURCES += $(wildcard $(KCONFIG_USER_CONFIG))
|
|
|
|
# Create directory to place generated files
|
|
$(GENERATED_DIR): $(CLEAN)
|
|
$(Q)mkdir -p $@
|
|
|
|
USEMODULE_W_PREFIX = $(addprefix MODULE_,$(USEMODULE))
|
|
USEPKG_W_PREFIX = $(addprefix PKG_,$(USEPKG))
|
|
|
|
# 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.
|
|
$(KCONFIG_GENERATED_DEPENDENCIES): FORCE | $(GENERATED_DIR)
|
|
$(Q)printf "%s " $(USEMODULE_W_PREFIX) $(USEPKG_W_PREFIX) \
|
|
| awk 'BEGIN {RS=" "}{ gsub("-", "_", $$0); \
|
|
printf "config %s\n\tbool\n\tdefault y\n", toupper($$0)}' \
|
|
| $(LAZYSPONGE) $(LAZYSPONGE_FLAGS) $@
|
|
|
|
.PHONY: menuconfig
|
|
|
|
# Opens the menuconfig interface for configuration of modules using the Kconfig
|
|
# system.
|
|
menuconfig: $(MENUCONFIG) $(KCONFIG_MERGED_CONFIG) $(KCONFIG_EDITED_CONFIG)
|
|
$(Q)KCONFIG_CONFIG=$(KCONFIG_MERGED_CONFIG) $(MENUCONFIG) $(KCONFIG)
|
|
|
|
# Marks that the configuration file has been edited via some interface, such as
|
|
# menuconfig
|
|
$(KCONFIG_EDITED_CONFIG): FORCE
|
|
$(Q)touch $(KCONFIG_EDITED_CONFIG)
|
|
|
|
# Generates a merged configuration file from the given sources. If the config
|
|
# file has been edited a '.editedconfig' file will be present.
|
|
# This is used to decide if the sources have to be merged or not.
|
|
$(KCONFIG_MERGED_CONFIG): $(MERGECONFIG) $(KCONFIG_GENERATED_DEPENDENCIES) FORCE
|
|
$(Q)\
|
|
if ! test -f $(KCONFIG_EDITED_CONFIG); then \
|
|
if ! test -z "$(strip $(MERGE_SOURCES))"; then \
|
|
$(MERGECONFIG) $(KCONFIG) $@ $(MERGE_SOURCES); \
|
|
else \
|
|
rm -f $@; \
|
|
fi \
|
|
fi
|
|
|
|
# Build a header file with all the Kconfig configurations. genconfig will avoid
|
|
# any unnecessary rewrites of the header file if no configurations changed.
|
|
$(KCONFIG_GENERATED_AUTOCONF_HEADER_C): $(KCONFIG_GENERATED_DEPENDENCIES) $(GENCONFIG) $(KCONFIG_MERGED_CONFIG) FORCE
|
|
$(Q)KCONFIG_CONFIG=$(KCONFIG_MERGED_CONFIG) $(GENCONFIG) --header-path $@ $(KCONFIG)
|