diff --git a/Makefile b/Makefile index b48240a1b..779ad742f 100644 --- a/Makefile +++ b/Makefile @@ -1022,7 +1022,7 @@ clean: archclean $(clean-dirs) @find . $(RCS_FIND_IGNORE) \ \( -name '*.[oas]' -o -name '*.ko' -o -name '.*.cmd' \ -o -name '.*.d' -o -name '.*.tmp' -o -name '*.mod.c' \ - -o -name '*.symtypes' \) \ + -o -name '*.symtypes' -o -name '*.bbenv.S' -o -name "*.bbenv" \) \ -type f -print | xargs rm -f # mrproper - Delete all generated files, including .config diff --git a/scripts/Makefile.lib b/scripts/Makefile.lib index e87e4016e..f71c3b7c2 100644 --- a/scripts/Makefile.lib +++ b/scripts/Makefile.lib @@ -98,6 +98,7 @@ multi-objs-y := $(addprefix $(obj)/,$(multi-objs-y)) multi-objs-m := $(addprefix $(obj)/,$(multi-objs-m)) subdir-ym := $(addprefix $(obj)/,$(subdir-ym)) obj-dirs := $(addprefix $(obj)/,$(obj-dirs)) +bbenv-y := $(addprefix $(obj)/,$(bbenv-y)) # These flags are needed for modversions and compiling, so we define them here # already @@ -229,6 +230,34 @@ $(obj)/%.dtb: $(src)/%.dts FORCE dtc-tmp = $(subst $(comma),_,$(dot-target).dts) +obj-y += $(patsubst %,%.bbenv$(DEFAULT_COMPRESSION_SUFFIX).o,$(bbenv-y)) +extra-y += $(patsubst %,%.bbenv$(DEFAULT_COMPRESSION_SUFFIX),$(bbenv-y)) +extra-y += $(patsubst %,%.bbenv$(DEFAULT_COMPRESSION_SUFFIX).S,$(bbenv-y)) +extra-y += $(patsubst %,%.bbenv$(DEFAULT_COMPRESSION_SUFFIX).o,$(bbenv-y)) + +quiet_cmd_env_S = ENV.S $@ +cmd_env_S = \ +( \ + echo '\#include '; \ + echo '.section .bbenv.rodata.$(subst -,_,$(*F)),"a"'; \ + echo '.balign STRUCT_ALIGNMENT'; \ + echo '.global __bbenv_$(subst -,_,$(*F))_start'; \ + echo '__bbenv_$(subst -,_,$(*F))_start:'; \ + echo '.incbin "$<" '; \ + echo '__bbenv_$(subst -,_,$(*F))_end:'; \ + echo '.global __bbenv_$(subst -,_,$(*F))_end'; \ + echo '.balign STRUCT_ALIGNMENT'; \ +) > $@ + +$(obj)/%.bbenv$(DEFAULT_COMPRESSION_SUFFIX).S: $(src)/%.bbenv$(DEFAULT_COMPRESSION_SUFFIX) FORCE + $(call if_changed,env_S) + +quiet_cmd_env = ENV $@ +cmd_env=$(srctree)/scripts/genenv $(srctree) $(objtree) $@ $< + +%.bbenv$(DEFAULT_COMPRESSION_SUFFIX): % FORCE + $(call cmd,env) + # Bzip2 # ---------------------------------------------------------------------------