trace: ensure $(tracetool-y) is defined in top level makefile
The build rules for trace files have a dependancy on $(tracetool-y). This variable populated in the trace/Makefile.objs file and thus its definition gets pulled into the top level makefile. This happens too late in the process though, so by the time $(tracetool-y) is defined, make has already evaluated $(tracetool-y) in the dependancies and found it to be empty. The result is that when the tracetool source is changed, the generated files are not rebuilt. The solution is to define the variable in the top level makefile too Signed-off-by: Daniel P. Berrange <berrange@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Tested-by: Eric Blake <eblake@redhat.com> Message-id: 20170315123421.28815-1-berrange@redhat.com Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
This commit is contained in:
parent
4175304e59
commit
8755b4afbd
3
Makefile
3
Makefile
@ -86,6 +86,9 @@ GENERATED_FILES += $(BUILD_DIR)/trace-events-all
|
|||||||
|
|
||||||
trace-group-name = $(shell dirname $1 | sed -e 's/[^a-zA-Z0-9]/_/g')
|
trace-group-name = $(shell dirname $1 | sed -e 's/[^a-zA-Z0-9]/_/g')
|
||||||
|
|
||||||
|
tracetool-y = $(SRC_PATH)/scripts/tracetool.py
|
||||||
|
tracetool-y += $(shell find $(SRC_PATH)/scripts/tracetool -name "*.py")
|
||||||
|
|
||||||
%/trace.h: %/trace.h-timestamp
|
%/trace.h: %/trace.h-timestamp
|
||||||
@cmp $< $@ >/dev/null 2>&1 || cp $< $@
|
@cmp $< $@ >/dev/null 2>&1 || cp $< $@
|
||||||
%/trace.h-timestamp: $(SRC_PATH)/%/trace-events $(tracetool-y)
|
%/trace.h-timestamp: $(SRC_PATH)/%/trace-events $(tracetool-y)
|
||||||
|
@ -1,13 +1,5 @@
|
|||||||
# -*- mode: makefile -*-
|
# -*- mode: makefile -*-
|
||||||
|
|
||||||
######################################################################
|
|
||||||
# tracetool source files
|
|
||||||
# Every rule that invokes tracetool must depend on this so code is regenerated
|
|
||||||
# if tracetool itself changes.
|
|
||||||
|
|
||||||
tracetool-y = $(SRC_PATH)/scripts/tracetool.py
|
|
||||||
tracetool-y += $(shell find $(SRC_PATH)/scripts/tracetool -name "*.py")
|
|
||||||
|
|
||||||
$(BUILD_DIR)/trace-events-all: $(trace-events-files)
|
$(BUILD_DIR)/trace-events-all: $(trace-events-files)
|
||||||
$(call quiet-command,cat $^ > $@)
|
$(call quiet-command,cat $^ > $@)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user