文档章节

进入保护模式(八)简单OS内存使用分布

Cobbage
 Cobbage
发布于 2013/12/29 20:48
字数 549
阅读 100
收藏 3

1.上次说要实现键盘中断还没实现的
2.接着又有问题了就是对于异常的处理,例如一个也异常的处理

一直在512字节里面写很憋屈,这下把书上的代码用上暂且内存分布如下

慢慢修改了,在更新修改

#直接用给的程序加载从第二个扇区开始
#加载的是保护模式的程序
#但是加载到什么地方哪?按照书上的位置

#显示的时候直接写显存位置怎么处理?怎么回车换行
#用一个全局变量标示写入的位置80*25的标准

#全局段描述表     
 0 空
 1 数据段         初始地址是0x0          界限是4G                   4G         全局修改
 2 主程序加载的段 初始地址是0x7C00       界限是1FF                  512字节    跳转保护
 3 堆栈段         初始地址是0x7C00       界限是0xFFFFE000<<FFFFFFFF 大小4KB    ESP的初始值?
 4 显示描述       初始地址是0xB8000      界限是7FFFF                也就是  
 5 系统公用例子代码段
 6 内核数据段
 7 内核代码段 
#全局段描述表结束
#中断描述符
   中断段         初始地址是0X0000A000   界限是2^11-1=0X7FF
#中断段描述符结束 
#内存分布图
00000000
00006C00-------------------------------------
                |
            4KB大小内核栈 地址换算 基地址限长     3
		        |
00007C00-------------------------------------
                |
			512字节的引导位置                     2    
                |			
00007DFF-------------------------------------
00007E00-------------------------------------
                |
			描述符位置(每个描述符占位8个字节) 1ff=512/8=64
                |	
00007FFF---------------------------------------
                |
			描述符防止不够空缺出来的            512额外字节
			    |
000081FF----------------------------------------
00008200----------------------------------------
                |
        	LDT描述符位置 1ff=512/8=63
                |			
000083FF----------------------------------------
                |
			防止描述符不够额外添加的	       512额外字节
				|
000085FF----------------------------------------
00008600----------------------------------------
                |
			 tss描述符  1ff 
			    |
00009FFF----------------------------------------
0000A000----------------------------------------
                |
             中断安装的位置 256*8=2^11				
				|			
0000A800-----------------------------------------               	
00010000---------------------------------------
00011000--------------------------------------		
00020000-------------------------------------
                |
		    1024页目录 4KB		
				|
00021000-------------------------------------
                |
		    1024页表   4KB->4M		
                |				
00022000-------------------------------------				
00040000-------------------------------------
                |
			系统核心的程序和数据加载位置(大小不固定)
                |				
0009ffff-------------------------------------
000A0000
000B8000-------------------------------------
                |  
            显示区域                             4
                |
000BFFFF-------------------------------------
000fffff
00100000-------------------------------------
                |
			用户程序和数据
			    |
FFFFFFFF-------------------------------------

------------------------------------------ 

更新:内存地址加载初始位置不变

         运行地址改为了0x50400处(由链接的过程静态确定了)

 

© 著作权归作者所有

共有 人打赏支持
Cobbage

Cobbage

粉丝 48
博文 136
码字总数 70152
作品 1
闵行
QA/测试工程师
进入保护模式(十八)持续更新篇

一、代码结构 -include _interrupt.h #中断的函数头文件 -io.h #输入输出函数的头文件 -process_struct.h #进程处理的结构体文件 -process.h #进程的头文件 -gloable.h #放一些全局的变量例如...

Cobbage
2014/02/28
0
0
进入保护模式(五)简单任务的安装

一、任务 任务是动态的概念,程序的执行状态。程序给的解释就是静态的,例如桌面上放了个五子棋的程序。 为了保存任务的状态,并在下次重新执行程序的时候恢复它们,每个任务都应当拥有一个额...

Cobbage
2013/12/19
0
0
自制操作系统Antz day05——深入理解保护模式与进入方法

Antz系统更新地址: https://www.cnblogs.com/LexMoon/category/1262287.html   在前几天的任务中,我们已经简单实现了MBR,直接操作显示器和硬盘操作来加载其他扇区的程序,我们这些任务都...

奶BerBer
07/29
0
0
自制操作系统Antz day07——实现内核 (上)

Antz系统更新地址: https://www.cnblogs.com/LexMoon/category/1262287.html   在前几天的任务中,我们已经简单实现了MBR,直接操作显示器和硬盘操作来加载其他扇区的程序,如今已经可以进...

奶BerBer
07/31
0
0
springCloud(6):Eureka的自我保护模式、多网卡下的IP选择、Eureka的健康检查

一、Eureka的自我保护模式 进入自我保护模式最直观的体现就是Eureka Server首页的警告,如下图: 默认情况下,如果Eureka Server在一定时间内没有接收到某个微服务实例的心跳,Eureka Server...

我爱大金子
2017/06/25
0
0

没有更多内容

加载失败,请刷新页面

加载更多

70.shell的函数 数组 告警系统需求分析

20.16/20.17 shell中的函数 20.18 shell中的数组 20.19 告警系统需求分析 20.16/20.17 shell中的函数: ~1. 函数就是把一段代码整理到了一个小单元中,并给这个小单元起一个名字,当用到这段...

王鑫linux
今天
3
0
分布式框架spring-session实现session一致性使用问题

前言:项目中使用到spring-session来缓存用户信息,保证服务之间session一致性,但是获取session信息为什么不能再服务层获取? 一、spring-session实现session一致性方式 用户每一次请求都会...

WALK_MAN
今天
6
0
C++ yield()与sleep_for()

C++11 标准库提供了yield()和sleep_for()两个方法。 (1)std::this_thread::yield(): 线程调用该方法时,主动让出CPU,并且不参与CPU的本次调度,从而让其他线程有机会运行。在后续的调度周...

yepanl
今天
4
0
Java并发编程实战(chapter_3)(线程池ThreadPoolExecutor源码分析)

这个系列一直没再写,很多原因,中间经历了换工作,熟悉项目,熟悉新团队等等一系列的事情。并发课题对于Java来说是一个又重要又难的一大块,除非气定神闲、精力满满,否则我本身是不敢随便写...

心中的理想乡
今天
47
0
shell学习之获取用户的输入命令read

在运行脚本的时候,命令行参数是可以传入参数,还有就是在脚本运行过程中需要用户输入参数,比如你想要在脚本运行时问个问题,并等待运行脚本的人来回答。bash shell为此提 供了read命令。 ...

woshixin
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部