英文:
Creating bootable image for VirtualBox
问题
I need just welcome message printed.
There are some hints on this forum, however it's hard to put all up together.
So I've created a mininmal .asm similar to this one
[ORG 0x7c00] 
BITS 16
main:
mov ax, 0x07C0
mov ds, ax
mov es, ax
mov bp, message
mov bh, 0
mov bl, 00001111b
mov cx, 13
mov al, 1
mov ah, 0x13
mov dx, 0
int 0x10
cli
hlt
jmp $
message db "Hello, World!"
length db (length - message)
times 510-($-$$) db 0
dw 0xaa55
Build:
nasm -f bin sboot.asm -o sboot.bin
dd if=sboot.bin of=sboot.img bs=512 count=1 conv=notrunc
And convert IMG file to ISO with program CDBurnerXP. I am using 'Boot options...' and select:
- Emulation type = Diskette 1.44MB (boot image 95/98/ME)
 - Load segment = 7c0
 - Sectors: 1
 - Platform: x86-64
I also add dummy txt file, so that the ISO is not empty and save everything as ISO file. 
Then I try to run it in Virtual Box with minimum options (disabled: audio, network, USB) and it crashes. Container goes into status 'Aborted'
Log from VirtualBox says nothing particular:
00:00:06.813147 PDMLdr: pdmR3LoadR0U: pszName="VMMR0.r0" rc=VERR_LDR_GENERAL_FAILURE szErr="SUP_IOCTL_LDR_OPEN failed"
00:00:06.813197 VMSetError: F:\tinderbox\win-rel\src\VBox\VMM\VMMR3\PDMLdr.cpp(750) int __cdecl pdmR3LoadR0U(struct UVM *,const char *,const char *,const char *); rc=VERR_LDR_GENERAL_FAILURE
00:00:06.813199 VMSetError: Failed to load R0 module C:\Program Files\Oracle\VirtualBox/VMMR0.r0: SUP_IOCTL_LDR_OPEN failed
00:00:06.813209 VMSetError: F:\tinderbox\win-rel\src\VBox\VMM\VMMR3\VM.cpp(585) int __cdecl vmR3CreateU(struct UVM *,unsigned int,int (__cdecl *)(struct UVM *,struct VM *,const struct VMMR3VTABLE *,void *) noexcept,void *); rc=VERR_LDR_GENERAL_FAILURE
00:00:06.813212 VMSetError: Failed to load VMMR0.r0
00:00:06.813425 ERROR [COM]: aRC=E_FAIL (0x80004005) aIID={6ac83d89-6ee7-4e33-8ae6-b257b2e81be8} aComponent={ConsoleWrap} aText={Failed to load R0 module C:\Program Files\Oracle\VirtualBox/VMMR0.r0: SUP_IOCTL_LDR_OPEN failed (VERR_LDR_GENERAL_FAILURE).
00:00:06.813445 Failed to load VMMR0.r0 (VERR_LDR_GENERAL_FAILURE)}, preserve=false aResultDetail=-618
00:00:06.813679 Console: Machine state changed to 'PoweredOff'
00:00:06.980955 Power up failed (vrc=VERR_LDR_GENERAL_FAILURE, rc=E_FAIL (0X80004005))
00:00:06.984607 GUI: UIMachineViewNormal::resendSizeHint: Restoring guest size-hint for screen 0 to 800x600
Any idea what went wrong?
英文:
I need just welcome message printed.
There are some hints on this forum, however it's hard to put all up together.
So I've created a mininmal .asm similar to this one
[ORG 0x7c00]   
BITS 16
main:
                mov ax, 0x07C0                                  
                mov ds, ax         
                mov es, ax         
                mov bp, message    
                mov bh, 0          
                mov bl, 00001111b  
                                   
                mov cx, 13         
                mov al, 1          
                                   
                mov ah, 0x13       
                mov dx, 0          
                int 0x10           
				cli
				hlt
				
                jmp $
message     db      "Hello, World!"
length      db      (length - message)
                             
times   510-($-$$) db 0
dw      0xaa55           
Build:
nasm -f bin sboot.asm -o sboot.bin
dd if=sboot.bin of=sboot.img bs=512 count=1 conv=notrunc
And convert IMG file to ISO with program CDBurnerXP. I am using 'Boot options...' and select:
- Emulation type = Diskette 1.44MB (boot image 95/98/ME)
 - Load segment = 7c0
 - Sectors: 1
 - Platform: x86-64
I also add dummy txt file, so that the ISO is not empty and save everything as ISO file. 
Then I try to run it in Virtual Box with minimum options (disabled: audio, network, USB) and it crashes. Container goes into status 'Aborted'
Log from VirtualBox says nothing particular:
00:00:06.813147 PDMLdr: pdmR3LoadR0U: pszName="VMMR0.r0" rc=VERR_LDR_GENERAL_FAILURE szErr="SUP_IOCTL_LDR_OPEN failed"
00:00:06.813197 VMSetError: F:\tinderbox\win-rel\src\VBox\VMM\VMMR3\PDMLdr.cpp(750) int __cdecl pdmR3LoadR0U(struct UVM *,const char *,const char *,const char *); rc=VERR_LDR_GENERAL_FAILURE
00:00:06.813199 VMSetError: Failed to load R0 module C:\Program Files\Oracle\VirtualBox/VMMR0.r0: SUP_IOCTL_LDR_OPEN failed
00:00:06.813209 VMSetError: F:\tinderbox\win-rel\src\VBox\VMM\VMMR3\VM.cpp(585) int __cdecl vmR3CreateU(struct UVM *,unsigned int,int (__cdecl *)(struct UVM *,struct VM *,const struct VMMR3VTABLE *,void *) noexcept,void *); rc=VERR_LDR_GENERAL_FAILURE
00:00:06.813212 VMSetError: Failed to load VMMR0.r0
00:00:06.813425 ERROR [COM]: aRC=E_FAIL (0x80004005) aIID={6ac83d89-6ee7-4e33-8ae6-b257b2e81be8} aComponent={ConsoleWrap} aText={Failed to load R0 module C:\Program Files\Oracle\VirtualBox/VMMR0.r0: SUP_IOCTL_LDR_OPEN failed (VERR_LDR_GENERAL_FAILURE).
00:00:06.813445 Failed to load VMMR0.r0 (VERR_LDR_GENERAL_FAILURE)}, preserve=false aResultDetail=-618
00:00:06.813679 Console: Machine state changed to 'PoweredOff'
00:00:06.980955 Power up failed (vrc=VERR_LDR_GENERAL_FAILURE, rc=E_FAIL (0X80004005))
00:00:06.984607 GUI: UIMachineViewNormal::resendSizeHint: Restoring guest size-hint for screen 0 to 800x600
Any idea what went wrong?
答案1
得分: 3
Your setup for DS and ES does not match the ORG setting!
If you use [ORG 0x7c00], then you have to set DS=0 and ES=0.
Since you only use the BIOS function 13h that depends on ES:BP, setting up ES would be enough:
xor ax, ax
mov es, ax
英文:
>     [ORG 0x7c00]
>     BITS 16
>  
>     main:
>               mov ax, 0x07C0                               
>               mov ds, ax      
>               mov es, ax
Your setup for DS  and ES does not match the ORG settting!
If you use [ORG 0x7c00], then you have to set DS=0 and ES=0.
Since you only use the BIOS function 13h that depends on ES:BP, setting up ES would be enough:
xor  ax, ax
mov  es, ax
通过集体智慧和协作来改善编程学习和解决问题的方式。致力于成为全球开发者共同参与的知识库,让每个人都能够通过互相帮助和分享经验来进步。


评论