資料介紹
2006-12-12 13:54:41 來源:Linux 寶庫
分享到:標簽:loadlin gzip
作者:opera
概述
====
1)當內核配置了內存盤時, 內核在初始化時可以將軟盤加載到內存盤中作為根盤。 當同時配置了初始化內存盤(Initail RAM Disk)時, 內核在初始化時可以在安裝主盤之前, 通過引導程序所加載的initrd文件建立一個內存初始化盤, 首先將它安裝成根文件系統, 然后執行其根目錄下的linuxrc 文件, 可用于在安裝主盤之前加載一些內核模塊。 等到linuxrc 程序退出后, 再將主盤安裝成根文件系統, 并將內存初始化盤轉移安裝到其/initrd目錄下。
2)當主盤就是initrd所生成的內存初始化盤時, 不再進行重新安裝, 在DOS下用loadlin加載的搶救盤就是這種工作方式。
3)引導程序所加載的initrd為文件系統的映象文件, 可以是gzip壓縮的, 也可以是不壓縮的。 能夠識別的文件系統有minix,ext2,romfs三種。
4)當內核的根盤為軟盤時, 內核初始化時會測試軟盤的指定部位是否存在文件系統或壓縮文件映象, 然后將之加載或解壓到內存盤中作為根盤。 這是單張搶救軟盤的工作方式。
有關代碼
========
代碼:
; init/main.c
#ifdef CONFIG_BLK_DEV_INITRD
kdev_t real_root_dev; 啟動參數所設定的根盤設備
#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為內核末端_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); 創建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為所請求根文件系統的塊設備
real_root_mountflags = root_mountflags;
if (initrd_start && mount_initrd) root_mountflags &= ~MS_RDONLY;
else mount_initrd =0;
#endif
start_context_thread();
do_initcalls(); 會調用partition_setup()中加載內存盤
/* 。. 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) {
; 如果當前根盤為initrd所建立的內存盤
int error;
int i, pid;
pid = kernel_thread(do_linuxrc, “/linuxrc”, SIGCHLD); 創建新的任務去執行程序/linuxrc
if (pid》0)
while (pid != wait(&i)); 等待linuxrc進程退出
if (MAJOR(real_root_dev) != RAMDISK_MAJOR
|| MINOR(real_root_dev) != 0) {
; 如果原來的根盤不是0號內存盤,則使用原來的根文件系統,
; 并且將內存盤轉移到其/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[] = { “linuxrc”, NULL, };
close(0);close(1);close(2);
setsid(); 設置新的session號
(void) open(“/dev/console”,O_RDWR,0);
?。╲oid) dup(0);
?。╲oid) dup(0);
return execve(shell, argv, envp_init);
}
分享到:標簽:loadlin gzip
作者:opera
概述
====
1)當內核配置了內存盤時, 內核在初始化時可以將軟盤加載到內存盤中作為根盤。 當同時配置了初始化內存盤(Initail RAM Disk)時, 內核在初始化時可以在安裝主盤之前, 通過引導程序所加載的initrd文件建立一個內存初始化盤, 首先將它安裝成根文件系統, 然后執行其根目錄下的linuxrc 文件, 可用于在安裝主盤之前加載一些內核模塊。 等到linuxrc 程序退出后, 再將主盤安裝成根文件系統, 并將內存初始化盤轉移安裝到其/initrd目錄下。
2)當主盤就是initrd所生成的內存初始化盤時, 不再進行重新安裝, 在DOS下用loadlin加載的搶救盤就是這種工作方式。
3)引導程序所加載的initrd為文件系統的映象文件, 可以是gzip壓縮的, 也可以是不壓縮的。 能夠識別的文件系統有minix,ext2,romfs三種。
4)當內核的根盤為軟盤時, 內核初始化時會測試軟盤的指定部位是否存在文件系統或壓縮文件映象, 然后將之加載或解壓到內存盤中作為根盤。 這是單張搶救軟盤的工作方式。
有關代碼
========
代碼:
; init/main.c
#ifdef CONFIG_BLK_DEV_INITRD
kdev_t real_root_dev; 啟動參數所設定的根盤設備
#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為內核末端_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); 創建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為所請求根文件系統的塊設備
real_root_mountflags = root_mountflags;
if (initrd_start && mount_initrd) root_mountflags &= ~MS_RDONLY;
else mount_initrd =0;
#endif
start_context_thread();
do_initcalls(); 會調用partition_setup()中加載內存盤
/* 。. 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) {
; 如果當前根盤為initrd所建立的內存盤
int error;
int i, pid;
pid = kernel_thread(do_linuxrc, “/linuxrc”, SIGCHLD); 創建新的任務去執行程序/linuxrc
if (pid》0)
while (pid != wait(&i)); 等待linuxrc進程退出
if (MAJOR(real_root_dev) != RAMDISK_MAJOR
|| MINOR(real_root_dev) != 0) {
; 如果原來的根盤不是0號內存盤,則使用原來的根文件系統,
; 并且將內存盤轉移到其/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[] = { “linuxrc”, NULL, };
close(0);close(1);close(2);
setsid(); 設置新的session號
(void) 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外置時鐘模塊重復初始化時間問題(單片機掉電,模塊電池供電)
- 嵌入式Linux開發使用NFS掛載根文件系統
- 如何配置WindowsCE內核及加載自己的驅動 10次下載
- Armlinux內核移植及系統初始化過程分析 11次下載
- 在51平臺下初始化文件的引入導致全局變量無法初始化的問題如何解決
- Linux教程之如何進行Bootloader的編寫詳細驅動學習資料匯總 7次下載
- 如何排除代碼編寫器Studio 2和2.10的初始化問題 4次下載
- ARM初始化時為什么要使用淺析GEL文件 7次下載
- 淺析GEL文件在ARM初始化時的作用和修改.pdf 1次下載
- SEED-DEC2812初始化函數說明 11次下載
- LINUX系統引導和初始化-LINUX內核解讀 53次下載
- 手機模塊初始化向導
- 嵌入式系統的內核啟動過程分析
- MCU單片機GPIO初始化該按什么順序配置?為什么初始化時有電平跳變? 1140次閱讀
- 自動初始化機制原理詳解 798次閱讀
- 類隔離實現之自定義類加載器的擴展 487次閱讀
- 如何在Segger J-Flash中設置芯片初始化序列? 1881次閱讀
- dart語言的變量聲明與初始化 1123次閱讀
- 帶初始化的if和switch語句詳解 1232次閱讀
- RT-Thread自動初始化機制 2357次閱讀
- Linux內存管理之伙伴系統 1228次閱讀
- KUKA C4機器人報:KSS13012<{總線識別號}>ECat Stack初始化時出錯 6682次閱讀
- 鴻蒙內核源碼:內核空間是怎么初始化的? 1731次閱讀
- 鴻蒙內核如何初始化物理內存? 1542次閱讀
- 基于Linux系統和S3C2410X處理器實現多媒體播放系統的設計 919次閱讀
- 一種基于CPLD加載FPGA的方案設計詳解 2135次閱讀
- 8253初始化程序分享_8253應用案例 2.1w次閱讀
- 8259a初始化的步驟及代碼介紹 2.9w次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關電源基礎知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統的設計與實現
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發板設計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關電源設計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅動電路設計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 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十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論
查看更多