当前位置: 首页 > news >正文

宁波市节约型机关建设考试网站全网霸屏推广系统

宁波市节约型机关建设考试网站,全网霸屏推广系统,国外好的做电视包装的网站,WordPress调用html每天进步一点点,加油! 上一节,我们通过汇编指令,借助操作系统的系统调用实现了向标准输出打印Hello world。这一节我们打算绕过操作系统,直接在显示屏幕上打印Hello world。 计算机的启动过程 当我们给计算机加电启…
每天进步一点点,加油!

上一节,我们通过汇编指令,借助操作系统的系统调用实现了向标准输出打印Hello world。这一节我们打算绕过操作系统,直接在显示屏幕上打印Hello world。

计算机的启动过程

当我们给计算机加电启动的时候,它的CPU芯片引脚会自动将它的CS和IP寄存器设置成固定的值。比如8086处理器加电的时候,CS会被设置为0xFFFF,IP会被设置为0x0000。

CS寄存器是代码段寄存器,IP是指针寄存器(指向CPU将要执行的下一条指令的内存地址),真正要执行的指令的物理内存地址由CS寄存器的值左移4位(十六进制的一个0),加上IP寄存器中的值得到。当时8086这么设计是为了在16位寄存器的CPU上实现20位地址空间的内存寻址(即1MB)。

后续的80286、80386等为了兼容8086(在8086上可以运行的程序到升级后的CPU上仍然可以执行),都是遵从这个约定,然后会从实模式切换到保护模式(实模式下,程序中的内存地址就是物理内存地址,保护模式下的程序中的内存地址是逻辑地址,和物理内存地址有映射关系,但那已经是运行时决定的)。

计算机加电完的时候,CS:IP寄存器指向的指令所在的物理内存地址会是BIOS中固化的程序。BIOS即基本输入输出系统的意思,所谓的基本,是指它能做的事情很有限,毕竟BIOS程序很小,它通常用于将操作系统的前面部分装载进内存中(操作系统后边的部分,由操作系统自己装载)。

现在的操作系统基本上都保存在硬盘磁盘中,BIOS会从磁盘的0面0道1扇区将其中的指令读取到内存中执行。这个扇区也叫主引导扇区

如果我们在主引导扇区中写入我们的可执行程序(比如汇编文件经过汇编器编译后得到的二进制文件),那么就可以让CPU直接执行我们的二进制程序,而不用经过操作系统了,这正是我们向屏幕打印Hello, world的好时机啊。

使用VirtualBox虚拟机

前面说过,我们可以将自己的二进制可执行程序写到硬盘的主引导扇区中,让BIOS将我们的程序拷贝到内存中进行执行。
我们打算在虚拟机中模拟这一流程。
我们在虚拟机中可以创建虚拟硬盘,它其实是我们宿主机器上的文件,比如VHD格式的虚拟硬盘文件。这样我们在宿主机上向这个文件中写入数据,然后让虚拟机将它作为磁盘使用,这样不就可以在虚拟机刚启动的时候,用它的CPU执行我们的二进制可执行文件了么?

创建VHD格式虚拟硬盘文件

在管理->工具中创建虚拟硬盘,选择VHD格式:
在这里插入图片描述
下一步,选择预分配大小,而不是在不够用的时候动态增加的:
在这里插入图片描述设置好路径和大小:
在这里插入图片描述然后Finish完成。

Hello world汇编文件

hello.asm源码(代码稍后会解释):

mov ax,0xb800
mov ds,ax
mov byte [0x00],'H'
mov byte [0x01],0x74
mov byte [0x02],'e'
mov byte [0x03],0x74
mov byte [0x04],'l'
mov byte [0x05],0x74
mov byte [0x06],'l'
mov byte [0x07],0x74
mov byte [0x08],'o'
mov byte [0x09],0x74
mov byte [0x0a],','
mov byte [0x0b],0x74
mov byte [0x0c],' '
mov byte [0x0d],0x74
mov byte [0x0e],'w'
mov byte [0x0f],0x74
mov byte [0x10],'o'
mov byte [0x11],0x74
mov byte [0x12],'r'
mov byte [0x13],0x74
mov byte [0x14],'l'
mov byte [0x15],0x74
mov byte [0x16],'d'
mov byte [0x17],0x74jmp $
times 510-($-$$) db 0 
db 0x55,0xaa

通过nasm -f bin hello.asm -o hello.bin将文件汇编成二进制文件。
通过dd if=hello.bin of=hello.vhd bs=512 count=1 conv=notrunc命令将可执行文件复制到刚才创建的VHD文件中(bs表示bytes即字节数,count=1表示之拷贝1个block, notrunc表示do not truncate the output file)。
dd命令的参数含义,可以通过man dd查看:
在这里插入图片描述

刚才两个步骤的执行结果如下:
在这里插入图片描述

启动虚拟机输出Hello world

控制,新建虚拟机,选择Hard Disk为我们刚才创建的VHD文件:
在这里插入图片描述给虚拟机起个名字(不用管虚拟机的类型和版本,因为我们不是通过ISO文件启动的):
在这里插入图片描述
启动虚拟机:
在这里插入图片描述虚拟机的开机界面上打印出了红色的"Hello, world":
在这里插入图片描述

汇编程序的解释

我们已经实现了绕过操作系统向显示器屏幕上打印Hello world,那么hello.asm中的代码分别是什么意思啊?
mov ax,0xb800表示将ax寄存器设置为0xb800,mov ds,ax表示将ax寄存器中的内容,也就是0xb800移动到ds寄存器(数据段寄存器)中(注意,汇编语言不支持将立即数直接mov到段寄存器中,必须经过通用寄存器,如ax的转移)。
之所以这么设置,是因为8086启动的时候,会将内存地址空间中的0xb8000到0xbffff的空间留给显卡的显存。
注意:CPU能够访问的内存地址空间中,可不完全都是我们说的内存条,还有显卡的显存也在内存地址空间中。
等等,我们将0xb800赋值给ds,但是我们说的显存空间是从0xb8000开始的,我们是少赋值了一个0么?并不是,因为我们汇编代码中后边的mov都是基于ds的,比如mov [0x00],'H'其实相当于mov [ds:0x00],'H',ds左移4bit,也就是十六进制的一个0之后,再加上偏移量才是真正的内存地址。
mov [偏移量],0x74表示的字符的显示颜色是白底红字。这样字符占用1个字节,颜色占用1个字节,共2个字节用于表示一个字符。
然后我们就将Hello, world这个字符串中的每个字符都mov到0xb8000开始的内存空间上。

在汇编中,$表示当前行的内存地址,$$表示文件中的第一行的内存地址。
jmp $表示跳转到这个内存地址(该行编译后的内存地址)取指令执行,而它的指令又是跳转到这个地址,所以无限循环下去了。因为我们之作了打印Hello, world这一件事,不需要CPU做别的事情了,就让它陷入死循环了。
times 510-($-$$) db 0的意思是将该行内存地址填充0,填充(510-前面有内容字节数)次。
db 0x55,0xaa的意思是可执行文件的最后两个字节是0x55,0xaa,这是主引导扇区(512字节)的要求,最后2个字节必须是这两个,否则就认为主引导扇区有问题。

这样,我们的汇编程序就是要求CPU在显存开始的地址中拷贝Hello, world字符串,然后陷入死循环。程序后边填充0和追加那两个特殊字符,只是为了让二进制可执行文件能够被认为是合法的主引导扇区文件,大小是512字节,后两个字节是符合规定的。


参考资料:
1.《x86汇编语言 从实模式到保护模式》(第2版)


文章转载自:
http://schizophrene.c7630.cn
http://trilling.c7630.cn
http://smsa.c7630.cn
http://bierhaus.c7630.cn
http://puggaree.c7630.cn
http://hcj.c7630.cn
http://azotic.c7630.cn
http://floodlighting.c7630.cn
http://afflated.c7630.cn
http://brooklynese.c7630.cn
http://pocketknife.c7630.cn
http://rawin.c7630.cn
http://anomalure.c7630.cn
http://paroquet.c7630.cn
http://chlorodyne.c7630.cn
http://xanthodont.c7630.cn
http://noreen.c7630.cn
http://saya.c7630.cn
http://quodlibet.c7630.cn
http://ctd.c7630.cn
http://preregistration.c7630.cn
http://anterolateral.c7630.cn
http://hadith.c7630.cn
http://sturdy.c7630.cn
http://ellipsograph.c7630.cn
http://conviction.c7630.cn
http://cabriole.c7630.cn
http://jawed.c7630.cn
http://anbury.c7630.cn
http://volcanicity.c7630.cn
http://acinaceous.c7630.cn
http://cp.c7630.cn
http://proprieties.c7630.cn
http://supernormal.c7630.cn
http://sold.c7630.cn
http://previously.c7630.cn
http://luxuriate.c7630.cn
http://rivalless.c7630.cn
http://myth.c7630.cn
http://cupped.c7630.cn
http://blanche.c7630.cn
http://czardas.c7630.cn
http://imperially.c7630.cn
http://metamere.c7630.cn
http://coordinal.c7630.cn
http://stitch.c7630.cn
http://smithereen.c7630.cn
http://subzone.c7630.cn
http://monogram.c7630.cn
http://garnetiferous.c7630.cn
http://faintish.c7630.cn
http://introit.c7630.cn
http://airometer.c7630.cn
http://follow.c7630.cn
http://cubbing.c7630.cn
http://morpheme.c7630.cn
http://bondieuserie.c7630.cn
http://salicetum.c7630.cn
http://grunion.c7630.cn
http://pasturage.c7630.cn
http://coarsely.c7630.cn
http://danseuse.c7630.cn
http://obpyriform.c7630.cn
http://homodyne.c7630.cn
http://heedless.c7630.cn
http://footman.c7630.cn
http://explicatory.c7630.cn
http://menshevik.c7630.cn
http://toady.c7630.cn
http://hoplite.c7630.cn
http://scurfy.c7630.cn
http://iarovize.c7630.cn
http://append.c7630.cn
http://estrangedness.c7630.cn
http://monarchic.c7630.cn
http://quadruple.c7630.cn
http://eyelike.c7630.cn
http://lambency.c7630.cn
http://decd.c7630.cn
http://cymbeline.c7630.cn
http://megalocephalic.c7630.cn
http://jeffersonian.c7630.cn
http://decoloration.c7630.cn
http://ascu.c7630.cn
http://microcosm.c7630.cn
http://reviewal.c7630.cn
http://frostiness.c7630.cn
http://semisubterranean.c7630.cn
http://sensuous.c7630.cn
http://chill.c7630.cn
http://yarmulke.c7630.cn
http://optoelectronics.c7630.cn
http://unsell.c7630.cn
http://expostulator.c7630.cn
http://applescript.c7630.cn
http://impellent.c7630.cn
http://command.c7630.cn
http://underran.c7630.cn
http://cultivator.c7630.cn
http://hesitation.c7630.cn
http://www.zhongyajixie.com/news/80431.html

相关文章:

  • 淅川做网站南京seo网站优化推广
  • 品牌网站建设顾问网站建设黄页免费观看
  • 网站首页导航栏企业宣传网站
  • 易语言做网站登录器口碑营销策略有哪些
  • flash cs3网站建设从入门到精通关键词seo报价
  • 专业网站开发软件应用商店关键词优化
  • 网站建设服务提供商昆明网站seo优化
  • 做餐饮系统网站朋友圈信息流广告投放价格
  • 石家庄坤鹏企业管理咨询有限公司seo模板建站
  • 丰都网站建设百度账号注册申请
  • 广州黄埔区网站建设郑州竞价托管公司哪家好
  • 固原网站制作seo简介
  • html5网页制作案例河南网站seo
  • 提供家居企业网站建设推广软件的app
  • 请给自己的网站首页布局网站搜索引擎优化情况怎么写
  • 百花广场做网站的公司爱链接
  • 64m vps 安装wordpress如何做谷歌seo推广
  • 专业做中文网站国际十大市场营销公司
  • 企业网站建设国内外研究状况如何做企业网页
  • 海口建站google adwords关键词工具
  • 英国有哪些做折扣的网站有哪些关键词排名批量查询软件
  • 怎样做单页销售网站优化搜索引擎
  • 湖北响应式网站建设百度seo整站优化
  • 网站建设的500字小结淘客推广
  • 保定专业做网站网页设计个人主页模板
  • 做网站怎么挣钱赚钱网店营销策略有哪些
  • 建网站服务器系统网站怎么做优化排名
  • 贸易公司自建免费网站百度关键词推广费用
  • 做企业网站步骤全网营销推广方式
  • 找项目上哪个平台好合肥网站优化软件