| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 | diff -Nur linux-2.6.29.1.orig/drivers/mtd/Kconfig linux-2.6.29.1/drivers/mtd/Kconfig--- linux-2.6.29.1.orig/drivers/mtd/Kconfig	2009-04-02 22:55:27.000000000 +0200+++ linux-2.6.29.1/drivers/mtd/Kconfig	2009-05-02 19:24:14.444062164 +0200@@ -53,6 +53,11 @@ 	  should normally be compiled as kernel modules. The modules perform 	  various checks and verifications when loaded. +config MTD_ROOTFS_ROOT_DEV+	bool "Automatically set 'rootfs' partition to be root filesystem"+	depends on MTD_PARTITIONS+	default y+ config MTD_REDBOOT_PARTS 	tristate "RedBoot partition table parsing" 	depends on MTD_PARTITIONSdiff -Nur linux-2.6.29.1.orig/drivers/mtd/mtdpart.c linux-2.6.29.1/drivers/mtd/mtdpart.c--- linux-2.6.29.1.orig/drivers/mtd/mtdpart.c	2009-04-02 22:55:27.000000000 +0200+++ linux-2.6.29.1/drivers/mtd/mtdpart.c	2009-05-02 19:26:39.038093851 +0200@@ -18,6 +18,7 @@ #include <linux/mtd/mtd.h> #include <linux/mtd/partitions.h> #include <linux/mtd/compatmac.h>+#include <linux/root_dev.h>  /* Our partition linked list */ static LIST_HEAD(mtd_partitions);@@ -37,7 +38,7 @@  * the pointer to that structure with this macro.  */ #define PART(x)  ((struct mtd_part *)(x))-+#define IS_PART(mtd) (mtd->read == part_read)  /*  * MTD methods which simply translate the effective address and pass through@@ -502,14 +503,23 @@ { 	struct mtd_part *slave; 	uint64_t cur_offset = 0;-	int i;+	int i, j, ret;  	printk(KERN_NOTICE "Creating %d MTD partitions on \"%s\":\n", nbparts, master->name); -	for (i = 0; i < nbparts; i++) {-		slave = add_one_partition(master, parts + i, i, cur_offset);+ 	for (i = 0, j = 0; i < nbparts; i++) {+ 		slave = add_one_partition(master, parts + i, j++, cur_offset); 		if (!slave) 			return -ENOMEM;+ 		if (!strcmp(parts[i].name, "rootfs") && slave->registered) {+#ifdef CONFIG_MTD_ROOTFS_ROOT_DEV+			if (ROOT_DEV == 0) {+				printk(KERN_NOTICE "mtd: partition \"rootfs\" "+					"set to be root filesystem\n");+				ROOT_DEV = MKDEV(MTD_BLOCK_MAJOR, slave->mtd.index);+			}+#endif+		} 		cur_offset = slave->offset + slave->mtd.size; 	} 
 |