180eeb67fSAndi Kleenpmu-events-y += pmu-events.o 27a759cd8SJiada WangJDIR = pmu-events/arch/$(SRCARCH) 380eeb67fSAndi KleenJSON = $(shell [ -d $(JDIR) ] && \ 480eeb67fSAndi Kleen find $(JDIR) -name '*.json' -o -name 'mapfile.csv') 5517db3b5SJohn GarryJDIR_TEST = pmu-events/arch/test 6517db3b5SJohn GarryJSON_TEST = $(shell [ -d $(JDIR_TEST) ] && \ 7517db3b5SJohn Garry find $(JDIR_TEST) -name '*.json') 800facc76SIan RogersJEVENTS_PY = pmu-events/jevents.py 9b777b3d2SIan RogersMETRIC_PY = pmu-events/metric.py 10b777b3d2SIan RogersMETRIC_TEST_PY = pmu-events/metric_test.py 11b777b3d2SIan RogersEMPTY_PMU_EVENTS_C = pmu-events/empty-pmu-events.c 12b777b3d2SIan RogersPMU_EVENTS_C = $(OUTPUT)pmu-events/pmu-events.c 13b777b3d2SIan RogersMETRIC_TEST_LOG = $(OUTPUT)pmu-events/metric_test.log 140fe881f1SIan RogersTEST_EMPTY_PMU_EVENTS_C = $(OUTPUT)pmu-events/test-empty-pmu-events.c 150fe881f1SIan RogersEMPTY_PMU_EVENTS_TEST_LOG = $(OUTPUT)pmu-events/empty-pmu-events.log 16e9d32c1bSJohn Garry 17b4f04660SIan Rogersifeq ($(JEVENTS_ARCH),) 18b4f04660SIan RogersJEVENTS_ARCH=$(SRCARCH) 19b4f04660SIan Rogersendif 205a09b1fdSIan RogersJEVENTS_MODEL ?= all 21b4f04660SIan Rogers 2280eeb67fSAndi Kleen# 2380eeb67fSAndi Kleen# Locate/process JSON files in pmu-events/arch/ 2480eeb67fSAndi Kleen# directory and create tables in pmu-events.c. 2580eeb67fSAndi Kleen# 2600facc76SIan Rogers 2700facc76SIan Rogersifeq ($(NO_JEVENTS),1) 28b777b3d2SIan Rogers$(PMU_EVENTS_C): $(EMPTY_PMU_EVENTS_C) 2900facc76SIan Rogers $(call rule_mkdir) 3000facc76SIan Rogers $(Q)$(call echo-cmd,gen)cp $< $@ 3100facc76SIan Rogerselse 32b777b3d2SIan Rogers$(METRIC_TEST_LOG): $(METRIC_TEST_PY) $(METRIC_PY) 33b777b3d2SIan Rogers $(call rule_mkdir) 34b777b3d2SIan Rogers $(Q)$(call echo-cmd,test)$(PYTHON) $< 2> $@ || (cat $@ && false) 35b777b3d2SIan Rogers 360fe881f1SIan Rogers$(TEST_EMPTY_PMU_EVENTS_C): $(JSON) $(JSON_TEST) $(JEVENTS_PY) $(METRIC_PY) $(METRIC_TEST_LOG) 370fe881f1SIan Rogers $(call rule_mkdir) 380fe881f1SIan Rogers $(Q)$(call echo-cmd,gen)$(PYTHON) $(JEVENTS_PY) none none pmu-events/arch $@ 390fe881f1SIan Rogers 400fe881f1SIan Rogers$(EMPTY_PMU_EVENTS_TEST_LOG): $(EMPTY_PMU_EVENTS_C) $(TEST_EMPTY_PMU_EVENTS_C) 410fe881f1SIan Rogers $(call rule_mkdir) 42b79f9a43SIan Rogers $(Q)$(call echo-cmd,test)diff -u $^ 2> $@ || (cat $@ && false) 430fe881f1SIan Rogers 44168910d0SIan Rogersifdef MYPY 45168910d0SIan Rogers PMU_EVENTS_PY_TESTS := $(wildcard *.py) 46168910d0SIan Rogers PMU_EVENTS_MYPY_TEST_LOGS := $(JEVENTS_PY_TESTS:%=%.mypy_log) 47168910d0SIan Rogerselse 48168910d0SIan Rogers PMU_EVENTS_MYPY_TEST_LOGS := 49168910d0SIan Rogersendif 50168910d0SIan Rogers 51168910d0SIan Rogers$(OUTPUT)%.mypy_log: % 52168910d0SIan Rogers $(call rule_mkdir) 53168910d0SIan Rogers $(Q)$(call echo-cmd,test)mypy "$<" > $@ || (cat $@ && rm $@ && false) 54168910d0SIan Rogers 55*8a54784eSIan Rogersifdef PYLINT 56*8a54784eSIan Rogers PMU_EVENTS_PY_TESTS := $(wildcard *.py) 57*8a54784eSIan Rogers PMU_EVENTS_PYLINT_TEST_LOGS := $(JEVENTS_PY_TESTS:%=%.pylint_log) 58*8a54784eSIan Rogerselse 59*8a54784eSIan Rogers PMU_EVENTS_PYLINT_TEST_LOGS := 60*8a54784eSIan Rogersendif 61*8a54784eSIan Rogers 62*8a54784eSIan Rogers$(OUTPUT)%.pylint_log: % 63*8a54784eSIan Rogers $(call rule_mkdir) 64*8a54784eSIan Rogers $(Q)$(call echo-cmd,test)pylint "$<" > $@ || (cat $@ && rm $@ && false) 65*8a54784eSIan Rogers 66168910d0SIan Rogers$(PMU_EVENTS_C): $(JSON) $(JSON_TEST) $(JEVENTS_PY) $(METRIC_PY) $(METRIC_TEST_LOG) \ 67*8a54784eSIan Rogers $(EMPTY_PMU_EVENTS_TEST_LOG) $(PMU_EVENTS_MYPY_TEST_LOGS) $(PMU_EVENTS_PYLINT_TEST_LOGS) 6800facc76SIan Rogers $(call rule_mkdir) 695a09b1fdSIan Rogers $(Q)$(call echo-cmd,gen)$(PYTHON) $(JEVENTS_PY) $(JEVENTS_ARCH) $(JEVENTS_MODEL) pmu-events/arch $@ 7000facc76SIan Rogersendif 717822a891SNamhyung Kim 727822a891SNamhyung Kim# pmu-events.c file is generated in the OUTPUT directory so it needs a 737822a891SNamhyung Kim# separate rule to depend on it properly 747822a891SNamhyung Kim$(OUTPUT)pmu-events/pmu-events.o: $(PMU_EVENTS_C) 757822a891SNamhyung Kim $(call rule_mkdir) 767822a891SNamhyung Kim $(call if_changed_dep,cc_o_c) 77