首页
技术博客
PHP教程
数据库技术
前端开发
HTML5
Nginx
php论坛
新用户注册
|
会员登录
PHP教程
技术博客
编程问答
PNG素材
编程语言
前端技术
Android
PHP教程
HTML5教程
数据库
Linux技术
Nginx技术
PHP安全
WebSerer
职场攻略
JavaScript
开放平台
业界资讯
大话程序猿
登录
极速注册
取消
热门标签 | HotTags
less
c语言
plugins
replace
select
erlang
node.js
iostream
expression
dll
heap
php5
数组
golang
runtime
integer
utf-8
hashcode
io
vba
solr
config
chat
email
jsp
ascii
command
frameworks
metadata
const
php7
instance
bit
emoji
uri
cpython
buffer
php
actionscrip
default
typescript
require
audio
char
flutter
uml
shell
schema
merge
heatmap
subset
get
bash
blob
md5
vbscript
perl
int
rsa
string
usb
process
nodejs
stream
list
go
express
spring
filter
js
tags
request
timestamp
settings
ip
python2
split
substring
scala
当前位置:
开发笔记
>
编程语言
> 正文
《linux内核完全剖析》第六章引导启动程序笔记
作者:小文662502914775 | 来源:互联网 | 2023-10-12 12:53
1、简介引导启动程序部分主要在boot子目录下,该目录包含三个汇编代码文件bootsect.S、head.S和setup.S。由于目前没有对汇编进行系统的学习
1、简介
引导启动程序部分主要在boot/子目录下,该目录包含三个汇编代码文件bootsect.S、head.S和setup.S。由于目前没有对汇编进行系统的学习,所以本文不对代码细节实现做讲解,主要描述代码的功能。
2、操作系统启动执行流程
PC电源打开后,80x86结构CPU进入实模式,从地址0xFFFF0执行程序代码,这个地址通常是BIOS中的地址。随后BIOS开始执行系统检测,在物理地址0处开始初始化中断向量,然后BIOS将启动设备的第一个扇区读入内存绝对地址0x7C00处,并跳转到此处。
从系统加电起所执行程序的顺序
3、bootsect.S程序功能描述
bootsect.S代码是磁盘引导块程序,驻留在磁盘的第一个扇区中,bootsect代码执行期间,它会将自己移动到内存绝对地址0x90000开始处并继续执行。该程序把从磁盘的第二个扇区开始的四个扇区的setup模块(setup.S编译而成)加载到内存紧接着bootsect后面位置处(0x90200),然后利用BIOS中断0x13取磁盘参数表中当前启动引导盘的参数,在屏幕上显示“Loading system...”字符串。再把磁盘上setup模块后面的system模块加载到内存0x10000开始的地方。随后确定根文件系统的设备号,如果没有指定,则根据所保存的引导盘的每磁道扇区数判别出盘的类型和种类并保存设备号于root_dev(引导块的508地址处)中最后长跳转到setup程序开始处(0x90200)去执行setup程序。磁盘上,引导块、setup模块和system模块的扇区位置如下。
Linux 0.12 内核在 1.44MB 磁盘上的分布情况
4、setup.S程序功能描述
setup是一个操作系统加载程序,它利用BIOS中断读取机器系统数据并把数据保存到0x90000开始的位置(覆盖了bootsect程序的位置)。然后setup程序把system模块从0x10000~0x8ffff整块下移到内存绝对地址0x00000处。接下来加载中断描述符标寄存器(idtr)和全局描述符表寄存器(gdtr),开启A20地址线,重新设置两个中断控制芯片8259A,把硬件中断号重新设置为0x20~0x2f。最后设置cpu的控制寄存器CR0,进入32位保护模式运行,并跳转到位于system模块最前面部分的head.s程序继续运行。
5、head.s程序功能描述
head.s程序在被编译生成目标文件后会与内核其他程序一起被链接成system模块,位于system模块的最前面开始部分。从这里开始,内核完全都是在保护模式下运行了。这段程序位于内存绝对地址0处开始的地方。head.s程序功能单一,首先加载各个数据段寄存器,重新设置中断描述符表idt,共256项,并使各个表项都指向一个只报错误的哑中断子程序ignore_int。然后重新设置全局段描述符表gdt,只是修改gdt的段限长。接着使用物理地址0与1MB开始处的字节内容相比较的方法,检测A20地址线是否开启。接着设置管理内存的分页处理机制,把页目录表放在绝对物理地址0开始处,紧随后面放置共可寻址16MB内存的4个页表并设置它们的表项。最后head.s程序利用返回指令把预先放置在堆栈中的/init/main.c程序的入口地址弹出,去运行main()程序。
linux
文件
x86
cpu
ios
编译
int
main
写下你的评论吧 !
吐个槽吧,看都看了
会员登录
|
用户注册
推荐阅读
io
解析与定位总线错误和段错误
对于许多初学者而言,遇到总线错误(bus error)或段错误(segmentation fault/core dump)是极其令人困扰的。本文详细探讨了这两种错误的成因、表现形式及解决方法,并提供了实用的调试技巧。 ...
[详细]
蜡笔小新 2024-12-20 20:54:09
io
优化DB2数据库性能的关键策略
本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ...
[详细]
蜡笔小新 2024-12-22 16:20:33
io
主调|大侠_重温C++
主调|大侠_重温C++ ...
[详细]
蜡笔小新 2024-12-20 20:43:56
const
Linux 文件输入输出操作
本文介绍了Linux系统中的文件IO操作,包括文件描述符、基本文件操作函数以及目录操作。详细解释了各个函数的参数和返回值,并提供了代码示例。 ...
[详细]
蜡笔小新 2024-12-24 02:33:04
const
如何使用PyCharm及常用配置详解
对于一枚pycharm工具的使用新手,正确了解这门工具的配置及其使用,在使用过程中遇到的很多问题也可以迎刃而解,文中有非常详细的介绍, ...
[详细]
蜡笔小新 2024-12-23 17:32:18
io
使用SSH密钥对实现Linux系统免密码登录
本文详细介绍如何在Linux系统中配置SSH密钥对,以实现从一台主机到另一台主机的无密码登录。内容涵盖密钥对生成、公钥分发及权限设置等关键步骤。 ...
[详细]
蜡笔小新 2024-12-23 16:17:45
io
C语言的起源与发展历程
本文详细介绍了C语言的起源、发展及其标准化过程,涵盖了从早期的BCPL和B语言到现代C语言的演变,并探讨了其在操作系统和跨平台编程中的重要地位。 ...
[详细]
蜡笔小新 2024-12-23 14:11:43
io
解决Android SDK中aapt错误:无法加载libstdc++.so.6共享库
在创建新的Android项目时,您可能会遇到aapt错误,提示无法打开libstdc++.so.6共享对象文件。本文将探讨该问题的原因及解决方案。 ...
[详细]
蜡笔小新 2024-12-23 11:49:11
const
紫荆花之恋:动态树上的小精灵友谊问题
本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ...
[详细]
蜡笔小新 2024-12-22 14:36:54
jsp
嵌入式开发环境搭建与文件传输指南
本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ...
[详细]
蜡笔小新 2024-12-22 13:38:48
c语言
深入解析GCD:任务队列与多线程编程
本文详细介绍了Grand Central Dispatch (GCD) 的核心概念和使用方法,探讨了任务队列、同步与异步执行以及常见的死锁问题。通过具体示例和代码片段,帮助开发者更好地理解和应用GCD进行多线程开发。 ...
[详细]
蜡笔小新 2024-12-22 10:11:08
io
Linux环境下C语言实现定时向文件写入当前时间
本文介绍如何在Linux系统中使用C语言编程,实现在每秒钟向指定文件中写入当前时间戳。通过此示例,读者可以了解基本的文件操作、时间处理以及循环控制。 ...
[详细]
蜡笔小新 2024-12-21 21:39:27
config
解决编译BSP包时遇到的 'gets' 未声明错误
在编译BSP包过程中,遇到了一个与 'gets' 函数相关的编译错误。该问题通常发生在较新的编译环境中,由于 'gets' 函数已被弃用并视为安全漏洞。本文将详细介绍如何通过修改源代码和配置文件来解决这一问题。 ...
[详细]
蜡笔小新 2024-12-21 11:21:05
email
Linux环境下进程间通信:深入解析信号机制
本文详细探讨了Linux系统中信号的生命周期,从信号生成到处理函数执行完毕的全过程,并介绍了信号编程中的注意事项和常见应用实例。通过分析信号在进程中的注册、注销及处理过程,帮助读者理解如何高效利用信号进行进程间通信。 ...
[详细]
蜡笔小新 2024-12-21 10:29:05
io
深入理解Java多线程并发处理:基础与实践
本文探讨了Java中的多线程并发处理机制,从基本概念到实际应用,帮助读者全面理解并掌握多线程编程技巧。通过实例解析和理论阐述,确保初学者也能轻松入门。 ...
[详细]
蜡笔小新 2024-12-20 19:28:45
小文662502914775
这个家伙很懒,什么也没留下!
Tags | 热门标签
less
c语言
plugins
replace
select
erlang
node.js
iostream
expression
dll
heap
php5
数组
golang
runtime
integer
utf-8
hashcode
io
vba
solr
config
chat
email
jsp
ascii
command
frameworks
metadata
const
RankList | 热门文章
1
C++ 编译器警告:“xxxx”:非标准语法,请使用 “&” 以创建指向成员的指针
2
如何在运行时动态获取Entity Framework中的ObjectSet
?
3
中国餐饮连锁加盟十大热门品牌榜单(全国最具人气的加盟选择)
4
Webvan的失败:基于用户假设的产品开发与快速扩张策略分析
5
深入解析 ulimit 的使用方法与应用场景
6
解决基于XML配置的MyBatis在Spring整合中出现“无效绑定语句(未找到):com.music.dao.MusicDao.findAll”问题的方法
7
从零起步:使用IntelliJ IDEA搭建Spring Boot应用的详细指南
8
优化后的标题:消息分发的撰写技巧与最佳实践
9
Kubernetes中为容器设置主机名解析配置
10
基于Node.js的高性能实时消息推送系统:利用Socket.IO与Express实现高并发消息转发
11
深入解析经典卷积神经网络及其实现代码
12
HihoCoder 1505: 深入解析算法挑战与编程技巧
13
[TyvjP1050] 动态规划求解最长公共子序列问题
14
如何高效处理大规模数据报表的分页展示,有哪些优化方法和技巧?
15
Linux 文件系统与分区操作指南
PHP1.CN | 中国最专业的PHP中文社区 |
DevBox开发工具箱
|
json解析格式化
|
PHP资讯
|
PHP教程
|
数据库技术
|
服务器技术
|
前端开发技术
|
PHP框架
|
开发工具
|
在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved |
京公网安备 11010802041100号
|
京ICP备19059560号-4
| PHP1.CN 第一PHP社区 版权所有