|
長春嵌入式培訓(xùn)學(xué)校_嵌入式linux啟動信息完全注釋,
作者: yut616@sohu.com 摘要 我們在這里討論的是對嵌入式linux系統(tǒng)的啟動過程的輸出信息的注釋,通過我們的討論,大家會對嵌入式linux啟動過程中出現(xiàn)的、以前感覺熟悉的、但卻又似是而非的東西有一個確切的了解,并且能了解到這些輸出信息的來龍去脈。 嵌入式linux的啟動信息是一個很值得我們?nèi)ズ煤醚芯康臇|西,它能將一幅縮影圖呈現(xiàn)在我們面前,來指導(dǎo)我們更加深入地理解linux內(nèi)核。 關(guān)鍵字:linux,嵌入式,啟動,bootloader 正文 作為一名嵌入系統(tǒng)開發(fā)者,你一定遇到過下面的情景: 在某論壇上看到一篇帖子,上面貼著嵌入式linux開發(fā)板啟動時的有關(guān)信息,然后大家在帖子里討論著這個啟動過程中出現(xiàn)的問題,隨機舉例如下: Linux version 2.4.20-uc0 (root@Local) (gcc version 2.95.3 20010315 (release)(ColdFire patches - 20010318 from http://f (uClinux XIP and shared lib patches from http://www.snapgear.com/)) #20 三 6月 1 8 00:58:31 CST 2003 Processor: Samsung S3C4510B revision 6 Architecture: SNDS100 On node 0 totalpages: 4096 zone(0): 0 pages. zone(1): 4096 pages. zone(2): 0 pages. Kernel command line: root=/dev/rom0 Calibrating delay loop... 49.76 BogoMIPS Memory: 16MB = 16MB total Memory: 14348KB available (1615K code, 156K data, 40K init) Dentry cache hash table entries: 2048 (order: 2, 16384 bytes) Inode cache hash table entries: 1024 (order: 1, Mount-cache hash table entries: 512 (order: 0, 4096 bytes) Buffer-cache hash table entries: 1024 (order: 0, 4096 bytes) Page-cache hash table entries: 4096 (order: 2, 16384 bytes) POSIX conformance testing by UNIFIX Linux NET4.0 for Linux 2.4 Based upon Swansea University Computer Society NET3.039 Initializing RT netlink socket Starting kswapd Samsung S3C4510 Serial driver version 0.9 (2001-12-27) with no serial options en abled ttyS00 at 0x3ffd000 (irq = 5) is a S3C4510B ttyS01 at 0x3ffe000 (irq = 7) is a S3C451 Blkmem copyright 1998,1999 D. Jeff Dionne Blkmem copyright 1998 Kenneth Albanowski Blkmem 1 disk images: 0: BE558-1A5D57 [VIRTUAL BE558-1A5D57] (RO) RAMDISK driver initialized: 16 RAM disks of 1024K size 1024 blocksize Samsung S3C4510 Ethernet driver version 0.1 (2002-02-20) eth0: 00:40:95:36:35:34 NET4: Linux TCP/IP 1.0 for NET4.0 IP Protocols: ICMP, UDP, TCP IP: routing cache hash table of 512 buckets, 4Kbytes TCP: Hash tables configured (established 1024 bind 1024) VFS: Mounted root (romfs Freeing init memory: 40K 上面的這些輸出信息,也可能包括你自己正在做的嵌入式linux開發(fā)板的輸出信息,其中的每一行,每一個字的含義,你是否深究過,或者說大部分的含義你能確切地知道的?本人想在這里結(jié)合本人在實踐中一些體會來和廣大嵌入式linux的開發(fā)者一起讀懂這些信息。 我們在這里將以一個真實的嵌入式linux系統(tǒng)的啟動過程為例,來分析這些輸出信息。啟動信息的原始內(nèi)容將用標(biāo)記標(biāo)出,以區(qū)別與注釋。 嵌入式linux的啟動主要分為兩個階段: ① 第一部分bootloader啟動階段 ② 第二部分linux 內(nèi)核初始化和啟動階段 第一節(jié):start_kernel 第二節(jié):用戶模式( user_mode )開始,start_kernel結(jié)束 第三節(jié):加載linux內(nèi)核完畢,轉(zhuǎn)入cpu_idle進程 第一部分 : bootloader啟動 Boot loader v0.12 NOTE: this boot loader is designed to boot kernels made with the 2.4.xx releases bootloader for XV Built at Nov 20 2005 10:12:35 Bootloader頭信息,版本,編譯時間等,這個因不同的bootloader的設(shè)計而有所不同,由此你能看出bootloader的版本信息,有很多使用的是通用的bootloader,如u-boot,redboot等。 Loaded to 0x90060000 將bootloader加載到內(nèi)存ram中的0x90060000處,即將bootloader加載到內(nèi)存的高端地址處。 Linux內(nèi)核將被bootloader加載到0x90090000處。 Found boot configuration 查找到了啟動boot的配置信息 Booted from parallel flash 從flash中啟動代碼,此處的flash為并行閃存。Flash的分類列舉如下: 閃存分三類:并行,串行,不可擦除。 ①并行Parallel flash |
|