kernel: fix mtd squashfs root regression on targets with CONFIG_FIT_PARTITION
Move 480-mtd-set-rootfs-to-be-root-dev.patch to hack-5.10 and fix assumption
about the block device index.
Fixes: 2809d00007 ("kernel: support FIT partition parser on mtdblock devices")
Acked-by: Daniel Golle <daniel@makrotopia.org>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
			
			
This commit is contained in:
		| @@ -74,7 +74,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org> | |||||||
|  	unsigned long flags; |  	unsigned long flags; | ||||||
| --- a/drivers/mtd/mtdcore.c | --- a/drivers/mtd/mtdcore.c | ||||||
| +++ b/drivers/mtd/mtdcore.c | +++ b/drivers/mtd/mtdcore.c | ||||||
| @@ -32,6 +32,7 @@ | @@ -31,6 +31,7 @@ | ||||||
|   |   | ||||||
|  #include <linux/mtd/mtd.h> |  #include <linux/mtd/mtd.h> | ||||||
|  #include <linux/mtd/partitions.h> |  #include <linux/mtd/partitions.h> | ||||||
| @@ -82,7 +82,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org> | |||||||
|   |   | ||||||
|  #include "mtdcore.h" |  #include "mtdcore.h" | ||||||
|   |   | ||||||
| @@ -858,6 +859,8 @@ int mtd_device_parse_register(struct mtd | @@ -848,6 +849,8 @@ int mtd_device_parse_register(struct mtd | ||||||
|  		register_reboot_notifier(&mtd->reboot_notifier); |  		register_reboot_notifier(&mtd->reboot_notifier); | ||||||
|  	} |  	} | ||||||
|   |   | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ Signed-off-by: Gabor Juhos <juhosg@openwrt.org> | |||||||
|  #include <linux/nvmem-provider.h> |  #include <linux/nvmem-provider.h> | ||||||
|   |   | ||||||
|  #include <linux/mtd/mtd.h> |  #include <linux/mtd/mtd.h> | ||||||
| @@ -693,6 +694,15 @@ int add_mtd_device(struct mtd_info *mtd)
 | @@ -694,6 +695,19 @@ int add_mtd_device(struct mtd_info *mtd)
 | ||||||
|  	   of this try_ nonsense, and no bitching about it |  	   of this try_ nonsense, and no bitching about it | ||||||
|  	   either. :) */ |  	   either. :) */ | ||||||
|  	__module_get(THIS_MODULE); |  	__module_get(THIS_MODULE); | ||||||
| @@ -28,9 +28,13 @@ Signed-off-by: Gabor Juhos <juhosg@openwrt.org> | |||||||
| +	if (!strcmp(mtd->name, "rootfs") &&
 | +	if (!strcmp(mtd->name, "rootfs") &&
 | ||||||
| +	    IS_ENABLED(CONFIG_MTD_ROOTFS_ROOT_DEV) &&
 | +	    IS_ENABLED(CONFIG_MTD_ROOTFS_ROOT_DEV) &&
 | ||||||
| +	    ROOT_DEV == 0) {
 | +	    ROOT_DEV == 0) {
 | ||||||
|  | +		unsigned int index = mtd->index;
 | ||||||
| +		pr_notice("mtd: device %d (%s) set to be root filesystem\n",
 | +		pr_notice("mtd: device %d (%s) set to be root filesystem\n",
 | ||||||
| +			  mtd->index, mtd->name);
 | +			  mtd->index, mtd->name);
 | ||||||
| +		ROOT_DEV = MKDEV(MTD_BLOCK_MAJOR, mtd->index);
 | +#ifdef CONFIG_FIT_PARTITION
 | ||||||
|  | +		index <<= 1;
 | ||||||
|  | +#endif
 | ||||||
|  | +		ROOT_DEV = MKDEV(MTD_BLOCK_MAJOR, index);
 | ||||||
| +	}
 | +	}
 | ||||||
| +
 | +
 | ||||||
|  	return 0; |  	return 0; | ||||||
| @@ -17,7 +17,7 @@ Reviewed-by: Miquel Raynal <miquel.raynal@bootlin.com> | |||||||
|  |  | ||||||
| --- a/drivers/mtd/mtdcore.c | --- a/drivers/mtd/mtdcore.c | ||||||
| +++ b/drivers/mtd/mtdcore.c | +++ b/drivers/mtd/mtdcore.c | ||||||
| @@ -1053,6 +1053,44 @@ out_unlock: | @@ -1043,6 +1043,44 @@ out_unlock: | ||||||
|  } |  } | ||||||
|  EXPORT_SYMBOL_GPL(get_mtd_device_nm); |  EXPORT_SYMBOL_GPL(get_mtd_device_nm); | ||||||
|   |   | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Felix Fietkau
					Felix Fietkau