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))))'; \ 20fe52b1f5SJerome Forissier 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 29*b924c494SJens Wiklanderdefine check-conf-cmake 30*b924c494SJens Wiklander $(q)set -e; \ 31*b924c494SJens Wiklander $(cmd-echo-silent) ' CHK $@'; \ 32*b924c494SJens Wiklander cnf='$(strip $(foreach var, \ 33*b924c494SJens Wiklander $(call cfg-vars-by-prefix,$1), \ 34*b924c494SJens Wiklander $(call cfg-cmake-set,$(var))))'; \ 35*b924c494SJens Wiklander guard="_`echo $@ | tr -- -/. ___`_"; \ 36*b924c494SJens Wiklander mkdir -p $(dir $@); \ 37*b924c494SJens Wiklander echo "# auto-generated TEE configuration file" >$@.tmp; \ 38*b924c494SJens Wiklander echo "# TEE version ${TEE_IMPL_VERSION}" >>$@.tmp; \ 39*b924c494SJens Wiklander echo -n "$${cnf}" | sed 's/_nl_ */\n/g' >>$@.tmp; \ 40*b924c494SJens Wiklander $(call mv-if-changed,$@.tmp,$@) 41*b924c494SJens Wiklanderendef 42*b924c494SJens Wiklander 433354f9b2SJerome Forissierdefine check-conf-mk 44dde0e235Setienne carriere $(q)set -e; \ 4562428631SJens Wiklander $(cmd-echo-silent) ' CHK $@'; \ 46bef37b8bSJerome Forissier cnf='$(strip $(foreach var, \ 47dde0e235Setienne carriere $(call cfg-vars-by-prefix,CFG_), \ 48bef37b8bSJerome Forissier $(strip $(var)=$($(var))_nl_)))'; \ 49dde0e235Setienne carriere mkdir -p $(dir $@); \ 50dde0e235Setienne carriere echo "# auto-generated TEE configuration file" >$@.tmp; \ 51b5569a68SPascal Brand echo "# TEE version ${TEE_IMPL_VERSION}" >>$@.tmp; \ 52dde0e235Setienne carriere echo "ARCH=${ARCH}" >>$@.tmp; \ 53dde0e235Setienne carriere echo "PLATFORM=${PLATFORM}" >>$@.tmp; \ 54dde0e235Setienne carriere echo "PLATFORM_FLAVOR=${PLATFORM_FLAVOR}" >>$@.tmp; \ 55dde0e235Setienne carriere echo -n "$${cnf}" | sed 's/_nl_ */\n/g' >>$@.tmp; \ 563354f9b2SJerome Forissier $(call mv-if-changed,$@.tmp,$@) 573354f9b2SJerome Forissierendef 583354f9b2SJerome Forissier 593354f9b2SJerome Forissier# Rename $1 to $2 only if file content differs. Otherwise just delete $1. 603354f9b2SJerome Forissierdefine mv-if-changed 613957863bSJerome Forissier if cmp -s $2 $1; then \ 623354f9b2SJerome Forissier rm -f $1; \ 633354f9b2SJerome Forissier else \ 6462428631SJens Wiklander $(cmd-echo-silent) ' UPD $2'; \ 653354f9b2SJerome Forissier mv $1 $2; \ 663354f9b2SJerome Forissier fi 67dde0e235Setienne carriereendef 68dde0e235Setienne carriere 69fe52b1f5SJerome Forissierdefine cfg-vars-by-prefix 70fe52b1f5SJerome Forissier $(strip $(if $(1),$(call _cfg-vars-by-prefix,$(1)), 715ef74e73SJerome Forissier $(call _cfg-vars-by-prefix,CFG_ _CFG_ PLATFORM_))) 72fe52b1f5SJerome Forissierendef 73fe52b1f5SJerome Forissier 74fe52b1f5SJerome Forissierdefine _cfg-vars-by-prefix 75fe52b1f5SJerome Forissier $(sort $(foreach prefix,$(1),$(filter $(prefix)%,$(.VARIABLES)))) 76fe52b1f5SJerome Forissierendef 77fe52b1f5SJerome Forissier 78fe52b1f5SJerome Forissier# Convert a makefile variable to a #define 79fe52b1f5SJerome Forissier# <undefined>, n => <undefined> 80fe52b1f5SJerome Forissier# y => 1 81fe52b1f5SJerome Forissier# <other value> => <other value> 82fe52b1f5SJerome Forissierdefine cfg-make-define 83fe52b1f5SJerome Forissier $(strip $(if $(filter y,$($1)), 84bef37b8bSJerome Forissier #define $1 1_nl_, 85fe52b1f5SJerome Forissier $(if $(filter xn x,x$($1)), 86bef37b8bSJerome Forissier /* $1 is not set */_nl_, 87bef37b8bSJerome Forissier #define $1 $($1)_nl_))) 88fe52b1f5SJerome Forissierendef 890a7f95b9SJerome Forissier 90*b924c494SJens Wiklander# Convert a makefile variable to a cmake set statement 91*b924c494SJens Wiklander# <undefined>, n => <undefined> 92*b924c494SJens Wiklander# <other value> => <other value> 93*b924c494SJens Wiklanderdefine cfg-cmake-set 94*b924c494SJens Wiklander $(strip $(if $(filter xn x,x$($1)), 95*b924c494SJens Wiklander # $1 is not set _nl_, 96*b924c494SJens Wiklander set($1 $($1))_nl_)) 97*b924c494SJens Wiklanderendef 98*b924c494SJens Wiklander 990a7f95b9SJerome Forissier# Returns 'y' if at least one variable is 'y', empty otherwise 1000a7f95b9SJerome Forissier# Example: 1010a7f95b9SJerome Forissier# FOO_OR_BAR := $(call cfg-one-enabled, FOO BAR) 1020a7f95b9SJerome Forissiercfg-one-enabled = $(if $(filter y, $(foreach var,$(1),$($(var)))),y,) 1030a7f95b9SJerome Forissier 1040a7f95b9SJerome Forissier# Returns 'y' if all variables are 'y', empty otherwise 1050a7f95b9SJerome Forissier# Example: 1060a7f95b9SJerome Forissier# FOO_AND_BAR := $(call cfg-all-enabled, FOO BAR) 1070a7f95b9SJerome Forissiercfg-all-enabled = \ 1080a7f95b9SJerome Forissier $(strip \ 1090a7f95b9SJerome Forissier $(if $(1), \ 1100a7f95b9SJerome Forissier $(if $(filter y,$($(firstword $(1)))), \ 1110a7f95b9SJerome 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))), \ 1240a7f95b9SJerome Forissier $(if $(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))), \ 1390a7f95b9SJerome Forissier $(if $(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