310 likes | 433 Views
Universidad Nacional de Ingeniería Microprocesadores. Unidad II: Arquitectura y Programacion de un Microprocesador (80X86). Contenidos. Interrupciones Interrupciones Internas De Hardware Interrupciones Externas De Hardware Interrupciones de Software Juegos de Instruccciones
E N D
Universidad Nacional de Ingeniería Microprocesadores Unidad II: Arquitectura y Programacion de un Microprocesador (80X86) Microprocesadores Ing. Carlos Ortega H.
Contenidos • Interrupciones • Interrupciones Internas De Hardware • Interrupciones Externas De Hardware • Interrupciones de Software • Juegos de Instruccciones • Instrucciones de transferencia de datos • Instrucciones aritméticas • Instrucciones lógicas • Instrucciones de Comparacion. • Instrucciones de desplazamiento y rotaciones • Instrucciones de E/S • Instrucciones de control del flujo del programa • Instrucciones de Salto. • Instruccion de Llamada de Procedimiento. • Instrucciones de cadena de caracteres Microprocesadores Ing. Carlos Ortega H.
Interrupciones Son instrucciones que detienen la ejecución de un programa para permitir el uso del UP a un proceso prioritario. Una vez concluido este último proceso le devuelve el control a la aplicación anterior. Las interrupciones ocurren muy seguido. Para lograr administrar todas estas interrupciones, la computadora cuenta con un espacio de memoria, llamado memoria baja, donde se almacenan las direcciones de cierta localidad de memoria donde se encuentran un juego de instrucciones que el UP ejecutará para después regresar a la aplicación en proceso. La sentencia para usar una interrupción en ensamblador es INT número. Existen 3 tipos de interrupciones Microprocesadores Ing. Carlos Ortega H.
INTERRUPCIONES INTERNAS DE HARDWARE Son generadas por ciertos eventos que surgen durante la ejecución de un programa. Son manejadas en su totalidad por el hardware y no es posible modificarlas. Un ejemplo claro de este tipo de interrupciones es la que actualiza el contador del reloj interno de la computadora, el hardware hace el llamado a esta interrupción varias veces durante un segundo para mantener la hora actualizada. No podemos controlar por software las actualizaciones del reloj, pero podemos crear un "reloj virtual" actualizado continuamente gracias al contador del reloj interno. Unicamente debemos escribir un programa que lea el valor actual del contador y lo traduzca a un formato entendible para el usuario. Microprocesadores Ing. Carlos Ortega H.
INTERRUPCIONES EXTERNAS DE HARDWARE Las interrupciones externas las generan los dispositivos periféricos, como pueden ser: teclado, impresoras, tarjetas de comunicaciones, etc. También son generadas por los coprocesadores. No es posible desactivar a las interrupciones externas. Estas interrupciones no son enviadas directamente a la UP, sino que se mandan a un circuito integrado cuya función es exclusivamente manejar este tipo de interrupciones. El circuito, llamado PIC 8259A, si es controlado por la UP utilizando para tal control una serie de vías de comunicación llamadas puertos. Microprocesadores Ing. Carlos Ortega H.
INTERRUPCIONES DE SOFTWARE Pueden ser activadas directamente por el ensamblador invocando al número de interrupción deseada con la instrucción INT. Este tipo de interrupciones podemos separarlas en dos categorías: las interrupciones del sistema operativo DOS y las interrupciones del BIOS. La diferencia es que las interrupciones del sistema operativo son más fáciles de usar pero también son más lentas ya que estas interrupciones hacen uso del BIOS, en cambio las interrupciones del BIOS son mucho más rápidas pero tienen la desventaja que, como son parte del hardware son muy específicas y pueden variar dependiendo de la marca del fabricante del circuito. Microprocesadores Ing. Carlos Ortega H.
La elección del tipo de interrupción a utilizar dependerá únicamente de las características que le quiera dar a su programa: velocidad (utilizando las del BIOS) o portabilidad (utilizando las del DOS). Interrupción 21H Propósito: Llamar a diversas funciones del DOS. Int 21H Nota: Es necesario especificar que el valor que estamos utilizando es hexadecimal. INTERRUPCIONES DE SOFTWARE Microprocesadores Ing. Carlos Ortega H.
Conjunto de Instrucciones del 8086 Microprocesadores Ing. Carlos Ortega H.
Juegos de Instruccciones Las instrucciones del 8086/88 se pueden dividir en varios grupos: • Instrucciones de transferencia de datos • Instrucciones aritméticas • Instrucciones lógicas • Instrucciones de desplazamiento y rotaciones • Instrucciones de E/S • Instrucciones de control del flujo del programa • Instrucciones de cadena de caracteres Microprocesadores Ing. Carlos Ortega H.
Instrucciones de transferencia de datos Las instrucciones de transferencia de datos copian datos de un sitio a otro y son: MOV, XCHG, XLAT, LEA, LDS, LES, LAHF, SAHF, PUSH, PUSHF, POP, POPF. MOV realiza la transferencia de datos del operando de origen al destino. MOV admite todos los tipos de direccionamiento. Ambos operandos deben ser del mismo tamaño y no pueden estar ambos en memoria. XCHG realiza el intercambio entre los valores de los operandos. Puede tener operando en registros y en memoria Ex: XCHG AX, BX Microprocesadores Ing. Carlos Ortega H.
XLAT carga en AL el contenido de la dirección apuntada por [BX+AL]. LEA carga en un registro especificado la dirección efectiva especificada como en el operando. Instrucciones de transferencia de datos • LEA reg, mem • Ejemplos: • LEA AX, [BX]; carga en AX la dirección apuntada por BX. • LEA AX, 3[BP+SI] ; carga en AX la dirección resultado de multiplicar por 3 la suma de los contenido de BP y SI. Microprocesadores Ing. Carlos Ortega H.
PUSH y POP realizan las operaciones de apilado y desapilado en la pila del procesador respectivamente, admiten todos los tipos de direccionamiento (excepto inmediato). Los operandos deben ser siempre de 16 bits Ejemplos: PUSH AX; envía a la pila AX POP DS; carga el primer elemento de la pila en DS Instrucciones de transferencia de datos Microprocesadores Ing. Carlos Ortega H.
Instrucciones Aritméticas Realizan operaciones aritméticas con los operandos. Y son: ADD, ADC,DAA, AAA, SUB, SBB, DAS, AAS, NEG, MUL, IMUL, AAM, DIV, IDIV, AAD, CBW, CWB, INC,DEC. ADD y ADC realizan la suma y la suma con acarreo (bit CF del registro de estado) de dos operandos, respectivamente, y guardan el resultado en el primero de ellos. Admiten todos los tipos de direccionamiento (excepto que ambos operando estén en memoria). Ejemplo: ; J = 34+f MOV AX, F ADD AX, 34 MOV J, AX • Estas instrucciones afectan a los bits OF, SF, ZF, AF, PF, CF del registro de estado. Microprocesadores Ing. Carlos Ortega H.
DAA realizan la corrección BCD empaquetado del resultado de una suma en AL. Si AF = 1 o el valor de los 4 bits menos significativos del AL es mayor que 9, entonces realiza el primer ajuste BCD. Para ello suma a AL el valor 06h. Después si CF = 1 o el valor de los 4 bits más significativos de AL es mayor que 9, realizar el segundo ajuste BCD. Para ello suma a AL el valor 60h Esta instrucción afecta también a los bits OF, SF, ZF, AF y PF del registro de estado. Instrucciones Aritméticas Microprocesadores Ing. Carlos Ortega H.
SUB y SBB realizan la resta y la resta con acarreo, respectivamente, de dos operandos y guardan el resultado en el primero de ellos. Admiten todos los modos de direccionamiento, excepto dos operando en memoria. Instrucciones Aritméticas Ejemplo ; J= F-34 MOV AX, F SUB AX, 34 MOV J, AX DAS realiza la corrección BCD del resultado de una resta en AL. NEG realiza la operación aritmética de negado de un operando y guarda el resultado en el mismo operando. Admite todos los tipos de direccionamiento, excepto inmediato. Microprocesadores Ing. Carlos Ortega H.
Instrucciones lógicas Realizan las operaciones lógicas y son: OR, XOR, AND, NOT, TEST, CMP. OR, XOR y AND realizan las operaciones lógicas respectivamente, de dos operandos, guardando el resultado en el primero de ellos. Estas operaciones son bit a bit. Admiten todos los modos de direccionamiento excepto los dos operandos en memoria. Afectan a los bits SF, ZF, PF del registro de estado. Además ponen a cero los bits CF y OF. NOT realiza la operación de negado lógico de los bits del operando. Admite todos los modos direccionamiento excepto inmediato. No afecta a ningún bit del registro de estado Microprocesadores Ing. Carlos Ortega H.
Instrucciones de comparación Estas instrucciones realizan funciones de comparación no guardando el resultado, pero si afecta al registro de estado (no cambian a los operandos). Son muy útiles en las instrucciones de salto TEST realiza la operación lógica “Y” de dos operandos, pero NO afecta a ninguno de ellos, SÓLO afecta al registro de estado. Admite todos los tipos de direccionamiento excepto los dos operandos en memoria. TEST reg, reg Microprocesadores Ing. Carlos Ortega H.
CMP realiza la resta de los dos operandos (como la instrucción SUB) pero NO afecta a ninguno de ellos, SÓLO afecta al registro de estado. Admite todos lo modos de direccionamiento, excepto los dos operando en memoria. CMP reg,reg CMP reg,mem CMP mem,reg CMP reg,inmediato CMP mem,inmediato Instrucciones de comparación Microprocesadores Ing. Carlos Ortega H.
Instrucciones de desplazamiento y rotaciones Realizan operaciones de desplazamiento y rotaciones de bits, y son: SAL/SHL, SAR, SHR, ROL, ROR, RCL, RCR. SAL/SHL realiza desplazamiento a la izquierda del primer operando tantos bits como indique el segundo operando, introduciendo un 0 y guardando el bit que sale en el bit CF del registro de estado. SHR realiza el desplazamiento a la derecha del operando, introduciendo un 0 y guardando el resultado en el bit CF del registro de estado. SAR reg, 1 ó SHR reg,1; desplaza 1 vez el contenido de reg SAR reg, CL ó SAR reg, CL; desplaza tantas veces el contenido de reg como indique CL. Microprocesadores Ing. Carlos Ortega H.
Instrucciones de E/S Se usan para la comunicación con los dispositivos periféricos. Y son IN, OUT. IN lee de un puerto (sólo si la dirección del puerto es menor que 255). Admite las siguientes formas: IN AX, inmediato;obtiene un WORD del puerto especificado y lo guarda en AX IN AX, DX;obtiene un WORD del puerto especificado en DX y lo guarda en AX OUT escribe en un puerto (sólo si la dirección del puerto es menor que 255). Admite las siguientes formas: OUT inmediato, AX;escribe un WORD (contenido en AX) en el puerto especificado OUT DX, AX;escribe un WORD (contenido en AX) en el puerto especificado en DX. Microprocesadores Ing. Carlos Ortega H.
Instrucciones de control del programa Se utilizan para el control del programa, son instrucciones de salto, bucles y llamadas a procedimientos. Instrucciones de salto Estas instrucciones permiten saltar a otras partes del código. Todas cambian el registro IP(contador de programa) y el registro CS (segmento de código) si es un salto lejano. Un salto es lejano cuando la dirección a la que se salta no está en el mismo segmento de código. Existen dos tipos de saltos: los absolutos; en lo que se especifica la dirección absoluta a la que se salta; y los relativos; que son saltos hacia delante o hacia atrás desde el valor de IP. Microprocesadores Ing. Carlos Ortega H.
Instrucciones de Salto JMP realiza un salto incondicional a la dirección especificada. La siguiente tabla relaciona los tipos de saltos y los argumentos que puede tomar esta instrucción. Microprocesadores Ing. Carlos Ortega H.
Instrucciones de Salto Saltos condicionales estas instrucciones realizan el salto a la dirección especificada en función de si se cumple o no una condición. Para evaluar la condición se considera el registro de estado, esto quiere decir que la condición depende directamente de la instrucción anterior. Microprocesadores Ing. Carlos Ortega H.
También existen instrucciones que evalúan sólo un bit del registro de estado. Instrucciones de Salto Estos saltos son siempre relativos, es decir, una dirección de 8 ó 16 bits. Microprocesadores Ing. Carlos Ortega H.
Instrucción de llamada a procedimiento La instrucción CALL se usa para realizar una llamada a un procedimiento y la instrucción RET se usa para volver de un procedimiento. Cuando se realiza una llamada a procedimiento con CALL, se guardan en la pila el valor de IP en caso de un salto corto, y de CS e IP en caso de un salto lejano. Cuando se ejecuta la instrucción RET se recuperan de la pila los valores de IP o de CS e IP dependiendo del caso. Microprocesadores Ing. Carlos Ortega H.
Bucles Las instrucciones de bucle se usan para realizar estructuras repetitivas, y utilizan el registro CX como contador. LOOP salta a la dirección especificada (salto dentro del segmento), mientras que CX sea distinto de 0 y decrementa CX en 1 cada vez. LOOP salto LOOPNE/LOOPNZ esta instrucción salta a la dirección especificada mientras que CX sea distinto de 0 y si ZF = 0. LOOPNE/LOOPNZ salto LOOPE/LOOPZ esta instrucción actúa como la anterior pero la condición adicional es ZF = 1. LOOPE/LOOPZ salto JCXZ esta instrucción realiza un salto si CX = 0. JCXZ salto Ninguna de estas instrucciones afectan al registro de estado. Microprocesadores Ing. Carlos Ortega H.
Instrucciones de cadena de carácteres REP repite la instrucción a la que acompaña mientras que CX sea distinto de 0 (decrementa CX cada vez). Las instrucciones con las que se puede usar son MOVS, MOVDSW o STOS. MOVS destino, fuente REP MOVS destino, fuente REPE/REPZ repite la instrucción a la que acompaña mientras que CX sea distinto de 0 y ZF = 1 (decrementa CX cada vez). Las instrucciones con las que se puede usar son CMPS o SCAS. CMPS destino, fuente REPE/REPZ CMPS destino, fuente REPNE/REPNZ repite la instrucción a la que acompaña si CX es distinto de 0 y ZF = 0 (decrementa CX cada vez). Las instrucciones con las que se puede usar son CMPS o SCAS. REPNE/REPN CMPS destino, fuente Microprocesadores Ing. Carlos Ortega H.
MOVS/MOVSW copia un byte o un WORD de una parte a otra de la memoria. MOVS destino, fuente donde destino es ES:DI y fuente es DS:SI, lo que quiere decir que antes de utilizar la instrucción hay que cargar en SI y DI los valores apropiados. Ejemplo: REP LEA SI, fuente LEA DI, ES:destino MOV CX, 100 MOVS destino, fuente Esta instrucción no afecta al registro de estado. Instrucciones de cadena de carácteres Microprocesadores Ing. Carlos Ortega H.
CMPS realiza la comparación de dos cadenas, devuelve el resultado en el registro de estado. CMPS destino, fuente Hay que realizar los mismos pasos para usar esta instrucción que en el caso de la instrucción MOVS/MOVSB, la única diferencia es que el modificador que usa es REPE/REPZ o REPNE/REPNZ. Esta instrucción afecta a todos los bits del registro de estado. Instrucciones de cadena de carácteres Microprocesadores Ing. Carlos Ortega H.
Muchas Gracias por su Atención Microprocesadores Ing. Carlos Ortega H.