我是 AT&T 语法新手。我想将以下 NASM 语法代码转换为 AT&T 语法只是为了便于理解。
我尝试将其转换为 AT&T 语法:
lgdt (gdtpointer)
jmp $gdtcode, $_start
gdt:
.quad 0x0000000000000000
gdtcode:
.word .- gdt
.quad 0x0020980000000000
gdtdata:
.word .- gdt
.quad 0x0000900000000000
gdtpointer:
.word .-gdt-1
.quad gdt
Error: can't handle non absolute segment in `jmp'
NASM 代码:
lgdt [gdt.pointer]
jmp gdt.code:startLongMode
;Global Descriptor Table
gdt:
dq 0x0000000000000000
.code equ $ - gdt
dq 0x0020980000000000
.data equ $ - gdt
dq 0x0000930000000000
.pointer:
dw $-gdt-1
dq gdt
;Ref: Intel System Programming Manual V1 - 2.1.1.1
在 GAS 中,因为 GDT 的定义出现在jmp $gdtcode, $_start
,汇编器将看到JMP并相信这个符号gdtcode
是一个外部符号(将由链接器重定位)而不是常量。因此,它会抱怨非绝对引用。
您还通过放置不正确地定义了您的 GDT.word .- gdt
after gdtcode:
and gdtdata
。这些行将在您不需要的地方向 GDT 发出一个 16 位字。
我相信您可能一直在尝试类似以下的事情。 GDT 在某个时刻被定义before the JMP:
gdt:
.quad 0x0000000000000000
gdtcode:
.quad 0x0020980000000000
gdtdata:
.quad 0x0000900000000000
gdtpointer:
.word .-gdt-1
.quad gdt
CODE64_SEL = gdtcode-gdt
DATA64_SEL = gdtdata-gdt
然后在文件的稍后位置您可以使用 FARJMP像这样:
jmp $CODE64_SEL, $_start
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)