blob: 6adfab164ee2fdf6a0f36082d4b21e0a706cecca [file] [log] [blame]
Neha Malcom Francis20a90042023-07-22 00:14:28 +05301// SPDX-License-Identifier: GPL-2.0
2/*
Tom Rinidec7ea02024-05-20 13:35:03 -06003 * Copyright (C) 2022-2024 Texas Instruments Incorporated - https://www.ti.com/
Neha Malcom Francis20a90042023-07-22 00:14:28 +05304 */
5
6#include "k3-binman.dtsi"
7
8#ifdef CONFIG_TARGET_J721E_R5_EVM
9
10&binman {
11 tiboot3-j721e_sr1_1-hs-evm.bin {
12 filename = "tiboot3-j721e_sr1_1-hs-evm.bin";
13 ti-secure-rom {
14 content = <&u_boot_spl>;
15 core = "public";
16 load = <CONFIG_SPL_TEXT_BASE>;
17 keyfile = "custMpk.pem";
18 };
19 u_boot_spl: u-boot-spl {
20 no-expanded;
21 };
22 };
Neha Malcom Francis20b15972023-12-20 17:04:33 +053023
24 tiboot3-j721e_sr2-hs-evm.bin {
25 filename = "tiboot3-j721e_sr2-hs-evm.bin";
26 ti-secure-rom {
27 content = <&u_boot_spl_sr2>;
28 core = "public";
29 load = <CONFIG_SPL_TEXT_BASE>;
30 keyfile = "custMpk.pem";
31 };
32 u_boot_spl_sr2: u-boot-spl {
33 no-expanded;
34 };
35 };
36
Neha Malcom Francis20a90042023-07-22 00:14:28 +053037 sysfw {
38 filename = "sysfw.bin";
39 ti-secure-rom {
40 content = <&ti_fs_cert>;
41 core = "secure";
42 load = <0x40000>;
43 keyfile = "custMpk.pem";
44 countersign;
45 };
46 ti_fs_cert: ti-fs-cert.bin {
47 filename = "ti-sysfw/ti-fs-firmware-j721e_sr1_1-hs-cert.bin";
48 type = "blob-ext";
49 optional;
50 };
51 ti-fs-firmware-j721e_sr1_1-hs-enc.bin {
52 filename = "ti-sysfw/ti-fs-firmware-j721e_sr1_1-hs-enc.bin";
53 type = "blob-ext";
54 optional;
55 };
56 };
Neha Malcom Francis20b15972023-12-20 17:04:33 +053057
58 sysfw_sr2 {
59 filename = "sysfw.bin_sr2";
60 ti-secure-rom {
61 content = <&ti_fs_cert_sr2>;
62 core = "secure";
63 load = <0x40000>;
64 keyfile = "custMpk.pem";
65 countersign;
66 };
67 ti_fs_cert_sr2: ti-fs-cert.bin {
68 filename = "ti-sysfw/ti-fs-firmware-j721e_sr2-hs-cert.bin";
69 type = "blob-ext";
70 optional;
71 };
72 ti-fs-firmware-j721e_sr2-hs-enc.bin {
73 filename = "ti-sysfw/ti-fs-firmware-j721e_sr2-hs-enc.bin";
74 type = "blob-ext";
75 optional;
76 };
77 };
78
Neha Malcom Francis20a90042023-07-22 00:14:28 +053079 itb {
80 filename = "sysfw-j721e_sr1_1-hs-evm.itb";
Neha Malcom Francis806b6f82023-11-15 15:40:24 +053081 insert-template = <&itb_template>;
Neha Malcom Francis20a90042023-07-22 00:14:28 +053082 };
Neha Malcom Francis20b15972023-12-20 17:04:33 +053083
84 itb_sr2 {
85 filename = "sysfw-j721e_sr2-hs-evm.itb";
86 insert-template = <&itb_template>;
87 fit {
88 images {
89 sysfw.bin {
90 blob-ext {
91 filename = "sysfw.bin_sr2";
92 };
93 };
94 board-cfg.bin {
95 ti-secure {
96 content = <&board_cfg_sr2>;
97 };
98 board_cfg_sr2: board-cfg {
99 filename = "board-cfg.bin";
100 };
101 };
102 pm-cfg.bin {
103 ti-secure {
104 content = <&pm_cfg_sr2>;
105 };
106 pm_cfg_sr2: pm-cfg {
107 filename = "pm-cfg.bin";
108 };
109 };
110 rm-cfg.bin {
111 ti-secure {
112 content = <&rm_cfg_sr2>;
113 };
114 rm_cfg_sr2: rm-cfg {
115 filename = "rm-cfg.bin";
116 };
117 };
118 sec-cfg.bin {
119 ti-secure {
120 content = <&sec_cfg_sr2>;
121 };
122 sec_cfg_sr2: sec-cfg {
123 filename = "sec-cfg.bin";
124 };
125 };
126
127 };
128 };
129 };
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530130};
131
132&binman {
Tom Rinidec7ea02024-05-20 13:35:03 -0600133 tiboot3-j721e_sr1_1-hs-fs-evm.bin {
134 filename = "tiboot3-j721e_sr1_1-hs-fs-evm.bin";
135 ti-secure-rom {
136 content = <&u_boot_spl_fs_sr1_1>;
137 core = "public";
138 core-opts = <2>;
139 load = <CONFIG_SPL_TEXT_BASE>;
140 keyfile = "custMpk.pem";
141 };
142 u_boot_spl_fs_sr1_1: u-boot-spl {
143 no-expanded;
144 };
145 };
146 sysfw_fs_sr1_1 {
147 filename = "sysfw.bin_fs_sr1_1";
148 ti-fs-cert-fs.bin {
149 filename = "ti-sysfw/ti-fs-firmware-j721e_sr1_1-hs-fs-cert.bin";
150 type = "blob-ext";
151 optional;
152 };
153 ti-fs-firmware-j721e-hs-fs-enc.bin {
154 filename = "ti-sysfw/ti-fs-firmware-j721e_sr1_1-hs-fs-enc.bin";
155 type = "blob-ext";
156 optional;
157 };
158 };
159 itb_fs_sr1_1 {
160 filename = "sysfw-j721e_sr1_1-hs-fs-evm.itb";
161 fit {
162 description = "SYSFW and Config fragments";
163 #address-cells = <1>;
164 images {
165 sysfw.bin {
166 description = "sysfw";
167 type = "firmware";
168 arch = "arm";
169 compression = "none";
170 blob-ext {
171 filename = "sysfw.bin_fs_sr1_1";
172 };
173 };
174 board-cfg.bin {
175 description = "board-cfg";
176 type = "firmware";
177 arch = "arm";
178 compression = "none";
179 board-cfg {
180 filename = "board-cfg.bin";
181 type = "blob-ext";
182 };
183
184 };
185 pm-cfg.bin {
186 description = "pm-cfg";
187 type = "firmware";
188 arch = "arm";
189 compression = "none";
190 pm-cfg {
191 filename = "pm-cfg.bin";
192 type = "blob-ext";
193 };
194 };
195 rm-cfg.bin {
196 description = "rm-cfg";
197 type = "firmware";
198 arch = "arm";
199 compression = "none";
200 rm-cfg {
201 filename = "rm-cfg.bin";
202 type = "blob-ext";
203 };
204 };
205 sec-cfg.bin {
206 description = "sec-cfg";
207 type = "firmware";
208 arch = "arm";
209 compression = "none";
210 sec-cfg {
211 filename = "sec-cfg.bin";
212 type = "blob-ext";
213 };
214 };
215 };
216 };
217 };
218};
219
220&binman {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530221 tiboot3-j721e_sr2-hs-fs-evm.bin {
222 filename = "tiboot3-j721e_sr2-hs-fs-evm.bin";
223 ti-secure-rom {
224 content = <&u_boot_spl_fs>;
225 core = "public";
226 load = <CONFIG_SPL_TEXT_BASE>;
227 keyfile = "custMpk.pem";
228 };
229 u_boot_spl_fs: u-boot-spl {
230 no-expanded;
231 };
232 };
233 sysfw_fs {
234 filename = "sysfw.bin_fs";
235 ti-fs-cert-fs.bin {
236 filename = "ti-sysfw/ti-fs-firmware-j721e_sr2-hs-fs-cert.bin";
237 type = "blob-ext";
238 optional;
239 };
240 ti-fs-firmware-j721e-hs-fs-enc.bin {
241 filename = "ti-sysfw/ti-fs-firmware-j721e_sr2-hs-fs-enc.bin";
242 type = "blob-ext";
243 optional;
244 };
245 };
246 itb_fs {
247 filename = "sysfw-j721e_sr2-hs-fs-evm.itb";
Neha Malcom Francis806b6f82023-11-15 15:40:24 +0530248 insert-template = <&itb_unsigned_template>;
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530249 };
250};
251
252&binman {
253 tiboot3-j721e-gp-evm.bin {
254 filename = "tiboot3-j721e-gp-evm.bin";
255 symlink = "tiboot3.bin";
256 ti-secure-rom {
257 content = <&u_boot_spl_unsigned>;
258 core = "public";
259 load = <CONFIG_SPL_TEXT_BASE>;
260 sw-rev = <CONFIG_K3_X509_SWRV>;
261 keyfile = "ti-degenerate-key.pem";
262 };
263 u_boot_spl_unsigned: u-boot-spl {
264 no-expanded;
265 };
266 };
267 sysfw_gp {
268 filename = "sysfw.bin_gp";
269 ti-secure-rom {
270 content = <&ti_fs>;
271 core = "secure";
272 load = <0x40000>;
273 sw-rev = <CONFIG_K3_X509_SWRV>;
274 keyfile = "ti-degenerate-key.pem";
275 };
276 ti_fs: ti-fs.bin {
277 filename = "ti-sysfw/ti-fs-firmware-j721e-gp.bin";
278 type = "blob-ext";
279 optional;
280 };
281 };
282 itb_gp {
283 filename = "sysfw-j721e-gp-evm.itb";
284 symlink = "sysfw.itb";
Neha Malcom Francis806b6f82023-11-15 15:40:24 +0530285 insert-template = <&itb_unsigned_template>;
286
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530287 fit {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530288 images {
289 sysfw.bin {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530290 blob-ext {
291 filename = "sysfw.bin_gp";
292 };
293 };
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530294 };
295 };
296 };
297};
Jonathan Humphreys324cb4d2024-05-31 17:51:05 -0500298
299#include "k3-binman-capsule-r5.dtsi"
300
301// Capsule update GUIDs in string form. See j721e_evm.h
302#define J721E_SK_TIBOOT3_IMAGE_GUID_STR "e672b518-7cd7-4014-bd8d-40724d0ad4dc"
303#define J721E_SK_SYSFW_IMAGE_GUID_STR "6fd10680-361b-431f-80aa-899455819e11"
304
305&capsule_tiboot3 {
306 efi-capsule {
307 image-guid = J721E_SK_TIBOOT3_IMAGE_GUID_STR;
308 };
309};
310
311&binman {
312 capsule-sysfw {
313 filename = "sysfw-capsule.bin";
314 efi-capsule {
315 image-index = <0x4>;
316 image-guid = J721E_SK_SYSFW_IMAGE_GUID_STR;
317 private-key = "arch/arm/mach-k3/keys/custMpk.pem";
318 public-key-cert = "arch/arm/mach-k3/keys/custMpk.crt";
319 monotonic-count = <0x1>;
320
321 blob {
322 filename = "sysfw.itb";
323 };
324 };
325 };
326};
327
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530328#endif
329
330#ifdef CONFIG_TARGET_J721E_A72_EVM
331
Neha Malcom Francis154bdbf2024-05-20 15:29:16 +0530332#define SPL_J721E_EVM_DTB "spl/dts/ti/k3-j721e-common-proc-board.dtb"
Manorit Chawdhry64ebddb2023-07-14 11:22:38 +0530333#define J721E_EVM_DTB "u-boot.dtb"
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530334
335&binman {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530336 ti-spl {
Neha Malcom Francis806b6f82023-11-15 15:40:24 +0530337 insert-template = <&ti_spl_template>;
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530338
339 fit {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530340 images {
Manorit Chawdhry5fa5cd42023-12-29 16:16:29 +0530341 atf {
342 ti-secure {
343 auth-in-place = <0xa02>;
344
345 firewall-257-0 {
346 /* cpu_0_cpu_0_msmc Background Firewall */
347 insert-template = <&firewall_bg_1>;
348 id = <257>;
349 region = <0>;
350 };
351
352 firewall-257-1 {
353 /* cpu_0_cpu_0_msmc Foreground Firewall */
354 insert-template = <&firewall_armv8_atf_fg>;
355 id = <257>;
356 region = <1>;
357 };
358
359 firewall-284-0 {
360 /* dru_0_msmc Background Firewall */
361 insert-template = <&firewall_bg_3>;
362 id = <284>;
363 region = <0>;
364 };
365
366 firewall-284-1 {
367 /* dru_0_msmc Foreground Firewall */
368 insert-template = <&firewall_armv8_atf_fg>;
369 id = <284>;
370 region = <1>;
371 };
372
373 /* firewall-4760-0 {
374 * nb_slv0__mem0 Background Firewall
375 * Already configured by the secure entity
376 * };
377 */
378
379 firewall-4760-1 {
380 /* nb_slv0__mem0 Foreground Firewall */
381 insert-template = <&firewall_armv8_atf_fg>;
382 id = <4760>;
383 region = <1>;
384 };
385
386 /* firewall-4761-0 {
387 * nb_slv1__mem0 Background Firewall
388 * Already configured by the secure entity
389 * };
390 */
391
392 firewall-4761-1 {
393 /* nb_slv1__mem0 Foreground Firewall */
394 insert-template = <&firewall_armv8_atf_fg>;
395 id = <4761>;
396 region = <1>;
397 };
398
399 };
400 };
401
402 tee {
403 ti-secure {
404 auth-in-place = <0xa02>;
405
406 /* cpu_0_cpu_0_msmc region 0 and 1 configured
407 * during ATF Firewalling
408 */
409
410 firewall-257-2 {
411 /* cpu_0_cpu_0_msmc Foreground Firewall */
412 insert-template = <&firewall_armv8_optee_fg>;
413 id = <257>;
414 region = <2>;
415 };
416
417 /* dru_0_msmc region 0 and 1 configured
418 * during ATF Firewalling
419 */
420
421 firewall-284-2 {
422 /* dru_0_msmc Foreground Firewall */
423 insert-template = <&firewall_armv8_optee_fg>;
424 id = <284>;
425 region = <2>;
426 };
427
428 firewall-4762-0 {
429 /* nb_slv2__mem0 Background Firewall */
430 insert-template = <&firewall_bg_3>;
431 id = <4762>;
432 region = <0>;
433 };
434
435 firewall-4762-1 {
436 /* nb_slv2__mem0 Foreground Firewall */
437 insert-template = <&firewall_armv8_optee_fg>;
438 id = <4762>;
439 region = <1>;
440 };
441
442 firewall-4763-0 {
443 /* nb_slv3__mem0 Background Firewall */
444 insert-template = <&firewall_bg_3>;
445 id = <4763>;
446 region = <0>;
447 };
448
449 firewall-4763-1 {
450 /* nb_slv3__mem0 Foreground Firewall */
451 insert-template = <&firewall_armv8_optee_fg>;
452 id = <4763>;
453 region = <1>;
454 };
455 };
456 };
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530457 dm {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530458 ti-secure {
459 content = <&dm>;
460 keyfile = "custMpk.pem";
461 };
Neha Malcom Francis82378212023-12-05 15:12:19 +0530462 dm: ti-dm {
Andrew Davis7ed4a852025-04-25 17:54:03 -0500463 filename = "ti-dm/j721e/ipc_echo_testb_mcu1_0_release_strip.xer5f";
464 optional;
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530465 };
466 };
467
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530468 fdt-0 {
469 description = "k3-j721e-common-proc-board";
470 type = "flat_dt";
471 arch = "arm";
472 compression = "none";
473 ti-secure {
Neha Malcom Francisa4515b02024-05-20 15:29:15 +0530474 content = <&spl_j721e_dtb>;
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530475 keyfile = "custMpk.pem";
476 };
Neha Malcom Francisa4515b02024-05-20 15:29:15 +0530477 spl_j721e_dtb: blob-ext {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530478 filename = SPL_J721E_EVM_DTB;
479 };
480 };
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530481 };
482
483 configurations {
484 default = "conf-0";
485
486 conf-0 {
487 description = "k3-j721e-common-proc-board";
488 firmware = "atf";
489 loadables = "tee", "dm", "spl";
490 fdt = "fdt-0";
491 };
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530492 };
493 };
494 };
495};
496
497&binman {
498 u-boot {
Neha Malcom Francis806b6f82023-11-15 15:40:24 +0530499 insert-template = <&u_boot_template>;
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530500 fit {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530501
502 images {
503 uboot {
Neha Malcom Francis806b6f82023-11-15 15:40:24 +0530504 description = "U-Boot for J721E Board";
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530505 };
506
507 fdt-0 {
508 description = "k3-j721e-common-proc-board";
509 type = "flat_dt";
510 arch = "arm";
511 compression = "none";
512 ti-secure {
Neha Malcom Francisa4515b02024-05-20 15:29:15 +0530513 content = <&j721e_dtb>;
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530514 keyfile = "custMpk.pem";
515
516 };
Neha Malcom Francisa4515b02024-05-20 15:29:15 +0530517 j721e_dtb: blob-ext {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530518 filename = J721E_EVM_DTB;
519 };
520 hash {
521 algo = "crc32";
522 };
523 };
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530524 };
525
526 configurations {
527 default = "conf-0";
528
529 conf-0 {
530 description = "k3-j721e-common-proc-board";
531 firmware = "uboot";
532 loadables = "uboot";
533 fdt = "fdt-0";
534 };
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530535 };
536 };
537 };
538};
539
540&binman {
541 ti-spl_unsigned {
Neha Malcom Francis806b6f82023-11-15 15:40:24 +0530542 insert-template = <&ti_spl_unsigned_template>;
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530543
544 fit {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530545 images {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530546 dm {
Neha Malcom Francis82378212023-12-05 15:12:19 +0530547 ti-dm {
Andrew Davis7ed4a852025-04-25 17:54:03 -0500548 filename = "ti-dm/j721e/ipc_echo_testb_mcu1_0_release_strip.xer5f";
549 optional;
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530550 };
551 };
552
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530553 fdt-0 {
554 description = "k3-j721e-common-proc-board";
555 type = "flat_dt";
556 arch = "arm";
557 compression = "none";
Neha Malcom Francisa4515b02024-05-20 15:29:15 +0530558 spl_j721e_dtb_unsigned: blob {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530559 filename = SPL_J721E_EVM_DTB;
560 };
561 };
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530562 };
563
564 configurations {
565 default = "conf-0";
566
567 conf-0 {
568 description = "k3-j721e-common-proc-board";
569 firmware = "atf";
570 loadables = "tee", "dm", "spl";
571 fdt = "fdt-0";
572 };
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530573 };
574 };
575 };
576};
577
578&binman {
579 u-boot_unsigned {
Neha Malcom Francis806b6f82023-11-15 15:40:24 +0530580 insert-template = <&u_boot_unsigned_template>;
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530581
582 fit {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530583 images {
584 uboot {
Neha Malcom Francis806b6f82023-11-15 15:40:24 +0530585 description = "U-Boot for J721E Board";
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530586 };
587
588 fdt-0 {
589 description = "k3-j721e-common-proc-board";
590 type = "flat_dt";
591 arch = "arm";
592 compression = "none";
Neha Malcom Francisa4515b02024-05-20 15:29:15 +0530593 j721e_dtb_unsigned: blob {
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530594 filename = J721E_EVM_DTB;
595 };
596 hash {
597 algo = "crc32";
598 };
599 };
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530600 };
601
602 configurations {
603 default = "conf-0";
604
605 conf-0 {
606 description = "k3-j721e-common-proc-board";
607 firmware = "uboot";
608 loadables = "uboot";
609 fdt = "fdt-0";
610 };
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530611 };
612 };
613 };
614};
Jonathan Humphreys324cb4d2024-05-31 17:51:05 -0500615
616#include "k3-binman-capsule.dtsi"
617
618// Capsule update GUIDs in string form. See j721e_evm.h
619#define J721E_SK_SPL_IMAGE_GUID_STR "86f710ad-10cf-46ea-ac67-856ae06efad2"
620#define J721E_SK_UBOOT_IMAGE_GUID_STR "81b58fb0-3b00-4add-a20a-c185bbaca1ed"
621
622&capsule_tispl {
623 efi-capsule {
624 image-guid = J721E_SK_SPL_IMAGE_GUID_STR;
625 };
626};
627
628&capsule_uboot {
629 efi-capsule {
630 image-guid = J721E_SK_UBOOT_IMAGE_GUID_STR;
631 };
632};
633
Neha Malcom Francis20a90042023-07-22 00:14:28 +0530634#endif