diff options
| author | Grant Likely <grant.likely@secretlab.ca> | 2007-09-24 09:05:31 -0600 | 
|---|---|---|
| committer | Grant Likely <grant.likely@secretlab.ca> | 2007-11-20 22:33:38 -0700 | 
| commit | 2f155f6c0a1f5e9a306a3f1f4fbe067db7ced3b1 (patch) | |
| tree | 872745bafb23aa357e7abbdfed81d17c0250ca85 /tools/scripts/define2mk.sed | |
| parent | f92edbd8a0ef16a2b9127cbb564c09685728e4b0 (diff) | |
| download | olio-uboot-2014.01-2f155f6c0a1f5e9a306a3f1f4fbe067db7ced3b1.tar.xz olio-uboot-2014.01-2f155f6c0a1f5e9a306a3f1f4fbe067db7ced3b1.zip | |
[BUILD] Generate include/autoconf.mk from board config files
Use cpp and sed to postprocess config.h and import the defined values
into include/autoconf.mk.  autoconf.mk is then included by config.mk to
give 'make' access to the board configuration.
Doing this enables conditional compilation at the Makefile level instead
of by wrapping every .c file with #ifdef/#endif wrappers.
Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
Diffstat (limited to 'tools/scripts/define2mk.sed')
| -rw-r--r-- | tools/scripts/define2mk.sed | 29 | 
1 files changed, 29 insertions, 0 deletions
| diff --git a/tools/scripts/define2mk.sed b/tools/scripts/define2mk.sed new file mode 100644 index 000000000..6464627ea --- /dev/null +++ b/tools/scripts/define2mk.sed @@ -0,0 +1,29 @@ +# +# Sed script to parse CPP macros and generate output usable by make +# +# It is expected that this script is fed the output of 'gpp -dM' +# which preprocesses the common.h header files and outputs the final +# list of CPP macros (and whitespace is sanitized) +# + +# Only process values prefixed with #define CONFIG_ +/^#define CONFIG_[A-Za-z0-9_]\+/ { +	# Strip the #define prefix +	s/#define *//; +	# Change to form CONFIG_*=VALUE +	s/ \+/=/; +	# Drop trailing spaces +	s/ *$//; +	# drop quotes around string values +	s/="\(.*\)"$/=\1/; +	# Concatenate string values +	s/" *"//g; +	# Wrap non-numeral values with quotes +	s/=\(.*\?[^0-9].*\)$/=\"\1\"/; +	# Change '1' and empty values to "y" (not perfect, but +	# supports conditional compilation in the makefiles +	s/=$/=y/; +	s/=1$/=y/; +	# print the line +	p +} |