Chinaunix首页 | 论坛 | 博客
  • 博客访问: 15496680
  • 博文数量: 2005
  • 博客积分: 11986
  • 博客等级: 上将
  • 技术积分: 22535
  • 用 户 组: 普通用户
  • 注册时间: 2007-05-17 13:56
文章分类

全部博文(2005)

文章存档

2014年(2)

2013年(2)

2012年(16)

2011年(66)

2010年(368)

2009年(743)

2008年(491)

2007年(317)

分类:

2010-06-02 10:56:24

关于如何在kernel起来之后通过直接dd读写nand flash分区来更新zImage的mtd问题

主要是设置struct mtd_partition中的mask_flags标志位
具体含义为:
1. master MTD flags to mask out for this partition
2. contains flags that have to be masked (removed) from the
   master MTD flag set for the corresponding MTD partition.
凡是置1的bit,相应属性将被惕掉,比如设置为MTD_WRITEABLE,那么表示剔出读写,
因此该mtd分区将只有读权限[luther.gliethttp].

static struct platform_driver pxa3xx_nand_driver = {
    .driver = {
        .name    = "pxa3xx-nand",
    },
    .probe        = pxa3xx_nand_probe,
    .remove        = pxa3xx_nand_remove,
#ifdef CONFIG_PM
    .suspend    = pxa3xx_nand_suspend,
    .resume        = pxa3xx_nand_resume,
#endif
};

pxa3xx_nand_probe
==> add_mtd_partitions(mtd, , pdata->parts, pdata->nr_parts);
===> slave->mtd.flags = master->flags & ~parts[i].mask_flags; // 取反mask_flags做掩码操作
其中pdata->parts对应struct mtd_partition结构体

drivers/mtd/mtdblock.c
// 读写mtd的fops
static struct mtd_blktrans_ops mtdblock_tr = {
    .name        = "mtdblock",
    .major        = 31,
    .part_bits    = 0,
    .blksize     = 512,
    .open        = mtdblock_open,
    .flush        = mtdblock_flush,
    .release    = mtdblock_release,
    .readsect    = mtdblock_readsect,
    .writesect    = mtdblock_writesect,
    .add_mtd    = mtdblock_add_mtd,
    .remove_dev    = mtdblock_remove_dev,
    .owner        = THIS_MODULE,
};

struct mtd_partition {
    char *name;            /* identifier string */
    u_int32_t size;            /* partition size */
    u_int32_t offset;        /* offset within the master MTD space */
    u_int32_t mask_flags;        /* master MTD flags to mask out for this partition */
    struct nand_ecclayout *ecclayout;    /* out of band layout for this partition (NAND only)*/
    struct mtd_info **mtdp;        /* pointer to store the MTD object */
};

// 如下即flash分区部分内容
static struct mtd_partition partition_info[] = {
    {
        name:        "Bootloader",
        offset:        0,
        mask_flags:    MTD_WRITEABLE  /* force read-only */ 去掉写权限
    },{
        name:        "Kernel",
        size:        0x00200000,
        mask_flags:    MTD_WRITEABLE  /* force read-only */ 去掉写权限
    },{
        name:        "Filesystem",
        size:        0x05000000,    /* only mount 48M fs */
    }, {
        name:        "MassStorage",                      这里mask_flags为0,所以具有读写权限
        size:        0x0, /* It will be set at probe function */
        offset:        MTDPART_OFS_APPEND /* Append after fs section */
    },
    ......
};

0x00200000表示2M,即2097152
读mtd分区:dd if=/dev/mtdblock1 of=zImage bs=dd bs=2097152 count=1
写mtd分区:dd if=/gliethttp/zImage of=/dev/mtdblock1
阅读(8199) | 评论(5) | 转发(1) |
给主人留下些什么吧!~~

laidoo2011-03-07 10:13:57

我觉得我的情况应该不是“bootloader加载zImage的参数需要修改为一个足够大的值”的关系吧,因为我flash内核的分区的大小还是足够的,不过我用的是uImage。

laidoo2011-03-07 10:10:19

我尝过过dd指令,或是用mtd_util工具指令都无法实现,用nanddump指令查看flash信息感觉是吧新的uImage写到flash上去了,但是,后面部分写到数据和在UBoot状态下烧写内核的数据不太一样,所以无法启动在线更新写进去的内核。我用的是Davinci 6446开发板,ARM处理器是ARM926,操作系统是montavista linux pro5.0。希望楼主能再指点下,谢谢!

gliethttp2011-02-20 11:40:27

laidoo: 楼主,我想请问用dd 指令,真的能够动态更新正在运行中的Linux内核或是文件系统吗?我试了下,结果不行,也行是我不懂怎么使用。请楼主赐教。.....
这是我实践通过的方法,需要注意的一点是你的bootloader加载zImage的参数需要修改为一个足够大的值,以保证通过dd烧写的新的zImage增大之后bootloader仍然能够完整的将该通过dd烧写的新的zImage加载进入内存(比如bootloader恒定加载zImage的大小设定为8M)

laidoo2011-02-16 16:52:26

楼主,我想请问用dd 指令,真的能够动态更新正在运行中的Linux内核或是文件系统吗?我试了下,结果不行,也行是我不懂怎么使用。请楼主赐教。

chinaunix网友2010-06-17 23:05:34

mbt lami shoes mbt lami shoe MBT Shoes on sale!If you are looking for nike air max 2010 and kobe shoes. I will tell you that MBT Shoes is well-known for its positive effect to human body.