从注册转储中查找故障代码

时间:2016-02-11 23:06:10

标签: assembly x86

我正在尝试调试崩溃的自定义启动加载程序。我在QEMU中运行它,并得到以下寄存器转储:

Triple fault
CPU Reset (CPU 0)
EAX=00000000 EBX=00000080 ECX=0005ff60 EDX=000258a8
ESI=0422fba0 EDI=0422fb90 EBP=00050000 ESP=0005ff5c
EIP=00025c8b EFL=00000046 [---Z-P-] CPL=0 II=0 A20=1 SMM=0 HLT=0
ES =0010 00000000 ffffffff 00cf9300 DPL=0 DS   [-WA]
CS =0008 00000000 000fffff 004f9e00 DPL=0 CS32 [CR-]
SS =0010 00000000 ffffffff 00cf9300 DPL=0 DS   [-WA]
DS =0010 00000000 ffffffff 00cf9300 DPL=0 DS   [-WA]
FS =0010 00000000 ffffffff 00cf9300 DPL=0 DS   [-WA]
GS =0010 00000000 ffffffff 00cf9300 DPL=0 DS   [-WA]
LDT=0000 00000000 0000ffff 00008200 DPL=0 LDT
TR =0000 00000000 0000ffff 00008b00 DPL=0 TSS32-busy
GDT=     0002ea88 00000038
IDT=     00000000 000003ff
CR0=00000011 CR2=00000000 CR3=00000000 CR4=00000000
DR0=0000000000000000 DR1=0000000000000000 DR2=0000000000000000 DR3=0000000000000000 
DR6=00000000ffff0ff0 DR7=0000000000000400
CCS=0000001c CCD=0005ff58 CCO=CLR     
EFER=0000000000000000
FCW=037f FSW=0000 [ST=0] FTW=00 MXCSR=00001f80
FPR0=0000000000000000 0000 FPR1=0000000000000000 0000
FPR2=0000000000000000 0000 FPR3=0000000000000000 0000
FPR4=0000000000000000 0000 FPR5=0000000000000000 0000
FPR6=0000000000000000 0000 FPR7=0000000000000000 0000
XMM00=00000000000000000000000000000000 XMM01=00000000000000000000000000000000
XMM02=00000000000000000000000000000000 XMM03=00000000000000000000000000000000
XMM04=00000000000000000000000000000000 XMM05=00000000000000000000000000000000
XMM06=00000000000000000000000000000000 XMM07=00000000000000000000000000000000

我怀疑三重故障的根本原因是尝试执行无效的处理器指令(在本例中为rdrand)。但是,我无法确认,因为我不知道上述转储中的异常代码在哪里。

1 个答案:

答案 0 :(得分:0)

事实证明,确实是一个导致这种情况的无效指令错误。我通过查看引导加载程序的反汇编并将其与Intel ISA文档进行比较来证明这一点。