모두의 코드
MOVS, MOVSB, MOVSW, MOVSD, MOVSQs (Intel x86/64 assembly instruction)

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

MOVS, MOVSB, MOVSW, MOVSD, MOVSQ

Move Data from String toString

참고 사항

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

OpcodeInstructionOp/
En
64-Bit
Mode
Compat/
Leg Mode
Description
A4MOVS m8 m8NPValidValidFor legacy mode, Move byte from address DS:(E)SI to ES:(E)DI. For 64-bit mode move byte from address (RE)SI to (RE)DI.
A5MOVS m16 m16NPValidValidFor legacy mode, move word from address DS:(E)SI to ES:(E)DI. For 64-bit mode move word at address (RE)SI to (RE)DI.
A5MOVS m32 m32NPValidValidFor legacy mode, move dword from address DS:(E)SI to ES:(E)DI. For 64-bit mode move dword from address (RE)SI to (RE)DI.
REX.W + A5MOVS m64 m64NPValidN.E.Move qword from address (RE)SI to (RE)DI.
A4MOVSBNPValidValidFor legacy mode, Move byte from address DS:(E)SI to ES:(E)DI. For 64-bit mode move byte from address (RE)SI to (RE)DI.
A5MOVSWNPValidValidFor legacy mode, move word from address DS:(E)SI to ES:(E)DI. For 64-bit mode move word at address (RE)SI to (RE)DI.
A5MOVSDNPValidValidFor legacy mode, move dword from address DS:(E)SI to ES:(E)DI. For 64-bit mode move dword from address (RE)SI to (RE)DI.
REX.W + A5MOVSQNPValidN.E.Move qword from address (RE)SI to (RE)DI.

Instruction Operand Encoding

Op/EnOperand 1Operand 2Operand 3Operand 4
NPNANANANA

Description

Moves the byte, word, or doubleword specified with the second operand (source operand) to the location specified with the first operand (destination operand). Both the source and destination operands are located in memory. The address of the source operand is read from the DS:ESI or the DS:SI registers (depending on the address-size attri-bute of the instruction, 32 or 16, respectively). The address of the destination operand is read from the ES:EDI or the ES:DI registers (again depending on the address-size attribute of the instruction). The DS segment may be overridden with a segment override prefix, but the ES segment cannot be overridden.

At the assembly-code level, two forms of this instruction are allowed: the "explicit-operands" form and the "no-operands" form. The explicit-operands form (specified with the MOVS mnemonic) allows the source and destination operands to be specified explicitly. Here, the source and destination operands should be symbols that indicate the size and location of the source value and the destination, respectively. This explicit-operands form is provided to allow documentation; however, note that the documentation provided by this form can be misleading. That is, the source and destination operand symbols must specify the correct type (size) of the operands (bytes, words, or doublewords), but they do not have to specify the correct location. The locations of the source and destination operands are always specified by the DS:(E)SI and ES:(E)DI registers, which must be loaded correctly before the move string instruction is executed.

The no-operands form provides "short forms" of the byte, word, and doubleword versions of the MOVS instruc-tions. Here also DS:(E)SI and ES:(E)DI are assumed to be the source and destination operands, respectively. The size of the source and destination operands is selected with the mnemonic: MOVSB (byte move), MOVSW (word move), or MOVSD (doubleword move).

After the move operation, the (E)SI and (E)DI registers are incremented or decremented automatically according to the setting of the DF flag in the EFLAGS register. (If the DF flag is 0, the (E)SI and (E)DI register are incre-

mented; if the DF flag is 1, the (E)SI and (E)DI registers are decremented.) The registers are incremented or decremented by 1 for byte operations, by 2 for word operations, or by 4 for doubleword operations.

NOTE

To improve performance, more recent processors support modifications to the processor's operation during the string store operations initiated with MOVS and MOVSB. See Section 7.3.9.3 in the Intel(R) 64 and IA-32 Architectures Software Developer's Manual, Volume 1 for additional information on fast-string operation.

The MOVS, MOVSB, MOVSW, and MOVSD instructions can be preceded by the REP prefix (see "REP/REPE/REPZ /REPNE/REPNZ--Repeat String Operation Prefix" for a description of the REP prefix) for block moves of ECX bytes, words, or doublewords.

In 64-bit mode, the instruction's default address size is 64 bits, 32-bit address size is supported using the prefix 67H. The 64-bit addresses are specified by RSI and RDI; 32-bit address are specified by ESI and EDI. Use of the REX.W prefix promotes doubleword operation to 64 bits. See the summary chart at the beginning of this section for encoding data and limits.

Operation

DEST <- SRC;
Non-64-bit Mode:
IF (Byte move)
    THEN IF DF = 0
          THEN 
                (E)SI <- (E)SI + 1; 
                (E)DI <- (E)DI + 1; 
          ELSE 
                (E)SI <- (E)SI - 1; 
                (E)DI <- (E)DI - 1; 
          FI;
    ELSE IF (Word move)
          THEN IF DF = 0
                (E)SI <- (E)SI + 2; 
                (E)DI <- (E)DI + 2; 
                FI;
          ELSE 
                (E)SI <- (E)SI - 2; 
                (E)DI <- (E)DI - 2; 
          FI;
    ELSE IF (Doubleword move)
          THEN IF DF = 0
                (E)SI <- (E)SI + 4; 
                (E)DI <- (E)DI + 4; 
                FI;
          ELSE 
                (E)SI <- (E)SI - 4; 
                (E)DI <- (E)DI - 4; 
          FI;
FI;
64-bit Mode:
IF (Byte move)
    THEN IF DF = 0
          THEN 
(R|E)SI <- (R|E)SI + 1; 
                (R|E)DI <- (R|E)DI + 1; 
          ELSE 
                (R|E)SI <- (R|E)SI - 1; 
                (R|E)DI <- (R|E)DI - 1; 
          FI;
    ELSE IF (Word move)
          THEN IF DF = 0
                (R|E)SI <- (R|E)SI + 2; 
                (R|E)DI <- (R|E)DI + 2; 
                FI;
          ELSE 
                (R|E)SI <- (R|E)SI - 2; 
                (R|E)DI <- (R|E)DI - 2; 
          FI;
    ELSE IF (Doubleword move)
          THEN IF DF = 0
                (R|E)SI <- (R|E)SI + 4; 
                (R|E)DI <- (R|E)DI + 4; 
                FI;
          ELSE 
                (R|E)SI <- (R|E)SI - 4; 
                (R|E)DI <- (R|E)DI - 4; 
          FI;
    ELSE IF (Quadword move)
          THEN IF DF = 0
                (R|E)SI <- (R|E)SI + 8; 
                (R|E)DI <- (R|E)DI + 8;
                FI;
          ELSE 
                (R|E)SI <- (R|E)SI - 8; 
                (R|E)DI <- (R|E)DI - 8; 
          FI;
FI;

Flags Affected

None

Protected Mode Exceptions

#GP(0)

  • If the destination is located in a non-writable segment.

  • If a memory operand effective address is outside the CS, DS, ES, FS, or GS segment limit.

  • If the DS, ES, FS, or GS register contains a NULL segment selector.

#SS(0)

  • If a memory operand effective address is outside the SS segment limit.

#PF(fault-code)

  • If a page fault occurs.

#AC(0)

  • If alignment checking is enabled and an unaligned memory reference is made while the current privilege level is 3.

#UD

  • If the LOCK prefix is used.

Real-Address Mode Exceptions

#GP

  • If a memory operand effective address is outside the CS, DS, ES, FS, or GS segment limit.

#SS

  • If a memory operand effective address is outside the SS segment limit.

#UD

  • If the LOCK prefix is used.

Virtual-8086 Mode Exceptions

#GP(0)

  • If a memory operand effective address is outside the CS, DS, ES, FS, or GS segment limit.

#SS(0)

  • If a memory operand effective address is outside the SS segment limit.

#PF(fault-code)

  • If a page fault occurs.

#AC(0)

  • If alignment checking is enabled and an unaligned memory reference is made.

#UD

  • If the LOCK prefix is used.

Compatibility Mode Exceptions

Same exceptions as in protected mode.

64-Bit Mode Exceptions

#SS(0)

  • If a memory address referencing the SS segment is in a non-canonical form.

#GP(0)

  • If the memory address is in a non-canonical form.

#PF(fault-code)

  • If a page fault occurs.

#AC(0)

  • If alignment checking is enabled and an unaligned memory reference is made while the current privilege level is 3.

#UD

  • If the LOCK prefix is used.

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