Apéndice: circuitos integrados E/S
|
|
|
- Pilar Villalobos Herrera
- hace 8 años
- Vistas:
Transcripción
1 Apéndice: circuitos integrados E/S Bibliografía: Hojas de datos (datasheets) de los circuitos integrados (disponibles en SWAD) 1
2 Apéndice: circuitos integrados E/S Interfaz de periféricos programable 8255 Controlador de interrupciones programable 8259 Interrupciones en el PC en modo real Controlador de DMA programable
3 Ejemplo de circuito integrado de interfaz paralela: 8255 Interfaz de periféricos programable 8255 (Programmable Peripheral Interface, PPI) Permite gestionar tres puertos de E/S de 8 bits. Se pueden seleccionar por software tres modos de funcionamiento: E/S programada sin validación: Modo 0: E/S básica (programada). E/S programada o por interrupciones con validación (handshaking). Modo 1: E/S con validación. Modo 2: E/S con bus bidireccional, validada. 3
4 Ejemplo de circuito integrado de interfaz paralela: 8255 Esquema general Permite gestionar 3 puertos de E/S de 8 bits. Búfer triestado de 8 bits bidireccional, usado como interfaz entre el 8255 y el bus de datos Los 3 puertos de 8 bits pueden configurarse por software para realizar varias funciones. Cada uno tiene características especiales. Gestiona todas las transferencias de datos y palabras de control y estado El puerto C puede convertirse en dos puertos de control de 4 bits 4
5 Ejemplo de circuito integrado de interfaz paralela: 8255 Asignación de patillas PA0, PA7: Puerto A de Entrada/Salida A0, A1: Seleccionan el puerto del que se va a leer o escribir PC0, PC7: Puerto C de Entrada/Salida PB0, PB7: Puerto B de Entrada/Salida 5
6 Ejemplo de circuito integrado de interfaz paralela: 8255 Asignación de patillas RD# (Read): =0 habilita al 8255 para que envíe la información de datos o de estado a la CPU a través del bus de datos CS# (Chip Select): =0 habilita la comunicación entre el 8255 y el procesador WR# (Write): =0 permite que la CPU escriba datos o palabras de control en el 8255 RESET: =1 borra el registro de control y pone los puertos en modo de entrada D0-D7: conexión al bus de datos 6
7 Ejemplo de circuito integrado de interfaz paralela: 8255 Palabra de control (bit 7 = 1) Se puede programar la configuración funcional de cada puerto escribiendo una palabra de control en el Puerto A: puede definirse como entrada o salida de 8 bits en los modos 0, 1 y 2. En el modo 2 funciona de forma bidireccional. Puerto B: puede definirse como entrada o salida de 8 bits en los modos 0 y 1. Puerto C: se divide en dos puertos de 4 bits que pueden definirse como entrada o salida en el modo 0. Para los modos 1 y 2 se divide en dos puertos de control de 4 bits para servicio de los puertos A o B. 7
8 Ejemplo de circuito integrado de interfaz paralela: 8255 Palabra de control (bit 7 = 0) Permite activar de forma individual cada bit del puerto C Es la única forma de escribir en C en los modos 1 y 2. 8
9 Ejemplo de circuito integrado de interfaz paralela: 8255 MODO 0 (E/S básica) No requiere handshaking, sino que los datos son simplemente leídos o escritos de un puerto. Cada puerto puede programarse independientemente como de entrada o de salida (el puerto C se programa como dos puertos independientes de 4 bits). Cada bit puede utilizarse para datos o para señales de control o de estado. 9
10 Ejemplo de circuito integrado de interfaz paralela: 8255 MODO 0 Según la aplicación deseada, cada puerto deberá declararse como entrada o como salida, escribiendo la oportuna palabra de control. 10
11 Ejemplo de circuito integrado de interfaz paralela: 8255 MODO 0 Temporización (entrada): 11
12 Ejemplo de circuito integrado de interfaz paralela: 8255 MODO 0 Temporización (salida): 12
13 Ejemplo de circuito integrado de interfaz paralela: 8255 MODO 1 (E/S validada) Puede utilizarse E/S en modo programado o por interrupciones. Se van a transferir datos usando señales de diálogo (handshaking) entre el 8255 y el periférico ( ojo!, no entre el 8255 y la CPU). El puerto A y el puerto B se pueden programar como entrada o como salida, y el puerto C se usa tanto para control de A y B como para E/S en modo 0. 13
14 Ejemplo de circuito integrado de interfaz paralela:
15 Ejemplo de circuito integrado de interfaz paralela: 8255 MODO 1 Es posible impedir o autorizar al 8255 interrumpir al procesador, poniendo a 0 ó 1 ciertas señales INTE (Interrupt Enable): Para escribir en el puerto C se puede usar una orden de escritura en ese puerto en el modo 0, o una orden de puesta/borrado de un bit en los tres modos. Ésta última orden también se usará para modificar los biestables INTE. 15
16 Ejemplo de circuito integrado de interfaz paralela: 8255 En una lectura del puerto C en los modos 1 y 2, el estado de las líneas de este puerto pasa al bus de datos, excepto las líneas ACK# y STB#, que son reemplazadas por INTE. 16
17 Ejemplo de circuito integrado de interfaz paralela: 8255 MODO 1 en entrada 1. Cuando el periférico tiene un dato para transmitir a la CPU, envía la señal STB#, que indica dato preparado, al El 8255 sube a 1 la señal IBF ( dato recibido ), y memoriza los datos de entrada (en modo 0 no se memorizan). 3. El flanco de subida de STB# pone a 1 la señal de petición de interrupción INTR, si está habilitada. Puede tener lugar una interrupción si además la línea está conectada a la CPU. 4. La señal de lectura generada por la CPU hace bajar las señales INTR e IBF. Se podría usar modo programado, no conectando INTR o desactivándola, y leyendo y comprobando los bits IBF hasta que estuvieran a 1, para después leer del puerto A o B. 17
18 Ejemplo de circuito integrado de interfaz paralela:
19 Ejemplo de circuito integrado de interfaz paralela: 8255 MODO 1 en salida 1. La escritura (WR#=0) de un dato en el puerto A o B hace que se active la señal OBF# para comunicar al perif. que la CPU ha puesto un dato en el 8255 listo para ser enviado a dicho perif. 2. Tras un tiempo más o menos largo que depende del periférico, éste activa la señal ACK# indicando dato aceptado. 3. Cuando el periférico pone de nuevo ACK# a 1, el 8255 activa la línea INTR si está habilitada. Puede tener lugar una interrupción si además la línea está conectada a la CPU. 4. La siguiente señal de escritura generada por la CPU hace bajar la señal INTR. Se podría usar modo programado para comprobar cuando el periférico ha leído el dato leyendo y comprobando los bits OBF# hasta que estuvieran a 1, para después escribir en el puerto A o B. 19
20 Ejemplo de circuito integrado de interfaz paralela:
21 Ejemplo de circuito integrado de interfaz paralela: 8255 MODO 2 (E/S validada con bus bidireccional) Está previsto para un intercambio bidireccional entre la interfaz y el periférico (transmitir y recibir). Es similar al modo 1 en lo que concierne a las señales de diálogo. Sólo el puerto A puede funcionar en modo 2. 21
22 Ejemplo de circuito integrado de interfaz paralela: 8255 MODO 2 En el modo 1 el 8255 escribía datos en el periférico en el flanco de subida de WR#. En el modo 2 el 8255 escribe datos en el periférico en el flanco de bajada de ACK#. El puerto A está en alta impedancia hacia el periférico cuando ACK# = 1. ACK# no indica dato aceptado sino perif. listo para recibir datos. Cualquier secuencia en la que WR# ocurra antes que ACK# y STB# ocurra antes que RD# es permisible. 22
23 Ejemplo de circuito integrado de interfaz paralela: 8255 Tabla comparativa de los modos 0, 1 y 2. 23
24 Ejemplo de circuito integrado de interfaz paralela: 8255 Combinación de modos El 8255 puede tener un puerto programado en cada modo. Ejemplos: 24
25 Ejemplo de circuito integrado de interfaz paralela: 8255 Interfaz de impresora: Interfaz de teclado y display: 25
26 Ejemplo de circuito integrado de interfaz paralela: 8255 Interfaz con conversores D/A y A/D: Interfaz de disquetera: 26
27 Ejemplo de circuito integrado de interfaz paralela: 8255 Ej. de operación de E/S programada usando el 8255 Control de una impresora (salida), y de un conmutador rotativo (entrada) que permite seleccionar entre 16 valores. Si BUSY = 1 la impresora está ocupada Un pulso negativo en DATASTROBE# carga el dato del puerto A en la impresora. 27
28 Ejemplo de circuito integrado de interfaz paralela: 8255 Ej. de operación de E/S programada usando el 8255 Programación del 8255: Palabra de control: MVI A, 8A OUT PPICTRL Hay que inicializar PC0 a 1: MVI A, 01 OUT PPICTRL 28
29 Ejemplo de circuito integrado de interfaz paralela: 8255 Ej. de operación de E/S programada usando el 8255 Impresión de un carácter (almacenado por ej, en M(1200)): BUCLE: IN PPIC ; A puerto C del 8255 ANI 80 ; Test de PC7 por enmascaramiento JNZ BUCLE ; Salto a BUCLE si BUSY = 1 LDA 1200 ; A dato almacenado en la... ;...dirección 1200 de memoria OUT PPIA ; puerto A del 8255 A MVI A, 00 ; Puesta a 0... OUT PPICTRL ;...de PC0 MVI A, 01 ; Puesta a 1... OUT PPICTRL ;...de PC0 Lectura del conmutador rotativo: IN PPIB ; A puerto B del 8255 STA 1201 ; almacenamiento en la... ;...dirección 1201 de memoria 29
30 Apéndice: circuitos integrados E/S Interfaz de periféricos programable 8255 Controlador de interrupciones programable 8259 Interrupciones en el PC en modo real Controlador de DMA programable
31 Ej. de circuito controlador de interrupciones: 8259 La mayoría de las familias de microprocesadores contienen circuitos especiales denominados controladores de interrupciones, que simplifican las diversas tareas de diseño (prioridades, enmascaramiento,...) asociadas con el control de las interrupciones externas, y permiten aumentar el número de líneas de petición de interrupción disponibles. 31
32 Ej. de circuito controlador de interrupciones: 8259 Programmable Interrupt Controller, PIC Permite manejar 8 líneas de interrupciones vectorizadas con prioridad. Compatible con las familias 8085 y Prioridades alterables por software. Permite enmascaramiento individual de cada línea. Es posible conectar 9 controladores para manejar hasta 64 niveles de interrupción. 32
33 Ej. de circuito controlador de interrupciones 8259 Esquema general Búfer triestado bidirec-cional de 8 bits, a través del cual se transfieren órdenes de control e información de estado Gestiona todas las transferencias IRR (Interrupt Request Register): niveles de interrupción que están solicitando servicio Almacena y compara la identificación de todos los 8259 conectados en cascada Determina las prioridades de los bits a 1 en el IRR. El que tenga mayor prioridad se selecciona y se lleva al bit correspondiente del ISR cuando la CPU acepta la interrupción ISR (In-Service Register): niveles de interrupción que están siendo servidos actualmente IMR (Interrupt Mask Register): inhabilita algunos niveles de interrupción a la salida de IRR 33
34 Ej. de circuito controlador de interrupciones 8259 Asignación de patillas CS#: a 0 habilita la comunicación entre 8259 y CPU WR#: a 0 habilita la escritura de órdenes de control desde la CPU RD#: a 0 habilita la lectura por parte de la CPU del estado de los registros IRR, ISR o IMR, o el nivel de interrupción (en modo polled ) D0-D7: conexión al bus de datos CAS0 - CAS2: Salidas cuando el 8259 es maestro (envían la identificación del 8259 al que le es aceptada una petición de interrupción). Entradas cuando es esclavo A0: junto con RD# y WR# selecciona el registro a leer/escribir INTA# (Interrupt Acknowledge): De la CPU al En forma de pulsos causa que el 8259 ponga información de vectorización en el bus de datos IR0, IR7: Peticiones de interrupción desde los periféricos INT: Del 8259 a la CPU para realizar una petición de interrupción SP#/EN# (Slave Progress / Enable Buffer) 34
35 Ej. de circuito controlador de interrupciones 8259 Conexión en cascada de varios 8259 El 8259 puede ser conectado en un sistema de un maestro con hasta 8 esclavos, para manejar hasta 64 niveles de prioridad. El maestro controla a los esclavos a través de las 3 líneas de cascada, que actúan como Chip Selects para los esclavos durante los pulsos INTA# (excepto el 1º) 35
36 Ej. de circuito controlador de interrupciones 8259 Cada 8259 debe seguir una secuencia de inicialización y puede programarse para trabajar en un modo diferente Las salidas INT de los esclavos se conectan a las entradas IR del maestro. Cuando una línea IRi se activa y después es reconocida, el maestro permite que el esclavo ponga en el bus de datos el vector de interrupción 36
37 Ej. de circuito controlador de interrupciones 8259 Secuencia de petición de interrupción para la CPU Una o más líneas IR0-IR7 se ponen a 1, activándose los correspondientes bits de IRR. 2.El 8259 evalúa estas peticiones y si es apropiado envía una petición de interrupción al 8085 por la patilla INT. 3.El 8085 reconoce la interrupción respondiendo con pulso INTA#. 4.Al recibir el INTA#, el 8259 pone a 1 el bit de ISR de mayor prioridad de entre los correspondientes a bits de IRR a 1. El correspondiente bit de IRR lo pone a 0. El 8259 envía el codop CALL ( ) por el bus de datos. Si la patilla IR atendida no sigue a 1 (petición demasiado breve) el 8259 envía una petición de nivel 7. 5.El 8085 envía otros dos pulsos INTA#. 6.El 8259 envía la dirección de la ISR a través del bus de datos (en el primer pulso envía el LSB y en el segundo el MSB). Si el modo es AEOI, el bit de mayor prioridad a 1 del ISR se pone a 0 al final del tercer pulso INTA#. Si no, el bit ISR permanece a 1 hasta que se envíe la orden EOI al 8259, normalmente al final de la rutina de servicio. 37
38 Ej. de circuito controlador de interrupciones 8259 Secuencia de petición de interrupción para la CPU Una o más líneas IR0-IR7 se ponen a 1, activándose los correspondientes bits de IRR. 2.El 8259 evalúa estas peticiones y si es apropiado envía una petición de interrupción al 8086 por la patilla INT. 3.El 8086 reconoce la interrupción respondiendo con pulso INTA#. 4.Al recibir el INTA#, el 8259 pone a 1 el bit de ISR de mayor prioridad de entre los correspondientes a bits de IRR a 1. El correspondiente bit de IRR lo pone a 0. El 8259 no envía nada en este ciclo por el bus de datos. Si la patilla IR atendida no sigue a 1 (petición demasiado breve) el 8259 envía una petición de nivel 7. 5.El 8086 envía otro pulso INTA#. 6.El 8259 envía un puntero de 8 bits a través del bus de datos (vector de interrupción). Si el modo es AEOI, el bit de mayor prioridad a 1 del ISR se pone a 0 al final del tercer pulso INTA#. Si no, el bit ISR permanece a 1 hasta que se envíe la orden EOI al 8259, normalmente al final de la rutina de servicio. 38
39 Ej. de circuito controlador de interrupciones 8259 Vectores enviados a la CPU (I) 39
40 8080, Ej. de circuito controlador de interrupciones 8259 Vectores enviados a la CPU (II) 40
41 Ej. de circuito controlador de interrupciones 8259 Programación del 8259 El 8259 acepta dos tipos de órdenes desde la CPU: De inicialización (Initialization Command Words, ICWs): Deben ser enviadas a cada 8259 antes de que comience el funcionamiento normal. De funcionamiento (Operation Command Words, OCWs): Hacen que el 8259 funcione en varios modos:» Completamente anidado» Con rotación de prioridad» Modo de máscara especial» Polled (por sondeo)... Las OCWs pueden escribirse en cualquier momento tras la inicialización. 41
42 Ej. de circuito controlador de interrupciones 8259 Secuencia de inicialización del 8259 Reset automático del circuito (se establecen valores por defecto) ICW1 e ICW2: Fijan vectores de interrupción y otras inicializaciones ICW3: Establece cómo están conectados 8259 esclavos a un 8259 maestro ICW4: Establece modos de funcionamiento 42
43 Ej. de circuito controlador de interrupciones 8259 Después de enviar las órdenes ICW, el 8259 queda programado por defecto en el modo completamente anidado. Modo completamente anidado (Fully Nested Mode) Las peticiones de interrupción están ordenadas desde 0 (IR0, la más prioritaria), hasta 7 (IR7, la menos prioritaria). Las prioridades no son alterables automáticamente (de ser necesario, podrían ser cambiadas por software). Mientras que un bit ISR esté a 1, sólo las líneas con mayor prioridad pueden interrumpir. Sólo serán reconocidas esas interrupciones si el biestable de habilitación de interrupciones del microprocesador ha sido rehabilitado por software (se haya ejecutado un EI / STI en la ISR). 43
44 Ej. de circuito controlador de interrupciones 8259 Órdenes de inicialización (ICW) ICW1 e ICW2 Establecen las direcciones de comienzo de las ISR (8080/8085) o los índices de la tabla de vectores de interrupción (8086). Informan al 8259 de si va a trabajar solo o en cascada. Establecen separación entre subrutinas (8080/8085) de 4/8 B. Establecen si las IRi se detectarán por flanco o por nivel. Indican al 8259 si se le va a enviar ICW4 o no. IRi debe quitarse antes de EOI para evitar que ocurra una segunda interrupción IRi puede seguir en alto sin generar nuevas interrupciones 44
45 Ej. de circuito controlador de interrupciones 8259 ICW3 Usada sólo cuando hay más de un 8259 (cascada) El formato de ICW3 es distinto para maestro y esclavo: MAESTRO (SP#/EN# = 1, o BUF=1&M/S=1 en ICW4) Un 1 en cada bit i tal que IRi esté conectado a un esclavo. ESCLAVO (SP#/EN# = 0, o BUF=1&M/S=0 en ICW4) Los bits 2-0 identificarán en adelante a ese esclavo. Cada vez que se produzca el primer INTA#, el esclavo los comparará con C2-C0 y si son iguales enviará el vector en los siguientes pulsos. 45
46 Ej. de circuito controlador de interrupciones 8259 ICW4 Establece si se van a usar los modos: Fin de interrupción automático Con buffers Completamente anidado especial Establece si se va a usar con un 8080/8085 o con un Si no se envía ICW4, todos los bits estarán a 0 (8080/8085, fin de interrupción normal, etc.) 46
47 Ej. de circuito controlador de interrupciones 8259 Tipos de fin de interrupción: El bit ISRi = 1 correspondiente a la instrucción que se está atendiendo puede ponerse a 0 de dos formas.» AEOI: automáticamente tras el flanco de subida del último pulso INTA#.» EOI normal: mediante una orden de fin de interrupción (EOI en OCW2). Modo con buffers: Hay sistemas con buffers en los buses, que deben ser habilitados para mandar información a través de ellos. En el modo con buffers, siempre que el 8259 saca datos al bus de datos, activa la señal SP#/EN#. Como la señal SP#/EN# ya no se puede usar para determinar si un 8259 es maestro o esclavo, esto se hará por software mediante el bit 2 de ICW4. 47
48 Ej. de circuito controlador de interrupciones Modo completamente anidado especial: Puede usarse en sistemas que trabajen en cascada, si se quiere conservar las prioridades dentro de cada esclavo. Es similar al modo completamente anidado normal, excepto:» En el modo completamente anidado normal, un esclavo queda enmascarado cuando su petición de interrupción está en servicio (no se pueden servir peticiones del mismo esclavo ni siquiera si son de más alta prioridad).» En el modo completamente anidado especial, el esclavo no queda bloqueado (las peticiones de mayor prioridad dentro del esclavo serán reconocidas por el maestro y generarán peticiones en el procesador). 48
49 Ej. de circuito controlador de interrupciones 8259 La ISR tiene que comprobar si la interrupción servida por ella fue la única desde ese esclavo. Para ello: 1. Envía una orden EOI al esclavo (OCW2). 2. Lee su registro ISR viendo si está a 0. Si es 0 tiene que mandar otro EOI al maestro. Si no es 0 no manda EOI al maestro. 49
50 Ej. de circuito controlador de interrupciones 8259 Órdenes de funcionamiento (OCW) OCW1 Pone a 1 ó a 0 cada bit del registro IMR. M i = 1 IRi enmascarada (inhabilitada) M i = 0 IRi habilitada 50
51 Ej. de circuito controlador de interrupciones 8259 OCW2 Los bits R, SL y EOI controlan varios modos de rotación de prioridad y de fin de interrupción. Los bits L 2, L 1, L 0 determinan el nivel de interrupción sobre el que se actúa cuando SL = 1. 51
52 Ej. de circuito controlador de interrupciones 8259 End Of Interrupt, fin de interrupción: En el modo normal de fin de interrupción (AEOI = 0 en ICW4), hay que enviar una orden EOI al 8259 antes de regresar de la ISR (o dos EOI, uno para el esclavo y otro para el maestro si se usa modo cascada). Hay dos tipos de órdenes EOI: EOI no específico (el caso normal). No hace falta decir qué interrupción ha terminado, pues será la más prioritaria de las que están siendo atendidas. El 8259 borra de su registro ISR el bit con mayor prioridad que esté puesto a 1. EOI específico (sólo se usa si se ha alterado la prioridad de interrupciones totalmente anidada). El 8259 no será capaz de determinar el último nivel de interrupción reconocido, por tanto hace falta mandar en L 2, L 1, L 0 el nivel de interrupción que se desea borrar del registro ISR. 52
53 Ej. de circuito controlador de interrupciones 8259 Automatic Rotation, rotación automática (si se desea que los dispositivos tengan igual prioridad): Tras ser servido, el dispositivo recibe la prioridad más baja. Cualquier dispositivo que está pidiendo interrupción espera como mucho el tiempo que tardan otros 7 dispositivos en ser atendidos una vez. Hay dos formas de llevar a cabo la rotación automática: Rotación al enviar una orden de EOI no específico. Rotación en el modo AEOI (se puede activar / desactivar). Ejemplo: Antes de rotar, IR4 tiene la prioridad más alta de las líneas en servicio Después de rotar (IR4 ha sido servida) 53
54 Ej. de circuito controlador de interrupciones 8259 Specific Rotation, rotación específica: El programador puede cambiar específicamente las prioridades decidiendo la línea con la prioridad más baja (el resto se fijará automáticamente). Ej.: Si IR5 se programa como la línea de menor prioridad, IR6 tendrá la mayor prioridad, luego IR7, luego IR0,... Hay dos formas de llevar a cabo la rotación específica: Rotación al enviar una orden de EOI específico. Orden set priority (fijar prioridad). 54
55 Ej. de circuito controlador de interrupciones 8259 OCW3 El bit ESMM permite activar/desactivar el modo máscara especial. El bit P permite escribir una orden poll (sondeo). El bit RR = 1 permite que los registros IRR e ISR sean leídos. 55
56 Ej. de circuito controlador de interrupciones 8259 Special Mask Mode, modo de máscara especial: Establece que todas las interrupciones puedan ser tratadas en el momento en que se produzcan sin tener en cuenta las prioridades, pero teniendo en cuenta los bits de máscara. Interrupciones de niveles más bajos que la que está siendo atendida pueden interrumpir a la CPU si no están enmascaradas. 56
57 Ej. de circuito controlador de interrupciones 8259 Poll command, orden de sondeo: El 8259 pasa a no generar interrupciones a la CPU. El 8259 tratará el siguiente pulso RD# como una aceptación de interrupción, fijará el bit ISR apropiado y escribirá en el bus de datos lo siguiente: 57
58 Ej. de circuito controlador de interrupciones 8259 Read Register command, lectura de IRR e ISR: Se envía una orden OCW3 con RR = 1. El siguiente pulso RD# transfiere a la CPU por el bus de datos el contenido de IRR (si RIS = 0) o el de ISR (si RIS = 1) (siempre con A0 = 0). (Para leer el IMR no se necesita una orden OCW3, basta con leer con A0 = 1) 58
59 Apéndice: circuitos integrados E/S Interfaz de periféricos programable 8255 Controlador de interrupciones programable 8259 Interrupciones en el PC en modo real Controlador de DMA programable
60 Interrupciones en el PC (modo real) Interrupciones vectorizadas: Existen 256 interrupciones posibles (0 a 255 = 0xFF), vectorizadas. Tabla de vectores de interrupción: primeros 1024 bytes de memoria (0 a 0x3FF). Cada vector de interrupción: doble palabra (32 bits, 4 bytes) dirección de la ISR asociada a esa interrupción Segmento (CS) Desplazamiento (IP) 60
61 Interrupciones en el PC (modo real) Interrupciones vectorizadas: Sólo unas pocas se generan por hardware (interna o externamente). si IF (Interrupt Flag) = 1, detienen temporalmente la ejecución del programa si IF = 0, el procesador ignora int. que llegan por la patilla INTR IF se borra con CLI/disable() y activa con STI/enable() Hay una interrupción no enmascarable especial que se reconoce siempre, independientemente de IF, cuando se activa la patilla NMI (Non Maskable Interrupt) Todas se pueden generar por software A través de las instrucciones INT e INTO En este caso no interrumpen realmente nada Son rutinas del SO que ejecutan tareas de E/S, gestión de ficheros, gestión de memoria, etc. 61
62 Interrupciones en el PC (modo real) Interrupciones vectorizadas: Cuando se produce una interrupción, el procesador: almacena el estado actual de la máquina introduciendo en la pila el registro de flags, el registro CS y el registro IP pone IF a 0 para evitar nuevas interrupciones multiplica por 4 el número de interrupción (que le llega por el bus de datos) para obtener la dirección de un vector de interrupción asigna a IP y CS el vector de interrupción se salta a la rutina que haya en esa dirección, que finalizará al ejecutar IRET 62
63 Interrupciones en el PC (modo real) Para gestionar las interrupciones hardware que provienen de la patilla INTR se dispone de dos 8259 (sólo uno en el PC/XT), con varios niveles de prioridad PC/XT AT 63
64 Interrupciones en el PC (modo real) ICW1 ICW2 ICW3 ICW4 0x20 0x21 0x21 0x21 OCW1 - IMR OCW2 OCW3 AT Leer IMR 0x21 0x20 0x20 0x21 ICW1 ICW2 ICW3 ICW4 0xA0 0xA1 0xA1 0xA1 OCW1 - IMR OCW2 OCW3 Leer IMR 0xA1 0xA0 0xA0 0xA1 64
65 Interrupciones en el PC (modo real) 8259 maestro IRQ0 IRQ1 IRQ2 IRQ3 IRQ4 IRQ5 IRQ6 IRQ esclavo IRQ8 IRQ9 IRQ10 IRQ11 IRQ12 IRQ13 IRQ14 IRQ15 PC COM1 COM2 Disco duro AT y post. temporizador teclado Bus - PC - reloj tiempo real - Bus ISA/PCI (tarjeta sonido) - Bus ISA/PCI - Bus ISA/PCI (ej. tarjeta video, NIC) - Bus ISA/PCI Ratón PS/2 Procesador matemático IDE1 IDE2 COM2 COM1 Normalmente LPT2 o tarjeta de sonido ISA Disquetera LPT1 Vector 0x08 0x09 0x0A 0x70 0x71 0x72 0x73 0x74 0x75 0x76 0x77 0x0B 0x0C 0x0D 0x0E 0x0F 65
66 Interrupciones en el PC (modo real) Ejemplo de ISR: ;rutina de interrupción ISR proc far sti ISR ; Si queremos que entren las... ;...interrupciones prioritarias push ax ; guardar AX push bx ; guardar otros regs. cambiados... pop bx ; recuperar otros regs. cambiados mov al,20h ; EOI out 20h,al ; OCW2 pop ax ; recuperar AX iret endp Se envía al 8259 maestro la orden de fin de interrupción antes del IRET (sólo para interrupciones provenientes del 8259) 66
67 Interrupciones en el PC (modo real) Pasos en la ejecución de una interrupción: SP SP 2 pila FLAGS IF, TF 0 SP SP 2 pila CS CS M[nº int. * 4 + 2] SP SP 2 pila IP IP M[nº int. * 4] (Ejecución de ISR) IP pila SP SP + 2 CS pila SP SP + 2 FLAGS pila SP SP + 2 Ejemplo 1: cómo afecta a la pila la ejecución de INT 1Ah 67
68 Interrupciones en el PC (modo real) Pasos en la ejecución de una interrupción: Ejemplo 2: ejecución de INT 4Ah 68
69 Interrupciones en el PC (modo real) Pasos en la ejecución de una interrupción: Ejemplo 3: camino seguido por INT 21h 69
70 Interrupciones en el PC (modo real) Modificación de una interrupción: Función 35h de INT 21h (getvect()) devuelve el valor actual de un vector Función 25h de INT 21h (setvect()) cambia el valor de un vector Ejemplo: modificación de la int. 16h para que se ejecute después de nuestro código 70
71 Apéndice: circuitos integrados E/S Interfaz de periféricos programable 8255 Controlador de interrupciones programable 8259 Interrupciones en el PC en modo real Controlador de DMA programable
72 Ejemplo de DMAC: 8237 Programmable DMA Controller 4 canales de DMA independientes: 72
73 Ejemplo de DMAC: 8237 Cada canal dispone de: un registro de direcciones de 16 bits: dir. a partir de la cual se comenzará a realizar la transfer. un contador de 16 bits: número de bytes a transmitir (65536 como máximo). Además existen otros registros para establecer las condiciones de trabajo de cada canal. 73
74 Ejemplo de DMAC: 8237 Funcionamiento del 8237: Ciclo inactivo: Cuando ningún canal está realizando una transferencia. El procesador puede escribir los registros de direcciones, contador de bytes, modos de trabajo y tipos de transferencia. Ciclo activo: Un periférico solicita una transferencia activando DREQi. El 8237 activa HRQ (pide los buses al procesador). El procesador pasa los buses a alta impedancia y activa HLDA. El 8237 activa DACKi permitiendo la transferencia al periférico. El 8237 genera IOR#, IOW#, MEMR# y MEMW#. El registro de direcciones se incrementa o decrementa para apuntar a la siguiente posición de memoria. El contador de bytes se decrementa. Si pasa de 0000 a FFFF se genera la señal EOP (End Of Process). El 8237 retira la señal HRQ. 74
75 Ejemplo de DMAC: 8237 Tipos de transferencia: Lectura: De memoria a periférico. Se activan MEMR# e IOW#. Escritura: De periférico a memoria. Se activan IOR# y MEMW#. Memoria a memoria: Se copian bytes desde un área de memoria, indicada por el registro de direcciones del canal 0, a otra área de memoria apuntada por el registro de direcciones del canal 1. 75
76 Ejemplo de DMAC: 8237 Modos de transferencia: Transferencia simple: Se transfiere un byte y se devuelve el control a la CPU. Contador--; si pasa de 0000 a FFFF se activa EOP. La línea DREQi debe mantenerse activa hasta que el 8237 responda con DACKi. Transferencia en bloques: Se transfieren tantos bytes, de forma consecutiva, como indique el contador. Cuando el contador pasa de 0000 a FFFF se genera EOP. La línea DREQi debe mantenerse activa hasta que el 8237 respnda con DACKi. Transferencia por demanda: No se tiene en cuenta el contador. Transferencia continua hasta que desaparezca la activación de DREQi, o hasta que se introduzca un nivel bajo por EOP. 76
77 Ejemplo de DMAC: 8237 Modo cascada: El canal correspondiente no actúa como un canal de transferencia propiamente dicho, sino que da paso a un segundo 8237, que es el que la realiza. Cada canal puede activar otro un 8237 puede activar a 4. Los otros 8237 podrían controlar a otros 8237 en cascada. 77
78 Ejemplo de DMAC: 8237 Otras opciones: Autoincremento / autodecremento: La transferencia puede seguir un curso ascendente (desde la dirección de memoria inicial a otras superiores) o descendente. Autoinicio: Cuando finaliza la transferencia de un bloque, se reponen los valores originales de dirección y contador, y se comienza de nuevo automáticamente. Prioridad fija: El canal 0 es el de mayor privilegio, el 3 el menos prioritario. Prioridad rotatoria: Cuando un canal termina una transferencia, pasa a tener el mínimo nivel de privilegio, y el siguiente canal, el máximo nivel. Nivel de activación (a 0 ó a 1): Es posible fijar cuáles son los niveles activos (0 ó 1) de las líneas DREQ y DACK. 78
79 Ejemplo de DMAC: 8237 Registros del 8237: 79
80 Ejemplo de DMAC: 8237 Direcciones de registros y órdenes: 80
81 Ejemplo de DMAC: 8237 Registros dirección (Address) y contador (Word Count): Base: valores iniciales Current: valores actuales Registro de estado (Status Register): Información sobre el estado de los canales. Registro de peticiones (Request Register): Permite comenzar operaciones de DMA por software. 81
82 Ejemplo de DMAC: 8237 Registro de órdenes (Command Register): Controla el funcionamiento del
83 Ejemplo de DMAC: 8237 Registros de modo (Mode Registers): Modo de transferencia de cada canal. 83
84 Ejemplo de DMAC: 8237 Registro de máscara (Mask Register): Permite deshabilitar (bit = 1) algunas líneas DREQi. 84
85 Ejemplo de DMAC: 8237 El 8237 en PC/XT y AT: PC/XT Refresco DRAM AT Libre Libre Disquetera Libre Libre Libre Libre Libre Disquetera HD 85
86 Ejemplo de DMAC: 8237 Generación de direcciones de DMA en PC/XT y AT: PC/XT (16 blq. de 64 KB) AT 8 bits (256 blq. de 64 KB) AT 16 bits (128 blq. de 128 KB) Transf. de palabras en direcc. pares Registro de página Registro de dirección del 8237 A19A18A17A16A15A14A13A12 A11A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 A0 A23A22A21A20A19A18A17A16A15A14A13A12 A11A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 A0 D7 D6 D5 D4 D3 D2 D1 D0 A23A22A21A20A19A18A17A16A15A14A13A12 A11A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 0 D7 D6 D5 D4 D3 D3 D2 D2 D1 D1 D0 86
87 Ejemplo de DMAC: 8237 Direcciones de puertos importantes: Registro dirección Registro contador Registro órdenes Registro máscara (set/reset 1 bit) Registro modo Borrar flip-flop byte-pointer Canal * 2 Canal * x08 0x0A 0x0B 0x0C Canal DMA Puerto E/S del registro de página 0x87 (sólo AT) En el XT, para el refresco, se usa el registro de página del canal 3 0x83 0x81 0x82 0x8B (sólo AT) 0x89 (sólo AT) 0x8A (sólo AT) 87
Controlador Programable de Interrupciones i8259
Controlador Programable de Interrupciones i8259 () Funciones Estructura externa (esquema de conexión) Estructura interna Secuencia de reconocimiento de una interrupción Conexión en cascada entre varios
MICROPROCESADORES I ELECTRONICA DIGITAL III INTERFASE PROGRAMABLE A PERIFERICOS PPI 8255
MICROPROCESADORES I ELECTRONICA DIGITAL III INTERFASE PROGRAMABLE A PERIFERICOS PPI 8255 INTRODUCCIÓN Este integrado de la firma INTEL, conocido como PPI 8255 (Programmable Peripherical Interfase) realizado
INTERRUPCIONES. Existen 256 interrupciones En el modo real cada una tiene un vector asociado Vectores de 4 bytes: segmento + offset 32 F0 50 8A
Tres tipos de interrupciones: Internas (TRAPS) Externas (HARDWARE) Software Existen 256 interrupciones En el modo real cada una tiene un vector asociado Vectores de 4 bytes: segmento + offset... 0000:0008
Velocidades Típicas de transferencia en Dispositivos I/O
Entradas Salidas Velocidades Típicas de transferencia en Dispositivos I/O Entradas/Salidas: Problemas Amplia variedad de periféricos Entrega de diferentes cantidades de datos Diferentes velocidades Variedad
Contenido TEMA 2 ENTRADA / SALIDA. Interfaz HW: buses del sistema. Interfaz HW de E/S
Contenido TEMA ENTRADA / SALIDA Sergio Romero Montiel Depto Arquitectura de Computadores El concepto de interfaz de E/S Direccionamiento de interfaces de E/S Mapa de memoria Organización Mapeada y no mapeada
Tema 4: SISTEMAS DE ENTRADA/SALIDA. Un computador no puede estar formado sólo por la CPU y la memoria.
Tema 4: SISTEMAS DE ENTRADA/SALIDA ÍNDICE 1. Introducción. 2. Módulos de Entrada/Salida: comunicación CPU - Periféricos. 3. Mapa de Entrada/Salida: común y separada. 4. Introducción a los métodos de programación
Entradas y Salidas. Componentes básicos de una PC
Entradas y Salidas a) Con periféricos de mediana velocidad conviene trabajar por FLAG (control por programa). b) Con periféricos rápidos utilizando el esquema de la línea READY. c) Con periféricos de Actuación
Introducción a los sistemas de entrada/salida Profesores y tutorías
Introducción a los sistemas de entrada/salida Profesores y tutorías Teoría: Daniel Cascado Caballero Despacho: F070 Horario de tutorías: Lunes: 17:30h a 19:30h Martes: 12:30h a 13:30h Jueves: 10:30h a
Tema 7: Sistemas de Entrada/Salida
Tema 7: Sistemas de Entrada/Salida Bibliografía Comunicación CPU-Periféricos Ejemplos de periféricos Unidad de disco Puerto serie Monitor Sistema de adquisición de datos Problemática de la Entrada/Salida:
Manejo de Entrada-Salida. Arquitectura de Computadoras
Manejo de Entrada-Salida Arquitectura de Computadoras Agenda 1.2.3.1Módulos de entrada/salida. 1.2.3.2Entrada/salida programada. 1.2.3.3Entrada/salida mediante interrupciones. 1.2.3.4Acceso directo a memoria.
Controlador de Interrupciones (Versión programable) Manual de Usuario
Controlador de Interrupciones (Versión programable) Manual de Usuario Índice de contenido 1. Características...2 2.Descripción general...3 3.Descripción funcional...3 4.Estructura Interna...4 4.1 Bloque
Manejo de Entrada-Salida. Arquitectura de Computadoras
Manejo de Entrada-Salida Arquitectura de Computadoras Agenda 1.2.3.1Módulos de entrada/salida. 1.2.3.2Entrada/salida programada. 1.2.3.3Entrada/salida mediante interrupciones. 1.2.3.4Acceso directo a memoria.
Guía rápida para gestionar el puerto paralelo del PC
Guía rápida para gestionar el puerto paralelo del PC Descarga desde: http://eii.unex.es/profesores/jisuarez/descargas/ip/guia_rapida_pp.pdf José Ignacio Suárez Marcelo Universidad de Extremadura Escuela
SUBSISTEMA DE ENTRADA-SALIDA. Arquitectura de Computadores I 4º tema
SUBSISTEMA DE ENTRADA-SALIDA Arquitectura de Computadores I 4º tema 1 Descripción de la interfaz de E/S Objetivo - Cómo se comunica la CPU con el exterior (periféricos de E/S) - Cómo se controla esta comunicación.
Estructura de Computadores. Contenido. Sistema de E/S. 7.- E/S y dispositivos periféricos
Estructura de Computadores 7.- E/S y dispositivos periféricos Contenido Clasificación y tipos de periféricos Módulos de E/S. Instrucciones de E/S. Técnicas de E/S. E/S programada. E/S mediante interrupciones.
CICLOS DEL PROCESADOR
UNIDAD DE CONTROL CICLOS DEL PROCESADOR Qué es un ciclo de búsqueda? Para qué sirve estudiar los ciclos de instrucción de una CPU? Para comprender el funcionamiento de la ejecución de instrucciones del
ESTRUCTURA FÍSICA DEL µp 8086
Características generales: Procesador de 16 bits Bus de direcciones de 20 bits : 1 Mbyte Bus de datos interno de 16 bits Bus de datos externo de 16 bits en el 8086 8 bits en el 8088 89 instrucciones Alimentación
APUNTE DEL 8155 ELECTRÓNICA DIGITAL III
APUNTE DEL 8155 ELECTRÓNICA DIGITAL III Revisión 1.1 Marzo, 2011 Interfaz a periférico 8155 Descripción general El chip 8155 es un dispositivo introducido por Intel en 1977. Contiene memoria RAM (SRAM)
VOCABULARIO DEL HARDWARE. Docente Yeni Ávila
VOCABULARIO DEL HARDWARE Docente Yeni Ávila HARDWARE El Hardware Básico: son las piezas fundamentales e imprescindibles para que la computadora funcione como son: Placa base, monitor, teclado y ratón.
6. Entrada y Salida Explicación de la interfaz entre el computador y el mundo exterior.
6. Entrada y Salida Explicación de la interfaz entre el computador y el mundo exterior. 6.1. El subsistema de E/S Qué es E/S en un sistema computador? Aspectos en el diseño del subsistema de E/S: localización
SISTEMAS BASADOS EN MICROPROCESADORES
SISTEMAS BASADOS EN MICROPROCESADORES Grado en Ingeniería Informática Escuela Politécnica Superior UAM COLECCIÓN DE PROBLEMAS DE LOS TEMAS 5.5 A 7.2 P1. Escribir una rutina de ensamblador que se quede
Arquitectura (Procesador familia 80 x 86 )
Arquitectura (Procesador familia 80 x 86 ) Diseño de operación Basada en la arquitectura Von Newman Memoria CPU asignadas direcciones I / O BUS: Es un canal de comunicaciones Bus de direcciones: Contiene
Mapas de Memoria y E/S
Mapas de Memoria y E/S Sistemas con Microprocesadores http://www.herrera.unt.edu.ar/procesadores Conexiones internas del CPU08 Dentro del mc el CPU08 se vincula con memoria y con los dispositivos de E/S
ITT-327-T Microprocesadores
ITT-327-T Microprocesadores Temporizador Programable (PIT) 8254. Temporizador/Contador Programable (PIT) 8254. Es un contador/temporizador programable diseñado para trabajar con los sistemas de microcomputadores.
Estructura del Computador
Estructura del Computador 1 definiciones preliminares Estructura: es la forma en que los componentes están interrelacionados Función: la operación de cada componente individual como parte de la estructura.
Arquitectura de computadoras
Arquitectura de computadoras Técnicas Digitales III Ing. Gustavo Nudelman 2013 Que entendemos por arquitectura Un sistema con una CPU, memoria y dispositivos de entrada y salida puede considerarse un sistema
Sist s em e a m s s O per e ativos o. s Unidad V Entrada Sali l d i a.
Sistemas Operativos. Unidad V Entrada Salida. Programación de Entrada y Salida Introducción. Comunicación de los procesos con el mundo externo : Mecanismo de E/S de información. Aspectos que diferencian
Introducción a la Entrada/Salida
Introducción a la Entrada/Salida Organización de entrada/salida La familia de procesadores 80x86, presente en el IBM PC, utiliza la arquitectura Von Neumann, que puede verse en la figura 1. El denominado
SISTEMAS OPERATIVOS Arquitectura de computadores
SISTEMAS OPERATIVOS Arquitectura de computadores Erwin Meza Vega [email protected] Esta presentación tiene por objetivo mostrar los conceptos generales de la arquitectura de los computadores, necesarios
UNIDAD 3 ARQUITECTURA DEL Z80. Microprocesadores Otoño 2011
1 UNIDAD 3 ARQUITECTURA DEL Z80 Microprocesadores Otoño 2011 Contenido 2 Arquitectura interna del Z-80 Interface Ciclos de máquina y temporización del bus de comunicación. Conjunto de Instrucciones Arquitectura
MICROCONTROLADORES PIC
MICROCONTROLADORES PIC LOS TIMER DE LOS 16F87x TEMA EL TIMER 1 CCFF D.P.E. MÓDULO DE PROYECTOS 1 Diagrama de Bloques del TIMER1 CCFF D.P.E. MÓDULO DE PROYECTOS 2 INTRODUCCIÓN El módulo TIMER1 es un temporizador/contador
PROBLEMAS TEMA 3: Unidad de Entrada/Salida
PROBLEMAS TEMA 3: Unidad de Entrada/Salida Problemas propuestos en examen 3.1 Un computador dispone de un canal multiplexor que controla 2 unidades de disco y 2 unidades de cinta. Las unidades de disco
(7) Unidad 7. Buses básicos de la arquitectura 80x86 SISTEMAS BASADOS EN MICROPROCESADORES. Grado en Ingeniería Informática EPS - UAM
Unidad 7 Buses básicos de la arquitectura 80x86 SISTEMAS BASADOS EN MICROPROCESADORES Grado en Ingeniería Informática EPS - UAM Índice 7. Buses básicos de la arquitectura 80x86. 7.1. La importancia de
28/09/2012. Interfaz con Dispositivos de Salida. Interfaz con Dispositivos de Entrada. Port Mapped. Memory mapped. Interfaz con Dispositivos I/O
Interfaz con Dispositivos I/O Interfaz con Dispositivos de Salida y Salida Unidad 4, Segunda Parte Port Mapped Memory mapped 1 2 Ejecución de la Instrucción OUT Ejecución de la instrucción OUT Dirección
TEMA 1: Concepto de ordenador
TEMA 1: Concepto de ordenador 1.1 Introducción Los ordenadores necesitan para su funcionamiento programas. Sin un programa un ordenador es completamente inútil. Para escribir estos programas necesitamos
Entrada/Salida. Polling e Interrupciones. Verano de 2011. Mariano Moscato. Organización del Computador 1
Entrada/Salida Polling e Interrupciones Mariano Moscato Organización del Computador 1 Verano de 2011 El GuidoBot Robot docente Basado en tecnología ORGA1 tiene un procesador y una memoria ORGA1 Sus dispositivos
Tema 3 SUBRUTINAS. Estructura de Computadores OCW_2015 Nekane Azkona Estefanía
Tema 3 SUBRUTINAS ÍNDICE Definición e instrucciones básicas Soporte para el tratamiento de subrutinas (ejecución de la subrutina y gestión del bloque de activación) Interrupciones vs llamadas a procedimiento
INDICE Programa Entrada Unidad de control Unidad aritmética y lógica (ALU)
INDICE Capitulo 1. Qué es un computador? 1.1. Introducción 1 1.2. El computador como dispositivo electrónico 2 1.3. Cómo se procesa la información? 3 1.4.Diagrama de bloques de un computador 1.4.1. Información
Sistema electrónico digital (binario) que procesa datos siguiendo unas instrucciones almacenadas en su memoria
1.2. Jerarquía de niveles de un computador Qué es un computador? Sistema electrónico digital (binario) que procesa datos siguiendo unas instrucciones almacenadas en su memoria Es un sistema tan complejo
Arquitectura de Computadores. Apellidos, Nombre:
No se considerarán como válidas las respuestas en las que no se justifiquen los cálculos realizados No se permite el uso de ningún tipo de documentación, ni de calculadora Sólo existe una única opción
Funcionamiento del 8086/8088
En este capítulo se ofrece una pequeña descripción del funcionamiento de un 8086/8088. En concreto, se explica cómo está organizada la memoria, como se ejecuta un programa y cómo se manejan las interrupciones.
2º CURSO INGENIERÍA TÉCNICA EN INFORMÁTICA DE GESTIÓN TEMA 5 ENTRADA/SALIDA. JOSÉ GARCÍA RODRÍGUEZ JOSÉ ANTONIO SERRA PÉREZ Tema 5.
ARQUITECTURAS DE COMPUTADORES 2º CURSO INGENIERÍA TÉCNICA EN INFORMÁTICA DE GESTIÓN TEMA 5 ENTRADA/SALIDA JOSÉ GARCÍA RODRÍGUEZ JOSÉ ANTONIO SERRA PÉREZ Tema 5. Unidad de E/S 1 Unidad de E/S Indice Introducción.
1-Componentes Físicos y Lógicos de un Ordenador.
1-Componentes Físicos y Lógicos de un Ordenador. En este capítulo trataremos de explicar el conjunto de elementos por lo que está compuesto un ordenador. A grandes rasgos un Ordenador Personal o PC ( Personal
TEMA III - Interrupciones en Sistemas en Tiempo Real
1 TEMA III - Interrupciones en Sistemas en Tiempo Real 3.1. Introducción Definición. Objetivo. Mecanismo básico. Ejemplo. Muestreo o polling. 3.2. Interrupciones Simples Componentes. Mecanismo. Ejemplo.
Conceptos de Arquitectura de Computadoras Curso 2015
PRACTICA 1 Assembly, Instrucciones, Programas, Subrutinas y Simulador MSX88 Objetivos: que el alumno Domine las instrucciones básicas del lenguaje assembly del MSX88. Utilice los diferentes modos de direccionamiento.
Introducción a la arquitectura de computadores
Introducción a la arquitectura de computadores Departamento de Arquitectura de Computadores Arquitectura de computadores Se refiere a los atributos visibles por el programador que trabaja en lenguaje máquina
Funcionamiento de la Pila (o stack)
Funcionamiento de la Pila (o stack) Todo μp cuenta con una memoria de almacenamiento temporal denominada Pila Es una estructura de datos de tipo secuencial (LIFO) Existen dos operaciones básicas posibles:
INTRODUCCIÓN. Interrupciones.
Interrupciones. INTRODUCCIÓN Una interrupción es la ocurrencia de un evento o condición la cuál causa una suspensión temporal del programa mientras la condición es atendida por otro subprograma. Una interrupción
Práctica 3: El teclado del PC
Práctica 3: El teclado del PC Gustavo Romero López Arquitectura y Tecnología de Computadores 7 de junio de 2016 Gustavo Romero López Práctica 3: El teclado del PC 1 / 11 Objetivos Objetivos: Fuentes: Recordar
Tema: Microprocesadores
Universidad Nacional de Ingeniería Arquitectura de Maquinas I Unidad I: Introducción a los Microprocesadores y Microcontroladores. Tema: Microprocesadores Arq. de Computadora I Ing. Carlos Ortega H. 1
Ensamblador. Interrupciones. Dentro de una computadora existen dos clases de interrupciones:
Ensamblador Interrupciones Definición: Una interrupción es el rompimiento en la secuencia de un programa para ejecutar un programa especial llamando una rutina de servicio cuya característica principal
Lenguaje binario. Código ASCII. Medidas de la información
Hardware y Software (1/5) Lenguaje binario Los ordenadores sólo entienden 1 y 0. Lógica positiva: 0: no hay señal 1: hay señal Código ASCII Medidas de la información Unidad mínima de información: BIT (0
Tutoría 2. Banco de memoria de 8 y 16 bits (8086)
Tutoría 2. Banco de memoria de 8 y 16 bits (8086) RESUMEN Cuando el procesador opera en modo mínimo, éste genera las señales de control para la memoria y los dispositivos de E/S. [1, pág. 292]. Para utilizar
PicController. Manual de usuario. Raquel Sánchez Díaz
PicController Manual de usuario Raquel Sánchez Díaz Tabla de Contenidos 1. INTRODUCCIÓN...1 2. DESCRIPCIÓN DE LA VENTANA PRINCIPAL...1 2.1. MENÚ CONFIGURACIÓN...2 2.2. MENÚ PUERTO SERIE...2 2.3. MENÚ
Institución Educativa Distrital Madre Laura Tecnología e Inform ática GRADO 7
LA TORRE O GABINETE DEL COMPUTADOR Es el lugar donde se ubican los dispositivos encargados del procesamiento, almacenamiento y transferencia de información en el computador. Dentro del gabinete o torre
0-31 : caracteres de control : carac. Comunes : especiales (flechas, símbolos) y particulares (ñ)
Hardware y Software (1/6) Lenguaje binario Los ordenadores sólo entienden 1 y 0. Lógica positiva: 0: no hay señal 1: hay señal Código ASCII American Standard Code for Information Interchange Carácter =
Gestión de Entrada-salida
Gestión de Entrada-salida E. Campo M. Knoblauch Ó. López J. Clemente Departamento de Automática Universidad de Alcalá Sistemas Operativos Avanzados Gestión de Entrada-salida 1 / 18 Índice Introducción
Características de los Canales de E/S
Canales Los dispositivos son cada vez más sofisticados Ej: tarjetas gráficas 3D. Evolución: 1. La CPU controla directamente los periféricos. 2. Se agrega un módulo o controlador. 3. Idem 2 más llamado
ESTRUCTURA BÁSICA DE UN ORDENADOR
ESTRUCTURA BÁSICA DE UN ORDENADOR QUÉ ES UN ORDENADOR? Un ordenador es una máquina... QUÉ ES UN ORDENADOR? Un ordenador es una máquina... QUÉ ES UN ORDENADOR? Un ordenador es una máquina... Qué son los
2.2-1 Visión Interna PIC16F873/876. SBM
2.2-1 Visión Interna PIC16F873/876. 1 2.2-2 Visión Interna PIC16F874/877. 2 2.2-3 Sistema de memoria. Tienen arquitectura Harvard, separa la memoria de datos y la memoria de programa, y se accede a ellas
Tema: MAPAS DE MEMORIA: LÓGICA DE SELECCIÓN, GESTIÓN Y ORDENACIÓN DE LA MEMORIA. J. Luis Lázaro, J. Jesús García "MAPA DE MEMORIA" 0
Tema: MAPAS DE MEMORIA: LÓGICA DE SELECCIÓN, GESTIÓN Y ORDENACIÓN DE LA MEMORIA J. Luis Lázaro, J. Jesús García "MAPA DE MEMORIA" 0 MAPA DE MEMORIA Mapa de memoria Memoria que es capaz de direccionar un
AUTOMATIZACIÓN INDUSTRIAL
Departamento de Ingenieria de Sistemas y Automática AUTOMATIZACIÓN INDUSTRIAL 1 AUTOMATIZACION INDUSTRIAL 2 AUTOMATIZACION INDUSTRIAL 3 AUTOMATAS PROGRAMABLES Surgen de la necesidad de controlar automáticamente
1.2.- EL MICROPROCESADOR.
1.2.- EL MICROPROCESADOR. El microprocesador es un circuito integrado que contiene algunos o todos los elementos necesarios para conformar una (o más) unidad central de procesamiento UCP, también conocido
1. DATOS e INFORMACIÓN.
TEMA 1 HARDWARE 1. DATOS e INFORMACIÓN. Datos (en informática): Información codificada, lista para ser introducida y procesada por un ordenador. Carecen de significado y sólo lo alcanzan cuando son descodificados
TEMA 8. REGISTROS Y CONTADORES.
TEMA 8. REGISTROS Y CONTADORES. TECNOLOGÍA DE COMPUTADORES. CURSO 2007/08 8.1. Registros. Tipos de registros. Registros de desplazamiento. Los registros son circuitos secuenciales capaces de almacenar
TEMA 3. CONCEPTOS FUNDAMENTALES DEL NIVEL DEL SISTEMA OPERATIVO. Definición y objetivos de un S.O
TEMA 3. CONCEPTOS FUNDAMENTALES DEL NIVEL DEL SISTEMA OPERATIVO Definición y objetivos de un S.O Definición y objetivos del sistema operativo Estructura, componentes y servicios de un S.O Llamadas al sistema
Práctica 5MODBUS: Bus Modbus
Práctica 5MODBUS: Bus Modbus 1 Objetivos El objetivo de esta práctica es la utilización y la programación de una red Modbus. El alumno debe ser capaz de: Diferenciar los tres niveles fundamentales de la
Estructura de un Ordenador
Estructura de un Ordenador 1. Unidad Central de Proceso (CPU) 2. Memoria Principal 3. El Bus: La comunicación entre las distintas unidades 4. La unión de todos los elementos: la placa Base Estructura de
EL ORDENADOR A. PERIFÉRICOS. B. UNIDAD CENTRAL. 1. HARDWARE Y SOFTWARE. 2. FUNCIONAMIENTO DE UN SISTEMA INFORMÁTICO 3. CONCEPTO DE SISTEMA INFORMÁTICO
EL ORDENADOR 1. HARDWARE Y SOFTWARE. 2. FUNCIONAMIENTO DE UN SISTEMA INFORMÁTICO 3. CONCEPTO DE SISTEMA INFORMÁTICO 4. PARTES DE UN SISTEMA INFORMÁTICO A. PERIFÉRICOS. B. UNIDAD CENTRAL. a) CARCASA b)
Tema 9 Periféricos de Entrada
Tema 9 Periféricos de Entrada Periféricos e Interfaces Tema 9/1 Contenido TECLADOS DISPOSITIVOS APUNTADORES DIGITALIZADORES Teclados Tecnología y Tipos Estructura Funcionalidad Interfaz al computador:
4. Escribe con palabras lo que significan las siguientes letras y di cuántos bytes hay aproximadamente: a) 1 Gb? b) 1 Mb? C) 1 Kb?
1. Qué es un bit? 2. Qué valores puede tener un bit? 3. Cuántos bits hay en 1 byte? 4. Escribe con palabras lo que significan las siguientes letras y di cuántos bytes hay aproximadamente: a) 1 Gb? b) 1
MEMORIA EJERCICIO 1 EJERCICIO 2
MEMORIA EJERCICIO 1 Determinar el mapa de memoria de un procesador con 16 señales de bus de direcciones, una señal de asentimiento de bus de direcciones AS, una señal de lectura R, otra de escritura W
INDICE Control de dispositivos específicos Diseño asistido por computadora Simulación Cálculos científicos
INDICE Parte I. La computadora digital: organización, operaciones, periféricos, lenguajes y sistemas operativos 1 Capitulo 1. La computadora digital 1.1. Introducción 3 1.2. Aplicaciones de las computadoras
SOPORTE FÍSICO O HARDWARE (I)
SOPORTE FÍSICO O HARDWARE (I) 4.1. DISTINCIÓN ENTRE SOPORTE TÉCNICO Y SOPORTE LÓGICO 4.2. ESQUEMA DE LA ORGANIZACIÓN FÍSICA DEL ORDENADOR 4.3. LA PLACA BASE 4.4. EL MICROPROCESADOR 4.5. LA 4.6. LOS BUSES
Introducción a la Computación. Capítulo 10 Repertorio de instrucciones: Características y Funciones
Introducción a la Computación Capítulo 10 Repertorio de instrucciones: Características y Funciones Que es un set de instrucciones? La colección completa de instrucciones que interpreta una CPU Código máquina
AUTOMATIZACION. Reconocer la arquitectura y características de un PLC Diferenciar los tipos de entradas y salidas MARCO TEORICO. Estructura Interna
AUTOMATIZACION GUIA DE TRABAJO 3 DOCENTE: VICTOR HUGO BERNAL UNIDAD No. 3 OBJETIVO GENERAL Realizar una introducción a los controladores lógicos programables OBJETIVOS ESPECIFICOS: Reconocer la arquitectura
PCF8574 EXPANSOR REMOTO 8-BIT I/O PARA I²C-BUS
PCF8574 EXPANSOR REMOTO 8-BIT I/O PARA I²C-BUS 1. CARACTERISTCAS Suministro de voltaje de funcionamiento 2.5 a 6 V Bajo consumo de corriente de espera (standby) de 10 ma máximo. Expansor I²C a puerto paralelo.
Arquitectura de Computadores II Clase #3
Clase #3 Facultad de Ingeniería Universidad de la República Instituto de Computación Curso 2010 Veremos Registros Repertorio de instrucciones Modos de direccionamiento El stack Formatos de datos Control
Qué es un programa informático?
Qué es un programa informático? Un programa informático es una serie de comandos ejecutados por el equipo. Sin embargo, el equipo sólo es capaz de procesar elementos binarios, es decir, una serie de 0s
CONTADORES CARACTERISTICAS IMPORTANTES UTILIDAD CONTADORES DE RIZADO. CONTADOR DE RIZADO MODULO- 16.
CONTADORES Son circuitos digitales lógicos secuenciales de salida binaria o cuenta binaria, caracteristica de temporizacion y de memoria, por lo cual están constituidos a base de flip-flops. CARACTERISTICAS
PRINCIPALES COMPONENTES DE LA PLACA MADRE NAYAT C. BENSALEM MEDINA LUCAS BALDÁN MANZANO HELENA MEDINA SÁNCHEZ 2º BACHILLERATO B
PRINCIPALES COMPONENTES DE LA PLACA MADRE NAYAT C. BENSALEM MEDINA LUCAS BALDÁN MANZANO HELENA MEDINA SÁNCHEZ 2º BACHILLERATO B ÍNDICE GENERAL 1. Qué es la placa madre 2. Imágenes tomadas en el aula 2.1.
PREGUNTAS INFORMÁTICA MONITOR UPB EXAMEN 1
PREGUNTAS INFORMÁTICA MONITOR UPB EXAMEN 1 1. Cuál de los siguientes componentes no forma parte del esquema general de un ordenador? A Memoria Principal B Disco Duro C Unidad de Control D Unidad Aritmético
Estructura de Microprocesadores. Profesor Ing. Johan Carvajal Godínez
Estructura de Microprocesadores PIC 18F4550 Administración de la memoria Profesor Ing. Johan Carvajal Godínez Contenidos Organización de la memoria del MCU Administración de la memoria de programa (Flash)
CONTROL DE UN VENTILADOR POR PUERTO PARALELO
CONTROL DE UN VENTILADOR POR PUERTO PARALELO En este articulo se dará una reseña de las características del puerto paralelo de una computadora personal, así como el control de un pequeño ventilador de
Práctica 2. Control de velocidad mediante el autómata CP1L y el variador MX2 de Omron
Sistemas de Control Automático Práctica 2. Control de velocidad mediante el autómata CP1L y el variador MX2 de Omron Jorge Pomares Baeza Grupo de Innovación Educativa en Automática 2011 GITE IEA - 1 -
Ensamblador. Introducción. Dpto. Física y Arquitectura de Computadores. Universidad Miguel Hernandez
Dpto. Física y Arquitectura de Computadores Universidad Miguel Hernandez Es el lenguaje de más bajo nivel que admite una máquina. El ensamblador hace que el código binario(máquina sea transparente al usuario)
CÓMO FUNCIONA UN PLC Control Combinacional Programación del PLC
CÓMO FUNCIONA UN PLC Control Combinacional Programación del PLC PROGRAMACIÓN DE PLC Procedimiento para programar y cargar: Determinar los requisitos del sistema al cual se aplica el PLC. Identificar los
2º Cuatrimestre MÓDULO 12: Introducción al Subsistema de Entrada/Salida. fc 2
2º Cuatrimestre 2012 2013 MÓDULO 12: Introducción al Subsistema de Entrada/Salida 1 CPU MEMORIA El código/datos de una aplicación debe estar en memoria pero cómo llega allí? Dónde está almacenado el fichero
INSTITUTO POLITÉCNICO NACIONAL ESCUELA SUPERIOR DE INGENIERIA MECANICA Y ELECTRICA INGENIERIA EN COMUNICACIONES Y ELECTRÓNICA ACADEMIA DE COMPUTACIÓN
INSTITUTO POLITÉCNICO NACIONAL ESCUELA SUPERIOR DE INGENIERIA MECANICA Y ELECTRICA UNIDAD CULHUACAN INGENIERIA EN COMUNICACIONES Y ELECTRÓNICA ACADEMIA DE COMPUTACIÓN LABORATORIO DE CIRCUITOS DIGITALES
SISTEMAS ELECTRÓNICOS DIGITALES
SISTEMAS ELECTRÓNICOS DIGITALES PRÁCTICA 6 SISTEMA DE ENCRIPTACIÓN 1. Objetivos - Estudio del funcionamiento de memorias RAM y CAM. - Estudio de métodos de encriptación y compresión de datos. 2. Enunciado
(1) Unidad 1. Sistemas Digitales Basados en Microprocesador SISTEMAS BASADOS EN MICROPROCESADORES. Grado en Ingeniería Informática EPS - UAM
Unidad 1 Sistemas Digitales Basados en Microprocesador SISTEMAS BASADOS EN MICROPROCESADORES Grado en Ingeniería Informática EPS - UAM Índice 1. Sistemas digitales basados en microprocesador. 1.1. Arquitectura
Computadora y Sistema Operativo
Computadora y Sistema Operativo Según la RAE (Real Academia de la lengua española), una computadora es una máquina electrónica, analógica o digital, dotada de una memoria de gran capacidad y de métodos
Arquitectura de Computadores
Arquitectura de Computadores 5. Sistemas de Entrada/Salida 1. Estructura de un Sistema de E/S 2. Métodos de E/S 3. E/S por sondeo (polling) 4. E/S por interrupciones 5. E/S por Acceso Directo a Memoria
Registros de desplazamiento
Registros de desplazamiento Definición de registro de desplazamiento básico Tipos de registro de desplazamiento Configuraciones específicas Aplicaciones más típicas VHDL Ejercicio propuestos Definición
PROCESADORES. Existen 3 tipos de procesadores: DE GALLETA, DE PINES Y DE CONTACTO. DE GALLETA: se utilizaban en las board en los años 80 y 90.
PROCESADORES TIPOS DE PROCESADORES. Existen 3 tipos de procesadores: DE GALLETA, DE PINES Y DE CONTACTO DE GALLETA: se utilizaban en las board en los años 80 y 90. DE PINES: reemplazaron los procesadores
El microprocesador de 8 bits Z80
INTRODUCCIÓN El microprocesador de 8 bits Z80 El Z80 es un microprocesador de la empresa Zilog Inc., que surgió de personas que desarrollaron el 8080 en INTEL, por lo que mantiene cierta compatibilidad
SELECCIÓN DE COMPONENTES PARA ENSAMBLE DE EQUIPOS DE COMPUTO. Ing. Eduardo Cruz Romero
SELECCIÓN DE COMPONENTES PARA ENSAMBLE DE EQUIPOS DE COMPUTO. Ing. Eduardo Cruz Romero www.tics-tlapa.com Tarjeta madre Procesador Memoria RAM Gabinete Fuente de Poder Disco Duro Unidad CD/DVD Teclado
La arquitectura del 8086/8088
Repasamos aquí la arquitectura de un PC. Para más información sobre lo aquí expuesto se puede consultar [PA01] y los capítulos iniciales de [Tej01], [Rod00] y [Nor01]. Anatomía del PC A grandes rasgos,
