assembler set de instrucciones. introducción creado para facilitar la elaboración de programas....

Post on 03-Jan-2015

25 Views

Category:

Documents

5 Downloads

Preview:

Click to see full reader

TRANSCRIPT

AssemblerAssembler

Set de InstruccionesSet de Instrucciones

IntroducciónIntroducción

Creado para facilitar la elaboración de Creado para facilitar la elaboración de programas.programas.

Al "hablar" en Assembler, estamos Al "hablar" en Assembler, estamos diciéndole a la máquina, en lo más diciéndole a la máquina, en lo más cercano a su idioma posible, lo que tiene cercano a su idioma posible, lo que tiene que hacer.que hacer.

Sintaxis del AssemblerSintaxis del Assembler

Las órdenes en Assembler pueden ser:Las órdenes en Assembler pueden ser:

Mnemónicos (instrucciones)Mnemónicos (instrucciones)

(Ej. MOV, ADD, JMP)(Ej. MOV, ADD, JMP)

Directivas (palabras reservadas)Directivas (palabras reservadas)

(Ej. EQU, ORG, END)(Ej. EQU, ORG, END)

Formato general de una orden:Formato general de una orden:

mnemónico [Param1 [,Param2]]

La línea de código consta de cuatro partes: Etiquetas Directiva o instrucción Operando(s) Comentarios

Delimitadores:Delimitadores:

Los campos van separados sólo con espacios Los campos van separados sólo con espacios y/o tabulaciones. No se debe agregar nunca y/o tabulaciones. No se debe agregar nunca otros caracteres (comas, puntos, etc ).otros caracteres (comas, puntos, etc ).

No utilizar espacios extra, particularmente No utilizar espacios extra, particularmente después de comas que separan operandos. después de comas que separan operandos. ( Ej: ( Ej: movlw 5,w movlw 5,w ))

No usar caracteres delimitadores (espacios y No usar caracteres delimitadores (espacios y tabulaciones) en nombres o etiquetas.tabulaciones) en nombres o etiquetas.

Etiquetas:Etiquetas:

No más de una etiqueta por instrucción.No más de una etiqueta por instrucción.

No usar palabras reservadas (EQU) o No usar palabras reservadas (EQU) o instrucciones (MOV).instrucciones (MOV).

No usar números o caracteres no numéricos No usar números o caracteres no numéricos como 1º letra.como 1º letra.

Usar siempre Usar siempre letrasletras y en y en mayúscula.mayúscula.

Desventajas del AssemblerDesventajas del Assembler

Amplias diferencias entre el set de Amplias diferencias entre el set de instrucciones y tareas a realizarse.instrucciones y tareas a realizarse.

No Portable.No Portable.

Como remedio de lo anterior, se utilizan Como remedio de lo anterior, se utilizan lenguajes de medio o alto nivel como lenguajes de medio o alto nivel como C C o o Pascal.Pascal.

MOV (move)MOV (move)

Copia el contenido del parámetro origen al Copia el contenido del parámetro origen al destino.destino.

Ejemplo:Ejemplo:

MOV AX, BX equivale a AX = BX; (C)MOV AX, BX equivale a AX = BX; (C)

MOVSX & MOVZXMOVSX & MOVZX

Transfieren el operando origen a un Transfieren el operando origen a un registro y luego realizan la extensión registro y luego realizan la extensión

MOVSX (move with sign extension)MOVSX (move with sign extension)

MOVZX (move with zero extension)MOVZX (move with zero extension)

MOVS (Move String)MOVS (Move String)

Transfiere los elementos del string Transfiere los elementos del string especificados por la dirección del registro especificados por la dirección del registro ESI a la dirección especificada por el ESI a la dirección especificada por el registro EDI. registro EDI.

Los elementos a ser operados se Los elementos a ser operados se identifican con los registro ESI (source identifican con los registro ESI (source string element) y EDI (destination string string element) y EDI (destination string element).element).

MOVS (Move String)MOVS (Move String)

MOVSB (move byte string)MOVSB (move byte string)

MOVSW (move word string) MOVSW (move word string)

MOVSD (move doubleword string) MOVSD (move doubleword string)

MOV – RestriccionesMOV – Restricciones

NONO se puede mover datos… se puede mover datos…

Entre posiciones de memoriaEntre posiciones de memoria

MOV datos1, datos2 es ilegalMOV datos1, datos2 es ilegal

En su lugar se escribe:En su lugar se escribe:

MOV AX, datos2MOV AX, datos2

MOV datos1, AX (Utilización de variable MOV datos1, AX (Utilización de variable puente)puente)

MOV – RestriccionesMOV – Restricciones

NONO se puede mover datos… se puede mover datos…

De un registro de segmento a otro De un registro de segmento a otro

MOV DS, ES MOV DS, ES es ilegales ilegal

En su lugar se escribe:En su lugar se escribe:

MOV AX, ES MOV AX, ES

MOV DS, AX MOV DS, AX

MOV – RestriccionesMOV – Restricciones

NONO se puede mover… se puede mover…

Una constante directamente a un registro Una constante directamente a un registro de segmento. de segmento.

MOV DS, 1234H MOV DS, 1234H es ilegales ilegal

En su lugar se escribe:En su lugar se escribe:MOV AX, 1234HMOV AX, 1234HMOV DS, AXMOV DS, AX

MOV – RestriccionesMOV – Restricciones

NONO se puede… se puede…

CS (code segment) no debería usarse CS (code segment) no debería usarse como operando destinocomo operando destino

Podría tener el efecto de cambiar el Podría tener el efecto de cambiar el segmento que donde se esta ejecutando segmento que donde se esta ejecutando el código.el código.

XCHG (exchange)XCHG (exchange)

Intercambia el contenido de dos Intercambia el contenido de dos operandos. operandos.

No requiere una dirección temporaria.No requiere una dirección temporaria.

XCHG Dato1, Dato2XCHG Dato1, Dato2

Manipulación de pila – PUSHManipulación de pila – PUSH

Decrementa el puntero de pila (ESP), Decrementa el puntero de pila (ESP), luego copia el operando al tope de la luego copia el operando al tope de la misma.misma.

Manipulación de pila – POPManipulación de pila – POP

Copia el dato del tope de la pila (ESP) a la Copia el dato del tope de la pila (ESP) a la dirección especificada con el operando y dirección especificada con el operando y luego incrementa el registro ESP para luego incrementa el registro ESP para apuntar al nuevo tope de la pila.apuntar al nuevo tope de la pila.

PUSHA (push all registers)PUSHA (push all registers)

Guarda el contenido de los ocho registros Guarda el contenido de los ocho registros de propósito general en la pila.de propósito general en la pila.

Los registros se ingresan el la pila en el Los registros se ingresan el la pila en el siguiente orden: EAX, ECX, EDX, EBX, el siguiente orden: EAX, ECX, EDX, EBX, el valor inicial de ESP antes de que EAX sea valor inicial de ESP antes de que EAX sea ingresado en la pila, EBP, ESI, y EDI.ingresado en la pila, EBP, ESI, y EDI.

PUSHA (push all registers)PUSHA (push all registers)

POPA (pop all registers)POPA (pop all registers)

Saca los últimos ocho words o Saca los últimos ocho words o doublewords del tope de la pila y los doublewords del tope de la pila y los coloca en los registros de propósito coloca en los registros de propósito general, con excepción del registro ESP.general, con excepción del registro ESP.

El registro ESP se restaura por la acción El registro ESP se restaura por la acción de retirar los elementos de la pila.de retirar los elementos de la pila.

POPA (pop all registers)POPA (pop all registers)

Conversión de TiposConversión de Tipos

CBW CBW (convert byte to word)(convert byte to word)

CWDE CWDE (convert word to doubleword extended)(convert word to doubleword extended) CWD CWD (convert word to doubleword)(convert word to doubleword) CDQ CDQ (convert doubleword to quadword)(convert doubleword to quadword)

Instrucción Instrucción CMPCMP Realiza comparaciones entre dos

operandosSintaxis: CMP registro,registro CMP registro,memoria CMP memoria,registro CMP registro,valor CMP valor,registro

Los datos a comparar deben ser del mismo tamaño.Las comparaciones están íntimamente ligadas con los saltos condicionales.

CMPS (Compare string)CMPS (Compare string)

Resta los elementos del string destino de Resta los elementos del string destino de los elementos del string origen y actualiza los elementos del string origen y actualiza las banderas de estado (CF, ZF, OF, SF, las banderas de estado (CF, ZF, OF, SF, PF, y AF) en el registro EFLAGS de PF, y AF) en el registro EFLAGS de acuerdo a los resultados. acuerdo a los resultados.

Ningún elemento del string se escribe en Ningún elemento del string se escribe en la memoria. la memoria.

CMPS (Compare string)CMPS (Compare string)

CMPSB (compare byte strings) CMPSB (compare byte strings)

CMPSW (compare word strings) CMPSW (compare word strings)

CMPSD (compare doubleword strings)CMPSD (compare doubleword strings)

SCAS (Scan string)SCAS (Scan string)

Resta los elementos del string destino del Resta los elementos del string destino del contenido del registro EAX, AX o AL contenido del registro EAX, AX o AL (dependiendo de la longitud del operando) (dependiendo de la longitud del operando) y actualiza las banderas de estado de y actualiza las banderas de estado de acuerdo a los resultados.acuerdo a los resultados.

Ni los elementos del string ni el contenido Ni los elementos del string ni el contenido de los registros se modifican.de los registros se modifican.

SCAS (Scan string)SCAS (Scan string)

SCASB (Scan byte string) SCASB (Scan byte string)

SCASW (Scan word string) SCASW (Scan word string)

SCASD (Scan doubleword string)SCASD (Scan doubleword string)

LODS (Load string)LODS (Load string) Carga los elementos del string origen Carga los elementos del string origen

identificados por el registro ESI en el registro identificados por el registro ESI en el registro EAX, AX o AL. EAX, AX o AL.

LODSB (load byte string).LODSB (load byte string).

LODSW (load word string).LODSW (load word string).

LODSD (load doubleword string)LODSD (load doubleword string)

STOS (Store string)STOS (Store string) Almacena los elementos del string origen Almacena los elementos del string origen

del registro EAX, AX o AL en la dirección del registro EAX, AX o AL en la dirección de memoria identificada por el registro de memoria identificada por el registro EDI.EDI.

STOSB (store byte string).STOSB (store byte string). STOSW (store word string). STOSW (store word string).

STOSD (store doubleword string). STOSD (store doubleword string).

Entrada / SalidaEntrada / Salida

IN (input from port to register)IN (input from port to register) OUT (output from register to port)OUT (output from register to port)

Transfieren datos entre un puerto de E/S y Transfieren datos entre un puerto de E/S y el registro EAX (32 bits), el registro AX (16 el registro EAX (32 bits), el registro AX (16 bits) o el registro AL (8 bits) bits) o el registro AL (8 bits)

El puerto se especifica con un operando El puerto se especifica con un operando inmediato (si esta entre 0 y 255) o con una inmediato (si esta entre 0 y 255) o con una dirección en el registro DX. dirección en el registro DX.

Entrada / Salida (strings)Entrada / Salida (strings) INS (input from port to string)INS (input from port to string) OUTS (output string to port)OUTS (output string to port)

Los registros ESI y EDI se usan para Los registros ESI y EDI se usan para especificar los elementos del string en la especificar los elementos del string en la memoria y los prefijos de repetición (REP) se memoria y los prefijos de repetición (REP) se usan para repetir la instrucción para usan para repetir la instrucción para implementar una transferencia de bloque. implementar una transferencia de bloque.

Las instrucciones INS y OUTS usan una Las instrucciones INS y OUTS usan una dirección en el registro DX para especificar el dirección en el registro DX para especificar el puerto de E/S.puerto de E/S.

Entrada / Salida (strings)Entrada / Salida (strings)

INSB (input byte) INSB (input byte) INSW (input word) INSW (input word) INSD (input doubleword) INSD (input doubleword)

OUTB (output byte) OUTB (output byte) OUTW (output word) OUTW (output word) OUTD (output doubleword)OUTD (output doubleword)

Instrucciones Aritméticas BinariasInstrucciones Aritméticas Binarias

Operan con datos numéricos de 8, 16 y 32 bits, codificados como enteros binarios con signo y sin signo.

Básicamente Incluyen:

SumaSuma RestaResta

MultiplicaciónMultiplicación DivisiónDivisión

IncrementoIncremento DecrementoDecremento

ComparaciónComparación NegaciónNegación

Instrucción Instrucción ADDADD

Sintaxis:

ADD destino, fuente

Se suma ambos operandos y el resultado se almacena en el operando destino. Si se produce overflow se indica en los flags OF y CF. El signo del resultado se indica en el flag SF.

Instrucción Instrucción ADDADD

ADD AL,40 ;

le sumo al reg. AL el valor 40.

(AL+=40h ó AL=AL+40h)

Instrucción Instrucción SUBSUB

Sintaxis:

SUB destino, fuente

Se suma ambos operandos y el resultado se almacena en el operando destino. Si se produce overflow se indica en los flags OF y CF. El signo del resultado se indica en el flag SF.

Instrucciones de Instrucciones de Multiplicación y DivisiónMultiplicación y División

MUL Multiplicación sin signo

IMUL Multiplicación con signo

DIV División sin signo

IDIV División con signo

Instrucción Instrucción MULMUL Sintaxis:

MUL fuente

Realiza la multiplicación entre el operando dado con el acumulador. El acumulador a multiplicar va a depender del operador fuente que se ingrese.

Tamaño del operando

 

Registro Fuente Destino

Byte AL r/m8 AX

Word AX r/m16 DX:AX

DoubleWord EAX r/m32 EDX:EAX

Instrucción Instrucción IMULIMUL

Sintaxis:

IMUL fuente

Tiene tres formas según el número de operandos:

Un Operando

Dos Operandos

Tres Operandos

Instrucción Instrucción IMULIMUL

Un Operando:

Es idéntica a la instrucción MUL

Dos Operandos:

IMUL destino, fuente

Dos Operandos:

IMUL destino, fuente1, fuente2

Instrucción Instrucción DIVDIV Sintaxis:

DIV divisor

Divide el valor en los registros AX, DX:AX o EDX:EAX por el operando divisor. Esta operación arroja como resultado un cociente y un resto, el modo en que se almacena lo podemos observar en la siguiente tabla...

Tamaño del operando

Dividendo Divisor Cociente Resto Máximo Cociente

Word/byte AX r/m8 AL AH 255

Doubleword/word

DX:AX r/m16 AX DX 65,535

Quadword/doubleword

EDX:EAX r/m32 EAX EDX 232 - 1

Instrucciones De Instrucciones De Incremento y DecrementoIncremento y Decremento

INC Incremento DEC Decremento

Estas instrucciones adicionan 1 o restan 1 a un operando entero.

Sintaxis INC AX o DEC AX Equivale a ADD AX,1 o SUB AX,1

(A++) (A--)

Instrucciones de Instrucciones de Comparación y NegaciónComparación y Negación

Instrucción NEG Sintaxis:

NEG destino Genera el complemento a dos del

operando destino y lo almacena en este mismo operando.

MOV AX,1234h

NEG AX AX=EDCBh

Instrucciones LógicasInstrucciones Lógicas

AND Conjunción de dos operandos OR Disyunción inclusiva lógica de

dos operandos XOR Disyunción exclusiva lógica de

dos operandos NOT Negación bit por bit del

operando

InstrucciónInstrucción AND AND

AND destino, fuente

Cada bit del resultado se activa a 1 si ambos bits de los operandos son 1, en otro caso se pone a 0.

Fuente Destino Destino

1 1 11 0 00 1 00 0 0

Dirección de memoria

InstrucciónInstrucción OR OR

OR destino, fuente

Cada bit del resultado se pone en 0 si ambos bits de los operandos son 0, en otro caso se pone a 1.

Fuente Destino Destino

1 1 11 0 10 1 10 0 0

Dirección de memoria

InstrucciónInstrucción XOR XOR

XOR destino, fuente

Cada bit del resultado se activa a 1 si ambos bits de los operandos son diferentes, en otro caso es 0.

Fuente Destino Destino

1 1 0

1 0 1

0 1 1

0 0 0

InstrucciónInstrucción NOT NOT

NOT destino

Cada bit 1 se pone a 0 y cada bit 0 se pone a 1

Transferencia de ControlTransferencia de Control

Es un conjunto de instrucciones.Es un conjunto de instrucciones.

Permiten al programador romper el flujo Permiten al programador romper el flujo

secuencial en un programa.secuencial en un programa.

PPermite ejecutar trozos de código.ermite ejecutar trozos de código.

Clasificación:Clasificación:

Saltos incondicionales (JMP).Saltos incondicionales (JMP).

Bucles (LOOP).Bucles (LOOP). Saltos condicionales (Jnnn).Saltos condicionales (Jnnn).

Llamadas a procedimientos (CALL).Llamadas a procedimientos (CALL).

Llamadas a interrupciones (INT).Llamadas a interrupciones (INT).

JMP (Salto incondicional)JMP (Salto incondicional)

Desvía el flujo del programaDesvía el flujo del programa No verifica condiciones ni banderasNo verifica condiciones ni banderas Transfiere a una dirección especificadaTransfiere a una dirección especificada

Sintaxis: Sintaxis:

JMPJMP destino destino

Tipos de Salto IncondicionalTipos de Salto Incondicional

Ej: Ej: ;; porción de códigoporción de código

Inicio:Inicio:

JMPJMP Ejemplo Ejemplo

MOV cx,7MOV cx,7

Ejemplo:Ejemplo:

MOV cx,6MOV cx,6

; ; continúa códigocontinúa código

Salto Condicional (Jnnn)Salto Condicional (Jnnn)

Ejecuta trozos de código dependiendo del jecuta trozos de código dependiendo del valor de determinado registro o variablevalor de determinado registro o variable

Es necesario hacer una Es necesario hacer una comparacióncomparación

Salto Condicional (Jnnn)Salto Condicional (Jnnn)

Salto Condicional (Jnnn)Salto Condicional (Jnnn)

Bucle (LOOP)Bucle (LOOP)

Sirve para ejecutar un trozo de código un número de veces dado Por ejemplo:

; porción de código MOV CX,7 INICIO_BUCLE: ADD WORD PTR BX,CX INC BX LOOP INICIO_BUCLE MOV AX,BX ; continúa código

Llamada a interrupciones (INT)Llamada a interrupciones (INT)

Son las de tipo softwareSon las de tipo software Ayuda en la creación de programasAyuda en la creación de programas Una Una interrupcióninterrupción es una operación que es una operación que

invoca la ejecución de una rutina invoca la ejecución de una rutina específica específica

Su sintaxis es la siguiente:Su sintaxis es la siguiente:

INTINT numero_interrupción. numero_interrupción.

Llamada a interrupciones (INT)Llamada a interrupciones (INT)

Ejemplo:Ejemplo:

INT 10H INT 10H Provocaría una llamada a la Provocaría una llamada a la interrupción 10h (16 en decimal).interrupción 10h (16 en decimal).

Llamada a Procedimientos (CALL)Llamada a Procedimientos (CALL)

Trozos de código que van a ser usados en Trozos de código que van a ser usados en distintas partes del programa.distintas partes del programa.

Permiten tener un código más legible, Permiten tener un código más legible,

más estructurado.más estructurado.

Sintaxis:Sintaxis:

CALL CALL nombre_procedimientonombre_procedimiento

Llamada a Procedimientos (CALL)Llamada a Procedimientos (CALL)

El formato es el siguiente:

Inicialización PROC ….. Cuerpo del procedimiento. ….. RETInicialización ENDP

Llamada a Procedimientos (CALL)Llamada a Procedimientos (CALL)

Existen dos tipos de llamadas a procedimientos:Existen dos tipos de llamadas a procedimientos:

Llamadas directas (la llamada tieneLlamadas directas (la llamada tiene

el nombre del procedimiento)el nombre del procedimiento)

Llamadas indirectas (el llamado tieneLlamadas indirectas (el llamado tiene

la dirección que contiene la direcciónla dirección que contiene la dirección

de comienzo del procedimiento)de comienzo del procedimiento)

DeclaraciDeclaracióón de Variablesn de Variables

Es la posibilidad de ponerle nombres a las Es la posibilidad de ponerle nombres a las posiciones de memoriaposiciones de memoria

Sintaxis:Sintaxis:

Nombre Tipo ValorNombre Tipo Valor

DeclaraciDeclaracióón de Variables (Tipos)n de Variables (Tipos)

DB Para definir un byte, dice que la variable es un byte, o un array de Bytes

DW Para definir un Word o un array de Word.

DD Para definir un DWord, o un array de DWord.

DQ Para definir un QWord (QuadWord, u ocho bytes).

DT Para definir Ten Bytes (diez).

DeclaraciDeclaracióón de Variablesn de Variables

Ejemplos:Ejemplos:

LETRA_A DB ‘A’ ; variable con un carácterLETRA_A DB ‘A’ ; variable con un carácter

NUMBER_1 DW 1 ; un número 1, pero wordNUMBER_1 DW 1 ; un número 1, pero word

STRING DB ‘Hola, cómo estás!!!!’ ; cadenaSTRING DB ‘Hola, cómo estás!!!!’ ; cadena

Declaración de MacrosDeclaración de Macros

Permiten asignarle un nombre a una Permiten asignarle un nombre a una secuencia de instruccionessecuencia de instrucciones

Luego se utiliza el nombre de la macro Luego se utiliza el nombre de la macro en el programa como si se usase la en el programa como si se usase la secuencia de instrucciones anterior.secuencia de instrucciones anterior.

Las macros no son lo mismo que las Las macros no son lo mismo que las subrutinassubrutinas

Declaración de MacrosDeclaración de Macros

La declaración de macros se hace a La declaración de macros se hace a través de las directivas través de las directivas MACRO MACRO yy ENDMENDM..

Su sintaxis es:Su sintaxis es:

nombre nombre MACRO MACRO [[parámetrosparámetros,,,],,,]

declaracionesdeclaraciones ENDMENDM

top related