1.1        Uboot UBI的移植
  关于uboot的UBI的移植几乎没有说明介绍,移植首先要保证你的flash驱动能够跑起来,我是在nand  flash 上跑的UBI。刚开始的时候我也没有什么头绪,只能够从uboot的readme开始查找一些蛛丝马迹。
  - MTD Support (mtdparts command, UBI support)
                CONFIG_MTD_DEVICE
                Adds the MTD device infrastructure from the Linux kernel.
                Needed for mtdparts command support.
                CONFIG_MTD_PARTITIONS
                Adds the MTD partitioning infrastructure from the Linux
                kernel. Needed for UBI support.
  因此,要UBI支持首先得要MTD支持,因此在配置文件中要添加以上两项的定义。
  要移植UBI还要添加:
  #define CONFIG_CMD_UBIFS           
  #define CONFIG_CMD_UBI         
  总的关于UBI的部分是以下几个宏:
  #define CONFIG_CMD_UBI
  #define CONFIG_CMD_UBIFS
  #define CONFIG_CMD_MTDPARTS
  #define CONFIG_MTD_DEVICE
  #define CONFIG_MTD_PARTITIONS
  #define CONFIG_RBTREE
  #define CONFIG_LZO 
  同时要给NAND建立个默认的分区,方便以后操作。分区如下:
  #define MTDIDS_DEFAULT "nand0=nand0"
  #define MTDPARTS_DEFAULT "mtdparts=nand0:0x100000@0x0(u-boot),0x300000@0x120000(kernel),0x7b00000@0x420000(rootfs),-(reserved)"
  #define MTD_ACTIVE_PART "nand0,2"
  以上的配置都在uboot_imx/include/configs/mx51_vdphone.h文件中进行配置。
  需要注意的是增加UBI的支持之后uboot会增大到300多KB,在NAND中启动,需要修改以下文件uboot-imx\cpu\arm_cortexa8\mx51\mxc_nand_load.S 
        add r6, r0, #0x1E00
        ldr r5, =_end              /* Try get right image size */
        add r5, r2, #0x00060000 /* Fixme to get actual image size */ 
  这里使用0x60000(384K)大小,已经足够,如果实际有变化,可以进行相应调节。如果uboot传给Copy_Good_Blk 拷贝的uboot的大小小于uboot的长度的话,uboot跑不起来,移植的时候被这个问题必须注意。
  这个时候就可以make 了,执行以下命令:
  make clean
  make mx51_vdphone_config
  make all
  如果正常的话会编译出u-boot.bin在根目录下。
  1.2       u-boot 下ubi的使用
  1.2.1        配置u-boot nand 分区
  通过mtdpart命令配置u-boot下的nand 分区,本项目已经在配置头文件里面设置了默认nand 分区,
  #define MTDPARTS_DEFAULT "mtdparts=nand0:0x100000@0x0(u-boot),0x300000@0x120000(kernel),0x7b00000@0x420000(rootfs),-(reserved)"
  如果需要修改,可以通过修改默认分区列表,也可以通过命令mtdpart进行重新分区。这里使用默认分区,通过以下命令使默认分区生效:
         mtdpart default       //设置默认分区
         saveevn             //保存分区信息
  1.2.2        nand u-boot 烧写
  通过以上的配置编译,如果成功生成u-boot.bin,那就可以通过SD卡启动,直接烧写u-boot.bin到nand  flash了。操作步骤如下:
  1)         下载u-boot.bin 到内存
  tftp 0x90800000 /tftpboot/mx51/u-boot.bin
  2)         擦除u-boot分区
  nand erase u-boot
  3)         烧写u-boot到nand flash分区
  nand write 0x90800000 u-boot 0x60000
  1.2.3        内核的烧写
   内核的烧写和平常烧写方式一样,只需用nand 命令写入nand 即可,操作步骤如下:
  1)       擦除kernel分区
  nand erase kernel
  2)       下载kernel到内存
  tftp 0x90800000 /tftpboot/mx51/uImage  将内核通过tftp下载到内存中
  3)       烧写kernel 到nand kernel分区
  nand write 0x90800000 kernel 0x300000 
  1.2.4        UBI文件系统的烧写
  本项目使用的文件系统将根文件系统和system文件系统整合在一起。所以,只需要烧写整合后的文件系统即可。如果要使用ubifs文件系统作为根文件系统,在烧写之前必须通过mkfs.ubifs工具将做好的文件系统制作镜像文件。mkfs.ubifs 工具是通过编译mtd-utils工具下的mkfs.ubifs目录即可生成的PC端UBIFS文件系统镜像制作工具。操作步骤如下:
  1)       制作根文件系统
  mkfs.ubifs -r root/ -m 2048 -e 129024 -c 2364 -o root-fs.img
  root目录为整合android root和system文件系统后的目录,应当能够通过NFS系统的
  2)       擦除root分区
   nand erase root
  3)      激活root 分区为UBI格式
   ubi part root
               4)    创建root分区
  ubi create root
  5)       将文件系统下载到内存
   tftp 0x90800000 root-fs.img
  6)       将文件系统烧写到rootfs 中
  ubi write 0x90800000 rootfs 0x339600//0x339600为tftp 下载到的root-fs.img镜像大小,
  1.2.5         设置启动参数
  设置bootargs:
  setenv bootargs ubi.mtd=2 root=ubi0:rootfs rootfstype=ubifs console=ttymxc0,115200 wvga calibration init=/init rw
  启动拨码开关5,8位置设置为ON,上电重新启动,即可从Nand  flash 启动。
                 1.3       android FLASH UBI文件系统的制作和烧写
  将android编译为UBI文件系统格  式,生成的system.img,userdata.img,recover.img就可以直接在u-boot中通过ubi write 命令烧写,前提条件是uboot已经支持或完成ubi和UBIFS的移植工作,并且linux  kernel也要支持UBIFS文件系统。
                1.3.1   设置mtdpart分区
               1)    U-Boot中配置默认分区参数,路径如下:
  # 板级相关的配置文件include/configs/mx51/xxxx.h 
  mtdparts: mtdparts=nand0:0x100000@0x0(u-boot),0x300000@0x120000(kernel),0x100000@0x420000(ramdisk),0x4B00000@0x520000(system),0x1E00000@0x5020000(userdata),0xD00000@0x6E20000(cache),-(reserved)
              2)     第一次烧写完boot后,设置mtdpart分区:
  BBG U-Boot > mtdparts default # 加载默认分区配置
  BBG U-Boot > save # 保存配置
  BBG U-Boot > mtdpart # 查看分区配置
  device nand0 <nand0>, # parts = 7
   #: name                size            offset          mask_flags
   0: u-boot              0x00100000      0x00000000      0
   1: kernel              0x00300000      0x00120000      0
   2: ramdisk             0x00100000      0x00420000      0
   3: system              0x04b00000      0x00520000      0
   4: userdata            0x01e00000      0x05020000      0
   5: cache               0x00d00000      0x06e20000      0
   6: reserved            0x004e0000      0x07b20000      0
  active partition: nand0,0 - (u-boot) 0x00100000 @ 0x00000000
  defaults:
  mtdids  : nand0=nand0
                 3)    烧写U-Boot到FLASH
  BBG U-Boot > tftp 0x90800000 u-boot.bin # 获取U-Boot到内存
  BBG U-Boot > nand erase u-boot # 格式化u-boot分区
  BBG U-Boot > nand write 0x90800000 u-boot 0x100000 # 烧写u-boot到对应分区
                4)    烧写Linux内核到FLASH
  BBG U-Boot > tftp 0x90800000 uImage # 获取内核到内存
  BBG U-Boot > nand erase kernel # 格式化内存分区
  BBG U-Boot > nand write 0x90800000 kernel 0x300000 # 烧写内核到对应分区
                5)    烧写Ramdisk到FLASH
  BBG U-Boot > tftp 0x90800000 uramdisk.img # 获取uramdisk到内存
  BBG U-Boot > nand erase ramdisk # 格式化uramdisk分区
  BBG U-Boot > nand write 0x90800000 ramdisk 0x100000 # 烧写uramdisk到对应分区           
                6)    烧写System到FLASH
  BBG U-Boot > nand erase system # 擦除system分区
  BBG U-Boot > tftp 0x90800000 system.img # 获取system到内存
  BBG U-Boot > ubi part system # 激活system分区为ubi格式
  Creating 1 MTD partitions on "nand0":
  0x000097855f98-0x000000520000 : "<NULL>"
  UBI: attaching mtd1 to ubi0
  UBI: physical eraseblock size:   131072 bytes (128 KiB)
  UBI: logical eraseblock size:    129024 bytes
  UBI: smallest flash I/O unit:    2048
  UBI: sub-page size:              512
  UBI: VID header offset:          512 (aligned 512)
  UBI: data offset:                2048
  UBI: attached mtd1 to ubi0
  UBI: MTD device name:            "mtd=3"
  UBI: MTD device size:            78643200 MiB
  UBI: number of good PEBs:        600
  UBI: number of bad PEBs:         0
  UBI: max. allowed volumes:       128
  UBI: wear-leveling threshold:    4096
  UBI: number of internal volumes: 1
  UBI: number of user volumes:     0
  UBI: available PEBs:             590
  UBI: total number of reserved PEBs: 10
  UBI: number of PEBs reserved for bad PEB handling: 6
  UBI: max/mean erase counter: 1/1
  BBG U-Boot > ubi create system # 创建system分区
  Creating dynamic volume system of size 76124160
  # 烧写sytem分区,大小为tftp下载完成后提示的大小
  BBG U-Boot > ubi write 0x90800000 system 0x3ca9800
  Volume "system" found at volume id 0
                 7)     烧写userdata到FLASH
  BBG U-Boot > nand erase userdata # 擦除userdata分区
  BBG U-Boot > ubi part userdata # 激活userdata分区为ubi格式
  UBI: mtd1 is detached from ubi0
  Creating 1 MTD partitions on "nand0":
  0x000097855f98-0x000005020000 : "<NULL>"
  UBI: attaching mtd1 to ubi0
  UBI: physical eraseblock size:   131072 bytes (128 KiB)
  UBI: logical eraseblock size:    129024 bytes
  UBI: smallest flash I/O unit:    2048
  UBI: sub-page size:              512
  UBI: VID header offset:          512 (aligned 512)
  UBI: data offset:                2048
  UBI: empty MTD device detected
  UBI: create volume table (copy #1)
  UBI: create volume table (copy #2)
  UBI: attached mtd1 to ubi0
  UBI: MTD device name:            "mtd=4"
  UBI: MTD device size:            31457280 MiB
  UBI: number of good PEBs:        240
  UBI: number of bad PEBs:         0
  UBI: max. allowed volumes:       128
  UBI: wear-leveling threshold:    4096
  UBI: number of internal volumes: 1
  UBI: number of user volumes:     0
  UBI: available PEBs:             234
  UBI: total number of reserved PEBs: 6
  UBI: number of PEBs reserved for bad PEB handling: 2
  UBI: max/mean erase counter: 0/0
  BBG U-Boot > ubi create userdata # 创建userdata分区
  Creating dynamic volume userdata of size 30191616
  BBG U-Boot > tftp 0x90800000 userdata.img # 获取userdata到内存
  # 烧写userdata分区,大小为tftp下载完成后提示的大小
  BBG U-Boot > ubi write 0x90800000 userdata 0x979800
  Volume "userdata" found at volume id 0
                8)    初始化Cache分区
  BBG U-Boot > ubi part cache # 激活cache分区为ubi格式
  UBI: mtd1 is detached from ubi0
  Creating 1 MTD partitions on "nand0":
  0x000097855f98-0x000006e20000 : "<NULL>"
  UBI: attaching mtd1 to ubi0
  UBI: physical eraseblock size:   131072 bytes (128 KiB)
  UBI: logical eraseblock size:    129024 bytes
  UBI: smallest flash I/O unit:    2048
  UBI: sub-page size:              512
  UBI: VID header offset:          512 (aligned 512)
  UBI: data offset:                2048
  UBI: empty MTD device detected
  UBI: create volume table (copy #1)
  UBI: create volume table (copy #2)
  UBI: attached mtd1 to ubi0
  UBI: MTD device name:            "mtd=5"
  UBI: MTD device size:            13631488 MiB
  UBI: number of good PEBs:        104
  UBI: number of bad PEBs:         0
  UBI: max. allowed volumes:       128
  UBI: wear-leveling threshold:    4096
  UBI: number of internal volumes: 1
  UBI: number of user volumes:     0
  UBI: available PEBs:             98
  UBI: total number of reserved PEBs: 6
  UBI: number of PEBs reserved for bad PEB handling: 2
  UBI: max/mean erase counter: 0/0
  BBG U-Boot > ubi create cache   # 创建cache分区
                  9)     FLASH上Android的加载与启动
  设置启动参数
  setenv bootcmd_nand 'run bootargs_nand;nand read ${loadaddr} kernel; nand read ${rd_loadaddr} ramdisk; bootm ${loadaddr} ${rd_loadaddr}'
  setenv bootargs_nand 'setenv bootargs ubi.mtd=3 ubi.mtd=4 ubi.mtd=5 console=ttymxc0,115200 androidboot.console=ttymxc0 wvga calibration init=/init rw'
  setenv bootcmd 'run bootcmd_nand'
  saveenv
  重启即可从nand flash 启动烧写的ubi文件系统
  
0 件のコメント:
コメントを投稿