2023-08-30 17:31:07 +02:00
|
|
|
pmu-events-y += pmu-events.o
|
|
|
|
JDIR = pmu-events/arch/$(SRCARCH)
|
|
|
|
JSON = $(shell [ -d $(JDIR) ] && \
|
|
|
|
find $(JDIR) -name '*.json' -o -name 'mapfile.csv')
|
|
|
|
JDIR_TEST = pmu-events/arch/test
|
|
|
|
JSON_TEST = $(shell [ -d $(JDIR_TEST) ] && \
|
|
|
|
find $(JDIR_TEST) -name '*.json')
|
|
|
|
JEVENTS_PY = pmu-events/jevents.py
|
|
|
|
METRIC_PY = pmu-events/metric.py
|
|
|
|
METRIC_TEST_PY = pmu-events/metric_test.py
|
|
|
|
EMPTY_PMU_EVENTS_C = pmu-events/empty-pmu-events.c
|
|
|
|
PMU_EVENTS_C = $(OUTPUT)pmu-events/pmu-events.c
|
|
|
|
METRIC_TEST_LOG = $(OUTPUT)pmu-events/metric_test.log
|
|
|
|
|
|
|
|
ifeq ($(JEVENTS_ARCH),)
|
|
|
|
JEVENTS_ARCH=$(SRCARCH)
|
|
|
|
endif
|
|
|
|
JEVENTS_MODEL ?= all
|
|
|
|
|
|
|
|
#
|
|
|
|
# Locate/process JSON files in pmu-events/arch/
|
|
|
|
# directory and create tables in pmu-events.c.
|
|
|
|
#
|
|
|
|
|
|
|
|
ifeq ($(NO_JEVENTS),1)
|
|
|
|
$(PMU_EVENTS_C): $(EMPTY_PMU_EVENTS_C)
|
|
|
|
$(call rule_mkdir)
|
|
|
|
$(Q)$(call echo-cmd,gen)cp $< $@
|
|
|
|
else
|
|
|
|
$(METRIC_TEST_LOG): $(METRIC_TEST_PY) $(METRIC_PY)
|
|
|
|
$(call rule_mkdir)
|
|
|
|
$(Q)$(call echo-cmd,test)$(PYTHON) $< 2> $@ || (cat $@ && false)
|
|
|
|
|
|
|
|
$(PMU_EVENTS_C): $(JSON) $(JSON_TEST) $(JEVENTS_PY) $(METRIC_PY) $(METRIC_TEST_LOG)
|
|
|
|
$(call rule_mkdir)
|
|
|
|
$(Q)$(call echo-cmd,gen)$(PYTHON) $(JEVENTS_PY) $(JEVENTS_ARCH) $(JEVENTS_MODEL) pmu-events/arch $@
|
|
|
|
endif
|
2023-10-24 12:59:35 +02:00
|
|
|
|
|
|
|
# pmu-events.c file is generated in the OUTPUT directory so it needs a
|
|
|
|
# separate rule to depend on it properly
|
|
|
|
$(OUTPUT)pmu-events/pmu-events.o: $(PMU_EVENTS_C)
|
|
|
|
$(call rule_mkdir)
|
|
|
|
$(call if_changed_dep,cc_o_c)
|