博客
关于我
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/

你可能感兴趣的文章
mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
查看>>
Webpack 基本环境搭建
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>