 鲜花( 0)  鸡蛋( 0)
|
从事嵌入式开发的人都知道不同的嵌入式系统文件系统类型有不同的特点,因而根据存储设备的硬件特性、系统需求等有不同的应用场合。在嵌入式Linux应用中,主要的存储设备为 RAM(DRAM, SDRAM)
# p# M& d) v$ a I! @* P' E$ @ T
; t9 K2 A% G! k. V0 F. k和ROM(常采用FLASH存储器),常用的基于存储设备的文件系统类型包括:jffs2, yaffs, cramfs, romfs, ramdisk, ramfs/tmpfs等。( @0 { q$ W( C9 |: G5 [# N2 g+ d& G
7 \6 i5 ^* A* p, j g9 V) H9 I1. 基于FLASH的Linux嵌入式文件系统; [; m; b% b4 e* F
! Y4 N% T5 O: ~/ I( o- v. NFlash(闪存)作为嵌入式系统的主要存储媒介,有其自身的特性。Flash的写入操作只能把对应位置的1修改为0,而不能把0修改为1(擦除Flash就是把对应存储块的内容恢复为1),因此,一般情况下,向
4 k# d) b2 f$ K1 D* g d) _& M" |" F; C2 z$ Y
Flash写入内容时,需要先擦除对应的存储区间,这种擦除是以块(block)为单位进行的。6 W5 R$ o: ~8 {/ i( ]1 `
$ {# ~/ ]! T" d! ^闪存主要有NOR和NAND两种技术(简单比较见附录)。Flash存储器的擦写次数是有限的,NAND闪存还有特殊的硬件接口和读写时序。因此,必须针对Flash的硬件特性设计符合应用要求的文件系统;传统的
( B" M: ?1 k, H( `0 f6 j& p
' ^& c2 j3 y: K+ w" m! y$ n嵌入式系统文件系统如ext2等,用作Flash的文件系统会有诸多弊端。
' z% Z" M7 t' `' v# I9 K0 M+ i" [; k; u! C
在嵌入式Linux 下,MTD(Memory Technology Device,存储技术设备)为底层硬件(闪存)和上层(文件系统)之间提供一个统一的抽象接口,即Flash的文件系统都是基于MTD驱动层的(参见上面的Linux下的
' w$ U2 G' [7 P/ u- x! Z# G4 {" y; [! J. m6 k8 H- F; t& ~
文件系统结构图)。使用MTD驱动程序的主要优点在于,它是专门针对各种非易失性存储器(以闪存为主)而设计的,因而它对Flash有更好的支持、管理和基于扇区的擦除、读/写操作接口。顺便一提,一
: Y& e! v- o8 k& B( u& w! v! L4 @
' z$ O7 N$ @$ C. j& [块Flash芯片可以被划分为多个分区,各分区可以采用不同的文件系统;两块Flash芯片也可以合并为一个分区使用,采用一个文件系统。即文件系统是针对于存储器分区而言的,而非存储芯片。7 I0 `' r8 a, d, S+ e* G6 ?7 d
* I; k1 V9 T% D9 ^& @
(1) jffs2
+ f4 ~4 ~6 o `/ P" T* u
$ w. y+ V( A, l+ t4 _" d+ @6 BJFFS嵌入式系统文件系统最早是由瑞典 Axis Communications公司基于Linux2.0的内核为嵌入式系统开发的文件系统。JFFS2是RedHat公司基于JFFS开发的闪存文件系统,最初是针对RedHat公司的嵌入式 s+ R4 b+ P9 T7 {2 [( v3 B' q6 m
" Q% j0 \! \0 V9 l
产品eCos开发的嵌入式文件系统,所以JFFS2也可以用在Linux, uCLinux中。
. L" R: i8 S) I7 Q! L K; j
! L4 s4 b4 {) Y8 n$ RJffs2: 日志闪存嵌入式系统文件系统版本2 (Journalling Flash FileSystem v2)
& o6 S! Y8 p+ a/ @& Y5 S8 L9 a( J% U0 Y$ N4 @5 W
主要用于NOR型闪存,基于MTD驱动层,特点是:可读写的、支持数据压缩的、基于哈希表的日志型文件系统,并提供了崩溃/掉电安全保护,提供“写平衡”支持等。缺点主要是当文件系统已满或接近满+ E# e1 Z8 N' J3 n. v5 C
. R: y7 d# A$ v: j# ^) u
时,因为垃圾收集的关系而使jffs2的运行速度大大放慢。目前jffs3正在开发中。关于jffs系列文件系统的使用详细文档,可参考MTD补丁包中mtd-jffs-HOWTO.txt。# R* M: {# E2 y
( d, i9 N2 K' p0 t# d' g) w
jffsx不适合用于NAND闪存主要是因为NAND闪存的容量一般较大,这样导致jffs为维护日志节点所占用的内存空间迅速增大,另外,jffsx文件系统在挂载时需要扫描整个FLASH的内容,以找出所有的日志6 [; d1 W, Z, [% J7 A7 N1 p- @
+ w1 a u! P% ~# H& p, g节点,建立文件结构,对于大容量的NAND闪存会耗费大量时间。
7 c2 l9 k5 S+ m; H K5 H' @( S
# H% D2 v; ?& @/ o(2) yaffs:Yet Another Flash File System
: Q% Q" ^7 n& U/ k
5 S. z3 m) T% z# s0 N' `yaffs/yaffs2是专为嵌入式系统使用NAND型闪存而设计的一种日志型文件系统。与jffs2相比,它减少了一些功能(例如不支持数据压缩),所以速度更快,挂载时间很短,对内存的占用较小。另外,它还
2 ^9 ~+ @5 }& Q2 ]8 R" T% b2 [' M, u9 Q$ T1 [! R
是跨平台的文件系统,除了Linux和eCos,还支持WinCE, pSOS和ThreadX等。6 s7 @, z9 k4 H; m) |
( [3 @( ]+ x( o% h. a" _8 S# T1 syaffs/yaffs2自带NAND芯片的驱动,并且为嵌入式系统提供了直接访问文件系统的API,用户可以不使用Linux中的MTD与VFS,直接对文件系统操作。当然,yaffs也可与MTD驱动程序配合使用。
7 f; F7 P: H" Z0 R" r) e) y; k+ O4 K( v' I) S) S2 v0 Z" @2 k+ n
yaffs与yaffs2的主要区别在于,前者仅支持小页(512 Bytes) NAND闪存,后者则可支持大页(2KB) NAND闪存。同时,yaffs2在内存空间占用、垃圾回收速度、读/写速度等方面均有大幅提升。
# n/ a/ T5 u9 c( I8 [3 j% s
5 {. D- O' }! a5 ~(3) Cramfs:Compressed ROM File System8 G" Y, }4 n! ]2 Q( s
) A( D% Y9 K, G! `+ h- N9 ICramfs是Linux的创始人 Linus Torvalds参与开发的一种只读的压缩文件系统。它也基于MTD驱动程序。在cramfs文件系统中,每一页(4KB)被单独压缩,可以随机页访问,其压缩比高达2:1,为嵌入式系
9 R9 {/ ?( |) V- L
' Y1 T( e+ X3 z a X/ u统节省大量的Flash存储空间,使系统可通过更低容量的FLASH存储相同的文件,从而降低系统成本。* o, c8 `% T2 |; b! x6 q, t7 L9 k
8 |" V6 ^& c8 D7 l- Z4 A! b9 t2 D+ m
Cramfs文件系统以压缩方式存储,在运行时解压缩,所以不支持应用程序以XIP方式运行,所有的应用程序要求被拷到RAM里去运行,但这并不代表比Ramfs需求的RAM空间要大一点,因为Cramfs是采用分
% E1 u1 k5 e2 |9 V8 Z/ J" s1 ?6 N! Z$ ]3 ]$ X, k
页压缩的方式存放档案,在读取档案时,不会一下子就耗用过多的内存空间,只针对目前实际读取的部分分配内存,尚没有读取的部分不分配内存空间,当我们读取的档案不在内存时,Cramfs文件系统, H' ^" }% W+ v% c1 D# ]* J) v+ ^3 u
+ S; M- D5 _# j) b! a" m; c
自动计算压缩后的资料所存的位置,再即时解压缩到RAM中。另外,它的速度快,效率高,其只读的特点有利于保护文件系统免受破坏,提高了系统的可靠性。由于以上特性,Cramfs在嵌入式系统中应用' }! b- ~# m/ X/ `. @& U
2 n) U! V( u5 \" T( {! W U% f广泛。但是它的只读属性同时又是它的一大缺陷,使得用户无法对其内容对进扩充。Cramfs映像通常是放在Flash中,但是也能放在别的文件系统里,使用loopback 设备可以把它安装别的文件系统里。
9 k8 k/ G" h2 }) E2 n8 q2 h; y X
) }. S5 \2 i$ s+ y( c( Y# J(4) Romfs
; ]/ D4 L; `# t+ @- |: i b# B3 _# ~5 `9 i/ q9 h, l
传统型的Romfs文件系统是一种简单的、紧凑的、只读的文件系统,不支持动态擦写保存,按顺序存放数据,因而支持应用程序以 XIP(eXecute In Place,片内运行)方式运行,在系统运行时,节省RAM
7 B3 e+ E4 {6 i, C$ u
; D( a e4 o9 p" r+ b% |空间。uClinux系统通常采用Romfs文件系统。其他嵌入式系统文件:fat/fat32也可用于实际嵌入式系统的扩展存储器(例如PDA, Smartphone, 数码相机等的SD卡),这主要是为了更好的与最流行的7 @% j2 W6 V0 F' c; c
6 f N: w4 g- E" M3 p2 h4 X+ `
Windows桌面操作系统相兼容。ext2也可以作为嵌入式Linux的文件系统,不过将它用于 FLASH闪存会有诸多弊端。2 i, j; _! H. B3 J/ Q
8 s N3 Y6 m, d" E7 g* @2. 基于RAM的Linux嵌入式文件系统
& g% }; j9 S; |# @
: \* t/ H8 _2 I; |6 M/ }$ @; s U(1) Ramdisk, D M$ }- d5 E0 A) t
4 I; n0 V# I' e% L8 o% E& A% U. A0 ?Ramdisk是将一部分固定大小的内存当作分区来使用。它并非一个实际的嵌入式系统文件,而是一种将实际的文件系统装入内存的机制,并且可以作为根文件系统。将一些经常被访问而又不会更改的文件$ `- i7 y! G6 l: M( {
% B; a5 B8 @2 Y# O( r3 k) D1 |(如只读的根文件系统)通过Ramdisk放在内存中,可以明显地提高系统的性能。在Linux的启动阶段,initrd提供了一套机制,可以将内核映像和根文件系统一起载入内存。: X' W4 r" z; {7 E4 T
( u& K5 R3 }. Z; ?8 v) \. a7 Z(2)ramfs/tmpfs* y1 X& T& b0 F# M1 J' j
& p2 Z+ D; Z9 U @8 ?# y: ~
Ramfs是Linus Torvalds开发的一种基于内存的文件系统,工作于虚拟文件系统(VFS)层,不能格式化,可以创建多个,在创建时可以指定其最大能使用的内存大小。(实际上,VFS本质上可看成一种内存 m3 c+ \" M7 _
, x, p( ]# I, H0 K* s# S% m文件系统,它统一了文件在内核中的表示方式,并对磁盘文件系统进行缓冲。): z7 y" u3 Q2 @ S
1 t" m6 ?' R* J% \Ramfs/tmpfs文件系统把所有的文件都放在RAM中,所以读/写操作发生在RAM中,可以用ramfs/tmpfs来存储一些临时性或经常要修改的数据,例如/tmp和/var目录,这样既避免了对Flash存储器的读写损9 U$ I( Q( U" i' G& T
5 e- J! ?. {9 h3 w" s. s, p
耗,也提高了数据读写速度。Ramfs/tmpfs相对于传统的Ramdisk的不同之处主要在于:不能格式化,嵌入式系统文件大小可随所含文件内容大小变化。Tmpfs的一个缺点是当系统重新引导时会丢失所有数据。
8 ^* U9 K& @ A: Q7 |& V- Y6 C1 H+ l
说实在的,嵌入式这块水深的很,我当年从北京达内c++培训出来阴差阳错的进入了嵌入式这个行业,至今为止在这条路上一路坎坷走过。今年达内的老师跟我打电话说让我回去为达内嵌入式学院做讲座! @8 [' |1 q5 H* a$ {
,讲完后学员提问了很多问题,这是一个刚刚入门的师弟问我的这个问题,当时回答的不是很详细,回来后整理成此文,希望对学弟学妹们有所帮助。
/ v, o8 u# k1 C' T2 X; D4 i转自:http://www.3gtarena.com/ |
|