如何解决如何使用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文件并转到从那里。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。