博客
关于我
操作系统实验01——环境启动(知识准备)
阅读量:566 次
发布时间:2019-03-10

本文共 415 字,大约阅读时间需要 1 分钟。

知识储备

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

打开计算机后,计算机执行的第一条指令是什么?

以x86为例,刚开机,有一部分是固化的,即ROM BIOS

在这里插入图片描述
bootsect.s:
在这里插入图片描述
在这里插入图片描述
通过INT0x13 继续读取磁盘扇区,从第二个扇区开始读(bootsect本身是从第一个扇区进入内存的)4个扇区,从而读入setup.s的内容

显示开机画面:

在这里插入图片描述
继续读入磁盘中操作系统剩下内容,跳转到setup部分
在这里插入图片描述
至此,bootsect任务结束。

setup模块,即setup.s

读入内存大小,以便后续管理

将操作系统内容移动到内存0x0处
在这里插入图片描述

由实地址模式切换到保护模式

寻址方式改变,寄存器由16->32,相关指令格式发生改变
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

由head.s汇编文件跳到main.c

在这里插入图片描述

进入main()

在这里插入图片描述
在这里插入图片描述

boot :将操作系统从磁盘

setup:获得一些参数,进入保护模式
head :初始化GDT表,页表
main: 一堆init, 初始化操作

其实就是两件事:

1.将操作系统从磁盘读入内存
2.初始化

转载地址:http://snwvz.baihongyu.com/

你可能感兴趣的文章
MySQL —— 在CentOS9下安装MySQL
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
mysql 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>
Mysql 中的日期时间字符串查询
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>