文档章节

linux启动

mskk
 mskk
发布于 2017/05/04 21:20
字数 1082
阅读 1
收藏 0
点赞 0
评论 0

转自<http://www.docin.com/p-550589514.html>

 

         对于 Intel  x86   PC , 开启电源后, 机器就会开始执行 ROM BIOS 的一系列系统测
试动作,包括检查RAM,keyboard,显示器,软硬磁盘等等。执行完bios 的系统测试之后,
紧接着控制权会转移给ROM 中的启动程序(ROM bootstrap routine);这个程序会将磁盘上的
第 0 轨第 0 扇区 (叫boot sector 或 MBR <Master Boot Record >,系统的引导程序就放在
此处)读入内存中,并放到自 0x07C0:0x0000 开始的 512 个字节处;然后处理机将跳到此处
开始执行这一引导程序;也即装入MBR 中的引导程序后, CS:IP = 0x07C0:0x0000 。加电后
处理机运行在与 8086相兼容的实模式下。
       如果要用 bootsect-loader进行系统引导,则必须把 bootsect.S 编译连接后对应的
二进制代码置于 MBR; 当ROM  BIOS 把 bootsect.S 编译连接后对应的二进制代码装入内存
后,机器的控制权就完全转交给 bootsect; 也就是说,bootsect 将是第一个被读入内存中
并执行的程序。 Bootsect 接管机器控制权后,将依次进行以下一些动作:
 
       1.首先,bootsect 将它"自己"(自位置 0x07C0:0x0000 开始的 512 个字节)从被 ROM
BIOS 载入的地址 0x07C0:0x0000处搬到 0x9000:0000 处; 这一任务由 bootsect.S 的前十条
指令完成;第十一条指令“jmpi               go,INITSEG”则把机器跳转到“新”的 bootsect 的“jmpi
   go,INITSEG”后的那条指令“go: mov di,#0x4000-12”;之后,继续执行bootsect 的剩
下的代码;在bootsect.S 中定义了几个常量:
     BOOTSEG = 0x07C0      bios 载入 MBR 的约定位置的段址;
     INITSEG  = 0x9000     bootsect.S 的前十条指令将自己搬到此处(段址)
     SETUPSEG =0x9020      装入 Setup.S 的段址
     SYSSEG   =0x1000      系统区段址
对于这些常量可参见/include/asm/boot.h 中的定义;这些常量在下面的分析中将会经常用
到;
 
       2.以0x9000:0x4000-12为栈底,建立自己的栈区;其中0x9000:0x4000-12到
0x9000:0x4000 的一十二个字节预留作磁盘参数表区;
 
       3.在0x9000:0x4000-12到0x9000:0x4000 的一十二个预留字节中建立新的磁盘
参数表,之所以叫“新”的磁盘参数表,是相对于bios 建立的磁盘参数表而言的。由于
设计者考虑到有些老的bios 不能准确地识别磁盘“每个磁道的扇区数”,从而导致bios
建立的磁盘参数表妨碍磁盘的最高性能发挥,所以,设计者就在bios 建立的磁盘参数表
的基础上通过枚举法测试,试图建立准确的“新”的磁盘参数表(这是在后继步骤中完成
的);并把参数表的位置由原来的0x0000:0x0078搬到 0x9000:0x4000-12;且修改老的磁
盘参数表区使之指向新的磁盘参数表;
 
       4.接下来就到了load_setup子过程;它调用0x13 中断的第2 号服务;把第0
道第 2扇区开始的连续的 setup_sects (为常量4)个扇区读到紧邻bootsect 的内存区;,
即0x9000:0x0200 开始的2048个字节;而这四个扇区的内容即是
/arch/i386/boot/setup.S 编译连接后对应的二进制代码;                      也就是说,如果
要用bootsect-loader进行系统引导,不仅必须把bootsect.S 编译连接后对应的二进制
代码置于MBR,而且还得把 setup.S编译连接后对应的二进制代码置于紧跟MBR 后的连续
的四个扇区中;当然,由于setup.S对应的可执行码是由bootsect 装载的,所以,在我
们的这个项目中可以通过修改bootsect 来根据需要随意地放置 setup.S对应的可执行
码;
 
       5.load_setup子过程的唯一出口是probe_loop 子过程;该过程通过枚举法测试
磁盘“每个磁道的扇区数”;
 
       6.接下来几个子过程比较清晰易懂:打印我们熟悉的“Loading”;读入系统到
0x1000:0x0000; 关掉软驱马达;根据的5步测出的“每个磁道的扇区数”确定磁盘类型;
最后跳转到 0x9000:0x0200,即setup.S对应的可执行码的入口,将机器控制权转交
setup.S;整个bootsect 代码运行完毕;

 

本文转载自:http://gaylord.iteye.com/blog/2176802

共有 人打赏支持
mskk
粉丝 2
博文 151
码字总数 3099
作品 0
宝山
程序员
双系统恢复linux的grub2系统引导(附带windos、linux双系统安装简要攻略)

00x0 适用情况(亲测有效): 1.双系统,windows重新安装后无法进入grub引导启动linux 2.删除或者重装linux后进入了grub rescue>模式启动不了系统(此情况网上有在此模式下set修改位置修复的...

张豪飞
2015/02/07
0
0
深入理解Linux内存管理-之-目录导航

转自:https://blog.csdn.net/gatieme/article/details/52384965 1 内存描述 2 页表管理 3 初始化内存管理

zwfgogo
04/20
0
0
Linux mysql安装修改root密码服务

在向大家详细介绍Linux mysql之前,首先让大家了解下Linux mysql,然后全面介绍Linux mysql,希望对大家有用。 1. Linux mysql安装: $ yum install mysql-server 2. Linux mysql修改root密码...

Zero__One
2012/09/04
0
0
Ubuntu11.10 开机启动菜单 删除多余的内核(旧版本) 调整不同操作系统的启动顺序

很多用户一般都会选择Windows + Ubuntu的双系统。用得时间久了,随着Ubuntu内核的不断升级,开机启动菜单会变得越来越臃肿。下面简单介绍一下如何删除开机启动菜单多余的内核(旧版本),以及...

神勇小白鼠
2012/03/27
0
0
安装Linux与Windows双系统

简单说就是,先安装Windows系统,再安装Linux系统,之后在Windows中使用EasyBCD添加Linux引导条目,完成。 Q: 为什么要先安装Windows后Linux? A: 因为Windows对MBR的控制欲更强烈,并且不识...

wqli
2017/10/28
0
0
Linux系统密码忘记后的五种恢复方法

一. lilo引导 1. 在出现 lilo: 提示时键入 linux single Boot: linux single 2. 回车可直接进入linux单用户模式 3. vi /etc/passwd 删除root项中的密码 (这里也可以直接使用passwd命令重新设...

Start-up
2012/08/25
0
0
关于Windows下删除Linux系统的笔记

本文内容有: 一、windows直接删除linux系统,但未格式化原linux分区为NTFS格式 二、windows直接删除linux系统,直接格式化原linux分区为NTFS格式 三、正确的在windows目录下删除linux系统的...

acmfly
2013/10/23
0
0
[转]rhel 忘记root密码修改方法

一、进入单用户模式   1.使用Linux 系统启动软盘   如果你已创建了Linux 系统的启动软盘,而且设置计算机系统从软盘启动,当显示boot 提示符后输入:   boot: linux single   系统进...

mj4738
2012/07/30
0
0
Linux系统故障分析与排查,与解决

Linux系统故障分析与排查 在处理Linux系统出现的各种故障时,故障的症状是最先发现的,而导致这以故障的原因才是最终排除故障的关键。熟悉Linux系统的日志管理,了解常见故障的分析与解决办法...

cunlifang
06/26
0
0
在Linux系统中安装和使用VNC

经常使用Linux系统,大部分情况下都是在命令行状态下进行远程维护和管理,如果需要用到图形环境,该用什么工具进行连接维护管理呢?日常使用windows系统维护时都是用pcanywhere或远程桌面进行...

曹_翔
2010/12/03
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

前端基础

1. get请求传参长度的误区 误区:我们经常说get请求参数的大小存在限制,而post请求的参数大小是无限制的。 实际上HTTP 协议从未规定 GET/POST 的请求长度限制是多少。对get请求参数的限制是...

wenxingjun
今天
0
0
Android 复制和粘贴功能

做了一回搬运工,原文地址:https://blog.csdn.net/kennethyo/article/details/76602765 Android 复制和粘贴功能,需要调用系统服务ClipboardManager来实现。 ClipboardManager mClipboardM...

她叫我小渝
今天
0
0
拦截SQLSERVER的SSL加密通道替换传输过程中的用户名密码实现运维审计(一)

工作准备 •一台SQLSERVER 2005/SQLSERVER 2008服务 •SQLSERVER jdbc驱动程序 •Java开发环境eclipse + jdk1.8 •java反编译工具JD-Core 反编译JDBC分析SQLSERVER客户端与服务器通信原理 SQ...

紅顏為君笑
今天
6
0
jQuery零基础入门——(六)修改DOM结构

《jQuery零基础入门》系列博文是在廖雪峰老师的博文基础上,可能补充了个人的理解和日常遇到的点,用我的理解表述出来,主干出处来自廖雪峰老师的技术分享。 在《零基础入门JavaScript》的时...

JandenMa
今天
0
0
linux mint 1.9 qq 安装

转: https://www.jianshu.com/p/cdc3d03c144d 1. 下载 qq 轻聊版,可在百度搜索后下载 QQ7.9Light.exe 2. 去wine的官网(https://wiki.winehq.org/Ubuntu) 安装 wine . 提醒网页可以切换成中...

Canaan_
今天
0
0
PHP后台运行命令并管理运行程序

php后台运行命令并管理后台运行程序 class ProcessModel{ private $pid; private $command; private $resultToFile = ''; public function __construct($cl=false){......

colin_86
今天
1
0
数据结构与算法4

在此程序中,HighArray类中的find()方法用数据项的值作为参数传递,它的返回值决定是否找到此数据项。 insert()方法向数组下一个空位置放置一个新的数据项。一个名为nElems的字段跟踪记录着...

沉迷于编程的小菜菜
今天
1
1
fiddler安装和基本使用以及代理设置

项目需求 由于开发过程中客户端和服务器数据交互非常频繁,有时候服务端需要知道客户端调用接口传了哪些参数过来,这个时候就需要一个工具可以监听这些接口请求参数,已经接口的响应的数据,这种...

银装素裹
今天
0
0
Python分析《我不是药神》豆瓣评论

读取 Mongo 中的短评数据,进行中文分词 对分词结果取 Top50 生成词云 生成词云效果 看来网上关于 我不是药神 vs 达拉斯 的争论很热啊。关于词频统计就这些,代码中也会完成一些其它的分析任...

猫咪编程
今天
0
0
虚拟机怎么安装vmware tools

https://blog.csdn.net/tjcwt2011/article/details/72638977

AndyZhouX
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部