1fe52b1f5SJerome Forissier# Generate/check/update a .h file to reflect the values of Makefile 2fe52b1f5SJerome Forissier# variables 3fe52b1f5SJerome Forissier# 4fe52b1f5SJerome Forissier# Example usage (by default, check-conf-h will consider all CFG_* 55ef74e73SJerome Forissier# and _CFG_* variables plus PLATFORM_*): 6fe52b1f5SJerome Forissier# 7fe52b1f5SJerome Forissier# path/to/conf.h: FORCE 8fe52b1f5SJerome Forissier# $(call check-conf-h) 9fe52b1f5SJerome Forissier# 10fe52b1f5SJerome Forissier# Or, to include only the variables with the given prefix(es): 11fe52b1f5SJerome Forissier# 12fe52b1f5SJerome Forissier# path/to/crypto_config.h: FORCE 13fe52b1f5SJerome Forissier# $(call check-conf-h,CFG_CRYPTO_ CRYPTO_) 14fe52b1f5SJerome Forissierdefine check-conf-h 15fe52b1f5SJerome Forissier $(q)set -e; \ 1662428631SJens Wiklander $(cmd-echo-silent) ' CHK $@'; \ 17bef37b8bSJerome Forissier cnf='$(strip $(foreach var, \ 18fe52b1f5SJerome Forissier $(call cfg-vars-by-prefix,$1), \ 19bef37b8bSJerome Forissier $(call cfg-make-define,$(var))))'; \ 2021c9a576SEtienne Carriere guard="_`echo $@ | tr -- -/.+ _`_"; \ 21fe52b1f5SJerome Forissier mkdir -p $(dir $@); \ 22fe52b1f5SJerome Forissier echo "#ifndef $${guard}" >$@.tmp; \ 23fe52b1f5SJerome Forissier echo "#define $${guard}" >>$@.tmp; \ 24fe52b1f5SJerome Forissier echo -n "$${cnf}" | sed 's/_nl_ */\n/g' >>$@.tmp; \ 25fe52b1f5SJerome Forissier echo "#endif" >>$@.tmp; \ 263354f9b2SJerome Forissier $(call mv-if-changed,$@.tmp,$@) 27fe52b1f5SJerome Forissierendef 28fe52b1f5SJerome Forissier 29b924c494SJens Wiklanderdefine check-conf-cmake 30b924c494SJens Wiklander $(q)set -e; \ 31b924c494SJens Wiklander $(cmd-echo-silent) ' CHK $@'; \ 32b924c494SJens Wiklander cnf='$(strip $(foreach var, \ 33b924c494SJens Wiklander $(call cfg-vars-by-prefix,$1), \ 34b924c494SJens Wiklander $(call cfg-cmake-set,$(var))))'; \ 35b924c494SJens Wiklander mkdir -p $(dir $@); \ 36b924c494SJens Wiklander echo "# auto-generated TEE configuration file" >$@.tmp; \ 37b924c494SJens Wiklander echo "# TEE version ${TEE_IMPL_VERSION}" >>$@.tmp; \ 38b924c494SJens Wiklander echo -n "$${cnf}" | sed 's/_nl_ */\n/g' >>$@.tmp; \ 39b924c494SJens Wiklander $(call mv-if-changed,$@.tmp,$@) 40b924c494SJens Wiklanderendef 41b924c494SJens Wiklander 423354f9b2SJerome Forissierdefine check-conf-mk 43dde0e235Setienne carriere $(q)set -e; \ 4462428631SJens Wiklander $(cmd-echo-silent) ' CHK $@'; \ 45bef37b8bSJerome Forissier cnf='$(strip $(foreach var, \ 46dde0e235Setienne carriere $(call cfg-vars-by-prefix,CFG_), \ 47bef37b8bSJerome Forissier $(strip $(var)=$($(var))_nl_)))'; \ 48dde0e235Setienne carriere mkdir -p $(dir $@); \ 49dde0e235Setienne carriere echo "# auto-generated TEE configuration file" >$@.tmp; \ 50b5569a68SPascal Brand echo "# TEE version ${TEE_IMPL_VERSION}" >>$@.tmp; \ 51dde0e235Setienne carriere echo "ARCH=${ARCH}" >>$@.tmp; \ 52dde0e235Setienne carriere echo "PLATFORM=${PLATFORM}" >>$@.tmp; \ 53dde0e235Setienne carriere echo "PLATFORM_FLAVOR=${PLATFORM_FLAVOR}" >>$@.tmp; \ 54dde0e235Setienne carriere echo -n "$${cnf}" | sed 's/_nl_ */\n/g' >>$@.tmp; \ 553354f9b2SJerome Forissier $(call mv-if-changed,$@.tmp,$@) 563354f9b2SJerome Forissierendef 573354f9b2SJerome Forissier 583354f9b2SJerome Forissier# Rename $1 to $2 only if file content differs. Otherwise just delete $1. 593354f9b2SJerome Forissierdefine mv-if-changed 603957863bSJerome Forissier if cmp -s $2 $1; then \ 613354f9b2SJerome Forissier rm -f $1; \ 623354f9b2SJerome Forissier else \ 6362428631SJens Wiklander $(cmd-echo-silent) ' UPD $2'; \ 643354f9b2SJerome Forissier mv $1 $2; \ 653354f9b2SJerome Forissier fi 66dde0e235Setienne carriereendef 67dde0e235Setienne carriere 68fe52b1f5SJerome Forissierdefine cfg-vars-by-prefix 69fe52b1f5SJerome Forissier $(strip $(if $(1),$(call _cfg-vars-by-prefix,$(1)), 705ef74e73SJerome Forissier $(call _cfg-vars-by-prefix,CFG_ _CFG_ PLATFORM_))) 71fe52b1f5SJerome Forissierendef 72fe52b1f5SJerome Forissier 73fe52b1f5SJerome Forissierdefine _cfg-vars-by-prefix 74fe52b1f5SJerome Forissier $(sort $(foreach prefix,$(1),$(filter $(prefix)%,$(.VARIABLES)))) 75fe52b1f5SJerome Forissierendef 76fe52b1f5SJerome Forissier 77fe52b1f5SJerome Forissier# Convert a makefile variable to a #define 78fe52b1f5SJerome Forissier# <undefined>, n => <undefined> 79fe52b1f5SJerome Forissier# y => 1 80fe52b1f5SJerome Forissier# <other value> => <other value> 81fe52b1f5SJerome Forissierdefine cfg-make-define 82fe52b1f5SJerome Forissier $(strip $(if $(filter y,$($1)), 83bef37b8bSJerome Forissier #define $1 1_nl_, 84fe52b1f5SJerome Forissier $(if $(filter xn x,x$($1)), 85bef37b8bSJerome Forissier /* $1 is not set */_nl_, 86bef37b8bSJerome Forissier #define $1 $($1)_nl_))) 87fe52b1f5SJerome Forissierendef 880a7f95b9SJerome Forissier 89b924c494SJens Wiklander# Convert a makefile variable to a cmake set statement 90b924c494SJens Wiklander# <undefined>, n => <undefined> 91b924c494SJens Wiklander# <other value> => <other value> 92b924c494SJens Wiklanderdefine cfg-cmake-set 93b924c494SJens Wiklander $(strip $(if $(filter xn x,x$($1)), 94b924c494SJens Wiklander # $1 is not set _nl_, 95b924c494SJens Wiklander set($1 $($1))_nl_)) 96b924c494SJens Wiklanderendef 97b924c494SJens Wiklander 98*9e8c816aSJerome Forissier# Returns 'y' if at least one variable is 'y', 'n' otherwise 990a7f95b9SJerome Forissier# Example: 1000a7f95b9SJerome Forissier# FOO_OR_BAR := $(call cfg-one-enabled, FOO BAR) 101*9e8c816aSJerome Forissiercfg-one-enabled = $(if $(filter y, $(foreach var,$(1),$($(var)))),y,n) 1020a7f95b9SJerome Forissier 103b2a75cd4SJerome Forissier# Returns 'y' if all variables are 'y', 'n' otherwise 1040a7f95b9SJerome Forissier# Example: 1050a7f95b9SJerome Forissier# FOO_AND_BAR := $(call cfg-all-enabled, FOO BAR) 106b2a75cd4SJerome Forissiercfg-all-enabled = $(if $(strip $(1)),$(if $(call _cfg-all-enabled,$(1)),y,n),n) 107b2a75cd4SJerome Forissier_cfg-all-enabled = \ 1080a7f95b9SJerome Forissier $(strip \ 1090a7f95b9SJerome Forissier $(if $(1), \ 1100a7f95b9SJerome Forissier $(if $(filter y,$($(firstword $(1)))), \ 111b2a75cd4SJerome Forissier $(call _cfg-all-enabled,$(filter-out $(firstword $(1)),$(1))), \ 1120a7f95b9SJerome Forissier ), \ 1130a7f95b9SJerome Forissier y \ 1140a7f95b9SJerome Forissier ) \ 1150a7f95b9SJerome Forissier ) 1160a7f95b9SJerome Forissier 1170a7f95b9SJerome Forissier# Disable a configuration variable if some dependency is disabled 1180a7f95b9SJerome Forissier# Example: 1190a7f95b9SJerome Forissier# $(eval $(call cfg-depends-all,FOO,BAR BAZ)) 1200a7f95b9SJerome Forissier# Will clear FOO if it is initially 'y' and BAR or BAZ are not 'y' 1210a7f95b9SJerome Forissiercfg-depends-all = \ 1220a7f95b9SJerome Forissier $(strip \ 1230a7f95b9SJerome Forissier $(if $(filter y, $($(1))), \ 124b2a75cd4SJerome Forissier $(if $(filter y,$(call cfg-all-enabled,$(2))), \ 1250a7f95b9SJerome Forissier , \ 1260a7f95b9SJerome Forissier $(warning Warning: Disabling $(1) [requires $(strip $(2))]) \ 1270a7f95b9SJerome Forissier override $(1) := \ 1280a7f95b9SJerome Forissier ) \ 1290a7f95b9SJerome Forissier ) \ 1300a7f95b9SJerome Forissier ) 1310a7f95b9SJerome Forissier 1320a7f95b9SJerome Forissier# Disable a configuration variable if all dependencies are disabled 1330a7f95b9SJerome Forissier# Example: 1340a7f95b9SJerome Forissier# $(eval $(call cfg-depends-one,FOO,BAR BAZ)) 1350a7f95b9SJerome Forissier# Will clear FOO if it is initially 'y' and both BAR and BAZ are not 'y' 1360a7f95b9SJerome Forissiercfg-depends-one = \ 1370a7f95b9SJerome Forissier $(strip \ 1380a7f95b9SJerome Forissier $(if $(filter y, $($(1))), \ 139*9e8c816aSJerome Forissier $(if $(filter y,$(call cfg-one-enabled,$(2))), \ 1400a7f95b9SJerome Forissier , \ 1410a7f95b9SJerome Forissier $(warning Warning: Disabling $(1) [requires (one of) $(strip $(2))]) \ 1420a7f95b9SJerome Forissier override $(1) := \ 1430a7f95b9SJerome Forissier ) \ 1440a7f95b9SJerome Forissier ) \ 1450a7f95b9SJerome Forissier ) 146a8224611SJames Kung 147a8224611SJames Kung 148a8224611SJames Kung# Enable all depend variables 149a8224611SJames Kung# Example: 150a8224611SJames Kung# $(eval $(call cfg-enable-all-depends,FOO,BAR BAZ)) 151a8224611SJames Kung# Will enable BAR and BAZ if FOO is initially 'y' 152a8224611SJames Kungcfg-enable-all-depends = \ 153a8224611SJames Kung $(strip \ 154a8224611SJames Kung $(if $(2), \ 155a8224611SJames Kung $(if $(filter y, $($(1))), \ 156a8224611SJames Kung $(if $(filter y,$($(firstword $(2)))), \ 157a8224611SJames Kung , \ 158a8224611SJames Kung $(warning Warning: Enabling $(firstword $(2)) [required by $(1)]) \ 159c8212ba7SJerome Forissier $(eval override $(firstword $(2)) := y) \ 160a8224611SJames Kung ) \ 161a8224611SJames Kung $(call cfg-enable-all-depends,$(1),$(filter-out $(firstword $(2)),$(2))), \ 162a8224611SJames Kung ) \ 163a8224611SJames Kung , \ 164a8224611SJames Kung ) \ 165a8224611SJames Kung ) 166dffb0049SJerome Forissier 16710b7925cSJerome Forissier# Set a variable or error out if it was previously set to a different value 16810b7925cSJerome Forissier# The reason message (3rd parameter) is optional 169dffb0049SJerome Forissier# Example: 17010b7925cSJerome Forissier# $(call force,CFG_FOO,foo,required by CFG_BAR) 171dffb0049SJerome Forissierdefine force 17210b7925cSJerome Forissier$(eval $(call _force,$(1),$(2),$(3))) 173dffb0049SJerome Forissierendef 174dffb0049SJerome Forissier 175dffb0049SJerome Forissierdefine _force 176dffb0049SJerome Forissierifdef $(1) 177dffb0049SJerome Forissierifneq ($($(1)),$(2)) 17810b7925cSJerome Forissierifneq (,$(3)) 17910b7925cSJerome Forissier_reason := $$(_empty) [$(3)] 18010b7925cSJerome Forissierendif 18110b7925cSJerome Forissier$$(error $(1) is set to '$($(1))' (from $(origin $(1))) but its value must be '$(2)'$$(_reason)) 182dffb0049SJerome Forissierendif 183dffb0049SJerome Forissierendif 184dffb0049SJerome Forissier$(1) := $(2) 185dffb0049SJerome Forissierendef 186