嵌入式linux下添加flash分区,嵌入式linuxflash分区配置

嵌⼊式linux下添加flash分区,嵌⼊式linuxflash分区配置
uboot 与系统内核中 MTD分区的关系:
分区只是内核的概念,就是说A~B地址放内核,C~D地址放⽂件系统,等等。
1:在内核MTD中可以定义分区A~B,C~D。。。。。。并与以绝对的地址赋上值。
bootloader中只要能将内核下载到A~B区的A地址开始处就可以,C~D区的C起始地址下载⽂件系统。。。这些起始地址在MTD的分区信息中能到。
bootloader对分区的概念不重要,只要它能把内核烧到A位置,把⽂件系统烧到C位置。
所以,在bootloader对Flash进⾏操作时,哪块区域放什么是以内核为主。
⽽为了⽅便操作,bootloader类似也引⼊分区的概念,如,可以使⽤“nand write 3000000 kernel”命令将uImage烧到kernel分区,⽽不必写那么长:nand write 3000000 A ……
这要对bootloader对内核重新分区:这需要重新设置⼀下bootloader环境参数,就可以同步更新内核分区信息
如:
setenv bootargs 'noinitrd console=ttySAC0 root=/dev/mtdblock3 rootfstype=jffs2
mtdparts=nand_flash:128k(u-boot)ro,64k(u-boot envs),3m(kernel),30m(root.jffs2),30m(root.yaffs)'
内核配置时选上Device Drivers  ---> Memory Technology Device (MTD) support  ---> Command line partition table parsing
在设置了mtdparts变量之后,就可以在nand read/write/erase命令中直接使⽤分区的名字⽽不必指定分区的偏移位置.⽽这需要内核MTD 最好没有规划分区。
a 。如果你是通过uboot的内核命令⾏给MTD层传递MTD分区信息,这种情况下,内核读取到的分区信息始终和u-boot中的保持⼀致(推荐的做法)
b 。如果你是把分区信息写在内核源代码MTD⾥定义好的⽅法,那最好保证它和u-boot中的保持⼀致,即同步修改uboot及内核的相关部分。
2:
内核通过bootargs到⽂件系统,bootargs中的mtdblockx即代表分区,block1,2,3代表哪个分区。
事实上,bootargs中的"root=/dev/mtdblockx"只是告诉内核,root fs从第x个(x=0,)MTD分区挂载,mtdblock0对应第⼀个分
区,mtdblock1对应第⼆个分区,以此类推.
3:分区⽅法
1) MTD层的分区
2) 通过U-boot传递给内核的命令⾏中的mtdparts=...
3) 其他可以让内核知道分区信息的任何办法,(内核默认的命令参数)
下⾯说到mtdparts,及它的⽤法:
====>>
mtdparts
_flash:1920k(linux),128k(fdt),20M(ramdisk),4M(jffs2),38272k(user),256k(env),384k(uboot)
要想这个参数起作⽤,内核中的mtd驱动必须要⽀持,即内核配置时需要选上
Device Drivers---> Memory Technology Device (MTD) support---> Command line partition table parsing
mtdparts的格式如下:
mtdparts=[;
:= :[,]
:= [@offset][][ro]
:= unique id used in mapping driver/device
:= standard linux memsize OR "-" to denote all remaining space
:= (NAME)
因此你在使⽤的时候需要按照下⾯的格式来设置:
mtdparts=mtd-id:@(),@()
这⾥⾯有⼏个必须要注意的:
b.size在设置的时候可以为实际的size(xxM,xxk,xx),也可以为'-'这表⽰剩余的所有空间。
相关信息可以查看drivers/mtd/cmdlinepart.c中的注释到相关描述。
U-boot的环境变量值得注意的有两个:bootcmd和bootargs。
引⽤:
ubootcmd
前⾯有说过bootcmd是⾃动启动时默认执⾏的⼀些命令,因此你可以在当前环境中定义各种不同配置,不同环境的参数设置,然后设置bootcmd为你经常使⽤的那种参数。
ubootargs
bootargs是环境变量中的重中之重,甚⾄可以说整个环境变量都是围绕着bootargs来设置的。bootargs的种类⾮常⾮常的多,我们平常只是使⽤了⼏种⽽已,感兴趣的可以看看这篇⽂章说的很全:。bootargs⾮常的灵活,内核和⽂件系统的不同搭配就会有不同的设置⽅法,甚⾄你也可以不设
置bootargs,⽽直接将其写到内核中去(在配置内核的选项中可以进⾏这样的设置),正是这些原因导致了bootargs使⽤上的困难。
下⾯介绍⼀下bootargs常⽤参数,bootargs的种类⾮常的多,⽽且随着kernel的发展会出现⼀些新的参数,使得设置会更加灵活多样。
A. root
⽤来指定rootfs的位置,常见的情况有:
root=/dev/ram rw
root=/dev/ram0 rw
请注意上⾯的这两种设置情况是通⽤的,我做过测试甚⾄root=/dev/ram1 rw和root=/dev/ram2 rw也是可以的,⽹上有⼈说在某些情况下是不通⽤的,即必须设置成ram或者ram0,但是⽬前还没有遇到,还需要进⼀步确认,遇到不⾏的时候可以逐⼀尝试。
root=/dev/mtdx rw
root=/dev/mtdblockx rw
root=/dev/mtdblock/x rw
root=31:0x
上⾯的这⼏个在⼀定情况下是通⽤的,当然这要看你当前的系统是否⽀持,不过mtd是字符设备,⽽mtdblock是块设备,有时候你的挨个的试到底当前的系统⽀持上⾯那种情况下,不过root=/dev/mtdblockx rw⽐较通⽤。此外,如果直接指定设备名可以的话,那么使⽤此设备的设备号也是可以的。
root=/dev/nfs
在⽂件系统为基于nfs的⽂件系统的时候使⽤。当然指定root=/dev/nfs之后,还需要指定nfsroot=serverip:nfs_dir,即指明⽂件系统存在那个主机的那个⽬录下⾯。
B. rootfstype
这个选项需要跟root⼀起配合使⽤,⼀般如果根⽂件系统是ext2的话,有没有这个选项是⽆所谓的,但是如果是jffs2,squashfs等⽂件系统的话,就需要rootfstype指明⽂件系统的类型,不然会⽆法挂载根分区.
console=tty使⽤虚拟串⼝终端设备.
console=ttyS[,options]使⽤特定的串⼝,options可以是这样的形式bbbbpnx,这⾥bbbb是指串⼝的波特率,p是奇偶校验位,n是指的bits。
console=ttySAC[,options]同上⾯。
看你当前的环境,有时⽤ttyS,有时⽤ttySAC,⽹上有⼈说,这是跟内核的版本有关,2.4⽤ttyS,2.6⽤ttySAC,但实际情况是官⽅⽂档中也是使⽤ttyS,所以应该是跟内核版本没有关联的。可以查看到相关描述。
D. mem
mem=xxM指定内存的⼤⼩,不是必须的
E. ramdisk_size
ramdisk=xxxxx不推荐
ramdisk_size=xxxxx推荐
上⾯这两个都可以告诉ramdisk驱动,创建的ramdisk的size,默认情况下是4m(s390默认8M),你可以查看
到相关的描述,不过ramdisk=xxxxx在新版的内核都已经没有提了,不推荐使⽤。
F. initrd, noinitrd
当你没有使⽤ramdisk启动系统的时候,你需要使⽤noinitrd这个参数,但是如果使⽤了的话,就需要指定initrd=r_addr,size, r_addr表⽰initrd在内存中的位置,size表⽰initrd的⼤⼩。
G. init
init指定的是内核启起来后,进⼊系统中运⾏的第⼀个脚本,⼀般init=/linuxrc,或者init=/etc/preinit,preinit的内容⼀般是创建console,null设备节点,运⾏init程序,挂载⼀些⽂件系统等等操作。请注意,很多初学者以为init=/linuxrc是固定写法,其实不
然,/linuxrc指的是/⽬录下⾯的linuxrc脚本,⼀般是⼀个连接罢了。
H.ip
指定系统启动之后⽹卡的ip地址,如果你使⽤基于nfs的⽂件系统,那么必须要有这个参数,其他的情况下就看你⾃⼰的喜好了。设置ip有两种⽅法:
ip = ip addr
ip=ip addr:server ip addr:gateway:netmask::which netcard:off
这两种⽅法可以⽤,不过很明显第⼆种要详细很多,请注意第⼆种中which netcard是指开发板上的⽹卡,⽽不是主机上的⽹卡。
---------------------------------------------------------------------------------------
说完常见的⼏种bootargs,那么我们来讨论平常我经常使⽤的⼏种组合:
1).假设⽂件系统是ramdisk,且直接就在内存中,bootargs的设置应该如下:
setenv bootargs ‘initrd=0x32000000,0xa00000 root=/dev/ram0 console=ttySAC0 mem=64Minit=/linuxrc’
2).假设⽂件系统是ramdisk,且在flash中,bootargs的设置应该如下:
setenv bootargs ‘mem=32M console=ttyS0,115200root=/dev/ram rw init=/linuxrc’
注意这种情况下你应该要在bootm命令中指定ramdisk在flash中的地址,如bootm kernel_addr ramdisk_addr (fdt_addr)
3).假设⽂件系统是jffs2类型的,且在flash中,bootargs的设置应该如下
setenv bootargs ‘mem=32M console=ttyS0,115200noinitrd root=/dev/mtdblock2 rwrootfstype=jffs2init=/linuxrc’4).假设⽂件系统是基于nfs的,bootargs的设置应该如下
setenv bootargs‘noinitrd mem=64M console=ttySAC0 root=/dev/nfs nfsroot=192.168.0.3:/nfs
ip=192.168.0.5:192.168.0.3:192.168.0.3:255.255.255.0::eth0:off’
或者
setenv bootargs‘noinitrd mem=64M console=ttySAC0 root=/dev/nfs nfsroot=192.168.0.3:/nfs ip=192.168.0.5’
--------------------------------------------------------------------------------------------------------------------------------------------
1. Uboot没有对Nandflash进⾏分区,通过bootargs参数将file system信息传递给kernel
2. 在kernel中对Nandflash分区信息:
arch/arm/mach-s3c6410/mach-smdk6410.c中
struct mtd_partition s3c_partition_info[] = {        {                .name          = "Bootloader",                .offset        = 0,
.size          = (512*SZ_1K),                /* .mask_flags  = MTD_CAP_NANDFLASH, */        },        {
.name          = "Kernel",                .offset        = (512*SZ_1K),                .size          = (8*SZ_1M),                /* .mask_flags = MTD_CAP_NANDFLASH, */        },        {                .name          = "File System",                .offset        = (8*SZ_1M + 512*SZ_1K),                .size          = (128*SZ_1M),        },        {                .name          = "User",                .offset        = MTDPART_OFS_APPEND,                .size          = MTDPART_SIZ_FULL,        } }; struct s3c_nand_mtd_info
s3c_nand_mtd_part_info = {        .chip_nr = 1,        .mtd_part_nr = ARRAY_SIZE(s3c_partition_info),        .partition =
s3c_partition_info, }; 3. 分区信息存放在Nandflash的最后⼀块

本文发布于:2024-09-21 01:42:35,感谢您对本站的认可!

本文链接:https://www.17tex.com/tex/4/89458.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:内核   分区   系统   设置   信息
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2024 Comsenz Inc.Powered by © 易纺专利技术学习网 豫ICP备2022007602号 豫公网安备41160202000603 站长QQ:729038198 关于我们 投诉建议