2012-12-14 23:13:09 +04:00
|
|
|
# -*- mode: makefile -*-
|
|
|
|
|
2015-10-28 17:38:41 +03:00
|
|
|
######################################################################
|
|
|
|
# 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")
|
|
|
|
|
2016-06-16 11:39:47 +03:00
|
|
|
$(BUILD_DIR)/trace-events-all: $(trace-events-y:%=$(SRC_PATH)/%)
|
|
|
|
$(call quiet-command,cat $^ > $@)
|
|
|
|
|
2014-01-30 07:47:56 +04:00
|
|
|
######################################################################
|
|
|
|
# Auto-generated event descriptions for LTTng ust code
|
|
|
|
|
2014-05-27 17:02:14 +04:00
|
|
|
ifeq ($(findstring ust,$(TRACE_BACKENDS)),ust)
|
2016-07-11 13:53:41 +03:00
|
|
|
|
2014-01-30 07:47:56 +04:00
|
|
|
$(obj)/generated-ust-provider.h: $(obj)/generated-ust-provider.h-timestamp
|
2015-10-28 17:45:10 +03:00
|
|
|
@cmp $< $@ >/dev/null 2>&1 || cp $< $@
|
2016-06-16 11:39:47 +03:00
|
|
|
$(obj)/generated-ust-provider.h-timestamp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
|
2014-01-30 07:47:56 +04:00
|
|
|
$(call quiet-command,$(TRACETOOL) \
|
|
|
|
--format=ust-events-h \
|
2014-05-27 17:02:14 +04:00
|
|
|
--backends=$(TRACE_BACKENDS) \
|
2014-01-30 07:47:56 +04:00
|
|
|
< $< > $@," GEN $(patsubst %-timestamp,%,$@)")
|
|
|
|
|
|
|
|
$(obj)/generated-ust.c: $(obj)/generated-ust.c-timestamp $(BUILD_DIR)/config-host.mak
|
2015-10-28 17:45:10 +03:00
|
|
|
@cmp $< $@ >/dev/null 2>&1 || cp $< $@
|
2016-06-16 11:39:47 +03:00
|
|
|
$(obj)/generated-ust.c-timestamp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
|
2014-01-30 07:47:56 +04:00
|
|
|
$(call quiet-command,$(TRACETOOL) \
|
|
|
|
--format=ust-events-c \
|
2014-05-27 17:02:14 +04:00
|
|
|
--backends=$(TRACE_BACKENDS) \
|
2014-01-30 07:47:56 +04:00
|
|
|
< $< > $@," GEN $(patsubst %-timestamp,%,$@)")
|
|
|
|
|
|
|
|
$(obj)/generated-events.h: $(obj)/generated-ust-provider.h
|
|
|
|
$(obj)/generated-events.c: $(obj)/generated-ust.c
|
2016-07-11 13:53:41 +03:00
|
|
|
|
2014-01-30 07:47:56 +04:00
|
|
|
endif
|
|
|
|
|
2012-12-14 23:13:09 +04:00
|
|
|
######################################################################
|
2013-03-05 17:47:32 +04:00
|
|
|
# Auto-generated event descriptions
|
|
|
|
|
|
|
|
$(obj)/generated-events.h: $(obj)/generated-events.h-timestamp
|
2015-10-28 17:45:10 +03:00
|
|
|
@cmp $< $@ >/dev/null 2>&1 || cp $< $@
|
2016-06-16 11:39:47 +03:00
|
|
|
$(obj)/generated-events.h-timestamp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
|
2013-03-05 17:47:32 +04:00
|
|
|
$(call quiet-command,$(TRACETOOL) \
|
|
|
|
--format=events-h \
|
2014-05-27 17:02:14 +04:00
|
|
|
--backends=$(TRACE_BACKENDS) \
|
2013-03-05 17:47:32 +04:00
|
|
|
< $< > $@," GEN $(patsubst %-timestamp,%,$@)")
|
|
|
|
|
2013-03-08 18:52:15 +04:00
|
|
|
$(obj)/generated-events.c: $(obj)/generated-events.c-timestamp $(BUILD_DIR)/config-host.mak
|
2015-10-28 17:45:10 +03:00
|
|
|
@cmp $< $@ >/dev/null 2>&1 || cp $< $@
|
2016-06-16 11:39:47 +03:00
|
|
|
$(obj)/generated-events.c-timestamp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
|
2013-03-05 17:47:32 +04:00
|
|
|
$(call quiet-command,$(TRACETOOL) \
|
|
|
|
--format=events-c \
|
2014-05-27 17:02:14 +04:00
|
|
|
--backends=$(TRACE_BACKENDS) \
|
2013-03-05 17:47:32 +04:00
|
|
|
< $< > $@," GEN $(patsubst %-timestamp,%,$@)")
|
|
|
|
|
|
|
|
util-obj-y += generated-events.o
|
|
|
|
|
|
|
|
|
|
|
|
######################################################################
|
|
|
|
# Auto-generated tracing routines
|
2012-12-14 23:13:09 +04:00
|
|
|
|
2014-05-30 16:11:50 +04:00
|
|
|
##################################################
|
|
|
|
# Execution level
|
|
|
|
|
2012-12-24 17:06:27 +04:00
|
|
|
$(obj)/generated-tracers.h: $(obj)/generated-tracers.h-timestamp
|
2013-01-15 16:47:33 +04:00
|
|
|
@cmp -s $< $@ || cp $< $@
|
2016-06-16 11:39:47 +03:00
|
|
|
$(obj)/generated-tracers.h-timestamp: $(BUILD_DIR)/trace-events-all $(BUILD_DIR)/config-host.mak $(tracetool-y)
|
2012-12-14 23:13:09 +04:00
|
|
|
$(call quiet-command,$(TRACETOOL) \
|
|
|
|
--format=h \
|
2014-05-27 17:02:14 +04:00
|
|
|
--backends=$(TRACE_BACKENDS) \
|
2012-12-14 23:13:09 +04:00
|
|
|
< $< > $@," GEN $(patsubst %-timestamp,%,$@)")
|
|
|
|
|
2014-05-30 16:11:50 +04:00
|
|
|
##############################
|
|
|
|
# non-DTrace
|
2012-12-24 17:06:27 +04:00
|
|
|
|
2012-12-14 23:13:09 +04:00
|
|
|
$(obj)/generated-tracers.c: $(obj)/generated-tracers.c-timestamp
|
2013-01-15 16:47:33 +04:00
|
|
|
@cmp -s $< $@ || cp $< $@
|
2016-06-16 11:39:47 +03:00
|
|
|
$(obj)/generated-tracers.c-timestamp: $(BUILD_DIR)/trace-events-all $(BUILD_DIR)/config-host.mak $(tracetool-y)
|
2012-12-14 23:13:09 +04:00
|
|
|
$(call quiet-command,$(TRACETOOL) \
|
|
|
|
--format=c \
|
2014-05-27 17:02:14 +04:00
|
|
|
--backends=$(TRACE_BACKENDS) \
|
2012-12-14 23:13:09 +04:00
|
|
|
< $< > $@," GEN $(patsubst %-timestamp,%,$@)")
|
|
|
|
|
|
|
|
$(obj)/generated-tracers.o: $(obj)/generated-tracers.c $(obj)/generated-tracers.h
|
|
|
|
|
2014-05-30 16:11:50 +04:00
|
|
|
##############################
|
|
|
|
# DTrace
|
2012-12-14 23:13:09 +04:00
|
|
|
|
|
|
|
# Normal practice is to name DTrace probe file with a '.d' extension
|
|
|
|
# but that gets picked up by QEMU's Makefile as an external dependency
|
|
|
|
# rule file. So we use '.dtrace' instead
|
2014-05-27 17:02:14 +04:00
|
|
|
ifeq ($(findstring dtrace,$(TRACE_BACKENDS)),dtrace)
|
2016-07-11 13:53:41 +03:00
|
|
|
|
2014-05-27 17:02:14 +04:00
|
|
|
$(obj)/generated-tracers-dtrace.dtrace: $(obj)/generated-tracers-dtrace.dtrace-timestamp
|
2015-10-28 17:45:10 +03:00
|
|
|
@cmp $< $@ >/dev/null 2>&1 || cp $< $@
|
2016-06-16 11:39:47 +03:00
|
|
|
$(obj)/generated-tracers-dtrace.dtrace-timestamp: $(BUILD_DIR)/trace-events-all $(BUILD_DIR)/config-host.mak $(tracetool-y)
|
2012-12-14 23:13:09 +04:00
|
|
|
$(call quiet-command,$(TRACETOOL) \
|
|
|
|
--format=d \
|
2014-05-27 17:02:14 +04:00
|
|
|
--backends=$(TRACE_BACKENDS) \
|
2012-12-14 23:13:09 +04:00
|
|
|
< $< > $@," GEN $(patsubst %-timestamp,%,$@)")
|
|
|
|
|
2014-05-27 17:02:14 +04:00
|
|
|
$(obj)/generated-tracers-dtrace.h: $(obj)/generated-tracers-dtrace.dtrace
|
2012-12-14 23:13:09 +04:00
|
|
|
$(call quiet-command,dtrace -o $@ -h -s $<, " GEN $@")
|
|
|
|
|
2014-05-27 17:02:14 +04:00
|
|
|
$(obj)/generated-tracers-dtrace.o: $(obj)/generated-tracers-dtrace.dtrace
|
|
|
|
|
|
|
|
util-obj-y += generated-tracers-dtrace.o
|
2012-12-24 17:06:27 +04:00
|
|
|
endif
|
2012-12-14 23:13:09 +04:00
|
|
|
|
2014-05-30 16:11:50 +04:00
|
|
|
##################################################
|
|
|
|
# Translation level
|
|
|
|
|
2014-05-30 16:12:01 +04:00
|
|
|
$(obj)/generated-helpers-wrappers.h: $(obj)/generated-helpers-wrappers.h-timestamp
|
2015-10-28 17:45:10 +03:00
|
|
|
@cmp $< $@ >/dev/null 2>&1 || cp $< $@
|
2016-06-16 11:39:47 +03:00
|
|
|
$(obj)/generated-helpers-wrappers.h-timestamp: $(BUILD_DIR)/trace-events-all $(BUILD_DIR)/config-host.mak $(tracetool-y)
|
2014-05-30 16:12:01 +04:00
|
|
|
$(call quiet-command,$(TRACETOOL) \
|
|
|
|
--format=tcg-helper-wrapper-h \
|
|
|
|
--backend=$(TRACE_BACKENDS) \
|
|
|
|
< $< > $@," GEN $(patsubst %-timestamp,%,$@)")
|
|
|
|
|
2014-05-30 16:11:50 +04:00
|
|
|
$(obj)/generated-helpers.h: $(obj)/generated-helpers.h-timestamp
|
2015-10-28 17:45:10 +03:00
|
|
|
@cmp $< $@ >/dev/null 2>&1 || cp $< $@
|
2016-06-16 11:39:47 +03:00
|
|
|
$(obj)/generated-helpers.h-timestamp: $(BUILD_DIR)/trace-events-all $(BUILD_DIR)/config-host.mak $(tracetool-y)
|
2014-05-30 16:11:50 +04:00
|
|
|
$(call quiet-command,$(TRACETOOL) \
|
|
|
|
--format=tcg-helper-h \
|
|
|
|
--backend=$(TRACE_BACKENDS) \
|
|
|
|
< $< > $@," GEN $(patsubst %-timestamp,%,$@)")
|
|
|
|
|
2014-05-30 16:11:56 +04:00
|
|
|
$(obj)/generated-helpers.c: $(obj)/generated-helpers.c-timestamp
|
2015-10-28 17:45:10 +03:00
|
|
|
@cmp $< $@ >/dev/null 2>&1 || cp $< $@
|
2016-06-16 11:39:47 +03:00
|
|
|
$(obj)/generated-helpers.c-timestamp: $(BUILD_DIR)/trace-events-all $(BUILD_DIR)/config-host.mak $(tracetool-y)
|
2014-05-30 16:11:56 +04:00
|
|
|
$(call quiet-command,$(TRACETOOL) \
|
|
|
|
--format=tcg-helper-c \
|
|
|
|
--backend=$(TRACE_BACKENDS) \
|
|
|
|
< $< > $@," GEN $(patsubst %-timestamp,%,$@)")
|
|
|
|
|
|
|
|
$(obj)/generated-helpers.o: $(obj)/generated-helpers.c
|
|
|
|
|
|
|
|
target-obj-y += generated-helpers.o
|
|
|
|
|
2014-05-30 16:11:50 +04:00
|
|
|
|
2014-05-30 16:12:13 +04:00
|
|
|
$(obj)/generated-tcg-tracers.h: $(obj)/generated-tcg-tracers.h-timestamp
|
2015-10-28 17:45:10 +03:00
|
|
|
@cmp $< $@ >/dev/null 2>&1 || cp $< $@
|
2016-06-16 11:39:47 +03:00
|
|
|
$(obj)/generated-tcg-tracers.h-timestamp: $(BUILD_DIR)/trace-events-all $(BUILD_DIR)/config-host.mak $(tracetool-y)
|
2014-05-30 16:12:13 +04:00
|
|
|
$(call quiet-command,$(TRACETOOL) \
|
|
|
|
--format=tcg-h \
|
|
|
|
--backend=$(TRACE_BACKENDS) \
|
|
|
|
< $< > $@," GEN $(patsubst %-timestamp,%,$@)")
|
|
|
|
|
|
|
|
|
2012-12-14 23:13:09 +04:00
|
|
|
######################################################################
|
|
|
|
# Backend code
|
|
|
|
|
2014-09-03 07:44:54 +04:00
|
|
|
util-obj-$(CONFIG_TRACE_SIMPLE) += simple.o generated-tracers.o
|
2013-04-11 15:25:15 +04:00
|
|
|
util-obj-$(CONFIG_TRACE_FTRACE) += ftrace.o
|
2014-01-30 07:47:56 +04:00
|
|
|
util-obj-$(CONFIG_TRACE_UST) += generated-ust.o
|
2012-12-21 12:45:20 +04:00
|
|
|
util-obj-y += control.o
|
2016-07-11 13:53:41 +03:00
|
|
|
target-obj-y += control-target.o
|
2014-08-25 15:19:57 +04:00
|
|
|
util-obj-y += qmp.o
|