如何使用Bochs运行汇编代码?

问题描述

| 我想将Bochs用作8086模拟器。是否有捷径可寻?我想要的是类似emu8086(http://www.emu8086.com/)的东西。     

解决方法

如果程序的初始部分适合512字节,并且您不介意将自己限制在BIOS调用,
in
/
out
指令以及写入I / O的魔术内存位置中,那就可以了! 假设您正在使用NASM,这是一个愚蠢的示例……(警告:我的16位汇编技能不是很好,并且有点生锈,所以它可能不是最好的代码。)
[org 7c00h]              ; BIOS will load us to this address

mov ax,0b800h           ; Console memory is at 0xb8000; set up a segment
mov es,ax               ; for the start of the console text.

;
; Let\'s clear the screen....
;

xor di,di               ; Start at beginning of screen
mov cx,80*25            ; Number of chars in the screen
mov al,\' \'              ; Space character
mov ah,0fh              ; Color (white on black)
repne stosw              ; Copy!

;
; Write an \'a\' to the screen...
;

mov byte [es:0],\'a\'     ; Write an \'a\'

sleep:
hlt                      ; Halts CPU until the next external interrupt is fired
jmp sleep                ; Loop forever

times 510-($-$$) db 0    ; Pad to 510 bytes
dw 0aa55h                ; Add boot magic word to mark us as bootable
然后,您可以组装:
nasm foo.asm
并将其写入到这样的软盘映像中:(假设使用Unix类型的系统...)
$ dd if=/dev/zero of=floppy.img bs=512 count=2880
$ dd if=foo of=floppy.img conv=notrunc
现在,您可以在Bochs中引导该软盘映像(或者,如果将其写入软盘,则可以在真实PC上运行它),并且应该在屏幕上写一个“ a”。 请注意,这通常仅在编写引导加载程序或操作系统时才有用。但是,进行试验很有趣,尤其是在学习的过程中。 更新:我阅读了emu8086网站...似乎有点面向x86的嵌入式使用,而不是PC。看起来它具有一些用于仿真硬件的有趣功能。如果您对定位PC不感兴趣,那么Bochs就不会引起您的兴趣。如果那不是您想要做的,我同意建议使用emu8086本身的评论者。 如果您对PC感兴趣,但是想要一些程序来逐步执行程序,则...我经常使用qemu来实现此目的。它的调试标志(请参见
-d
的联机帮助页)足以在汇编级别观察x86程序的执行状态。 (只要您仔细查看C编译器生成的内容,我什至发现它对于调试用C编写的OS内核已经足够有用。)     ,
sudo apt-get install bochs bochs-sdl

printf \'ata0-master: type=disk,path=\"main.img\",mode=flat,cylinders=1,heads=1,spt=1
boot: disk
display_library: sdl
megs: 128
\' > .bochsrc

bochs -q
在Ubuntu 14.04,Bochs 2.4.6和512字节长引导扇区ѭ7long上为我工作。
cylinders=1,spt=1
指定磁盘大小,并且必须与您的映像匹配!在这里,我们将所有内容都设置为ѭ9,以表示1个柱面,这与我们的图像文件一样为512字节。 由于Ubuntu打包错误,可能需要10美元 main7ѭ是从main.asm生成的:
org 0x7c00
bits 16
cli
mov ax,0x0E61
int 0x10
hlt
times 510 - ($-$$) db 0
dw 0xaa55
然后:
nasm -f bin -o main.img main.asm
该图像使用BIOS在屏幕上打印单个字符“ 14”。 使用以下命令行可以避免创建the15ѭ文件:
bochs \\
    -qf /dev/null \\
    \'ata0-master: type=disk,spt=1\' \\
    \'boot: disk\' \\
    \'display_library: sdl\' \\
    \'megs: 128\'
ѭ17部分很难看,但这是我设法自动跳过菜单屏幕的唯一方法: 总是要求
-q
-n
,我必须按
6
后才能运行
-qn <(echo ...)
也可以使用,但使用的Bash扩展名在我的Makefile中失败 QEMU的界面更易于入门,因此我建议改用它。 带有此示例的GitHub存储库:https://github.com/cirosantilli/x86-bare-metal-examples/blob/cba0757990843f412b14dffad45467ad0034d286/Makefile#L33     ,那不是您真正想要做的。 (嗯,也许是...) 基本上,Bochs是x86 PC仿真器。为了在其上执行机器代码,您需要将机器代码放在\“ disk \”映像上。磁盘映像是一种结构类似于磁盘(软盘或硬盘驱动器)的文件。 PC具有特定的启动顺序,可以查看磁盘的各个部分,在其中加载机器代码并执行。这就是操作系统的启动方式。 坦率地说,要使“ hello world”在程序集中运行会有些麻烦,因为除了BIOS之外,您什么都没有,因为您没有要在上面运行的OS。 因此,如果您要执行此操作,您将需要查找爱好操作系统上的书籍和站点,并了解引导过程的工作方式,等等。否则,请使用DOS系统之类的东西,并创建COM文件并转到从那里。     

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...