]> git.ipfire.org Git - ipfire-2.x.git/blame - lfs/flash-images
flash-images: Mark the /boot partition as bootable
[ipfire-2.x.git] / lfs / flash-images
CommitLineData
52ca8220
AF
1###############################################################################
2# #
3# IPFire.org - A linux based firewall #
ea9d53c8 4# Copyright (C) 2007-2018 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
b302b9a6 39IMAGE_FILE = /install/images/$(SNAME)-$(VERSION).2gb-ext4.$(BUILD_ARCH)-full-core$(CORE).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
53md5 :
54
55###############################################################################
56# Installation Details
57###############################################################################
52ca8220 58MNThdd := /install/harddisk
c42cbc86 59IMG := /install/images/image.img
8a5ef45f
SS
60
61# All sizes in blocks
dc7d6b20 62ifeq "$(BUILD_PLATFORM)" "arm"
c42cbc86 63 BOOTLOADER =
8a5ef45f
SS
64 S_OFFSET = 8192
65
66 # FAT32
67 PART_TYPE = c
68else
c42cbc86
MT
69 BOOTLOADER = grub
70 S_OFFSET = 8192
8a5ef45f
SS
71
72 # Logical
73 PART_TYPE = L
74endif
75
784cd5cb
MT
76ifeq "$(EFI)" "1"
77 S_EFI = 204800
784cd5cb
MT
78else
79 S_EFI = 0
80endif
81
779706b5 82# /boot: 128MB - OFFSET
02c36af4 83# / : 1200 MB
779706b5 84S_BOOT := $(shell echo $$(( 262144 - $(S_OFFSET) )))
02c36af4 85S_ROOT := 2477600
52ca8220 86
7051d2af
MT
87PADDING = 100 # MB
88
784cd5cb 89ifeq "$(EFI)" "1"
8662e981 90 SFDISK_EFI = $(S_OFFSET),$(S_EFI),U\n
784cd5cb
MT
91 SFDISK = $(SFDISK_BOOT)$(SFDISK_EFI)$(SFDISK_ROOT)
92else
93 SFDISK_SWAP = ,0,0\n
94 SFDISK = $(SFDISK_BOOT)$(SFDISK_SWAP)$(SFDISK_ROOT)
95endif
96
8662e981 97SFDISK_BOOT = $(shell echo $$(( $(S_OFFSET) + $(S_EFI) ))),$(S_BOOT),$(PART_TYPE),*\n
784cd5cb
MT
98SFDISK_ROOT = $(shell echo $$(( $(S_OFFSET) + $(S_EFI) + $(S_BOOT) ))),$(S_ROOT),L\n
99
52ca8220 100$(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
c42cbc86
MT
101 # Stop if $(MNThdd) is still mounted
102 mountpoint $(MNThdd) && exit 1 || exit 0
103
104 rm -rf $(IMG) $(MNThdd) && mkdir -p $(MNThdd)
105
106 # Allocate image on disk
784cd5cb 107 dd if=/dev/zero of=$(IMG) bs=512 count=$$(( $(S_OFFSET) + $(S_BOOT) + $(S_EFI) + $(S_ROOT) ))
c42cbc86 108 losetup $(DEVICE) $(IMG)
52ca8220 109
c42cbc86 110 # Write Partition table
784cd5cb
MT
111 echo -e "$(SFDISK)" | sfdisk -uS $(DEVICE)
112
113 # Remove 2nd empty partition
114ifneq "$(EFI)" "1"
025e1fe1 115 -echo -e "d\n2\nw\n\q\n" | fdisk $(DEVICE)
784cd5cb 116endif
52ca8220 117
c42cbc86 118 kpartx -v -a $(DEVICE)
52ca8220
AF
119
120 # Format them
8a5ef45f 121ifeq "$(PART_TYPE)" "c"
c42cbc86 122 mkfs.vfat $(PART_BOOT)
185f92e1 123else
c42cbc86 124 mkfs.ext2 -F $(PART_BOOT)
784cd5cb
MT
125endif
126ifeq "$(EFI)" "1"
127 mkfs.vfat $(PART_EFI)
185f92e1 128endif
c42cbc86 129 mkfs.ext4 -O ^has_journal,extent -F $(PART_ROOT)
52ca8220 130
e9b5c815
AF
131 # Most systems that use Flashimages has no RTC at boot
132 # so the interval check should disables
c42cbc86
MT
133 tune2fs -i0 $(PART_ROOT)
134
135 # Mount root partition
136 mount $(PART_ROOT) $(MNThdd)
e9b5c815 137
c42cbc86
MT
138 # Mount boot partition
139 mkdir -pv $(MNThdd)/boot
140 mount $(PART_BOOT) $(MNThdd)/boot
52ca8220 141
784cd5cb
MT
142ifeq "$(EFI)" "1"
143 mkdir -pv $(MNThdd)/boot/efi
144 mount $(PART_EFI) $(MNThdd)/boot/efi
145endif
146
56e211f6 147 # Install Pandaboard MLO and uboot first
a649b645 148ifeq "$(BUILD_ARCH)" "armv5tel"
9831c245 149 cp -v /boot/MLO $(MNThdd)/boot/
7284262a 150 cp -v /boot/u-boot.img $(MNThdd)/boot/
9831c245
AF
151 sync
152 umount $(MNThdd)/boot
c42cbc86 153 mount $(PART_BOOT) $(MNThdd)/boot
9831c245
AF
154endif
155
52ca8220 156 # Install IPFire
dc7d6b20 157ifneq "$(BUILD_PLATFORM)" "arm"
c061d66f 158 tar -x --xz -C $(MNThdd)/ -f /install/cdrom/distro.img
9b35b114
AF
159else
160 tar -x -C $(MNThdd)/ -f /install/cdrom/distro.img
161endif
185f92e1 162 -touch $(MNThdd)/lib/modules/$(KVER)-ipfire/modules.dep
52ca8220
AF
163 mkdir $(MNThdd)/proc
164 mount --bind /proc $(MNThdd)/proc
165 mount --bind /dev $(MNThdd)/dev
166 mount --bind /sys $(MNThdd)/sys
c42cbc86 167
52ca8220 168 chroot $(MNThdd) /usr/bin/perl -e "require '/var/ipfire/lang.pl'; &Lang::BuildCacheLang"
c42cbc86
MT
169
170 # Create /etc/fstab
171 printf "$(FSTAB_FMT)" "$$(blkid -o value -s UUID $(PART_BOOT))" "/boot" \
172 "auto" "defaults" 1 2 > $(MNThdd)/etc/fstab
784cd5cb
MT
173ifeq "$(EFI)" "1"
174 printf "$(FSTAB_FMT)" "$$(blkid -o value -s UUID $(PART_EFI))" "/boot/efi" \
175 "auto" "defaults" 1 2 >> $(MNThdd)/etc/fstab
176endif
c42cbc86
MT
177 printf "$(FSTAB_FMT)" "$$(blkid -o value -s UUID $(PART_ROOT))" "/" \
178 "auto" "defaults" 1 1 >> $(MNThdd)/etc/fstab
edc2be70 179
c42cbc86 180ifeq "$(BOOTLOADER)" "grub"
6b566244
AF
181 # backup defaults file
182 cp $(MNThdd)/etc/default/grub $(MNThdd)/etc/default/grub.backup
183
184 # Enable also serial console on GRUB
185 echo "GRUB_TERMINAL=\"serial console\"" >> $(MNThdd)/etc/default/grub
c42cbc86 186 echo "GRUB_SERIAL_COMMAND=\"serial --unit=0 --speed=115200\"" >> $(MNThdd)/etc/default/grub
52ca8220 187
6b566244
AF
188 # Add additional entry for Serial console
189 cp $(DIR_SRC)/config/flash-images/grub/11_linux_scon \
190 $(MNThdd)/etc/grub.d/
dfc4bc56 191
c42cbc86 192 # Create configuration
dfb0084e
MT
193 mkdir -pv $(MNThdd)/boot/grub
194 chroot $(MNThdd) grub-mkconfig -o /boot/grub/grub.cfg
9831c245 195
1f2a90b5
MT
196 # Boot the first kernel by default
197 chroot $(MNThdd) grub-set-default 0
198
38956241
AF
199 # Insert the UUID because grub-mkconfig often fails to
200 # detect that correctly
c42cbc86 201 sed -i $(MNThdd)/boot/grub/grub.cfg \
efd02229 202 -e "s/root=[A-Za-z0-9\/=-]*/root=UUID=$$(blkid -o value -s UUID $(PART_ROOT))/g"
52ca8220 203
c42cbc86 204 # Install GRUB
5021ee33 205 grub-install --force --recheck --no-floppy --target=i386-pc \
c42cbc86 206 --root-directory=$(MNThdd) $(DEVICE)
6b566244 207
7d456c39
MT
208ifeq "$(EFI)" "1"
209 # Install GRUB for EFI
210 grub-install --target=$(BUILD_ARCH)-efi --removable --no-nvram \
211 --boot-directory=$(MNThdd)/boot --efi-directory=$(MNThdd)/boot/efi
212endif
213
6b566244
AF
214 # restore orginal defaults
215 mv -f $(MNThdd)/etc/default/grub.backup $(MNThdd)/etc/default/grub
216 rm -f $(MNThdd)/etc/grub.d/11_linux_scon
185f92e1 217endif
52ca8220 218
920f1950
AF
219 # Set ramdisk mode to automatic
220 echo RAMDISK_MODE=2 > $(MNThdd)/etc/sysconfig/ramdisk
221
a2454679
MT
222 # Automatically resize the root partition to its maximum size at first boot
223 touch $(MNThdd)/.partresize
224
c42cbc86
MT
225 # Unmount
226 umount $(MNThdd)/proc
227 umount $(MNThdd)/sys
228 umount $(MNThdd)/dev
784cd5cb
MT
229ifeq "$(EFI)" "1"
230 umount $(MNThdd)/boot/efi
231endif
52ca8220
AF
232 umount $(MNThdd)/boot
233 umount $(MNThdd)
234
c42cbc86 235 # zerofree the ext2 images to get better compression
8a5ef45f 236ifneq "$(PART_TYPE)" "c"
c42cbc86
MT
237 zerofree $(PART_BOOT)
238 -fsck.ext2 -f -y $(PART_BOOT)
239 fsck.ext2 -f -y $(PART_BOOT)
185f92e1 240endif
c42cbc86
MT
241 zerofree $(PART_ROOT)
242 -fsck.ext4 -f -y $(PART_ROOT)
243 fsck.ext4 -f -y $(PART_ROOT)
dfc4bc56 244
e0b9a600 245 sleep 10 #Ubuntu compiling: allow time to automount/dismount
c42cbc86
MT
246 kpartx -d -v $(DEVICE)
247 losetup -d $(DEVICE)
52ca8220 248
7051d2af
MT
249 # Add padding at the end of the image (to fix alignment issues if the image is
250 # not copied to a block device)
251 dd if=/dev/zero bs=1M count=$(PADDING) >> $(IMG)
252
a649b645 253ifeq "$(BUILD_ARCH)" "armv5tel"
0a21d63f
AF
254 # Install u-boot for Orangepi Zero/Nanopi DUO into image 8KB
255 dd if=/usr/share/u-boot/orangepi_zero/u-boot-sunxi-with-spl.bin of=$(IMG) bs=1K seek=8 conv=notrunc
56e211f6
AF
256endif
257
52ca8220 258 # Compress Image
b302b9a6 259 xz $(XZ_OPT) < $(IMG) > $(IMAGE_FILE)
c42cbc86 260 rm -rf $(IMG) $(MNThdd)