博客
关于我
Ubuntu下使用bximage+dd制作可供bochs使用的硬盘镜像
阅读量:421 次
发布时间:2019-03-06

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

最近在看《x86_x64体系探索及编程》,在制作可供bochs使用的硬盘镜像时出了一些问题,主要有以下几个:

步骤

如书中所说,做了:

  • [x] 使用bximage生成了硬盘镜像

  • [x] 对bochs的配置文件进行了配置

  • [x] 利用dd工具将uboot, setup, lib16二进制文件导入到hello.img中,使用的命令为:
dd if=uboot of=hello.img seek=63 count=1 conv=notruncdd if=setup of=hello.img seek=1 count=1 conv=notruncdd if=lib16 of=hello.img seek=20 count=1 conv=notrunc

这里需要说明, dd的if选项为输入, of选项为输出,seek跳过输出的几个单元开始写,一个单元512个字节,count是写的单元数,尤其要注意的是conv选项,邓志的书中并未加conv选项,这导致输出文件被截断,不能保持原本的大小,notrunc的意思就是不要截断。

  • [x] 使用以下语句启动bochs
bochs -f bxrc# 执行上面的语句后需要在terminal中输入c,意为continue,bochs才会继续执行

现象

Boot failed: not a bootable disk.

分析

  1. 能够进入最后一个界面,说明bochs的配置文件没有问题,那么问题一定出在镜像hello.img上,hello.img和随书提供的源码中的c.img有何不同呢?我用hex软件看了一下,hello.img的前512个字节是空的,而c.img中有一些内容,书上说硬盘的第一个单元是用来存放MBR的,当从硬盘启动时,先将MBR载入到0x7C00,再由MBR读取位于第64个单元的boot程序,因此MBR非常重要。仔细分析后发现原来我们使用bximage产生的hello.img并不自带MBR,所以我将c.img中的前512个字节写入了hello.img,使用下面的代码:
dd if=c.img of=hello.img seek=0 count=1 conv=notrunc

但是运行

bochs -f bxrc# 执行上面的语句后需要在terminal中输入c,意为continue,bochs才会继续执行

之后仍然出现Boot failed: not a bootable disk.

  1. 那么出问题一定在setup二进制文件了,因为这个实验中最后起作用的就是setup文件,在屏幕上显示。因此我使用nasm重新编译了setup.asm,编译过程中出现了类似于can't open xxx.inc之类的错误,原因就是linux使用../作为上级目录的代替,而windows使用的是..\,只要将..\换为../../就可以编译通过。重新编译setup.asm,将新生成的setup写入hello.img,运行bochs

结果

成功了!!!

总结

1、MBR

2、重新编译

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

你可能感兴趣的文章
mutiplemap 总结
查看>>
MySQL Error Handling in Stored Procedures---转载
查看>>
MVC 区域功能
查看>>
MySQL FEDERATED 提示
查看>>
mysql generic安装_MySQL 5.6 Generic Binary安装与配置_MySQL
查看>>
Mysql group by
查看>>
MySQL I 有福啦,窗口函数大大提高了取数的效率!
查看>>
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
mysql problems
查看>>