博客
关于我
操作系统实验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创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
MySQL删除数据几种情况以及是否释放磁盘空间【转】
查看>>
Mysql删除重复数据通用SQL
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>
mysql加强(5)~DML 增删改操作和 DQL 查询操作
查看>>
mysql加强(6)~子查询简单介绍、子查询分类
查看>>
mysql加强(7)~事务、事务并发、解决事务并发的方法
查看>>
MySQL千万级多表关联SQL语句调优
查看>>
mysql千万级大数据SQL查询优化
查看>>
MySQL千万级大表优化策略
查看>>