📄 065-block2mtd_init.patch
字号:
Index: linux-2.6.21.7/drivers/mtd/devices/block2mtd.c===================================================================--- linux-2.6.21.7.orig/drivers/mtd/devices/block2mtd.c+++ linux-2.6.21.7/drivers/mtd/devices/block2mtd.c@@ -16,6 +16,7 @@ #include <linux/list.h> #include <linux/init.h> #include <linux/mtd/mtd.h>+#include <linux/mtd/partitions.h> #include <linux/buffer_head.h> #include <linux/mutex.h> #include <linux/mount.h>@@ -288,10 +289,11 @@ static void block2mtd_free_device(struct /* FIXME: ensure that mtd->size % erase_size == 0 */-static struct block2mtd_dev *add_device(char *devname, int erase_size)+static struct block2mtd_dev *add_device(char *devname, int erase_size, char *mtdname) { struct block_device *bdev; struct block2mtd_dev *dev;+ struct mtd_partition *part; if (!devname) return NULL;@@ -330,14 +332,18 @@ static struct block2mtd_dev *add_device( /* Setup the MTD structure */ /* make the name contain the block device in */- dev->mtd.name = kmalloc(sizeof("block2mtd: ") + strlen(devname),- GFP_KERNEL);++ if (!mtdname)+ mtdname = devname;++ dev->mtd.name = kmalloc(strlen(mtdname) + 1, GFP_KERNEL);+ if (!dev->mtd.name) goto devinit_err;+ + strcpy(dev->mtd.name, mtdname); - sprintf(dev->mtd.name, "block2mtd: %s", devname);-- dev->mtd.size = dev->blkdev->bd_inode->i_size & PAGE_MASK;+ dev->mtd.size = dev->blkdev->bd_inode->i_size & PAGE_MASK & ~(erase_size - 1); dev->mtd.erasesize = erase_size; dev->mtd.writesize = 1; dev->mtd.type = MTD_RAM;@@ -349,15 +355,18 @@ static struct block2mtd_dev *add_device( dev->mtd.read = block2mtd_read; dev->mtd.priv = dev; dev->mtd.owner = THIS_MODULE;-- if (add_mtd_device(&dev->mtd)) {+ + part = kzalloc(sizeof(struct mtd_partition), GFP_KERNEL);+ part->name = dev->mtd.name;+ part->offset = 0;+ part->size = dev->mtd.size;+ if (add_mtd_partitions(&dev->mtd, part, 1)) { /* Device didnt get added, so free the entry */ goto devinit_err; } list_add(&dev->list, &blkmtd_device_list); INFO("mtd%d: [%s] erase_size = %dKiB [%d]", dev->mtd.index,- dev->mtd.name + strlen("blkmtd: "),- dev->mtd.erasesize >> 10, dev->mtd.erasesize);+ mtdname, dev->mtd.erasesize >> 10, dev->mtd.erasesize); return dev; devinit_err:@@ -430,9 +439,9 @@ static __initdata char block2mtd_paramli static int block2mtd_setup2(const char *val) {- char buf[80 + 12]; /* 80 for device, 12 for erase size */+ char buf[80 + 12 + 80]; /* 80 for device, 12 for erase size, 80 for name */ char *str = buf;- char *token[2];+ char *token[3]; char *name; size_t erase_size = PAGE_SIZE; int i, ret;@@ -443,7 +452,7 @@ static int block2mtd_setup2(const char * strcpy(str, val); kill_final_newline(str); - for (i = 0; i < 2; i++)+ for (i = 0; i < 3; i++) token[i] = strsep(&str, ","); if (str)@@ -463,8 +472,10 @@ static int block2mtd_setup2(const char * parse_err("illegal erase size"); } }+ if (token[2] && (strlen(token[2]) + 1 > 80))+ parse_err("mtd device name too long"); - add_device(name, erase_size);+ add_device(name, erase_size, token[2]); return 0; }@@ -498,7 +509,7 @@ static int block2mtd_setup(const char *v module_param_call(block2mtd, block2mtd_setup, NULL, NULL, 0200);-MODULE_PARM_DESC(block2mtd, "Device to use. \"block2mtd=<dev>[,<erasesize>]\"");+MODULE_PARM_DESC(block2mtd, "Device to use. \"block2mtd=<dev>[,<erasesize>[,<name>]]\""); static int __init block2mtd_init(void) {
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -