blob: 80042d6c3e29784b4fe582e05416674d5127abfd [file] [log] [blame]
Jorge Ramirez-Ortizbf084dc2018-09-23 09:36:13 +02001#
2# Copyright (c) 2018, Renesas Electronics Corporation. All rights reserved.
3#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6
7PROGRAMMABLE_RESET_ADDRESS := 0
8COLD_BOOT_SINGLE_CPU := 1
9ARM_CCI_PRODUCT_ID := 500
10TRUSTED_BOARD_BOOT := 1
11RESET_TO_BL31 := 1
12GENERATE_COT := 1
13BL2_AT_EL3 := 1
14
15$(eval $(call add_define,PLAT_EXTRA_LD_SCRIPT))
16
17ifeq (${SPD},none)
18 SPD_NONE:=1
19 $(eval $(call add_define,SPD_NONE))
20endif
21
22# LSI setting common define
23RCAR_H3:=0
24RCAR_M3:=1
25RCAR_M3N:=2
26RCAR_E3:=3
27RCAR_H3N:=4
28RCAR_AUTO:=99
29$(eval $(call add_define,RCAR_H3))
30$(eval $(call add_define,RCAR_M3))
31$(eval $(call add_define,RCAR_M3N))
32$(eval $(call add_define,RCAR_E3))
33$(eval $(call add_define,RCAR_H3N))
34$(eval $(call add_define,RCAR_AUTO))
35RCAR_CUT_10:=0
36RCAR_CUT_11:=1
37RCAR_CUT_20:=10
38RCAR_CUT_30:=20
39$(eval $(call add_define,RCAR_CUT_10))
40$(eval $(call add_define,RCAR_CUT_11))
41$(eval $(call add_define,RCAR_CUT_20))
42$(eval $(call add_define,RCAR_CUT_30))
43
44ifndef LSI
45 $(error "Error: Unknown LSI. Please use LSI=<LSI name> to specify the LSI")
46else
47 ifeq (${LSI},AUTO)
48 RCAR_LSI:=${RCAR_AUTO}
49 else ifeq (${LSI},H3)
50 RCAR_LSI:=${RCAR_H3}
51 ifndef LSI_CUT
52 # enable compatible function.
53 RCAR_LSI_CUT_COMPAT := 1
54 $(eval $(call add_define,RCAR_LSI_CUT_COMPAT))
55 else
56 # disable compatible function.
57 ifeq (${LSI_CUT},10)
58 RCAR_LSI_CUT:=0
59 else ifeq (${LSI_CUT},11)
60 RCAR_LSI_CUT:=1
61 else ifeq (${LSI_CUT},20)
62 RCAR_LSI_CUT:=10
63 else ifeq (${LSI_CUT},30)
64 RCAR_LSI_CUT:=20
65 else
66 $(error "Error: ${LSI_CUT} is not supported.")
67 endif
68 $(eval $(call add_define,RCAR_LSI_CUT))
69 endif
70 else ifeq (${LSI},H3N)
71 RCAR_LSI:=${RCAR_H3N}
72 ifndef LSI_CUT
73 # enable compatible function.
74 RCAR_LSI_CUT_COMPAT := 1
75 $(eval $(call add_define,RCAR_LSI_CUT_COMPAT))
76 else
77 # disable compatible function.
78 ifeq (${LSI_CUT},30)
79 RCAR_LSI_CUT:=20
80 else
81 $(error "Error: ${LSI_CUT} is not supported.")
82 endif
83 $(eval $(call add_define,RCAR_LSI_CUT))
84 endif
85 else ifeq (${LSI},M3)
86 RCAR_LSI:=${RCAR_M3}
87 ifndef LSI_CUT
88 # enable compatible function.
89 RCAR_LSI_CUT_COMPAT := 1
90 $(eval $(call add_define,RCAR_LSI_CUT_COMPAT))
91 else
92 # disable compatible function.
93 ifeq (${LSI_CUT},10)
94 RCAR_LSI_CUT:=0
95 else ifeq (${LSI_CUT},11)
96 RCAR_LSI_CUT:=1
97 else
98 $(error "Error: ${LSI_CUT} is not supported.")
99 endif
100 $(eval $(call add_define,RCAR_LSI_CUT))
101 endif
102 else ifeq (${LSI},M3N)
103 RCAR_LSI:=${RCAR_M3N}
104 ifndef LSI_CUT
105 # enable compatible function.
106 RCAR_LSI_CUT_COMPAT := 1
107 $(eval $(call add_define,RCAR_LSI_CUT_COMPAT))
108 else
109 # disable compatible function.
110 ifeq (${LSI_CUT},10)
111 RCAR_LSI_CUT:=0
112 else ifeq (${LSI_CUT},11)
113 RCAR_LSI_CUT:=1
114 else
115 $(error "Error: ${LSI_CUT} is not supported.")
116 endif
117 $(eval $(call add_define,RCAR_LSI_CUT))
118 endif
119 else ifeq (${LSI},E3)
120 RCAR_LSI:=${RCAR_E3}
121 ifndef LSI_CUT
122 # enable compatible function.
123 RCAR_LSI_CUT_COMPAT := 1
124 $(eval $(call add_define,RCAR_LSI_CUT_COMPAT))
125 else
126 # disable compatible function.
127 ifeq (${LSI_CUT},10)
128 RCAR_LSI_CUT:=0
129 else
130 $(error "Error: ${LSI_CUT} is not supported.")
131 endif
132 $(eval $(call add_define,RCAR_LSI_CUT))
133 endif
134 else
135 $(error "Error: ${LSI} is not supported.")
136 endif
137 $(eval $(call add_define,RCAR_LSI))
138endif
139
Jorge Ramirez-Ortiz87c04052018-11-19 19:26:56 +0100140# lock RPC HYPERFLASH access by default
141# unlock to repogram the ATF firmware from u-boot
142ifndef RCAR_RPC_HYPERFLASH_LOCKED
143RCAR_RPC_HYPERFLASH_LOCKED := 1
144endif
145$(eval $(call add_define,RCAR_RPC_HYPERFLASH_LOCKED))
146
Jorge Ramirez-Ortizbf084dc2018-09-23 09:36:13 +0200147# Process RCAR_SECURE_BOOT flag
148ifndef RCAR_SECURE_BOOT
149RCAR_SECURE_BOOT := 1
150endif
151$(eval $(call add_define,RCAR_SECURE_BOOT))
152
153# Process RCAR_QOS_TYPE flag
154ifndef RCAR_QOS_TYPE
155RCAR_QOS_TYPE := 0
156endif
157$(eval $(call add_define,RCAR_QOS_TYPE))
158
159# Process RCAR_DRAM_SPLIT flag
160ifndef RCAR_DRAM_SPLIT
161RCAR_DRAM_SPLIT := 0
162endif
163$(eval $(call add_define,RCAR_DRAM_SPLIT))
164
165# Process RCAR_BL33_EXECUTION_EL flag
166ifndef RCAR_BL33_EXECUTION_EL
167RCAR_BL33_EXECUTION_EL := 0
168endif
169$(eval $(call add_define,RCAR_BL33_EXECUTION_EL))
170
171# Process RCAR_AVS_SETTING_ENABLE flag
172ifeq (${RCAR_AVS_SETTING_ENABLE},0)
173AVS_SETTING_ENABLE := 0
174else
175AVS_SETTING_ENABLE := 1
176endif
177$(eval $(call add_define,AVS_SETTING_ENABLE))
178
179# Process RCAR_LOSSY_ENABLE flag
180ifndef RCAR_LOSSY_ENABLE
181RCAR_LOSSY_ENABLE := 0
182endif
183$(eval $(call add_define,RCAR_LOSSY_ENABLE))
184
185# Process LIFEC_DBSC_PROTECT_ENABLE flag
186ifndef LIFEC_DBSC_PROTECT_ENABLE
187LIFEC_DBSC_PROTECT_ENABLE := 1
188endif
189$(eval $(call add_define,LIFEC_DBSC_PROTECT_ENABLE))
190
191# Process PMIC_ROHM_BD9571 flag
192ifndef PMIC_ROHM_BD9571
193PMIC_ROHM_BD9571 := 1
194endif
195$(eval $(call add_define,PMIC_ROHM_BD9571))
196
197# Process PMIC_LEVEL_MODE flag
198ifndef PMIC_LEVEL_MODE
199PMIC_LEVEL_MODE := 1
200endif
201$(eval $(call add_define,PMIC_LEVEL_MODE))
202
203# Process RCAR_GEN3_ULCB flag
204ifndef RCAR_GEN3_ULCB
205RCAR_GEN3_ULCB := 0
206endif
207ifeq (${RCAR_GEN3_ULCB},1)
208 BOARD_DEFAULT := 0x10
209 $(eval $(call add_define,BOARD_DEFAULT))
210endif
211$(eval $(call add_define,RCAR_GEN3_ULCB))
212
213# Process RCAR_REF_INT flag
214ifndef RCAR_REF_INT
215RCAR_REF_INT :=0
216endif
217$(eval $(call add_define,RCAR_REF_INT))
218
219# Process RCAR_REWT_TRAINING flag
220ifndef RCAR_REWT_TRAINING
221RCAR_REWT_TRAINING := 0
222endif
223$(eval $(call add_define,RCAR_REWT_TRAINING))
224
225# Process RCAR_SYSTEM_SUSPEND flag
226ifndef RCAR_SYSTEM_SUSPEND
227RCAR_SYSTEM_SUSPEND := 1
228endif
229$(eval $(call add_define,RCAR_SYSTEM_SUSPEND))
230
231# SYSTEM_SUSPEND requires power control of PMIC etc.
232# When executing SYSTEM_SUSPEND other than Salvator-X, Salvator-XS and Ebisu,
233# processing equivalent to that implemented in PMIC_ROHM_BD9571 is necessary.
234ifeq (${RCAR_SYSTEM_SUSPEND},1)
235 ifeq (${PMIC_ROHM_BD9571},0)
236 $(error "Error: When you want RCAR_SYSTEM_SUSPEND to be enable, please also set PMIC_ROHM_BD9571 to enable.")
237 endif
238endif
239
240# Process RCAR_DRAM_LPDDR4_MEMCONF flag
241ifndef RCAR_DRAM_LPDDR4_MEMCONF
242RCAR_DRAM_LPDDR4_MEMCONF :=1
243endif
244$(eval $(call add_define,RCAR_DRAM_LPDDR4_MEMCONF))
245
246# Process RCAR_DRAM_DDR3L_MEMCONF flag
247ifndef RCAR_DRAM_DDR3L_MEMCONF
248RCAR_DRAM_DDR3L_MEMCONF :=1
249endif
250$(eval $(call add_define,RCAR_DRAM_DDR3L_MEMCONF))
251
252# Process RCAR_DRAM_DDR3L_MEMDUAL flag
253ifndef RCAR_DRAM_DDR3L_MEMDUAL
254RCAR_DRAM_DDR3L_MEMDUAL :=1
255endif
256$(eval $(call add_define,RCAR_DRAM_DDR3L_MEMDUAL))
257
258# Process RCAR_BL33_ARG0 flag
259ifdef RCAR_BL33_ARG0
260$(eval $(call add_define,RCAR_BL33_ARG0))
261endif
262
263#Process RCAR_BL2_DCACHE flag
264ifndef RCAR_BL2_DCACHE
265RCAR_BL2_DCACHE := 0
266endif
267$(eval $(call add_define,RCAR_BL2_DCACHE))
268
269# Process RCAR_DRAM_CHANNEL flag
270ifndef RCAR_DRAM_CHANNEL
271RCAR_DRAM_CHANNEL :=15
272endif
273$(eval $(call add_define,RCAR_DRAM_CHANNEL))
274
275#Process RCAR_SYSTEM_RESET_KEEPON_DDR flag
276ifndef RCAR_SYSTEM_RESET_KEEPON_DDR
277RCAR_SYSTEM_RESET_KEEPON_DDR := 0
278endif
279$(eval $(call add_define,RCAR_SYSTEM_RESET_KEEPON_DDR))
280
281# RCAR_SYSTEM_RESET_KEEPON_DDR requires power control of PMIC etc.
282# When executing SYSTEM_SUSPEND other than Salvator-X, Salvator-XS and Ebisu,
283# processing equivalent to that implemented in PMIC_ROHM_BD9571 is necessary.
284# Also, it is necessary to enable RCAR_SYSTEM_SUSPEND.
285ifeq (${RCAR_SYSTEM_RESET_KEEPON_DDR},1)
286 ifeq (${PMIC_ROHM_BD9571},0)
287 $(error "Error: When you want RCAR_SYSTEM_RESET_KEEPON_DDR to be enable, please also set PMIC_ROHM_BD9571 to enable.")
288 endif
289 ifeq (${RCAR_SYSTEM_SUSPEND},0)
290 $(error "Error: When you want RCAR_SYSTEM_RESET_KEEPON_DDR to be enable, please also set RCAR_SYSTEM_SUSPEND to enable.")
291 endif
292endif
293
294# Enable workarounds for selected Cortex-A53 erratas.
295ERRATA_A53_835769 := 1
296ERRATA_A53_843419 := 1
297ERRATA_A53_855873 := 1
298
299# Enable workarounds for selected Cortex-A57 erratas.
300ERRATA_A57_859972 := 1
301ERRATA_A57_813419 := 1
302
Jorge Ramirez-Ortiz47503d22018-09-23 09:36:52 +0200303include drivers/staging/renesas/rcar/ddr/ddr.mk
304include drivers/staging/renesas/rcar/qos/qos.mk
305include drivers/staging/renesas/rcar/pfc/pfc.mk
Marek Vasut93c85fc2018-10-02 20:45:18 +0200306include lib/libfdt/libfdt.mk
Jorge Ramirez-Ortizbf084dc2018-09-23 09:36:13 +0200307
308PLAT_INCLUDES := -Iinclude/common/tbbr \
Jorge Ramirez-Ortiz47503d22018-09-23 09:36:52 +0200309 -Idrivers/staging/renesas/rcar/ddr \
310 -Idrivers/staging/renesas/rcar/qos \
Jorge Ramirez-Ortizbf084dc2018-09-23 09:36:13 +0200311 -Idrivers/renesas/rcar/iic_dvfs \
312 -Idrivers/renesas/rcar/board \
313 -Idrivers/renesas/rcar/avs \
314 -Idrivers/renesas/rcar/delay \
315 -Idrivers/renesas/rcar/rom \
316 -Idrivers/renesas/rcar/scif \
317 -Idrivers/renesas/rcar/emmc \
318 -Idrivers/renesas/rcar/pwrc \
319 -Idrivers/renesas/rcar/io \
Jorge Ramirez-Ortizbf084dc2018-09-23 09:36:13 +0200320 -Iplat/renesas/rcar/include/registers \
321 -Iplat/renesas/rcar/include \
322 -Iplat/renesas/rcar
323
324PLAT_BL_COMMON_SOURCES := drivers/renesas/rcar/iic_dvfs/iic_dvfs.c
325
326
327RCAR_GIC_SOURCES := drivers/arm/gic/common/gic_common.c \
328 drivers/arm/gic/v2/gicv2_main.c \
329 drivers/arm/gic/v2/gicv2_helpers.c \
330 plat/common/plat_gicv2.c
331
332BL2_SOURCES += ${RCAR_GIC_SOURCES} \
333 lib/cpus/aarch64/cortex_a53.S \
334 lib/cpus/aarch64/cortex_a57.S \
Marek Vasut93c85fc2018-10-02 20:45:18 +0200335 ${LIBFDT_SRCS} \
Jorge Ramirez-Ortizbf084dc2018-09-23 09:36:13 +0200336 common/desc_image_load.c \
337 plat/renesas/rcar/aarch64/platform_common.c \
338 plat/renesas/rcar/aarch64/plat_helpers.S \
339 plat/renesas/rcar/bl2_interrupt_error.c \
340 plat/renesas/rcar/bl2_secure_setting.c \
341 plat/renesas/rcar/bl2_plat_setup.c \
342 plat/renesas/rcar/plat_storage.c \
343 plat/renesas/rcar/bl2_plat_mem_params_desc.c \
344 plat/renesas/rcar/plat_image_load.c \
345 plat/renesas/rcar/bl2_cpg_init.c \
346 drivers/renesas/rcar/console/rcar_printf.c \
347 drivers/renesas/rcar/scif/scif.S \
348 drivers/renesas/rcar/common.c \
349 drivers/renesas/rcar/io/io_emmcdrv.c \
350 drivers/renesas/rcar/io/io_memdrv.c \
351 drivers/renesas/rcar/io/io_rcar.c \
352 drivers/renesas/rcar/auth/auth_mod.c \
353 drivers/renesas/rcar/rpc/rpc_driver.c \
354 drivers/renesas/rcar/dma/dma_driver.c \
355 drivers/renesas/rcar/avs/avs_driver.c \
356 drivers/renesas/rcar/delay/micro_delay.S \
357 drivers/renesas/rcar/emmc/emmc_interrupt.c \
358 drivers/renesas/rcar/emmc/emmc_utility.c \
359 drivers/renesas/rcar/emmc/emmc_mount.c \
360 drivers/renesas/rcar/emmc/emmc_init.c \
361 drivers/renesas/rcar/emmc/emmc_read.c \
362 drivers/renesas/rcar/emmc/emmc_cmd.c \
363 drivers/renesas/rcar/watchdog/swdt.c \
364 drivers/renesas/rcar/rom/rom_api.c \
365 drivers/renesas/rcar/board/board.c \
366 drivers/io/io_storage.c
367
368BL31_SOURCES += ${RCAR_GIC_SOURCES} \
369 lib/cpus/aarch64/cortex_a53.S \
370 lib/cpus/aarch64/cortex_a57.S \
371 plat/common/plat_psci_common.c \
372 plat/renesas/rcar/plat_topology.c \
373 plat/renesas/rcar/aarch64/plat_helpers.S \
374 plat/renesas/rcar/aarch64/platform_common.c \
375 plat/renesas/rcar/bl31_plat_setup.c \
376 plat/renesas/rcar/plat_pm.c \
377 drivers/renesas/rcar/console/rcar_console.S \
378 drivers/renesas/rcar/console/rcar_printf.c \
379 drivers/renesas/rcar/pwrc/call_sram.S \
380 drivers/renesas/rcar/pwrc/pwrc.c \
381 drivers/renesas/rcar/common.c \
382 drivers/arm/cci/cci.c
383
384ifeq (${RCAR_GEN3_ULCB},1)
385BL31_SOURCES += drivers/renesas/rcar/cpld/ulcb_cpld.c
386endif
387
388include lib/xlat_tables_v2/xlat_tables.mk
389include drivers/auth/mbedtls/mbedtls_crypto.mk
390PLAT_BL_COMMON_SOURCES += ${XLAT_TABLES_LIB_SRCS}
391
392# build the layout images for the bootrom and the necessary srecords
393rcar: rcar_layout_tool rcar_srecord
394distclean realclean clean: clean_layout_tool clean_srecord
395
396# layout images
397LAYOUT_TOOLPATH ?= tools/renesas/rcar_layout_create
398
399clean_layout_tool:
400 @echo "clean layout tool"
401 ${Q}${MAKE} -C ${LAYOUT_TOOLPATH} clean
402
403.PHONY: rcar_layout_tool
404rcar_layout_tool:
405 @echo "generating layout srecs"
406 ${Q}${MAKE} CPPFLAGS="-D=AARCH64" --no-print-directory -C ${LAYOUT_TOOLPATH}
407
408# srecords
409SREC_PATH = ${BUILD_PLAT}
410BL2_ELF_SRC = ${SREC_PATH}/bl2/bl2.elf
411BL31_ELF_SRC = ${SREC_PATH}/bl31/bl31.elf
412
413clean_srecord:
414 @echo "clean bl2 and bl31 srecs"
415 rm -f ${SREC_PATH}/bl2.srec ${SREC_PATH}/bl31.srec
416
417.PHONY: rcar_srecord
Marek Vasut7043fce2018-12-31 19:47:37 +0100418rcar_srecord: $(BL2_ELF_SRC) $(BL31_ELF_SRC)
Jorge Ramirez-Ortizbf084dc2018-09-23 09:36:13 +0200419 @echo "generating srec: ${SREC_PATH}/bl2.srec"
420 $(Q)$(OC) -O srec --srec-forceS3 ${BL2_ELF_SRC} ${SREC_PATH}/bl2.srec
421 @echo "generating srec: ${SREC_PATH}/bl31.srec"
422 $(Q)$(OC) -O srec --srec-forceS3 ${BL31_ELF_SRC} ${SREC_PATH}/bl31.srec
423