資料介紹
2006-12-12 13:54:41 來源:Linux 寶庫
分享到:標(biāo)簽:loadlin gzip
作者:opera
概述
====
1)當(dāng)內(nèi)核配置了內(nèi)存盤時, 內(nèi)核在初始化時可以將軟盤加載到內(nèi)存盤中作為根盤。 當(dāng)同時配置了初始化內(nèi)存盤(Initail RAM Disk)時, 內(nèi)核在初始化時可以在安裝主盤之前, 通過引導(dǎo)程序所加載的initrd文件建立一個內(nèi)存初始化盤, 首先將它安裝成根文件系統(tǒng), 然后執(zhí)行其根目錄下的linuxrc 文件, 可用于在安裝主盤之前加載一些內(nèi)核模塊。 等到linuxrc 程序退出后, 再將主盤安裝成根文件系統(tǒng), 并將內(nèi)存初始化盤轉(zhuǎn)移安裝到其/initrd目錄下。
2)當(dāng)主盤就是initrd所生成的內(nèi)存初始化盤時, 不再進行重新安裝, 在DOS下用loadlin加載的搶救盤就是這種工作方式。
3)引導(dǎo)程序所加載的initrd為文件系統(tǒng)的映象文件, 可以是gzip壓縮的, 也可以是不壓縮的。 能夠識別的文件系統(tǒng)有minix,ext2,romfs三種。
4)當(dāng)內(nèi)核的根盤為軟盤時, 內(nèi)核初始化時會測試軟盤的指定部位是否存在文件系統(tǒng)或壓縮文件映象, 然后將之加載或解壓到內(nèi)存盤中作為根盤。 這是單張搶救軟盤的工作方式。
有關(guān)代碼
========
代碼:
; init/main.c
#ifdef CONFIG_BLK_DEV_INITRD
kdev_t real_root_dev; 啟動參數(shù)所設(shè)定的根盤設(shè)備
#endif
asmlinkage void __init start_kernel(void)
{
char * command_line;
unsigned long mempages;
extern char saved_command_line[];
lock_kernel();
printk(linux_banner);
setup_arch(&command_line); arch/i386/kernel/setup.c中,初始化initrd_start和initrd_end兩個變量
。..
#ifdef CONFIG_BLK_DEV_INITRD
if (initrd_start && !initrd_below_start_ok &&
initrd_start 《 min_low_pfn 《《 PAGE_SHIFT) {
; min_low_pfn為內(nèi)核末端_end所開始的物理頁號,initrd_start,initrd_end在rd.c中定義
printk(KERN_CRIT “initrd overwritten (0x%08lx 《 0x%08lx) - ”
“disabling it.n”,initrd_start,min_low_pfn 《《 PAGE_SHIFT);
initrd_start = 0;
}
#endif
。..
kernel_thread(init, NULL, CLONE_FS | CLONE_FILES | CLONE_SIGNAL); 創(chuàng)建init進程
unlock_kernel();
current-》need_resched = 1;
cpu_idle();
}
static int init(void * unused)
{
lock_kernel();
do_basic_setup();
/*
* Ok, we have completed the initial bootup, and
* we‘re essentially up and running. Get rid of the
* initmem segments and start the user-mode stuff.。
*/
free_initmem();
unlock_kernel();
if (open(“/dev/console”, O_RDWR, 0) 《 0)
printk(“Warning: unable to open an initial console.n”);
?。╲oid) dup(0);
?。╲oid) dup(0);
/*
* We try each of these until one succeeds.
*
* The Bourne shell can be used instead of init if we are
* trying to recover a really broken machine.
*/
if (execute_command)
execve(execute_command,argv_init,envp_init);
execve(“/sbin/init”,argv_init,envp_init);
execve(“/etc/init”,argv_init,envp_init);
execve(“/bin/init”,argv_init,envp_init);
execve(“/bin/sh”,argv_init,envp_init);
panic(“No init found. Try passing init= option to kernel.”);
}
static void __init do_basic_setup(void)
{
#ifdef CONFIG_BLK_DEV_INITRD
int real_root_mountflags;
#endif
。..
#ifdef CONFIG_BLK_DEV_INITRD
real_root_dev = ROOT_DEV; ROOT_DEV為所請求根文件系統(tǒng)的塊設(shè)備
real_root_mountflags = root_mountflags;
if (initrd_start && mount_initrd) root_mountflags &= ~MS_RDONLY;
else mount_initrd =0;
#endif
start_context_thread();
do_initcalls(); 會調(diào)用partition_setup()中加載內(nèi)存盤
/* 。. filesystems 。. */
filesystem_setup();
/* Mount the root filesystem.。 */
mount_root();
mount_devfs_fs ();
#ifdef CONFIG_BLK_DEV_INITRD
root_mountflags = real_root_mountflags;
if (mount_initrd && ROOT_DEV != real_root_dev
&& MAJOR(ROOT_DEV) == RAMDISK_MAJOR && MINOR(ROOT_DEV) == 0) {
; 如果當(dāng)前根盤為initrd所建立的內(nèi)存盤
int error;
int i, pid;
pid = kernel_thread(do_linuxrc, “/linuxrc”, SIGCHLD); 創(chuàng)建新的任務(wù)去執(zhí)行程序/linuxrc
if (pid》0)
while (pid != wait(&i)); 等待linuxrc進程退出
if (MAJOR(real_root_dev) != RAMDISK_MAJOR
|| MINOR(real_root_dev) != 0) {
; 如果原來的根盤不是0號內(nèi)存盤,則使用原來的根文件系統(tǒng),
; 并且將內(nèi)存盤轉(zhuǎn)移到其/initrd目錄下
error = change_root(real_root_dev,“/initrd”);
if (error)
printk(KERN_ERR “Change root to /initrd: ”
“error %dn”,error);
}
}
#endif
}
#ifdef CONFIG_BLK_DEV_INITRD
static int do_linuxrc(void * shell)
{
static char *argv[] = { “l(fā)inuxrc”, NULL, };
close(0);close(1);close(2);
setsid(); 設(shè)置新的session號
?。╲oid) open(“/dev/console”,O_RDWR,0);
?。╲oid) dup(0);
?。╲oid) dup(0);
return execve(shell, argv, envp_init);
}
分享到:標(biāo)簽:loadlin gzip
作者:opera
概述
====
1)當(dāng)內(nèi)核配置了內(nèi)存盤時, 內(nèi)核在初始化時可以將軟盤加載到內(nèi)存盤中作為根盤。 當(dāng)同時配置了初始化內(nèi)存盤(Initail RAM Disk)時, 內(nèi)核在初始化時可以在安裝主盤之前, 通過引導(dǎo)程序所加載的initrd文件建立一個內(nèi)存初始化盤, 首先將它安裝成根文件系統(tǒng), 然后執(zhí)行其根目錄下的linuxrc 文件, 可用于在安裝主盤之前加載一些內(nèi)核模塊。 等到linuxrc 程序退出后, 再將主盤安裝成根文件系統(tǒng), 并將內(nèi)存初始化盤轉(zhuǎn)移安裝到其/initrd目錄下。
2)當(dāng)主盤就是initrd所生成的內(nèi)存初始化盤時, 不再進行重新安裝, 在DOS下用loadlin加載的搶救盤就是這種工作方式。
3)引導(dǎo)程序所加載的initrd為文件系統(tǒng)的映象文件, 可以是gzip壓縮的, 也可以是不壓縮的。 能夠識別的文件系統(tǒng)有minix,ext2,romfs三種。
4)當(dāng)內(nèi)核的根盤為軟盤時, 內(nèi)核初始化時會測試軟盤的指定部位是否存在文件系統(tǒng)或壓縮文件映象, 然后將之加載或解壓到內(nèi)存盤中作為根盤。 這是單張搶救軟盤的工作方式。
有關(guān)代碼
========
代碼:
; init/main.c
#ifdef CONFIG_BLK_DEV_INITRD
kdev_t real_root_dev; 啟動參數(shù)所設(shè)定的根盤設(shè)備
#endif
asmlinkage void __init start_kernel(void)
{
char * command_line;
unsigned long mempages;
extern char saved_command_line[];
lock_kernel();
printk(linux_banner);
setup_arch(&command_line); arch/i386/kernel/setup.c中,初始化initrd_start和initrd_end兩個變量
。..
#ifdef CONFIG_BLK_DEV_INITRD
if (initrd_start && !initrd_below_start_ok &&
initrd_start 《 min_low_pfn 《《 PAGE_SHIFT) {
; min_low_pfn為內(nèi)核末端_end所開始的物理頁號,initrd_start,initrd_end在rd.c中定義
printk(KERN_CRIT “initrd overwritten (0x%08lx 《 0x%08lx) - ”
“disabling it.n”,initrd_start,min_low_pfn 《《 PAGE_SHIFT);
initrd_start = 0;
}
#endif
。..
kernel_thread(init, NULL, CLONE_FS | CLONE_FILES | CLONE_SIGNAL); 創(chuàng)建init進程
unlock_kernel();
current-》need_resched = 1;
cpu_idle();
}
static int init(void * unused)
{
lock_kernel();
do_basic_setup();
/*
* Ok, we have completed the initial bootup, and
* we‘re essentially up and running. Get rid of the
* initmem segments and start the user-mode stuff.。
*/
free_initmem();
unlock_kernel();
if (open(“/dev/console”, O_RDWR, 0) 《 0)
printk(“Warning: unable to open an initial console.n”);
?。╲oid) dup(0);
?。╲oid) dup(0);
/*
* We try each of these until one succeeds.
*
* The Bourne shell can be used instead of init if we are
* trying to recover a really broken machine.
*/
if (execute_command)
execve(execute_command,argv_init,envp_init);
execve(“/sbin/init”,argv_init,envp_init);
execve(“/etc/init”,argv_init,envp_init);
execve(“/bin/init”,argv_init,envp_init);
execve(“/bin/sh”,argv_init,envp_init);
panic(“No init found. Try passing init= option to kernel.”);
}
static void __init do_basic_setup(void)
{
#ifdef CONFIG_BLK_DEV_INITRD
int real_root_mountflags;
#endif
。..
#ifdef CONFIG_BLK_DEV_INITRD
real_root_dev = ROOT_DEV; ROOT_DEV為所請求根文件系統(tǒng)的塊設(shè)備
real_root_mountflags = root_mountflags;
if (initrd_start && mount_initrd) root_mountflags &= ~MS_RDONLY;
else mount_initrd =0;
#endif
start_context_thread();
do_initcalls(); 會調(diào)用partition_setup()中加載內(nèi)存盤
/* 。. filesystems 。. */
filesystem_setup();
/* Mount the root filesystem.。 */
mount_root();
mount_devfs_fs ();
#ifdef CONFIG_BLK_DEV_INITRD
root_mountflags = real_root_mountflags;
if (mount_initrd && ROOT_DEV != real_root_dev
&& MAJOR(ROOT_DEV) == RAMDISK_MAJOR && MINOR(ROOT_DEV) == 0) {
; 如果當(dāng)前根盤為initrd所建立的內(nèi)存盤
int error;
int i, pid;
pid = kernel_thread(do_linuxrc, “/linuxrc”, SIGCHLD); 創(chuàng)建新的任務(wù)去執(zhí)行程序/linuxrc
if (pid》0)
while (pid != wait(&i)); 等待linuxrc進程退出
if (MAJOR(real_root_dev) != RAMDISK_MAJOR
|| MINOR(real_root_dev) != 0) {
; 如果原來的根盤不是0號內(nèi)存盤,則使用原來的根文件系統(tǒng),
; 并且將內(nèi)存盤轉(zhuǎn)移到其/initrd目錄下
error = change_root(real_root_dev,“/initrd”);
if (error)
printk(KERN_ERR “Change root to /initrd: ”
“error %dn”,error);
}
}
#endif
}
#ifdef CONFIG_BLK_DEV_INITRD
static int do_linuxrc(void * shell)
{
static char *argv[] = { “l(fā)inuxrc”, NULL, };
close(0);close(1);close(2);
setsid(); 設(shè)置新的session號
?。╲oid) open(“/dev/console”,O_RDWR,0);
?。╲oid) dup(0);
?。╲oid) dup(0);
return execve(shell, argv, envp_init);
}
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- ADC初始化測定方法 1次下載
- multisim14.0無法加載初始化dao/jet引擎處理方法 0次下載
- 解決ds1302外置時鐘模塊重復(fù)初始化時間問題(單片機掉電,模塊電池供電)
- 嵌入式Linux開發(fā)使用NFS掛載根文件系統(tǒng)
- 如何配置WindowsCE內(nèi)核及加載自己的驅(qū)動 10次下載
- Armlinux內(nèi)核移植及系統(tǒng)初始化過程分析 11次下載
- 在51平臺下初始化文件的引入導(dǎo)致全局變量無法初始化的問題如何解決
- Linux教程之如何進行Bootloader的編寫詳細(xì)驅(qū)動學(xué)習(xí)資料匯總 7次下載
- 如何排除代碼編寫器Studio 2和2.10的初始化問題 4次下載
- ARM初始化時為什么要使用淺析GEL文件 7次下載
- 淺析GEL文件在ARM初始化時的作用和修改.pdf 1次下載
- SEED-DEC2812初始化函數(shù)說明 11次下載
- LINUX系統(tǒng)引導(dǎo)和初始化-LINUX內(nèi)核解讀 53次下載
- 手機模塊初始化向?qū)?/a>
- 嵌入式系統(tǒng)的內(nèi)核啟動過程分析
- MCU單片機GPIO初始化該按什么順序配置?為什么初始化時有電平跳變? 1140次閱讀
- 自動初始化機制原理詳解 798次閱讀
- 類隔離實現(xiàn)之自定義類加載器的擴展 487次閱讀
- 如何在Segger J-Flash中設(shè)置芯片初始化序列? 1881次閱讀
- dart語言的變量聲明與初始化 1123次閱讀
- 帶初始化的if和switch語句詳解 1232次閱讀
- RT-Thread自動初始化機制 2357次閱讀
- Linux內(nèi)存管理之伙伴系統(tǒng) 1228次閱讀
- KUKA C4機器人報:KSS13012<{總線識別號}>ECat Stack初始化時出錯 6682次閱讀
- 鴻蒙內(nèi)核源碼:內(nèi)核空間是怎么初始化的? 1731次閱讀
- 鴻蒙內(nèi)核如何初始化物理內(nèi)存? 1542次閱讀
- 基于Linux系統(tǒng)和S3C2410X處理器實現(xiàn)多媒體播放系統(tǒng)的設(shè)計 919次閱讀
- 一種基于CPLD加載FPGA的方案設(shè)計詳解 2135次閱讀
- 8253初始化程序分享_8253應(yīng)用案例 2.1w次閱讀
- 8259a初始化的步驟及代碼介紹 2.9w次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關(guān)電源基礎(chǔ)知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計與實現(xiàn)
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發(fā)板設(shè)計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關(guān)電源設(shè)計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅(qū)動電路設(shè)計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論
查看更多