]> git.ipfire.org Git - people/mlorenz/ipfire-2.x.git/blame - lfs/flash-images
add kernel driver patchset to support Raspberry PI 5
[people/mlorenz/ipfire-2.x.git] / lfs / flash-images
CommitLineData
52ca8220
AF
1###############################################################################
2# #
3# IPFire.org - A linux based firewall #
17aaad5d 4# Copyright (C) 2007-2022 IPFire Team <info@ipfire.org> #
52ca8220
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
27VER = ipfire
28
29THISAPP = flash-image
30TARGET = $(DIR_INFO)/$(THISAPP)
31
c42cbc86
MT
32DEVICE = $(shell losetup -f)
33PART_BOOT = /dev/mapper/$(patsubst /dev/%,%,$(DEVICE))p1
784cd5cb
MT
34ifeq "$(EFI)" "1"
35 PART_EFI = /dev/mapper/$(patsubst /dev/%,%,$(DEVICE))p2
36endif
05656571 37PART_ROOT = /dev/mapper/$(patsubst /dev/%,%,$(DEVICE))p3
c42cbc86 38
2e583372 39IMAGE_FILE = /install/images/$(SNAME)-$(VERSION)-core$(CORE)-$(BUILD_ARCH).img.xz
c42cbc86
MT
40
41FSTAB_FMT = UUID=%s %-8s %-4s %-10s %d %d\n
42
52ca8220
AF
43###############################################################################
44# Top-level Rules
45###############################################################################
46
47install : $(TARGET)
48
49check :
50
51download :
52
9a7e4d85 53b2 :
52ca8220
AF
54
55###############################################################################
56# Installation Details
57###############################################################################
7c62b3a5 58MNThdd := $(DIR_TMP)/harddisk
cf3ad73c 59IMG := /var/tmp/image.img
8a5ef45f
SS
60
61# All sizes in blocks
46a4581d 62ifeq "$(BUILD_PLATFORM)" "arm"
c42cbc86 63 BOOTLOADER =
8a5ef45f
SS
64 S_OFFSET = 8192
65
66 # FAT32
67 PART_TYPE = c
46a4581d
AF
68ifeq "$(BUILD_ARCH)" "aarch64"
69 BOOTLOADER = grub
954ac9df 70 S_OFFSET = 32768
46a4581d 71endif
8a5ef45f 72else
c42cbc86
MT
73 BOOTLOADER = grub
74 S_OFFSET = 8192
8a5ef45f 75
89e79c50 76 # Linux
8a5ef45f
SS
77 PART_TYPE = L
78endif
79
cf3ad73c
ML
80# all numbers are calculated as sectors with 512KB size
81# /boot: 1048576 = 512MB - OFFSET
82# / : 5242880 = 2.5GB - 2GB is not more enough
ffdc6fbb 83S_BOOT := $(shell echo $$(( 1048576 - $(S_OFFSET) )))
cf3ad73c 84S_ROOT := 5242880
89e79c50 85
784cd5cb 86ifeq "$(EFI)" "1"
e1bfac3e 87 S_EFI = 65536 # 64 MB
784cd5cb
MT
88else
89 S_EFI = 0
90endif
91
7051d2af
MT
92PADDING = 100 # MB
93
784cd5cb 94ifeq "$(EFI)" "1"
784cd5cb
MT
95 SFDISK = $(SFDISK_BOOT)$(SFDISK_EFI)$(SFDISK_ROOT)
96else
9023689d 97 SFDISK = $(SFDISK_BOOT),0,0\n$(SFDISK_ROOT)
784cd5cb
MT
98endif
99
89e79c50
MT
100SFDISK_BOOT = $(S_OFFSET),$(S_BOOT),$(PART_TYPE),*\n
101SFDISK_EFI = $(shell echo $$(( $(S_OFFSET) + $(S_BOOT) ))),$(S_EFI),U\n
102SFDISK_ROOT = $(shell echo $$(( $(S_OFFSET) + $(S_BOOT) + $(S_EFI) ))),$(S_ROOT),L\n
784cd5cb 103
52ca8220 104$(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
c42cbc86
MT
105 # Stop if $(MNThdd) is still mounted
106 mountpoint $(MNThdd) && exit 1 || exit 0
107
108 rm -rf $(IMG) $(MNThdd) && mkdir -p $(MNThdd)
109
110 # Allocate image on disk
784cd5cb 111 dd if=/dev/zero of=$(IMG) bs=512 count=$$(( $(S_OFFSET) + $(S_BOOT) + $(S_EFI) + $(S_ROOT) ))
c42cbc86 112 losetup $(DEVICE) $(IMG)
52ca8220 113
c42cbc86 114 # Write Partition table
784cd5cb
MT
115 echo -e "$(SFDISK)" | sfdisk -uS $(DEVICE)
116
c42cbc86 117 kpartx -v -a $(DEVICE)
52ca8220
AF
118
119 # Format them
8a5ef45f 120ifeq "$(PART_TYPE)" "c"
c42cbc86 121 mkfs.vfat $(PART_BOOT)
185f92e1 122else
c42cbc86 123 mkfs.ext2 -F $(PART_BOOT)
784cd5cb
MT
124endif
125ifeq "$(EFI)" "1"
126 mkfs.vfat $(PART_EFI)
185f92e1 127endif
c42cbc86 128 mkfs.ext4 -O ^has_journal,extent -F $(PART_ROOT)
52ca8220 129
e9b5c815
AF
130 # Most systems that use Flashimages has no RTC at boot
131 # so the interval check should disables
c42cbc86
MT
132 tune2fs -i0 $(PART_ROOT)
133
134 # Mount root partition
135 mount $(PART_ROOT) $(MNThdd)
e9b5c815 136
c42cbc86
MT
137 # Mount boot partition
138 mkdir -pv $(MNThdd)/boot
139 mount $(PART_BOOT) $(MNThdd)/boot
52ca8220 140
784cd5cb
MT
141ifeq "$(EFI)" "1"
142 mkdir -pv $(MNThdd)/boot/efi
143 mount $(PART_EFI) $(MNThdd)/boot/efi
144endif
145
52ca8220 146 # Install IPFire
dc7d6b20 147ifneq "$(BUILD_PLATFORM)" "arm"
5621b0ef 148 tar $(TAR_OPTIONS) -x --zstd -C $(MNThdd)/ -f $(DIR_TMP)/cdrom/distro.img
9b35b114 149else
b37678e9 150 tar $(TAR_OPTIONS) -x -C $(MNThdd)/ -f $(DIR_TMP)/cdrom/distro.img
9b35b114 151endif
185f92e1 152 -touch $(MNThdd)/lib/modules/$(KVER)-ipfire/modules.dep
52ca8220
AF
153 mkdir $(MNThdd)/proc
154 mount --bind /proc $(MNThdd)/proc
155 mount --bind /dev $(MNThdd)/dev
156 mount --bind /sys $(MNThdd)/sys
c42cbc86 157
52ca8220 158 chroot $(MNThdd) /usr/bin/perl -e "require '/var/ipfire/lang.pl'; &Lang::BuildCacheLang"
c42cbc86
MT
159
160 # Create /etc/fstab
161 printf "$(FSTAB_FMT)" "$$(blkid -o value -s UUID $(PART_BOOT))" "/boot" \
17aaad5d 162 "auto" "defaults,nodev,noexec,nosuid" 1 2 > $(MNThdd)/etc/fstab
784cd5cb
MT
163ifeq "$(EFI)" "1"
164 printf "$(FSTAB_FMT)" "$$(blkid -o value -s UUID $(PART_EFI))" "/boot/efi" \
165 "auto" "defaults" 1 2 >> $(MNThdd)/etc/fstab
166endif
c42cbc86
MT
167 printf "$(FSTAB_FMT)" "$$(blkid -o value -s UUID $(PART_ROOT))" "/" \
168 "auto" "defaults" 1 1 >> $(MNThdd)/etc/fstab
edc2be70 169
c42cbc86 170ifeq "$(BOOTLOADER)" "grub"
6b566244
AF
171 # backup defaults file
172 cp $(MNThdd)/etc/default/grub $(MNThdd)/etc/default/grub.backup
173
174 # Enable also serial console on GRUB
175 echo "GRUB_TERMINAL=\"serial console\"" >> $(MNThdd)/etc/default/grub
c42cbc86 176 echo "GRUB_SERIAL_COMMAND=\"serial --unit=0 --speed=115200\"" >> $(MNThdd)/etc/default/grub
52ca8220 177
6b566244
AF
178 # Add additional entry for Serial console
179 cp $(DIR_SRC)/config/flash-images/grub/11_linux_scon \
180 $(MNThdd)/etc/grub.d/
dfc4bc56 181
c42cbc86 182 # Create configuration
dfb0084e 183 mkdir -pv $(MNThdd)/boot/grub
b8b36e96 184 GRUB_FIRST_BOOT=true KERNEL_RELEASE="$(KVER)-ipfire" chroot $(MNThdd) \
dd730a39 185 grub-mkconfig -o /boot/grub/grub.cfg
9831c245 186
1f2a90b5
MT
187 # Boot the first kernel by default
188 chroot $(MNThdd) grub-set-default 0
189
38956241
AF
190 # Insert the UUID because grub-mkconfig often fails to
191 # detect that correctly
c42cbc86 192 sed -i $(MNThdd)/boot/grub/grub.cfg \
efd02229 193 -e "s/root=[A-Za-z0-9\/=-]*/root=UUID=$$(blkid -o value -s UUID $(PART_ROOT))/g"
52ca8220 194
a5c92f50 195ifeq "$(BUILD_PLATFORM)" "x86"
c42cbc86 196 # Install GRUB
5021ee33 197 grub-install --force --recheck --no-floppy --target=i386-pc \
c42cbc86 198 --root-directory=$(MNThdd) $(DEVICE)
a5c92f50 199endif
6b566244 200
7d456c39
MT
201ifeq "$(EFI)" "1"
202 # Install GRUB for EFI
a5c92f50 203 grub-install --target=$(GRUB_ARCH)-efi --removable --no-nvram \
7d456c39
MT
204 --boot-directory=$(MNThdd)/boot --efi-directory=$(MNThdd)/boot/efi
205endif
206
6b566244
AF
207 # restore orginal defaults
208 mv -f $(MNThdd)/etc/default/grub.backup $(MNThdd)/etc/default/grub
209 rm -f $(MNThdd)/etc/grub.d/11_linux_scon
185f92e1 210endif
52ca8220 211
2b6b6df3 212ifeq "$(BUILD_PLATFORM)" "arm"
e47e01f6
AF
213 # Insert the UUID to uENV.txt
214 sed -i $(MNThdd)/boot/uENV.txt \
215 -e "s/^root_dev=.*/root_dev=UUID=$$(blkid -o value -s UUID $(PART_ROOT))/g"
216endif
217
920f1950
AF
218 # Set ramdisk mode to automatic
219 echo RAMDISK_MODE=2 > $(MNThdd)/etc/sysconfig/ramdisk
220
a2454679
MT
221 # Automatically resize the root partition to its maximum size at first boot
222 touch $(MNThdd)/.partresize
223
c42cbc86
MT
224 # Unmount
225 umount $(MNThdd)/proc
226 umount $(MNThdd)/sys
227 umount $(MNThdd)/dev
784cd5cb
MT
228ifeq "$(EFI)" "1"
229 umount $(MNThdd)/boot/efi
230endif
52ca8220
AF
231 umount $(MNThdd)/boot
232 umount $(MNThdd)
233
c42cbc86 234 # zerofree the ext2 images to get better compression
8a5ef45f 235ifneq "$(PART_TYPE)" "c"
c42cbc86
MT
236 zerofree $(PART_BOOT)
237 -fsck.ext2 -f -y $(PART_BOOT)
238 fsck.ext2 -f -y $(PART_BOOT)
185f92e1 239endif
c42cbc86
MT
240 zerofree $(PART_ROOT)
241 -fsck.ext4 -f -y $(PART_ROOT)
242 fsck.ext4 -f -y $(PART_ROOT)
dfc4bc56 243
e0b9a600 244 sleep 10 #Ubuntu compiling: allow time to automount/dismount
c42cbc86
MT
245 kpartx -d -v $(DEVICE)
246 losetup -d $(DEVICE)
52ca8220 247
7051d2af
MT
248 # Add padding at the end of the image (to fix alignment issues if the image is
249 # not copied to a block device)
250 dd if=/dev/zero bs=1M count=$(PADDING) >> $(IMG)
251
954ac9df
AF
252ifeq "$(BUILD_ARCH)" "aarch64"
253 # Install u-boot for NanoPi R2S into image 8KB
254 dd if=/usr/share/u-boot/nanopi_r2s/u-boot-rockchip.bin of=$(IMG) bs=1K seek=32 conv=notrunc
255endif
56e211f6 256
52ca8220 257 # Compress Image
c4dd9dfc 258 xz $(XZ_OPT) < $(IMG) > $(IMAGE_FILE)
70e7351c 259 rm -rf $(IMG) $(MNThdd) $(DIR_TMP)/cdrom