NASM给出的错误(尽管我的工作操作系统)是“无效的有效地址”。
现在我已经看到很多关于如何使用LEA的例子,我认为我做对了,但我的NASM不喜欢它。我试过lea cx, [cx+9]
并且它有效; lea cx, [bx+cx]
没有。
现在,如果我将寄存器扩展到32位(即lea ecx, [ecx*8+ecx]
),一切都会好的,但我只能使用16位和8位寄存器。
这里有谁知道这些知识渊博的人谁可以解释我为什么我的汇编程序不让我按照我认为应该使用的方式使用lea?
答案 0 :(得分:9)
这是因为[bx+cx]
在16位x86上的任何寻址模式下都无效,有关详细信息,请参阅此site。
lea cx, [bx+di]
或lea cx, [bx+si]
应该有效。
如果您的代码将在386或更高版本的16位模式下运行,则可以使用lea cx, [ecx + 9]
(地址大小前缀但仍为16位操作数大小)。
另请参阅this Q&A on x86 addressing modes (mostly discussing 32/64bit addressing modes和x86代码wiki。
答案 1 :(得分:6)
lea cx,[cx*8+cx]
不起作用,因为“scale-index-base”寻址仅适用于32位寄存器。这不是汇编程序的限制 - 它是处理器的限制。
答案 2 :(得分:3)
以下用于构建postbyte的表显示哪个寄存器可以用作地址寄存器,哪些寄存器可以与第二个地址寄存器(baseregister + indexregister和可能缩放)组合以使用它构建地址。 (从16位地址模式观察,其中未设置D标志。)
Instruction Prefix 0 or 1 Byte
Address-Size Prefix 0 or 1 Byte
Operand-Size Prefix 0 or 1 Byte
Segment Prefix 0 or 1 Byte
Opcode 1 or 2 Byte
Mod R/M (Postbyte) 0 or 1 Byte
SIB, Scale Index Base (386+) 0 or 1 Byte
Displacement 0, 1, 2 or 4 Byte (4 only 386+)
Immediate 0, 1, 2 or 4 Byte (4 only 386+)
Format of Postbyte(Mod R/M from Intel-Manual)
------------------------------------------
MM RRR MMM
MM - Memeory addressing mode
RRR - Register operand address
MMM - Memoy operand address
RRR Register Names
Filds 8bit 16bit 32bit
000 AL AX EAX
001 CL CX ECX
010 DL DX EDX
011 Bl BX EBX
100 AH SP ESP
101 CH BP EBP
110 DH SI ESI
111 BH DI EDI
---
16bit memory (No 32 bit memory address prefix)
MMM Default MM Field
Field Sreg 00 01 10 11=MMM is reg
000 DS [BX+SI] [BX+SI+o8] [BX+SI+o16]
001 DS [BX+DI] [BX+DI+o8] [BX+DI+o16]
010 SS [BP+SI] [BP+SI+o8] [BP+SI+o16]
011 SS [BP+DI] [BP+DI+o8] [BP+DI+o16]
100 DS [SI] [SI+o8] [SI+o16]
101 DS [DI] [DI+o8] [SI+o16]
110 SS [o16] [BP+o8] [BP+o16]
111 DS [BX] [BX+o8] [BX+o16]
Note: MMM=110,MM=0 Default Sreg is DS !!!!
32bit memory (Has 67h 32 bit memory address prefix)
MMM Default MM Field
Field Sreg 00 01 10 11=MMM is reg
000 DS [EAX] [EAX+o8] [EAX+o32]
001 DS [ECX] [ECX+o8] [ECX+o32]
010 DS [EDX] [EDX+o8] [EDX+o32]
011 DS [EBX] [EBX+o8] [EBX+o32]
100 SIB [SIB] [SIB+o8] [SIB+o32]
101 SS [o32] [EBP+o8] [EBP+o32]
110 DS [ESI] [ESI+o8] [ESI+o32]
111 DS [EDI] [EDI+o8] [EDI+o32]
Note: MMM=110,MM=0 Default Sreg is DS !!!!
---
SIB is (Scale/Base/Index)
SS BBB III
Note: SIB address calculated as:
<sib address>=<Base>+<Index>*(2^(Scale))
Fild Default Base
BBB Sreg Register Note
000 DS EAX
001 DS ECX
010 DS EDX
011 DS EBX
100 SS ESP
101 DS o32 if MM=00 (Postbyte)
SS EBP if MM<>00 (Postbyte)
110 SS ESI
111 DS EDI
Fild Index
III register Note
000 EAX
001 ECX
010 EDX
011 EBX
100 never Index SS can be 00
101 EBP
110 ESI
111 EDI
Fild Scale coefficient
SS =2^(SS)
00 1
01 2
10 4
11 8
德克