]> git.ipfire.org Git - ipfire-2.x.git/blame - lfs/u-boot
suricata: Change midstream policy to "pass-flow"
[ipfire-2.x.git] / lfs / u-boot
CommitLineData
17d9546f
AF
1###############################################################################
2# #
3# IPFire.org - A linux based firewall #
ba145791 4# Copyright (C) 2007-2023 IPFire Team <info@ipfire.org> #
17d9546f
AF
5# #
6# This program is free software: you can redistribute it and/or modify #
7# it under the terms of the GNU General Public License as published by #
8# the Free Software Foundation, either version 3 of the License, or #
9# (at your option) any later version. #
10# #
11# This program is distributed in the hope that it will be useful, #
12# but WITHOUT ANY WARRANTY; without even the implied warranty of #
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
14# GNU General Public License for more details. #
15# #
16# You should have received a copy of the GNU General Public License #
17# along with this program. If not, see <http://www.gnu.org/licenses/>. #
18# #
19###############################################################################
20
21###############################################################################
22# Definitions
23###############################################################################
24
25include Config
26
6163e1b7 27VER = 2022.10
17d9546f 28
ddc492dd
MT
29THISAPP = u-boot-$(VER)
30DL_FILE = $(THISAPP).tar.bz2
17d9546f
AF
31DL_FROM = $(URL_IPFIRE)
32DIR_APP = $(DIR_SRC)/$(THISAPP)
2a0947f2 33TARGET = $(DIR_INFO)/$(THISAPP)-$(MKIMAGE)
39f94ee8 34SUP_ARCH = aarch64
17d9546f 35
1f38bac0 36CFLAGS := $(patsubst -fstack-protector-strong,,$(CFLAGS))
c0637090 37LDFLAGS += --no-warn-rwx-segments
1f38bac0 38
6163e1b7 39ATF_VER = 2.7
75c9d8c2 40
17d9546f
AF
41###############################################################################
42# Top-level Rules
43###############################################################################
44
706d8255 45objects = $(DL_FILE) arm-trusted-firmware-$(ATF_VER).tar.gz arm-trusted-firmware-$(ATF_VER)-rk3399-binary.tar.xz
17d9546f
AF
46
47$(DL_FILE) = $(DL_FROM)/$(DL_FILE)
75c9d8c2 48arm-trusted-firmware-$(ATF_VER).tar.gz = $(DL_FROM)/arm-trusted-firmware-$(ATF_VER).tar.gz
498ea595 49arm-trusted-firmware-$(ATF_VER)-rk3399-binary.tar.xz = $(DL_FROM)/arm-trusted-firmware-$(ATF_VER)-rk3399-binary.tar.xz
17d9546f 50
6163e1b7
AF
51$(DL_FILE)_BLAKE2 = 42aa7a6f131735888939982e579de4342e3909e064ab896b0df6f1ff56c20ed6cb11d25286da7c052a5f67dcef6fa7a746944d8df6dd504586f5a71502d157e1
52arm-trusted-firmware-$(ATF_VER).tar.gz_BLAKE2 = 4fc4d5646e272200d40081902e17f0be32956f451622f011a0d568c8cf26e15ab165fe16a69cf222241f7ba1d443add562d6d382277eb4fb2b49c3918cabdbad
53arm-trusted-firmware-$(ATF_VER)-rk3399-binary.tar.xz_BLAKE2 = 04424a7dcda0771f469c8e918a24aed75017c1a28c1b8c2c794e3ce31afbc01e7906ccab6faf1459d69a5ec1ef4fdde2bab1011b883980efeae7372013f2570e
17d9546f
AF
54
55install : $(TARGET)
56
57check : $(patsubst %,$(DIR_CHK)/%,$(objects))
58
59download :$(patsubst %,$(DIR_DL)/%,$(objects))
60
9a7e4d85 61b2 : $(subst %,%_BLAKE2,$(objects))
17d9546f
AF
62
63###############################################################################
9a7e4d85 64# Downloading, checking, b2sum
17d9546f
AF
65###############################################################################
66
67$(patsubst %,$(DIR_CHK)/%,$(objects)) :
68 @$(CHECK)
69
70$(patsubst %,$(DIR_DL)/%,$(objects)) :
71 @$(LOAD)
72
9a7e4d85
PM
73$(subst %,%_BLAKE2,$(objects)) :
74 @$(B2SUM)
17d9546f 75
66c36198 76dist:
17d9546f
AF
77 @$(PAK)
78
79###############################################################################
80# Installation Details
81###############################################################################
82
83$(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
84 @$(PREBUILD)
ddc492dd
MT
85 @rm -rf $(DIR_APP) && cd $(DIR_SRC) && tar axf $(DIR_DL)/$(DL_FILE)
86
963f6e97 87 # Raspberry Pi 3
184cbf9b 88 -mkdir -pv /usr/share/u-boot/rpi
963f6e97
AF
89 cd $(DIR_APP) && make CROSS_COMPILE="" rpi_3_config
90 cd $(DIR_APP) && sed -i -e 's!^CONFIG_IDENT_STRING=.*!CONFIG_IDENT_STRING=" RPi3 - IPFire.org"!' .config
91 cd $(DIR_APP) && make CROSS_COMPILE="" HOSTCC="gcc $(CFLAGS)"
92 cd $(DIR_APP) && install -v -m 644 u-boot.bin \
184cbf9b
AF
93 /usr/share/u-boot/rpi/u-boot-rpi3.bin
94 cd $(DIR_APP) && install u-boot.bin /boot/u-boot-rpi3.bin
ba145791 95 cd $(DIR_APP) && install -v -m 755 tools/mkimage /usr/bin
184cbf9b
AF
96 cd $(DIR_APP) && make distclean
97
98 # Raspberry Pi 4
99 -mkdir -pv /usr/share/u-boot/rpi
100 cd $(DIR_APP) && make CROSS_COMPILE="" rpi_4_config
101 cd $(DIR_APP) && sed -i -e 's!^CONFIG_IDENT_STRING=.*!CONFIG_IDENT_STRING=" RPi4 - IPFire.org"!' .config
102 cd $(DIR_APP) && make CROSS_COMPILE="" HOSTCC="gcc $(CFLAGS)"
103 cd $(DIR_APP) && install -v -m 644 u-boot.bin \
104 /usr/share/u-boot/rpi/u-boot-rpi4.bin
105 cd $(DIR_APP) && install u-boot.bin /boot/u-boot-rpi4.bin
963f6e97
AF
106 cd $(DIR_APP) && make distclean
107
d814021a
AF
108 # OrangePi Zero Plus
109 cd $(DIR_APP) && rm -rf arm-trusted-firmware-$(ATF_VER)
110 cd $(DIR_APP) && tar axf $(DIR_DL)/arm-trusted-firmware-$(ATF_VER).tar.gz
c0637090 111 cd $(DIR_APP)/arm-trusted-firmware-$(ATF_VER) && make PLAT=sun50i_a64 DEBUG=0 bl31 LDFLAGS="$(LDFLAGS)"
d814021a
AF
112 cd $(DIR_APP) && cp arm-trusted-firmware-$(ATF_VER)/build/sun50i_a64/release/bl31.bin bl31.bin
113 cd $(DIR_APP) && rm -rf arm-trusted-firmware-$(ATF_VER)
114 -mkdir -pv /usr/share/u-boot/orangepi_zero_plus
115 cd $(DIR_APP) && make CROSS_COMPILE="" orangepi_zero_plus_config
116 cd $(DIR_APP) && sed -i -e 's!^CONFIG_IDENT_STRING=.*!CONFIG_IDENT_STRING=" OrangePi Zero+ - IPFire.org"!' .config
117 cd $(DIR_APP) && make CROSS_COMPILE="" HOSTCC="gcc $(CFLAGS)"
118 cd $(DIR_APP) && install -v -m 644 u-boot-sunxi-with-spl.bin \
119 /usr/share/u-boot/orangepi_zero_plus
120 cd $(DIR_APP) && make distclean
121 cd $(DIR_APP) && rm -f bl31.bin
122
1f38bac0 123 # Nanopi R2S
75c9d8c2
AF
124 cd $(DIR_APP) && rm -rf arm-trusted-firmware-$(ATF_VER)
125 cd $(DIR_APP) && tar axf $(DIR_DL)/arm-trusted-firmware-$(ATF_VER).tar.gz
c0637090 126 cd $(DIR_APP)/arm-trusted-firmware-$(ATF_VER) && make PLAT=rk3328 ARCH=aarch64 DEBUG=0 bl31 LDFLAGS="$(LDFLAGS)"
75c9d8c2
AF
127 cd $(DIR_APP) && cp arm-trusted-firmware-$(ATF_VER)/build/rk3328/release/bl31/bl31.elf bl31.elf
128 cd $(DIR_APP) && rm -rf arm-trusted-firmware-$(ATF_VER)
dac49f1b 129 -mkdir -pv /usr/share/u-boot/nanopi_r2s
1f38bac0
AF
130 cd $(DIR_APP) && make CROSS_COMPILE="" nanopi-r2s-rk3328_config
131 cd $(DIR_APP) && sed -i -e 's!^CONFIG_IDENT_STRING=.*!CONFIG_IDENT_STRING=" Nanopi R2S - IPFire.org"!' .config
fe582c9d 132 cd $(DIR_APP) && sed -i -e 's!^CONFIG_BOOTCOMMAND=.*!CONFIG_BOOTCOMMAND="console=ttyS2,115200n8;run distro_bootcmd"!' .config
75c9d8c2 133 cd $(DIR_APP) && sed -i -e 's!^CONFIG_BAUDRATE=.*!CONFIG_BAUDRATE=115200!' .config
6163e1b7 134 cd $(DIR_APP) && sed -i -e 's!.*CONFIG_ENV_OVERWRITE.*!CONFIG_ENV_OVERWRITE=y!' .config
1f38bac0
AF
135 cd $(DIR_APP) && make CROSS_COMPILE="" HOSTCC="gcc $(CFLAGS)"
136 cd $(DIR_APP) && install -v -m 644 u-boot-rockchip.bin \
dac49f1b 137 /usr/share/u-boot/nanopi_r2s/u-boot-rockchip.bin
1f38bac0
AF
138 cd $(DIR_APP) && make distclean
139
0a7f6097 140 # Nanopi R2C
8b251380 141 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/u-boot/rockchip/add-nanopi-r2c-and-orangepi-r1-plus-lts.patch
0a7f6097
AF
142 cd $(DIR_APP) && rm -rf arm-trusted-firmware-$(ATF_VER)
143 cd $(DIR_APP) && tar axf $(DIR_DL)/arm-trusted-firmware-$(ATF_VER).tar.gz
144 cd $(DIR_APP)/arm-trusted-firmware-$(ATF_VER) && make PLAT=rk3328 ARCH=aarch64 DEBUG=0 bl31 LDFLAGS="$(LDFLAGS)"
145 cd $(DIR_APP) && cp arm-trusted-firmware-$(ATF_VER)/build/rk3328/release/bl31/bl31.elf bl31.elf
146 cd $(DIR_APP) && rm -rf arm-trusted-firmware-$(ATF_VER)
147 -mkdir -pv /usr/share/u-boot/nanopi_r2c
148
149 cd $(DIR_APP) && make CROSS_COMPILE="" nanopi-r2c-rk3328_config
150 cd $(DIR_APP) && sed -i -e 's!^CONFIG_IDENT_STRING=.*!CONFIG_IDENT_STRING=" Nanopi R2C - IPFire.org"!' .config
151 cd $(DIR_APP) && sed -i -e 's!^CONFIG_BOOTCOMMAND=.*!CONFIG_BOOTCOMMAND="console=ttyS2,115200n8;run distro_bootcmd"!' .config
152 cd $(DIR_APP) && sed -i -e 's!^CONFIG_BAUDRATE=.*!CONFIG_BAUDRATE=115200!' .config
153 cd $(DIR_APP) && sed -i -e 's!.*CONFIG_ENV_OVERWRITE.*!CONFIG_ENV_OVERWRITE=y!' .config
154 cd $(DIR_APP) && make CROSS_COMPILE="" HOSTCC="gcc $(CFLAGS)"
155 cd $(DIR_APP) && install -v -m 644 u-boot-rockchip.bin \
156 /usr/share/u-boot/nanopi_r2c/u-boot-rockchip.bin
157 cd $(DIR_APP) && make distclean
158
8b251380
AF
159 # Orangepi R1 plus lts
160 cd $(DIR_APP) && rm -rf arm-trusted-firmware-$(ATF_VER)
161 cd $(DIR_APP) && tar axf $(DIR_DL)/arm-trusted-firmware-$(ATF_VER).tar.gz
162 cd $(DIR_APP)/arm-trusted-firmware-$(ATF_VER) && make PLAT=rk3328 ARCH=aarch64 DEBUG=0 bl31 LDFLAGS="$(LDFLAGS)"
163 cd $(DIR_APP) && cp arm-trusted-firmware-$(ATF_VER)/build/rk3328/release/bl31/bl31.elf bl31.elf
164 cd $(DIR_APP) && rm -rf arm-trusted-firmware-$(ATF_VER)
165 -mkdir -pv /usr/share/u-boot/orangepi_r1_plus_lts
166
167 cd $(DIR_APP) && make CROSS_COMPILE="" orangepi-r1-plus-lts-rk3328_config
168 cd $(DIR_APP) && sed -i -e 's!^CONFIG_IDENT_STRING=.*!CONFIG_IDENT_STRING=" OrangePi R1 plus lts - IPFire.org"!' .config
169 cd $(DIR_APP) && sed -i -e 's!^CONFIG_BOOTCOMMAND=.*!CONFIG_BOOTCOMMAND="console=ttyS2,115200n8;run distro_bootcmd"!' .config
170 cd $(DIR_APP) && sed -i -e 's!^CONFIG_BAUDRATE=.*!CONFIG_BAUDRATE=115200!' .config
171 cd $(DIR_APP) && sed -i -e 's!.*CONFIG_ENV_OVERWRITE.*!CONFIG_ENV_OVERWRITE=y!' .config
172 cd $(DIR_APP) && make CROSS_COMPILE="" HOSTCC="gcc $(CFLAGS)"
173 cd $(DIR_APP) && install -v -m 644 u-boot-rockchip.bin \
174 /usr/share/u-boot/orangepi_r1_plus_lts/u-boot-rockchip.bin
175 cd $(DIR_APP) && make distclean
0a7f6097 176
75c9d8c2
AF
177 # Nanopi R4S
178 # arm trusted firmware for rk3399 cannot build without cortex m0 gcc crosscompiler
6163e1b7 179 # it is build on ubuntu with make PLAT=rk3399 ARCH=aarch64 DEBUG=0 bl31
7d5a7fea 180 cd $(DIR_APP) && tar axf $(DIR_DL)/arm-trusted-firmware-$(ATF_VER)-rk3399-binary.tar.xz
75c9d8c2
AF
181 -mkdir -pv /usr/share/u-boot/nanopi_r4s
182 cd $(DIR_APP) && make CROSS_COMPILE="" nanopi-r4s-rk3399_config
183 cd $(DIR_APP) && sed -i -e 's!^CONFIG_IDENT_STRING=.*!CONFIG_IDENT_STRING=" Nanopi R4S - IPFire.org"!' .config
184 cd $(DIR_APP) && sed -i -e 's!^CONFIG_BOOTCOMMAND=.*!CONFIG_BOOTCOMMAND="console=ttyS2,115200n8;run distro_bootcmd"!' .config
185 cd $(DIR_APP) && sed -i -e 's!^CONFIG_BAUDRATE=.*!CONFIG_BAUDRATE=115200!' .config
6163e1b7 186 cd $(DIR_APP) && sed -i -e 's!.*CONFIG_ENV_OVERWRITE.*!CONFIG_ENV_OVERWRITE=y!' .config
75c9d8c2
AF
187 cd $(DIR_APP) && make CROSS_COMPILE="" HOSTCC="gcc $(CFLAGS)"
188 cd $(DIR_APP) && install -v -m 644 u-boot-rockchip.bin \
189 /usr/share/u-boot/nanopi_r4s/u-boot-rockchip.bin
190 cd $(DIR_APP) && make distclean
191
2a0947f2
AF
192 # create an empty 128 KB File for the u-boot env
193 dd if=/dev/zero of=/boot/uboot.env bs=1K count=128
66c36198 194
2a0947f2 195 # config (uEnv.txt and boot.*)
56e211f6 196 cp -vf $(DIR_SRC)/config/u-boot/* /boot/
afa464fd
AF
197 # create signed binary boot script (boot.scr)
198 mkimage -C none -A arm -T script -d /boot/boot.cmd /boot/boot.scr
199
6cda03e8
AF
200 # patch real Kernel version to uEnv.txt
201 sed -e "s/xxxKVERxxx/$(KVER)/g" -i /boot/uEnv.txt
56e211f6 202
17d9546f
AF
203 @rm -rf $(DIR_APP)
204 @$(POSTBUILD)