Linux啟動(dòng)過(guò)程中文件系統的加載
前言:我覺(jué)得我的文章相對來(lái)說(shuō)都是比較淺顯的。一些初學(xué)者可以看看,這也是我不在嵌入式那個(gè)版上發(fā)文的原因。對于高手來(lái)說(shuō),如果你們不吝嗇時(shí)間的話(huà),希望也能幫我看看,指點(diǎn)一下其中的錯誤。這也是我到這里來(lái)和大家交流的目的。
在完成了模塊驅動(dòng)后,就要掛載文件系統了。我一直以為:
我編譯的內核是采用了initrd的模式,設備是在RAM DISK文件系統下的/linuxrc腳本程序加載的,因此在這上面浪費了很多時(shí)間。不過(guò)對initrd算是有了比較深的理解,這個(gè)等一下再說(shuō)。
其實(shí),內核掛載的第一個(gè)文件系統就是nand flash中的root.cramfs,關(guān)于掛載相關(guān)的代碼mount_root()在文件/fs/super.c里面。隨后將devcie文件系統掛載到/dev目錄下面,代碼為mount_devfs_fs()。因為采用了noninitrd的模式,因此文件系統的掛載就完畢了,init進(jìn)程繼續往下走到一直到運行:
if (execute_command)execve(execute_command,argv_init,envp_init);這里init切換成另外一個(gè)線(xiàn)程,運行程序在execute_command中定義。execute_command是vivi傳進(jìn)來(lái)的命令行,啟動(dòng)過(guò)程中可以看到:
Kernel command line: noinitrd root=/dev/bon/2 init=/linuxrc console=ttyS0因此execute_command對應/linuxrc,因此程序運行根目錄下的腳本linuxrc,在我的系統中他對應:
#!/bin/shecho "mount /etc as ramfs"/bin/mount -n -t ramfs ramfs /etc/bin/cp -a /mnt/etc/* /etcecho "re-create the /etc/mtab entries"/bin/mount -f -t cramfs -o remount,ro /dev/mtdblock/3 //bin/mount -f -t ramfs ramfs /etcexec /sbin/init這個(gè)就不解釋了(最后是啟動(dòng)bash),大家可以在linux下把root.cramfs掛載到/mnt下面看看內容就知道了:
mount –t cramfs –o loop root.cramfs /mnt/cramfs這里其實(shí)想告訴大家,我們如何實(shí)現開(kāi)機自動(dòng)加載一些運行程序,現在應該很明白了吧,寫(xiě)個(gè)腳本就OK了。(其實(shí)是我以前一直在yy這個(gè)問(wèn)題)最后講一下initrd(initail ram disk)原理我就不說(shuō)了,陳詞濫調了,網(wǎng)上多的很。我將一點(diǎn)我的理解,initrd包含了部分module的驅動(dòng),從一定程度上分擔了內核的大小,因為啟動(dòng)的時(shí)候這兩者還是要同時(shí)被load到memory中去的;因此更重要的是它可以保證內核的可移植性,對不同的硬件平臺,只要提供不同的initrd文件系統,而內核可以保持不變。因此,initrd的主要作用是加載一些復雜的與平臺相關(guān)的硬件,如SCSI硬盤(pán)驅動(dòng),網(wǎng)卡驅動(dòng)(像無(wú)盤(pán)工作站,使用nfs)等。
評論