X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/m1-debian/blobdiff_plain/e1af00a32584e2155a2252a2eafe838cf40aeb39..eeaa52fd62df83ed6795e2139308a0de18afcb03:/files/rc.local diff --git a/files/rc.local b/files/rc.local index fbd572a..cb4e021 100755 --- a/files/rc.local +++ b/files/rc.local @@ -1,13 +1,8 @@ #!/usr/bin/perl -# [x] resize root filesystem -# [ ] find boot partition -# [ ] generate fstab -# [ ] mount boot -# [ ] extract wifi firmware -# [ ] reloads the kernel modules -# [ ] install grub -# [ ] disables itself +my $firmware_tarball = '/boot/efi/vendorfw/firmware.tar'; +my $firmware_manifest = '/lib/firmware/ASAHI_FIRMWARE_MANIFEST'; +my $grubcfg = '/mnt/EFI/debian/grub.cfg'; sub find_root_device @@ -25,6 +20,111 @@ find_root_device die("Could not find root device"); } -my $root_block_device = find_root_device(); +sub +find_fs_uuid_of_device +{ + my $dev = shift || die; + my $blkid_output = `blkid ${dev}`; + + if ($blkid_output =~ /UUID="([^"]+)"/) { + return $1; + } + + die("Could not find fs uuid of $dev"); +} + +sub +find_efi_parition +{ + my $uuid_in_grub_cfg = shift || die; + my @candidates; + + my $efi_parition = undef; + + for (`blkid`) { + if (/^([\S]+):.*TYPE="vfat"/) { + push(@candidates, $1); + } + } + + for my $dev (@candidates) { + system("mount -o ro $dev /mnt"); + if (-f $grubcfg) { + open(GRUBCFG, '<', $grubcfg) || die ("Can't open $grubcfg: $!"); + my @lines = ; + for (@lines) { + if (/${uuid_in_grub_cfg}/) { + $efi_parition = $dev; + } + } + close(GRUBCFG); + } + system("umount /mnt"); + last if defined $efi_parition; + } + + die ("No efi parition found") unless defined $efi_parition; + + return $efi_parition; +} + +sub +generate_fstab +{ + my $root_fs_uuid = shift || die; + my $efi_fs_uuid = shift || die; + + open(FSTAB, '>', '/etc/fstab') || die ("Can not open fstab"); + print FSTAB < $firmware_manifest"); + system("tar -C /lib/firmware/ -xf $firmware_tarball"); + + unlink('/etc/modprobe.d/blacklist.conf'); + system('modprobe brcmfmac'); +} + +my $root_block_device = undef; +my $initial_root_fs_uuid = undef; +my $efi_block_device = undef; +my $efi_fs_uuid = undef; + +unless (-f '/boot/grub/grub.cfg') { + $root_block_device = find_root_device(); + system("resize2fs $root_block_device"); + $initial_root_fs_uuid = find_fs_uuid_of_device($root_block_device); + $efi_block_device = find_efi_parition($initial_root_fs_uuid); + $efi_fs_uuid = find_fs_uuid_of_device($efi_block_device); + generate_fstab($initial_root_fs_uuid, $efi_fs_uuid); + system('mount /boot/efi'); + install_grub(); +} -system("resize2fs $root_block_device"); +update_wifi_firmware_if_necessary();