2 ROOT_MB := $(shell printf '%i\n' "$$(( ${imagesize} - ${BOOT_MB} - 3 ))")
5 PACKAGES += btrfs-progs bzip2 ca-certificates cron deborphan firmware-linux-free gzip htop ifupdown iputils-ping irqbalance isc-dhcp-client less make net-tools nmap ntpdate openssh-client psmisc rsync sshfs sudo traceroute unzip vim wget wireless-tools wpasupplicant xz-utils zip
8 PACKAGES += $(subst ${comma_},${space_},${packages})
11 export DEBCONF RPICONFIG
16 keyboard-configuration keyboard-configuration/model select Generic 105-key (Intl) PC
17 keyboard-configuration keyboard-configuration/variant select English (US) - English (Macintosh)
23 dtoverlay=vc4-fkms-v3d,cma-256
26 .PHONY: _debconf_selections _raspberry_config _keyboard
27 _install: _debconf_selections
28 _debconf_selections: ${SYSROOT}
29 printf '%s\n' "$${DEBCONF}" |chroot "$${SYSROOT}" debconf-set-selections
35 -sed -Ei 's;^XKBLAYOUT=.*$$;XKBLAYOUT="${keyboard}";;' "$${CFGROOT}/etc/default/keyboard"
38 _config: _raspberry_config _raspberry_initrd
41 _raspberry_config: ${CFGROOT}
42 printf '%s\n' "$${RPICONFIG}" >>"$${CFGROOT}/boot/config.txt"
44 _raspberry_initrd: ${CFGROOT}
45 k=$${CFGROOT}/lib/modules/*-v7+; \
46 chroot $${CFGROOT} update-initramfs -c -k "$${k##*/}"; \
47 printf 'initramfs initrd.img-%s\n' "$${k##*/}" >>"$${CFGROOT}/boot/config.txt"
49 .PHONY: _timezone _locales
63 printf '%s\n' "$${timezone}" >"$${CFGROOT}/etc/timezone"
64 ln -sf /usr/share/zoneinfo/"$${timezone}" "$${CFGROOT}/etc/localtime"
67 for l in $(subst ${comma_},${space_},${locales}); do \
68 printf '%s %s\n' "$${l}" "$${l#*.}"; \
69 done >"$${CFGROOT}/etc/locale.gen"
70 printf 'LANG=%s\n' "$(firstword $(subst ${comma_},${space_},${locales}))" >"$${CFGROOT}/etc/default/locale"
71 chroot "$${CFGROOT}" locale-gen
73 .PHONY: _rootpass _users _hostname
95 chroot "$${CFGROOT}" usermod -p "$$(openssl passwd "$${rootpass}")" root
98 [ -f "$@" ] || ssh-keygen -N '' -f "$${rootkey}"
100 _rootkey: ${CFGROOT} ${rootkey}.pub
101 mkdir -m 700 "$${CFGROOT}/root/.ssh/"
102 cp "$${rootkey}.pub" "$${CFGROOT}/root/.ssh/authorized_keys"
105 for u in $(subst ${comma_},${space_},${users}); do \
106 chroot "$${CFGROOT}" useradd -s /bin/bash -p "$$(openssl passwd "")" "$$u"; \
109 _hostname: ${CFGROOT}
110 printf '%s\n' "$${hostname}" >"$${CFGROOT}/etc/hostname"
111 sed -Ei "s;^127\.0\.0\.1.*$$;& $${hostname};" "$${CFGROOT}/etc/hosts"
114 _config: ${CFGROOT}/etc/network/interfaces.d/wifi
117 ${CFGROOT}/etc/network/interfaces.d/wifi: ${CFGROOT}
118 printf 'auto wlan0\nallow-hotplug wlan0\n\niface wlan0 inet dhcp\n' >$@
119 printf ' wpa-ssid "%s"\n wpa-psk "%s"\n' "$$wifi" "$$wifipass" >>$@
122 ${CFGROOT}/etc/network/interfaces.d/wifi: ${CFGROOT}
123 printf 'auto wlan0\nallow-hotplug wlan0\n\niface wlan0 inet dhcp\n' >$@
124 printf ' wireless-ssid "%s"\n' "$$wifi" >>$@