¿Qué es exactamente la instrucción¿Qué hace la instrucción MOVZBL en IA-32 sintaxis de AT & T?
movzbl 0x01(%eax,%ecx),%eax
hace?
¿Qué es exactamente la instrucción¿Qué hace la instrucción MOVZBL en IA-32 sintaxis de AT & T?
movzbl 0x01(%eax,%ecx),%eax
hace?
AT & sintaxis T divide la movzx
Intel instruction mnemonic en diferentes mnemotécnicos para diferentes tamaños de fuente (movzb
vs. movzw
). En la sintaxis Intel, es:
movzx eax, byte ptr [eax+ecx+1]
es decir, cargar un byte de la memoria en eax + ecx + 1 y cero extenderse a registro completo.
Por cierto, la mayoría de las herramientas de GNU ahora tienen un interruptor o una opción de configuración para preferir la sintaxis de Intel. (Como objdump -Mintel
o gcc -S -masm=intel
, aunque esto último afecta la sintaxis utilizada al compilar inline-asm). Sin duda, recomendaría examinarlo, si no lo hace AT & T montaje para la vida. Consulte también la wiki de etiquetas x86 para obtener más documentos y guías.
Absolutamente correcto. –
Entendido: esto cargará el byte de la dirección '% eax +% ecx + 1' y lo ampliará a largo con un cero a la izquierda. ¡Muchas gracias! –
Ejemplo:
mov $0x, %eax
mov $1, %bl
movzbl %bl, %eax
# %eax == 0000 0001
mov $0x, %eax
mov $-1, %bl
movzbl %bl, %eax
# %eax == 0000 00FF
El mnemónico es:
También existen versiones para otros tamaños:
movzbw
: byte (8 bits) de la palabra (16 bits)movzwl
: palabra (16 bits) de largo (32 bits)Como la mayoría de las instrucciones GAS, se puede omitir el último carácter de tamaño cuando se trata de registros:
movzb %bl, %eax
pero no puedo entender por qué no podemos omitir el penúltimo Lett er, p. la siguiente falla:
movz %bl, %eax
¿Por qué no se deduce a partir del tamaño de los operandos cuando son registros como para mov
y la sintaxis de Intel?
Y si utiliza registros del tamaño incorrecto, falla al compilar ej .:
movzb %ax, %eax
Ejecutable Intel example with assertions on GitHub.
@downvoters por favor explique :-) –
Si [mira los códigos de operación] (http://www.felixcloutier.com/x86/MOVZX.html), el "tamaño de operando" controla el tamaño del destino pero hay diferentes códigos de operación para diferentes tamaños de fuente. Por lo tanto, tiene sentido que el gas trate 'movzb' como una instrucción separada de' movzw'. (Para la extensión de la señal, AMD incluso agregó una nueva mnemónica de sintaxis Intel para 'movsxd r64, r/m32' en lugar de sobrecargar a' movsx'. IDK por qué). –
mismo para movsbl: http://stackoverflow.com/questions/7861095/what-does-movsbl-instruction-do –