blob: 592be7f670664c32f1e190966bb15a1796770069 [file] [log] [blame]
Michal Simeka7178b72019-10-02 15:55:57 +02001#!/bin/sh
2# SPDX-License-Identifier: GPL-2.0+
3#
4# script to generate FIT image source for Xilinx ZynqMP boards with
5# ARM Trusted Firmware and multiple device trees (given on the command line)
6#
7# usage: $0 <dt_name> [<dt_name> [<dt_name] ...]
8
9BL33="u-boot-nodtb.bin"
10[ -z "$BL31" ] && BL31="bl31.bin"
Michal Simekf0887502021-05-31 11:13:45 +020011BL31_ELF="${BL31%.*}.elf"
12[ -f ${BL31_ELF} ] && ATF_LOAD_ADDR=`${CROSS_COMPILE}readelf -l "${BL31_ELF}" | \
13awk '/Entry point/ { print $3 }'`
14
Michal Simeka7178b72019-10-02 15:55:57 +020015[ -z "$ATF_LOAD_ADDR" ] && ATF_LOAD_ADDR="0xfffea000"
Michal Simek48bd9ba2021-06-07 12:37:32 +020016ATF_LOAD_ADDR_LOW=`printf 0x%x $((ATF_LOAD_ADDR & 0xffffffff))`
17ATF_LOAD_ADDR_HIGH=`printf 0x%x $((ATF_LOAD_ADDR >> 32))`
Michal Simeka7178b72019-10-02 15:55:57 +020018
Michal Simekf0887502021-05-31 11:13:45 +020019[ -z "$BL32" ] && BL32="tee.bin"
20BL32_ELF="${BL32%.*}.elf"
21[ -f ${BL32_ELF} ] && TEE_LOAD_ADDR=`${CROSS_COMPILE}readelf -l "${BL32_ELF}" | \
22awk '/Entry point/ { print $3 }'`
23
24[ -z "$TEE_LOAD_ADDR" ] && TEE_LOAD_ADDR="0x60000000"
Michal Simek48bd9ba2021-06-07 12:37:32 +020025TEE_LOAD_ADDR_LOW=`printf 0x%x $((TEE_LOAD_ADDR & 0xffffffff))`
26TEE_LOAD_ADDR_HIGH=`printf 0x%x $((TEE_LOAD_ADDR >> 32))`
Michal Simekf0887502021-05-31 11:13:45 +020027
Michal Simeka7178b72019-10-02 15:55:57 +020028if [ -z "$BL33_LOAD_ADDR" ];then
29 BL33_LOAD_ADDR=`awk '/CONFIG_SYS_TEXT_BASE/ { print $3 }' include/generated/autoconf.h`
30fi
Michal Simek48bd9ba2021-06-07 12:37:32 +020031BL33_LOAD_ADDR_LOW=`printf 0x%x $((BL33_LOAD_ADDR & 0xffffffff))`
32BL33_LOAD_ADDR_HIGH=`printf 0x%x $((BL33_LOAD_ADDR >> 32))`
Michal Simeka7178b72019-10-02 15:55:57 +020033
34DTB_LOAD_ADDR=`awk '/CONFIG_XILINX_OF_BOARD_DTB_ADDR/ { print $3 }' include/generated/autoconf.h`
35if [ ! -z "$DTB_LOAD_ADDR" ]; then
Michal Simek48bd9ba2021-06-07 12:37:32 +020036 DTB_LOAD_ADDR_LOW=`printf 0x%x $((DTB_LOAD_ADDR & 0xffffffff))`
37 DTB_LOAD_ADDR_HIGH=`printf 0x%x $((DTB_LOAD_ADDR >> 32))`
38 DTB_LOAD="load = <$DTB_LOAD_ADDR_HIGH $DTB_LOAD_ADDR_LOW>;"
Michal Simeka7178b72019-10-02 15:55:57 +020039else
40 DTB_LOAD=""
41fi
42
43if [ -z "$*" ]; then
44 DT=arch/arm/dts/${DEVICE_TREE}.dtb
45else
46 DT=$*
47fi
48
49if [ ! -f $BL31 ]; then
Michal Simekcf73de12020-03-23 14:40:52 +010050 echo "WARNING: BL31 file $BL31 NOT found, U-Boot will run in EL3" >&2
Michal Simeka7178b72019-10-02 15:55:57 +020051 BL31=/dev/null
Michal Simeka7178b72019-10-02 15:55:57 +020052fi
53
54cat << __HEADER_EOF
55// SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
56
57/dts-v1/;
58
59/ {
60 description = "Configuration to load ATF before U-Boot";
61
62 images {
63 uboot {
64 description = "U-Boot (64-bit)";
65 data = /incbin/("$BL33");
66 type = "firmware";
67 os = "u-boot";
68 arch = "arm64";
69 compression = "none";
Michal Simek48bd9ba2021-06-07 12:37:32 +020070 load = <$BL33_LOAD_ADDR_HIGH $BL33_LOAD_ADDR_LOW>;
71 entry = <$BL33_LOAD_ADDR_HIGH $BL33_LOAD_ADDR_LOW>;
Michal Simeka7178b72019-10-02 15:55:57 +020072 hash {
73 algo = "md5";
74 };
75 };
Michal Simekcf73de12020-03-23 14:40:52 +010076__HEADER_EOF
77
78if [ -f $BL31 ]; then
79cat << __ATF
Michal Simeka7178b72019-10-02 15:55:57 +020080 atf {
81 description = "ARM Trusted Firmware";
82 data = /incbin/("$BL31");
83 type = "firmware";
84 os = "arm-trusted-firmware";
85 arch = "arm64";
86 compression = "none";
Michal Simek48bd9ba2021-06-07 12:37:32 +020087 load = <$ATF_LOAD_ADDR_HIGH $ATF_LOAD_ADDR_LOW>;
88 entry = <$ATF_LOAD_ADDR_HIGH $ATF_LOAD_ADDR_LOW>;
Michal Simeka7178b72019-10-02 15:55:57 +020089 hash {
90 algo = "md5";
91 };
92 };
Michal Simekcf73de12020-03-23 14:40:52 +010093__ATF
94fi
Michal Simeka7178b72019-10-02 15:55:57 +020095
Michal Simekf0887502021-05-31 11:13:45 +020096if [ -f $BL32 ]; then
97cat << __TEE
98 tee {
99 description = "TEE firmware";
100 data = /incbin/("$BL32");
101 type = "firmware";
102 os = "tee";
103 arch = "arm64";
104 compression = "none";
Michal Simek48bd9ba2021-06-07 12:37:32 +0200105 load = <$TEE_LOAD_ADDR_HIGH $TEE_LOAD_ADDR_LOW>;
106 entry = <$TEE_LOAD_ADDR_HIGH $TEE_LOAD_ADDR_LOW>;
Michal Simekf0887502021-05-31 11:13:45 +0200107 hash {
108 algo = "md5";
109 };
110 };
111__TEE
112fi
113
Michal Simeka7178b72019-10-02 15:55:57 +0200114DEFAULT=1
115cnt=1
116for dtname in $DT
117do
118 cat << __FDT_IMAGE_EOF
119 fdt_$cnt {
120 description = "$(basename $dtname .dtb)";
121 data = /incbin/("$dtname");
122 type = "flat_dt";
123 arch = "arm64";
124 compression = "none";
125 $DTB_LOAD
126 hash {
127 algo = "md5";
128 };
129 };
130__FDT_IMAGE_EOF
131
132[ "x$(basename $dtname .dtb)" = "x${DEVICE_TREE}" ] && DEFAULT=$cnt
133
134cnt=$((cnt+1))
135done
136
137cat << __CONF_HEADER_EOF
138 };
139 configurations {
140 default = "config_$DEFAULT";
141
142__CONF_HEADER_EOF
143
144cnt=1
145for dtname in $DT
146do
Michal Simekcf73de12020-03-23 14:40:52 +0100147if [ ! -f $BL31 ]; then
148cat << __CONF_SECTION1_EOF
149 config_$cnt {
150 description = "$(basename $dtname .dtb)";
151 firmware = "uboot";
152 fdt = "fdt_$cnt";
153 };
154__CONF_SECTION1_EOF
155else
Michal Simekf0887502021-05-31 11:13:45 +0200156if [ -f $BL32 ]; then
157cat << __CONF_SECTION1_EOF
158 config_$cnt {
159 description = "$(basename $dtname .dtb)";
160 firmware = "atf";
161 loadables = "uboot", "tee";
162 fdt = "fdt_$cnt";
163 };
164__CONF_SECTION1_EOF
165else
Michal Simeka7178b72019-10-02 15:55:57 +0200166cat << __CONF_SECTION1_EOF
167 config_$cnt {
168 description = "$(basename $dtname .dtb)";
169 firmware = "atf";
170 loadables = "uboot";
171 fdt = "fdt_$cnt";
172 };
173__CONF_SECTION1_EOF
Michal Simekcf73de12020-03-23 14:40:52 +0100174fi
Michal Simekf0887502021-05-31 11:13:45 +0200175fi
Michal Simekcf73de12020-03-23 14:40:52 +0100176
Michal Simeka7178b72019-10-02 15:55:57 +0200177cnt=$((cnt+1))
178done
179
180cat << __ITS_EOF
181 };
182};
183__ITS_EOF