mirror of
				https://git.proxmox.com/git/grub2
				synced 2025-10-26 16:17:05 +00:00 
			
		
		
		
	10_linux: avoid multi-device root= kernel argument
If root filesystem is multidev btrfs, do not attempt to pass all devices as kernel root= argument. This results in splitting command line in GRUB due to embedded newline and even if we managed to quote it, kernel does not know how to interpret it anyway. Multidev btrfs requires user space device scanning, so passing single device would not work too. This still respects user settings GRUB_DISABLE_LINUX_UUID. Not sure what we should do in this case. Closes: 45709
This commit is contained in:
		
							parent
							
								
									ff84a9b868
								
							
						
					
					
						commit
						7290bb5623
					
				| @ -43,9 +43,11 @@ case ${GRUB_DEVICE} in | ||||
|   ;; | ||||
| esac | ||||
| 
 | ||||
| # btrfs may reside on multiple devices. We cannot pass them as value of root= parameter | ||||
| # and mounting btrfs requires user space scanning, so force UUID in this case. | ||||
| if [ "x${GRUB_DEVICE_UUID}" = "x" ] || [ "x${GRUB_DISABLE_LINUX_UUID}" = "xtrue" ] \ | ||||
|     || ! test -e "/dev/disk/by-uuid/${GRUB_DEVICE_UUID}" \ | ||||
|     || uses_abstraction "${GRUB_DEVICE}" lvm; then | ||||
|     || test -e "${GRUB_DEVICE}" && uses_abstraction "${GRUB_DEVICE}" lvm; then | ||||
|   LINUX_ROOT_DEVICE=${GRUB_DEVICE} | ||||
| else | ||||
|   LINUX_ROOT_DEVICE=UUID=${GRUB_DEVICE_UUID} | ||||
|  | ||||
| @ -43,9 +43,11 @@ case ${GRUB_DEVICE} in | ||||
|   ;; | ||||
| esac | ||||
| 
 | ||||
| # btrfs may reside on multiple devices. We cannot pass them as value of root= parameter | ||||
| # and mounting btrfs requires user space scanning, so force UUID in this case. | ||||
| if [ "x${GRUB_DEVICE_UUID}" = "x" ] || [ "x${GRUB_DISABLE_LINUX_UUID}" = "xtrue" ] \ | ||||
|     || ! test -e "/dev/disk/by-uuid/${GRUB_DEVICE_UUID}" \ | ||||
|     || uses_abstraction "${GRUB_DEVICE}" lvm; then | ||||
|     || test -e "${GRUB_DEVICE}" && uses_abstraction "${GRUB_DEVICE}" lvm; then | ||||
|   LINUX_ROOT_DEVICE=${GRUB_DEVICE} | ||||
| else | ||||
|   LINUX_ROOT_DEVICE=UUID=${GRUB_DEVICE_UUID} | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Andrei Borzenkov
						Andrei Borzenkov