162306a36Sopenharmony_cipmu-events-y += pmu-events.o 262306a36Sopenharmony_ciJDIR = pmu-events/arch/$(SRCARCH) 362306a36Sopenharmony_ciJSON = $(shell [ -d $(JDIR) ] && \ 462306a36Sopenharmony_ci find $(JDIR) -name '*.json' -o -name 'mapfile.csv') 562306a36Sopenharmony_ciJDIR_TEST = pmu-events/arch/test 662306a36Sopenharmony_ciJSON_TEST = $(shell [ -d $(JDIR_TEST) ] && \ 762306a36Sopenharmony_ci find $(JDIR_TEST) -name '*.json') 862306a36Sopenharmony_ciJEVENTS_PY = pmu-events/jevents.py 962306a36Sopenharmony_ciMETRIC_PY = pmu-events/metric.py 1062306a36Sopenharmony_ciMETRIC_TEST_PY = pmu-events/metric_test.py 1162306a36Sopenharmony_ciEMPTY_PMU_EVENTS_C = pmu-events/empty-pmu-events.c 1262306a36Sopenharmony_ciPMU_EVENTS_C = $(OUTPUT)pmu-events/pmu-events.c 1362306a36Sopenharmony_ciMETRIC_TEST_LOG = $(OUTPUT)pmu-events/metric_test.log 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ciifeq ($(JEVENTS_ARCH),) 1662306a36Sopenharmony_ciJEVENTS_ARCH=$(SRCARCH) 1762306a36Sopenharmony_ciendif 1862306a36Sopenharmony_ciJEVENTS_MODEL ?= all 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_ci# 2162306a36Sopenharmony_ci# Locate/process JSON files in pmu-events/arch/ 2262306a36Sopenharmony_ci# directory and create tables in pmu-events.c. 2362306a36Sopenharmony_ci# 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ciifeq ($(NO_JEVENTS),1) 2662306a36Sopenharmony_ci$(PMU_EVENTS_C): $(EMPTY_PMU_EVENTS_C) 2762306a36Sopenharmony_ci $(call rule_mkdir) 2862306a36Sopenharmony_ci $(Q)$(call echo-cmd,gen)cp $< $@ 2962306a36Sopenharmony_cielse 3062306a36Sopenharmony_ci$(METRIC_TEST_LOG): $(METRIC_TEST_PY) $(METRIC_PY) 3162306a36Sopenharmony_ci $(call rule_mkdir) 3262306a36Sopenharmony_ci $(Q)$(call echo-cmd,test)$(PYTHON) $< 2> $@ || (cat $@ && false) 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_ci$(PMU_EVENTS_C): $(JSON) $(JSON_TEST) $(JEVENTS_PY) $(METRIC_PY) $(METRIC_TEST_LOG) 3562306a36Sopenharmony_ci $(call rule_mkdir) 3662306a36Sopenharmony_ci $(Q)$(call echo-cmd,gen)$(PYTHON) $(JEVENTS_PY) $(JEVENTS_ARCH) $(JEVENTS_MODEL) pmu-events/arch $@ 3762306a36Sopenharmony_ciendif 3862306a36Sopenharmony_ci 3962306a36Sopenharmony_ci# pmu-events.c file is generated in the OUTPUT directory so it needs a 4062306a36Sopenharmony_ci# separate rule to depend on it properly 4162306a36Sopenharmony_ci$(OUTPUT)pmu-events/pmu-events.o: $(PMU_EVENTS_C) 4262306a36Sopenharmony_ci $(call rule_mkdir) 4362306a36Sopenharmony_ci $(call if_changed_dep,cc_o_c) 44