mirror of
				https://git.launchpad.net/livecd-rootfs
				synced 2025-10-26 06:24:06 +00:00 
			
		
		
		
	functions: stop removing systemd-detect-virt unconditionally in undivert_grub
One can call divert_grub; replace_kernel; undivert_grub. And replace_kernel will call into force_boot_without_initramfs, which under certain conditions can call divert_grub & undivert_grub. Resulting in undivert_grub called twice in a row. When undivert_grub is called twice in a row it wipes systemd-detect-virt binary from disk, as the rm call is unguarded to check that there is something to divert if systemd package is installed. And if the systemd package is not installed, it does not check that systemd-detect-virt file is in-fact what divert_grub has created. Add a guard to check that systemd-detect-virt is the placeholder one, before removing it. LP: #1902260 (cherry picked from commit 096a00f40459187719840ccad99e86c7ade2ec12)
This commit is contained in:
		
							parent
							
								
									d2e70ab48e
								
							
						
					
					
						commit
						6832b6bda4
					
				| @ -357,7 +357,9 @@ undivert_grub() { | |||||||
| 		--divert /etc/grub.d/30_os-prober.dpkg-divert \ | 		--divert /etc/grub.d/30_os-prober.dpkg-divert \ | ||||||
| 		--rename /etc/grub.d/30_os-prober | 		--rename /etc/grub.d/30_os-prober | ||||||
| 
 | 
 | ||||||
| 	rm "$CHROOT_ROOT"/usr/bin/systemd-detect-virt | 	if grep -q "^exit 1$" "$CHROOT_ROOT"/usr/bin/systemd-detect-virt; then | ||||||
|  | 		rm "$CHROOT_ROOT"/usr/bin/systemd-detect-virt | ||||||
|  | 	fi | ||||||
| 	chroot "$CHROOT_ROOT" dpkg-divert --remove --local \ | 	chroot "$CHROOT_ROOT" dpkg-divert --remove --local \ | ||||||
| 		--rename /usr/bin/systemd-detect-virt | 		--rename /usr/bin/systemd-detect-virt | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user