- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我最近编写了一个 x86“引导加载程序”程序,它在 BIOS 跳转到我的程序后显示硬件寄存器的值。出于测试的目的,我将AX
寄存器设置为一个已知值,以确保程序正确运行。
BITS 16
%macro pad 1-2 0
times %1 - ($ - $$) db %2
%endmacro
[org 0x7C00]
CLD ; clear direction flag (forward direction)
CLI ; clear interrupt flag (disable interrupts, opposite of 65xx)
MOV [0x8000], AX ; display all registers,
MOV [0x8004], BX ; including stack,
MOV [0x8008], CX ; segment, & extra
MOV [0x800C], DX ; registers
MOV [0x8010], SP
MOV [0x8014], BP
MOV [0x8018], SI
MOV [0x801C], DI
MOV [0x8020], CS
MOV [0x8024], SS ; we also display DS register,
MOV [0x8028], ES ; so we can't modify it or
MOV [0x802C], DS ; we'll loose our data
MOV [0x8030], FS
MOV [0x8034], GS
MOV AX, 0x0123 ; write 0x0123 to [0x8000]
MOV [0x8000], AX ; for debugging
MOV DI, 0x804C ; DI is pointer to address 0x804C
; (temporary data)
MOV AH, 0x02
MOV BH, 0x00 ; video page 0?
MOV DX, 0x0401
INT 0x10 ; move cursor to XY:($01, $04)
; display register data
MOV AL, 'A'
CALL printXl ; print 'AX:'
MOV DX, [0x8000] ; recall value of AX register
; (set to 0x0123 for test)
CALL printascii ; print 16-bit value @ [0x8000]
;... ; omitted code: display other registers
MOV AH, 0x00 ; wait for keyboard press
INT 0x16
INT 0x18 ; boot Windows
printXl:
MOV AH, 0x0E
XOR BX, BX
INT 0x10 ; display character in 'AL'
MOV AL, 'X'
; falls through
prnt: ; referenced in omitted code
MOV AH, 0x0E
INT 0x10 ; display character 'X'/'S'
MOV AL, ':'
INT 0x10 ; display character ':'
RET
printascii:
MOV [DI], DX ; store value for later recall
MOV AH, 0x0E ; INT 10,E
MOV SI, hexascii ; load address of 'hexascii'
AND DX, 0xF000
SHR DX, 0x0C ; shift high nibble to lowest 4 bits
ADD SI, DX
CS LODSB ; AL = CS:[0x1EE + DX >> 12];
INT 0x10 ; display high nibble of character value
MOV SI, hexascii
MOV DX, [DI]
AND DX, 0x0F00
SHR DX, 0x08
ADD SI, DX
CS LODSB
INT 0x10 ; display low nibble of character value
MOV SI, hexascii
MOV DX, [DI]
AND DX, 0x00F0
SHR DX, 0x04
ADD SI, DX
CS LODSB
INT 0x10 ; display high nibble of character value
MOV SI, hexascii ;
MOV DX, [DI]
AND DX, 0x000F
ADD SI, DX
CS LODSB
INT 0x10 ; display low nibble of character value
RET
pad 0x01EE
hexascii:
db "0123456789ABCDEF" ;
pad 0x01FE ; pad to end of bootsector
dw 0xAA55 ; bootsector signature
当从 DOSBOX 运行时,我正确地看到 AX:0123
,但是当从我的软盘启动时,我看到 AX:FFFF
。我不知道我做错了什么。作为引用,我的 PC 是 Intel Core 2 Quad
。
最佳答案
不可能在保证 100% 安全的情况下做自己想做的事情。
问题是要将数据存储在任何地方你必须知道你正在将它存储在一个安全的地方(不覆盖你的堆栈,不被堆栈覆盖,不写入 ROM 或其他不是 RAM 的东西而不是损坏 RAM 中的任何其他内容,如 BIOS 数据或您的代码);并且您必须先修改寄存器(主要是段寄存器),然后才能知道将数据存储在安全的地方,因此您无法安全地将这些寄存器的原始值存储在任何地方。请注意,这是导致(至少一个)您最初问题的原因 - 不想更改 DS(因为您想打印其原始值)并最终不知道使用 DS 是否安全。
“最不安全”的替代方法是(暂时)使用 BIOS 留下的堆栈。很可能 BIOS 在某个地方留下了一个有足够空间的堆栈,以确保如果在 BIOS 跳转到您的代码之后但在您可以执行单个指令(或自己设置安全堆栈)之前发生 IRQ,它不会导致问题,因此您可能可以在该堆栈上存储少量数据。然而;无法保证任何中断(包括 IRQ 和 BIOS 函数)消耗的堆栈不会比您消耗一些后剩余的堆栈更多(因此您不想在堆栈上存储大量数据);理想情况下,您应该在启用 IRQ 或调用任何 BIOS 函数之前将存储在堆栈中的数据传输到其他地方。
这会导致如下内容(NASM 语法,未经测试):
org 0x7C00
start:
cli
push ds
push ax
xor ax,ax
mov ds,ax
call far [.fixCSIP] ;Push CS and IP then set CS and IP to known values
.fixCSIP:
dw 0x0000, .here ;Values to load into CS and IP
.here:
pop word [0x8020] ;Move original value of CS
pop ax ;ax = original value of "IP + (.fixCSIP - start)"
sub ax,.fixCSIP-start ;ax = original value of IP
mov [0x8038],ax ;Store original value of IP
pop word [0x8000] ;Move original value of AX
pop word [0x802C] ;Move original value of DS
;SP is now back to the value it originally had
mov [0x8010],sp
mov [0x8024],ss
xor ax,ax
mov ss,ax
mov sp,0x7C00
;Now CS:IP, DS and SS:SP are all "known safe" values, so we can start being normal
sti
mov [0x8004], bx
mov [0x8008], cx
mov [0x800C], dx
...
关于assembly - 是什么导致此引导加载程序在硬件上失败但在 DOSBOX 中没有?它显示所有寄存器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64069732/
我在 Ubuntu 12.04 的 DOSBox 上运行 Turbo C。 问题是两个黑色条纹出现在任一屏幕上。我想删除它们。 我的电脑是 Dell Studio 15z,屏幕分辨率为 1366x76
伙计们,我想要一个由阿迪在文本文件中添加的数据,并在文本文件中创建一些以前的数据。我找到的教程只是替换了前面的单词/数据。。我想在文本文件中添加一个新数据,即新数据在以前的数据之后。程序完成后,新数据
我们正在研究一个汇编程序,它将 386 处理器从实模式切换到保护模式,然后再返回到实模式。该程序是使用 TASM 编译的。 因为这个程序需要做一些特权操作,而且需要实模式启动,所以我们需要在DOS下运
我已经制作了一个写入文件的程序,并制作了一个用于写入代码的标签,但是我正在填充的字符串没有被写入文件。 编写程序: proc WriteToFile mov ah,40h mov bx
我正在组装一个“simon”游戏,我需要在按钮打开时发出蜂鸣声,蜂鸣声也应该彼此不同。谢谢 最佳答案 您可以使用speaker让您的设计保持简单。 扬声器可让您播放不同频率的方波,it can act
在 DOSBox 0.74 中,当我尝试使用 int 21h 的函数 3ch 打开任何文件上的文件句柄时,文件的数据将被清除,大小永久减小为 0 字节。 我测试过的文件都位于 Windows 10 的
我最近编写了一个 x86“引导加载程序”程序,它在 BIOS 跳转到我的程序后显示硬件寄存器的值。出于测试的目的,我将AX寄存器设置为一个已知值,以确保程序正确运行。 BITS 16 %macro p
我正在尝试使用 DOSBox 在另一台运行 Windows 10 的计算机上安装文件夹。 我已经尝试安装 //PC-NAME/filename,因为它在 Windows 资源管理器中显示,但它不起作用
我正在尝试使用 DOSBox 在另一台运行 Windows 10 的计算机上安装文件夹。 我已经尝试安装 //PC-NAME/filename,因为它在 Windows 资源管理器中显示,但它不起作用
我正在 DOSBox 中创建批处理多语言安装程序。 我想在子程序中创建一个变量,它根据用户的选择更改显示的语言。这是菜单的示例: :installer @echo off echo SELECT LA
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我正在使用 DosBox 0.74 并且我想使用 vectors 函数,但是我找不到它的头文件?它不是也不 .我在 Visual Studio 中尝试过,它运行良好。它在 DosBox 中有不同的名称
我正在尝试将 DOSBox 与 debug.exe 一起使用在 64 位系统上。如果我手动输入命令,它工作得很好。当我从文件重定向输入时: debug debug.com hello Hello, W
几周以来,我一直在学习汇编语言编程,今天我安装了编译汇编程序所需的所有应用程序。 我安装了 DOSBox 0.74、NASM(汇编器)和 AFD(调试器)。我安装了驱动器并正确地看到了我的 .asm
我想向 DOSBOX 发送单个键盘命令(向下箭头),然后在 C# 中执行一些处理代码,然后循环。我的目标是自动运行 DOS 程序。 我的代码在记事本和 Windows 资源管理器上成功运行,但在 DO
我目前正在开发一个汇编程序,但我需要让程序每隔一段时间等待一次。 所以,我一直在使用 int 15h/ah = 86h,但出于某种原因,DosBox 给我带来了困难,程序要么与像素(奇怪的颜色)混淆,
Wiki 说它是一个 x86 模拟器。那么,如果 DosBox 确实是 32 位应用程序的模拟器,那么为了支持 16 位应用程序,它必须有另一个模拟器,对吗?让它在 16 位模式下运行?(这不是常规操
我写了一段代码,在这段代码中我使用了 graphics.h,在 borland c++ 或 visual 中我无法打开和运行它,现在我想运行这段代码,我有 DOSBOX 0.72,如何用 DOSBOX
#include #include void main(){ float a,b,c; clrscr(); cout>a>>b; c=a+b; cout>a
好吧,我正在尝试在模拟环境 (DosBox) 中应用双缓冲技术,同时使用 IDE Turbo C++ 3.0 我正在运行 Windows 7 64 位(不确定这是否重要)并且我不知道如何正确执行此环境
我是一名优秀的程序员,十分优秀!