2014-01-17 83 views
0

我正在使用bochs来调试MIT的JOS。我很困惑,在Bochs的输出地址:从逻辑地址到机器地址的错误翻译,GDT

(0) [0x0010002e] 0008:0xf010002e (unk. ctxt): mov ebp, 0x00000000  ; bd00000000 

我试图找出0008:0xf010002e是如何转移到[0x0010002e]

基于逻辑地址的转换。到线性地址,我想我应该使用GDT的第8个条目的基地址加上偏移量0xf010002e

但是,我得到了GDT的内容如下:

<bochs:6> x /16wx 0x0010f000 
[bochs]: 
0x0010f000 <bogus+  0>: 0x00000000 0x00000000 0x0000ffff 0x10cf9a00 
0x0010f010 <bogus+  16>: 0x0000ffff 0x10cf9300 0xf0000017 0x00000010 
0x0010f020 <bogus+  32>: 0x32311b00 0x36353433 0x30393837 0x09083d2d 
0x0010f030 <bogus+  48>: 0x72657771 0x69757974 0x5d5b706f 0x7361000a 

第八项是:

0x69757974 0x5d5b706f 

Fig 5-3基于条目的格式,基地址为:0x730a8d5b。但是,0x730a8d5b + 0xf010002e不是0x0010002e!

任何人都可以帮我指出我错在哪里吗?

非常感谢你提前!

回答

1

0008表示第一段,而不是第8段。 因此,0x0000ffff 0x10cf9a00意味着段基址= 0x10000000,所以0008:0xf010002e重叠到0x0010002e。

编辑:(回答评语)

最低位0和段选择的1用作权限级别(环)选择器,位2 - GDT和LDT之间选择,所有的其它位用作相关描述符表的偏移量。因此,0x00080x000b意味着0x0008在GDT偏移权限级别0..3

指针的解释:Intel Software Developer Manual,第3卷合并成本小于合并

+0

@qwm嗨,为什么0008是指第一段?请你稍微解释一下,或给我一个解释指针?非常感谢! – Mike

+0

也许0008意味着8B抵消?那么它是指GDT的第一个入口? – Mike

+1

对不起,我很忙。答案已更新。 – qwm