모두의 코드
LEA (Intel x86/64 assembly instruction)

작성일 : 2020-09-01 이 글은 4161 번 읽혔습니다.

LEA

Load Effective Address

참고 사항

아래 표를 해석하는 방법은 x86-64 명령어 레퍼런스 읽는 법 글을 참조하시기 바랍니다.

Opcode

Instruction

Op/
En

64-Bit
Mode

Compat/
Leg Mode

Description

8D /r

LEA r16 m

RM

Valid

Valid

Store effective address for m in register r16.

8D /r

LEA r32 m

RM

Valid

Valid

Store effective address for m in register r32.

REX.W + 8D /r

LEA r64 m

RM

Valid

N.E.

Store effective address for m in register r64.

Instruction Operand Encoding

Op/En

Operand 1

Operand 2

Operand 3

Operand 4

RM

ModRM:reg (w)

ModRM:r/m (r)

NA

NA

Description

Computes the effective address of the second operand (the source operand) and stores it in the first operand (destination operand). The source operand is a memory address (offset part) specified with one of the processors addressing modes; the destination operand is a general-purpose register. The address-size and operand-size attri-butes affect the action performed by this instruction, as shown in the following table. The operand-size attribute of the instruction is determined by the chosen register; the address-size attribute is determined by the attribute of the code segment.

Table 3-53. Non-64-bit Mode LEA Operation with Address and Operand Size Attributes

Different assemblers may use different algorithms based on the size attribute and symbolic reference of the source operand.

In 64-bit mode, the instruction's destination operand is governed by operand size attribute, the default operand size is 32 bits. Address calculation is governed by address size attribute, the default address size is 64-bits. In 64-bit mode, address size of 16 bits is not encodable. See Table 3-54.

Operand Size

Address Size

Action Performed

16

16

16-bit effective address is calculated and stored in requested 16-bit register destination.

16

32

32-bit effective address is calculated. The lower 16 bits of the address are stored in the requested 16-bit register destination.

32

16

16-bit effective address is calculated. The 16-bit address is zero-extended and stored in the requested 32-bit register destination.

32

32

32-bit effective address is calculated and stored in the requested 32-bit register destination.

Table 3-54. 64-bit Mode LEA Operation with Address and Operand Size Attributes

Operand Size

Address Size

Action Performed

16

32

32-bit effective address is calculated (using 67H prefix). The lower 16 bits of the address are stored in the requested 16-bit register destination (using 66H prefix).

16

64

64-bit effective address is calculated (default address size). The lower 16 bits of the address are stored in the requested 16-bit register destination (using 66H prefix).

32

32

32-bit effective address is calculated (using 67H prefix) and stored in the requested 32-bit register destination.

32

64

64-bit effective address is calculated (default address size) and the lower 32 bits of the address are stored in the requested 32-bit register destination.

64

32

32-bit effective address is calculated (using 67H prefix), zero-extended to 64-bits, and stored in the requested 64-bit register destination (using REX.W).

64

64

64-bit effective address is calculated (default address size) and all 64-bits of the address are stored in the requested 64-bit register destination (using REX.W).

Operation

IF OperandSize = 16 and AddressSize = 16
    THEN 
          DEST <- EffectiveAddress(SRC); (* 16-bit address *)
    ELSE IF OperandSize = 16 and AddressSize = 32
          THEN
                temp <- EffectiveAddress(SRC); (* 32-bit address *)
                DEST <- temp[0:15]; (* 16-bit address *)
          FI;
    ELSE IF OperandSize = 32 and AddressSize = 16
          THEN
                temp <- EffectiveAddress(SRC); (* 16-bit address *)
                DEST <- ZeroExtend(temp); (* 32-bit address *)
          FI;
    ELSE IF OperandSize = 32 and AddressSize = 32
          THEN 
                DEST <- EffectiveAddress(SRC); (* 32-bit address *)
          FI;
    ELSE IF OperandSize = 16 and AddressSize = 64
          THEN 
                temp <- EffectiveAddress(SRC); (* 64-bit address *)
                DEST <- temp[0:15]; (* 16-bit address *)
          FI;
    ELSE IF OperandSize = 32 and AddressSize = 64
          THEN 
                temp <- EffectiveAddress(SRC); (* 64-bit address *)
                DEST <- temp[0:31]; (* 16-bit address *)
          FI;
    ELSE IF OperandSize = 64 and AddressSize = 64
          THEN 
                DEST <- EffectiveAddress(SRC); (* 64-bit address *)
          FI;
FI;

Flags Affected

None

Protected Mode Exceptions

#UD

  • If source operand is not a memory location.

  • If the LOCK prefix is used.

Real-Address Mode Exceptions

Same exceptions as in protected mode.

Virtual-8086 Mode Exceptions

Same exceptions as in protected mode.

Compatibility Mode Exceptions

Same exceptions as in protected mode.

64-Bit Mode Exceptions

Same exceptions as in protected mode.

첫 댓글을 달아주세요!
프로필 사진 없음
강좌에 관련 없이 궁금한 내용은 여기를 사용해주세요

    댓글을 불러오는 중입니다..