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