blob: a04e15895e58eda13783feeb4a09832ddfd46b46 [file] [log] [blame]
rjw1f884582022-01-06 17:20:42 +08001################################################################################
2# MET Kernel module mode
3################################################################################
4$(info ======== Build met.ko ... ========)
5MET_CORE := common
6obj-m := met.o
7
8ifneq ($(wildcard $(MET_PLF_DIR)/Kbuild.platform.include),)
9 include $(MET_PLF_DIR)/Kbuild.platform.include
10else
11 $(info ======= Missing $(MET_PLF_DIR)/Kbuild.platform.include ========)
12endif
13
14ccflags-y += -DCONFIG_MET_MODULE
15ccflags-y += -DMET_PLF_USE
16ccflags-y += -I$(MET_COMMON_DIR)
17ccflags-y += -I$(MET_PLF_DIR)
18ccflags-y += -I$(KERNEL_SRC)/include/
19ccflags-y += -I$(KERNEL_SRC)/drivers/misc/mediatek/include/
20ccflags-y += -I$(KERNEL_SRC)/drivers/misc/mediatek/include/mt-plat/
21ccflags-y += -I$(KERNEL_SRC)/drivers/misc/mediatek/include/mt-plat/$(MTK_PLATFORM)/include/
22
23ccflags-y += $(EXTRA_ARGS) $(EXTRA_CFLAGS)
24ccflags-y += -DMTK_PLATFORM=$(MTK_PLATFORM)
25
26met-y := $(MET_CORE)/met_main.o \
27 $(MET_CORE)/met_backlight.o \
28 $(MET_CORE)/met_tag_ex.o \
29 $(MET_CORE)/interface.o \
30 $(MET_CORE)/sampler.o \
31 $(MET_CORE)/dummy_header.o \
32 $(MET_CORE)/util.o \
33 $(MET_CORE)/stat.o \
34 $(MET_CORE)/cookie.o \
35 $(MET_CORE)/mem_stat.o \
36 $(MET_CORE)/switch.o \
37 $(MET_CORE)/trace_event.o \
38 $(MET_CORE)/core_plf_init.o \
39 $(MET_CORE)/core_plf_trace.o \
40 $(MET_CORE)/ondiemet.o \
41 $(MET_CORE)/ondiemet_log.o \
42 $(MET_CORE)/sspm/ondiemet_sspm.o
43
44CFLAGS_interface.o += -DMET_USER_EVENT_SUPPORT
45CFLAGS_met_tag_ex.o += -DMET_USER_EVENT_SUPPORT
46
47$(info CPUPMU_VERSION = $(CPUPMU_VERSION))
48ifeq ("$(CPUPMU_VERSION)", "V8_2")
49 ccflags-y += -DCPUPMU_V8_2
50endif
51
52$(info ARCH = $(ARCH))
53ifeq ($(ARCH), mips)
54 met-y += $(MET_CORE)/mips_pmu_hw.o
55endif #ifeq ($(ARCH), mips)
56
57ifeq ($(ARCH), arm)
58 ccflags-y += -DCONFIG_MET_ARM_32BIT
59 met-y += $(MET_CORE)/cpu_pmu.o
60 met-y += $(MET_CORE)/v7_pmu_hw.o
61 met-y += $(MET_CORE)/v6_pmu_hw.o
62endif #ifeq ($(ARCH), arm)
63
64ifeq ($(ARCH), arm64)
65 met-y += $(MET_CORE)/cpu_pmu.o
66 met-y += $(MET_CORE)/v8_pmu_hw.o
67endif
68
69$(info CONFIG_CPU_FREQ = $(CONFIG_CPU_FREQ))
70ifeq ($(CONFIG_CPU_FREQ),y)
71 met-y += $(MET_CORE)/power.o
72endif
73
74################################################################################
75# MET_SPM_TWAM
76################################################################################
77FEATURE_SPMTWAM := $(if $(FEATURE_SPMTWAM),$(FEATURE_SPMTWAM),y)
78$(info FEATURE_SPMTWAM = $(FEATURE_SPMTWAM))
79
80ifneq ($(FEATURE_SPMTWAM), n)
81 MET_SPM_TWAM := y
82
83 # for mtk_spm.h
84 ifneq ("$(wildcard $(KERNEL_SRC)/drivers/misc/mediatek/base/power/include/mtk_spm.h)","")
85 ccflags-y += -I$(KERNEL_SRC)/drivers/misc/mediatek/base/power/include/
86 ccflags-y += -I$(MET_COMMON_DIR)/spmtwam/include/
87 else
88 MET_SPM_TWAM = n
89 $(info ========= Missing $(KERNEL_SRC)/drivers/misc/mediatek/base/power/include/mtk_spm.h ========)
90 $(info ======== disable MET_SPM_TWAM ========)
91 endif
92else
93 MET_SPM_TWAM := n
94endif
95
96$(info SPMTWAM_VERSION = $(SPMTWAM_VERSION))
97$(info SPMTWAM_IDLE_SIGNAL_SUPPORT = $(SPMTWAM_IDLE_SIGNAL_SUPPORT))
98
99ifeq ("$(SPMTWAM_IDLE_SIGNAL_SUPPORT)", "single")
100 ccflags-y += -DSPMTWAM_SINGLE_IDLE_SIGNAL
101endif
102
103ifeq ("$(SPMTWAM_IDLE_SIGNAL_SUPPORT)", "multiple")
104 ccflags-y += -DSPMTWAM_MULTIPLE_IDLE_SIGNAL
105endif
106
107ifeq ("$(SPMTWAM_VERSION)", "ap")
108 ccflags-y += -DSPMTWAM_AP
109 met-$(MET_SPM_TWAM) += $(MET_CORE)/spmtwam/ap/met_spmtwam.o
110endif
111
112ifeq ("$(SPMTWAM_VERSION)", "sspm")
113 ccflags-y += -DSPMTWAM_SSPM
114 met-$(MET_SPM_TWAM) += $(MET_CORE)/spmtwam/sspm/met_spmtwam.o
115endif
116
117################################################################################
118# MET_SSPM_EMI
119################################################################################
120FEATURE_SSPM_EMI := $(if $(FEATURE_SSPM_EMI),$(FEATURE_SSPM_EMI),y)
121$(info FEATURE_SSPM_EMI = $(FEATURE_SSPM_EMI))
122
123MET_SSPM_EMI := $(if $(filter n,$(FEATURE_SSPM_EMI)),n,y)
124
125met-$(MET_SSPM_EMI) += $(MET_CORE)/met_emi.o \
126 $(MET_CORE)/mtk_emi_bm.o
127
128################################################################################
129# MET_GPU
130################################################################################
131FEATURE_GPU := $(if $(FEATURE_GPU),$(FEATURE_GPU),y)
132$(info FEATURE_GPU = $(FEATURE_GPU))
133
134ifneq ($(FEATURE_GPU), n)
135 MET_GPU := y
136
137 # for mtk_gpufreq.h
138 ifneq ("$(wildcard $(KERNEL_SRC)/drivers/misc/mediatek/base/power/$(MTK_PLATFORM)/mtk_gpufreq.h)","")
139 ccflags-y += -I$(KERNEL_SRC)/drivers/misc/mediatek/base/power/$(MTK_PLATFORM)/
140 else
141 MET_GPU = n
142 $(info ======= Missing $(KERNEL_SRC)/drivers/misc/mediatek/base/power/$(MTK_PLATFORM)/mtk_gpufreq.h ========)
143 $(info ======== disable MET_GPU ========)
144 endif
145
146 # for mtk_gpu_utility.h
147 ifneq ("$(wildcard $(KERNEL_SRC)/drivers/misc/mediatek/include/mt-plat/mtk_gpu_utility.h)","")
148 ccflags-y += -I$(KERNEL_SRC)/drivers/misc/mediatek/include/mt-plat/
149 else
150 MET_GPU = n
151 $(info ======== Missing $(KERNEL_SRC)/drivers/misc/mediatek/include/mt-plat/mtk_gpu_utility.h ========)
152 $(info ======== disable MET_GPU ========)
153 endif
154
155 ifneq ($(CONFIG_MTK_GPU_SUPPORT), y)
156 MET_GPU = n
157 $(info ======== CONFIG_MTK_GPU_SUPPORT = n ========)
158 $(info ======== disable MET_GPU ========)
159 endif
160else
161 MET_GPU := n
162endif
163
164met-$(MET_GPU) += $(MET_CORE)/mtk_gpu_metmonitor.o
165
166
167################################################################################
168# MET_VCOREDVFS
169################################################################################
170FEATURE_VCOREDVFS := $(if $(FEATURE_VCOREDVFS),$(FEATURE_VCOREDVFS),y)
171$(info FEATURE_VCOREDVFS = $(FEATURE_VCOREDVFS))
172
173ifneq ($(FEATURE_VCOREDVFS), n)
174 MET_VCOREDVFS := y
175
176 # for mtk_vcorefs_manager.h
177 ifneq ("$(wildcard $(MET_VCOREDVFS_INC)/mtk_vcorefs_manager.h)","")
178 ccflags-y += -I$(MET_VCOREDVFS_INC)/
179 else
180 MET_VCOREDVFS = n
181 $(info ======== Missing $(MET_VCOREDVFS_INC)/mtk_vcorefs_manager.h ========)
182 $(info ======== disable MET_VCOREDVFS ========)
183 endif
184
185 # for mtk_vcorefs_governor.h
186 ifneq ("$(wildcard $(MET_VCOREDVFS_INC)/mtk_vcorefs_governor.h)","")
187 ccflags-y += -I$(MET_VCOREDVFS_INC)
188 else
189 MET_VCOREDVFS = n
190 $(info ======== Missing $(MET_VCOREDVFS_INC)/mtk_vcorefs_governor.h ========)
191 $(info ======== disable MET_VCOREDVFS ========)
192 endif
193
194 # for helio-dvfsrc.h
195 ifneq ("$(wildcard $(KERNEL_SRC)/drivers/devfreq/helio-dvfsrc.h)","")
196 ccflags-y += -I$(KERNEL_SRC)/drivers/devfreq/
197 else
198 MET_VCOREDVFS = n
199 $(info ======== Missing $(KERNEL_SRC)/drivers/devfreq/helio-dvfsrc.h ========)
200 $(info ======== disable MET_VCOREDVFS ========)
201 endif
202else
203 MET_VCOREDVFS := n
204endif
205
206met-$(MET_VCOREDVFS) += $(MET_CORE)/met_vcoredvfs.o
207
208
209################################################################################
210# MET_PTPOD
211################################################################################
212FEATURE_PTPOD := $(if $(FEATURE_PTPOD),$(FEATURE_PTPOD),y)
213$(info FEATURE_PTPOD = $(FEATURE_PTPOD))
214
215ifneq ($(FEATURE_PTPOD), n)
216 MET_PTPOD := y
217
218 # for mtk_gpufreq.h
219 ifneq ("$(wildcard $(KERNEL_SRC)/drivers/misc/mediatek/base/power/$(MTK_PLATFORM)/mtk_gpufreq.h)","")
220 ccflags-y += -I$(KERNEL_SRC)/drivers/misc/mediatek/base/power/$(MTK_PLATFORM)/
221 else
222 MET_PTPOD = n
223 $(info ======== Missing $(KERNEL_SRC)/drivers/misc/mediatek/base/power/$(MTK_PLATFORM)/mtk_gpufreq.h ========)
224 $(info ======== disable MET_PTPOD ========)
225 endif
226
227 # for mtk_cpufreq_api.h
228 ifneq ("$(wildcard $(KERNEL_SRC)/drivers/misc/mediatek/include/mt-plat/$(MTK_PLATFORM)/include/mach/mtk_cpufreq_api.h)","")
229 ccflags-y += -I$(KERNEL_SRC)/drivers/misc/mediatek/include/mt-plat/$(MTK_PLATFORM)/include/
230 else
231 MET_PTPOD = n
232 $(info ======== Missing $(KERNEL_SRC)/drivers/misc/mediatek/include/mt-plat/$(MTK_PLATFORM)/include/mach/mtk_cpufreq_api.h ========)
233 $(info ======== disable MET_PTPOD ========)
234 endif
235
236 # for mtk_cpufreq_config.h
237 ifneq ("$(wildcard $(MET_PTPOD_INC)/mtk_cpufreq_config.h)","")
238 ccflags-y += -I$(MET_PTPOD_INC)
239 else
240 MET_PTPOD = n
241 $(info ======== Missing $(MET_PTPOD_INC)/mtk_cpufreq_config.h ========)
242 $(info ======== disable MET_PTPOD ========)
243 endif
244else
245 MET_PTPOD := n
246endif
247
248met-$(MET_PTPOD) += $(MET_CORE)/met_ptpod.o
249
250
251################################################################################
252# MET_CPUDSU
253################################################################################
254FEATURE_CPUDSU := $(if $(FEATURE_CPUDSU),$(FEATURE_CPUDSU),y)
255$(info FEATURE_CPUDSU = $(FEATURE_CPUDSU))
256
257MET_CPUDSU := $(if $(filter n,$(FEATURE_CPUDSU)),n,y)
258
259met-$(MET_CPUDSU) += $(MET_CORE)/cpu_dsu.o \
260 $(MET_CORE)/v8_dsu_hw.o
261
262################################################################################
263# MET_WALLTIME
264################################################################################
265FEATURE_WALLTIME := $(if $(FEATURE_WALLTIME),$(FEATURE_WALLTIME),y)
266$(info FEATURE_WALLTIME = $(FEATURE_WALLTIME))
267
268MET_WALLTIME := $(if $(filter n,$(FEATURE_WALLTIME)),n,y)
269
270met-$(MET_WALLTIME) += $(MET_CORE)/met_wall_time.o
271
272################################################################################
273# MET_SMI
274################################################################################
275FEATURE_SMI := $(if $(FEATURE_SMI),$(FEATURE_SMI),y)
276$(info FEATURE_SMI = $(FEATURE_SMI))
277
278MET_SMI := $(if $(filter n,$(FEATURE_SMI)),n,y)
279
280met-$(MET_SMI) += $(MET_CORE)/sspm/sspm_met_smi.o
281
282################################################################################
283# EVENT_POWER
284################################################################################
285FEATURE_EVENT_POWER := $(if $(FEATURE_EVENT_POWER),$(FEATURE_EVENT_POWER),y)
286$(info FEATURE_EVENT_POWER = $(FEATURE_EVENT_POWER))
287
288ifeq ($(FEATURE_EVENT_POWER), y)
289 ccflags-y += -DMET_EVENT_POWER_SUPPORT
290endif
291
292################################################################################
293# On-die-met SSPM only module
294################################################################################
295FEATURE_ONDIEMET := $(if $(FEATURE_ONDIEMET),$(FEATURE_ONDIEMET),y)
296ifeq ($(FEATURE_ONDIEMET), y)
297 FEATURE_ONDIEMET_WALLTIME := $(if $(FEATURE_ONDIEMET_WALLTIME),$(FEATURE_ONDIEMET_WALLTIME),y)
298else
299 FEATURE_ONDIEMET_WALLTIME := n
300endif
301
302$(info FEATURE_ONDIEMET = $(FEATURE_ONDIEMET))
303$(info FEATURE_ONDIEMET_WALLTIME = $(FEATURE_ONDIEMET_WALLTIME))
304
305ifneq ($(FEATURE_ONDIEMET), n)
306 subdir-ccflags-y += -DONDIEMET_SUPPORT
307
308 ifeq ($(CONFIG_MTK_TINYSYS_SSPM_SUPPORT),)
309 $(info CONFIG_MTK_TINYSYS_SSPM_SUPPORT = n)
310 else
311 $(info CONFIG_MTK_TINYSYS_SSPM_SUPPORT = $(CONFIG_MTK_TINYSYS_SSPM_SUPPORT))
312 endif
313
314 ifeq ($(CONFIG_MTK_TINYSYS_SSPM_SUPPORT),y)
315 # for sspm_ipi.h
316 subdir-ccflags-y += -I$(KERNEL_SRC)/drivers/misc/mediatek/sspm
317 subdir-ccflags-y += -I$(KERNEL_SRC)/drivers/misc/mediatek/sspm/$(MTK_PLATFORM)
318 met-y += $(MET_CORE)/sspm/sspm_ipi_handle.o
319 met-y += $(MET_CORE)/sspm/sspm_common.o
320 ccflags-y += -DMTK_TINYSYS_SSPM_SUPPORT
321
322 ifneq ("$(wildcard $(KERNEL_SRC)/drivers/misc/mediatek/sspm/$(MTK_PLATFORM)/sspm_ipi_define.h)","")
323 subdir-ccflags-y += -I$(KERNEL_SRC)/drivers/misc/mediatek/sspm \
324 -I$(KERNEL_SRC)/drivers/misc/mediatek/sspm/$(MTK_PLATFORM)
325
326 SYS_SSPM_READY := y
327 else
328 $(info ======== Missing $(KERNEL_SRC)/drivers/misc/mediatek/sspm/$(MTK_PLATFORM)/sspm_ipi_define.h========)
329 $(info ======== disable ALL ondiemet feature ========)
330
331 SYS_SSPM_READY := n
332 endif
333 else
334 $(info ======== CONFIG_MTK_TINYSYS_SSPM_SUPPORT = n ========)
335 $(info ======== disable ALL ondiemet feature ========)
336
337 SYS_SSPM_READY := n
338 endif
339
340 ifeq ($(SYS_SSPM_READY), y)
341 MET_SSPM_WALLTIME := $(if $(filter n,$(FEATURE_ONDIEMET_WALLTIME)),n,y)
342
343 met-$(MET_SSPM_WALLTIME) += $(MET_CORE)/sspm/sspm_walltime.o
344 endif
345endif
346
347##############################################################################################
348# include $(MET_PLF_DIR)/Kbuild
349##############################################################################################
350ifneq ($(wildcard $(MET_PLF_DIR)/Kbuild.yocto),)
351 include $(MET_PLF_DIR)/Kbuild.yocto
352else
353 $(info ======= Missing $(MET_PLF_DIR)/Kbuild.yocto ========)
354endif
355
356#################################################################################
357# add met_device flags
358#################################################################################
359ccflags-y += $(foreach v, $(filter MET_%,$(.VARIABLES)), $(if $(filter $($(v)),y),-D$(v)))