PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRÓNICA AREA DE CIRCUITOS Y SITEMAS ELECTRONICOS MICROCONTROLADORES ATMEGA8 ZENON CUCHO M. FRERI ORIHUELA Q. ROLANDO SÁNCHEZ P. LAUREANO RODRÍGUEZ P. 2007-I Curso de actualización de Microcontroladores Atmega8 1 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA SESIÓN 01 INTRODUCCION AL MICONTROLADOR ATMEGA8 PARTE TEÓRICA DESCRIPCION DEL MICROCONTROLADOR ATMEGA 8 MEMORIA DE PROGRAMAS Y ESPACIO DE MEMORIA DE DATOS DESCRIPCION DE LOS PUERTOS E/S PARTE PRÁCTICA • • • MANEJO DEL ENTORNO DE DESARROLLO VMLAB: EDICION, COMPILACION Y EJECUCION DE PROGRAMAS PROGRAMAS USANDO INTERRUPTORES Y PULSADORES Curso de actualización de Microcontroladores Atmega8 2 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA INTRODUCCION AL MICROCONTROLADOR 1.1 Introducción El microcontrolador es un circuito integrado de muy alta escala de integración que contiene las partes funcionales de un computador: • CPU (Central Processor Unit o Unidad de Procesamiento Central) • Memorias volátiles (RAM), para datos • Memorias no volátiles( ROM, PROM, EPROM) para escribir el programa • Líneas de entrada y salida para comunicarse con el mundo exterior. • Algunos periféricos (comunicación serial, temporizador, convertidor A/D, etc) Es decir el microcontrolador es un computador integrado en un solo chip. Integrar todos estos elementos en un solo circuito integrado a significado desarrollar aplicaciones importantes en la industria al economizar materiales, tiempo y espacio. ¿Que no hace el microcontrolador? Las aplicaciones de un microcontrolador son tan inmensas que el límite es la propia imaginación del usuario. Estos microcontroladores están en el auto, en el televisor, en el teléfono, en una impresora, en un horno de microondas, en un transbordador espacial, en un juguete, etc. Alguna fuentes estiman que en una casa típica de E.U se tiene alrededor de 250 microcontroladores. Los siguientes son algunos campos en los que los microcontroladores tienen gran uso: • En la industria del automóvil: Control de motor, alarmas, regulador del servofreno, dosificador, etc. • En la industria de los electrodomésticos: control de calefacciones, lavadoras, cocinas eléctricas, etc. • En informática: como controlador de periféricos. Por ejemplo para controlar impresoras, plotters, cámaras, scanners terminales, unidades de disco, teclados, comunicaciones (modems), etc. Curso de actualización de Microcontroladores Atmega8 3 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA • En la industria de imagen y sonido: tratamiento de la imagen y sonido, control de los motores de arrastre del giradiscos, magnetófono, video, etc. En la industria, en general se utilizan en: • Regulación: todas las familias de microcontroladores incorporan en alguna de sus versiones conversores A/D y D/A, para la regulación de la velocidad de las máquinas, de niveles, de temperatura, etc. • Automatismos: La enorme cantidad de líneas de entrada y salidas, y su inmunidad al ruido le hacen muy valioso para el control secuencial de procesos. Por ejemplo control de máquinas, herramientas, apertura y cierre automático de puertas según condiciones, plantas empaquetadoras, aparatos de maniobra de ascensores, etc. • Robótica: para control de los motores y captura de señales de los diferentes sensores, fabricación de controladores robóticos para sistemas automáticos, etc. Instrumentos portátiles compactos: • Radio paginador numérico (beeper) • Planímetro electrónico • Nivelímetro digital • Identificador-probador de circuitos integrados • Tacómetro digital • Panel frontal de un osciloscopio • Controlador de display LCD • Analizador de espectros, etc Dispositivos autónomos: • Fotocopiadoras • Máquinas de escribir • Selector, Codificador decodificador de TV • Localizador de peces • Teléfonos de tarjeta • Teléfonos celulares • Cerraduras electrónicas • Sistemas de seguridad Se emplea también en medicina, en aplicaciones militares, edificios inteligentes, etc. Curso de actualización de Microcontroladores Atmega8 4 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA 1.2 Principales fabricantes Por lo general los fabricantes de microprocesadores lo son de microcontroladores. Los fabricantes de microcontroladores son más de 50, podemos mencionar a: • • • • • • • • • • • • • • • Atmel Motorola Intel Microchip NEC Hitachi Mitsibishi Philips Matsushita Toshiba AT&T Zilog Siemens National Semiconductor etc. 1.3 APARICION Y DESARROLLO DE LOS MICROCONTROLADORES Breve Esbozo Histórico. La siguiente es una lista cronológica de los eventos tecnológicos más recientes que han tenido impacto sobre la aparición y el desarrollo del campo de los microcontroladores en la electrónica digital. 1971: Intel fabrica el primer microprocesador (el 4004) de tecnología PMOS. Este era un microprocesador de 4 bits y fue fabricado por Intel a petición de Datapoint Corporation con el objeto de sustituir la CPU de terminales inteligentes fabricadas en esa fecha por Datapoint mediante circuitería discreta. El dispositivo fabricado por Intel resultó 10 veces más lento de lo requerido y Datapoint no lo compró, de esta manera Intel comenzó a comercializarlo. El 4004 podía direccionar sólo 4096 (4k) posiciones de memoria de 4 bits, reconocía 45 instrucciones y podía ejecutar una instrucción en 20 µseg en promedio. 1972: Las aplicaciones del 4004 estaban muy limitadas por su reducida capacidad y rápidamente Intel desarrolló una versión más poderosa (el 8008), el cual podía Curso de actualización de Microcontroladores Atmega8 5 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA manipular bytes completos, por lo cual fue un microprocesador de 8 bits. La memoria que este podía manejar se incrementó a 16 kbytes, sin embargo, la velocidad de operación continuó igual. 1973: Intel lanza al mercado el 8080 el primer microprocesador de tecnología NMOS, lo cual permite superar la velocidad de su predecesor (el 8008) por un factor de diez, es decir, el 8080 puede realizar 500000 operaciones por segundo, además se incrementó la capacidad de direccionamiento de memoria a 64 kbytes. A partir del 8080 de Intel se produjo una revolución en el diseño de microomputadoras y varias compañías fabricantes de circuitos integrados comenzaron a producir microprocesadores. Algunos ejemplos de los primeros microprocesadores son: el IMP-4 y el SC/MP de National Semiconductors, el PPS-4 y PPS-8 de Rockwell International, el MC6800 de Motorola, el F-8 de Fairchild. 1975: Zilog lanza al mercado el Z80, uno de los microprocesadores de 8 bits más poderosos. En ese mismo año, Motorola reduce sus costos con sus microprocesadores 6501 y 6502 (este último adoptado por APPLE para su primera microcomputadora personal). estos microprocesadores se comercializan en $20 y $25 (dls.USA) respectivamente. Esto provoca un auge en el mercado de microcomputadoras de uso doméstico y un caos en la proliferación de lenguajes, sistemas operativos y programas (ningún producto era compatible con el de otro fabricante). 1976: Surgen las primeras microcomputadoras de un solo chip, que más tarde se denominarán microcontroladores. Dos de los primeros microcontroladores, son el 8048 de Intel y el 6805R2 de Motorola. 198x : En la década de los 80's comienza la ruptura entre la evolución tecnológica de los microprocesadores y la de los microcontroladores, Ya que los primeros han ido incorporando cada vez más y mejores capacidades para las aplicaciones en donde se requiere el manejo de grandes volúmenes de información y por otro lado, los segundos han incorporado más capacidades que les permiten la interacción con el mundo físico en tiempo real, además de mejores desempeños en ambientes de tipo industrial. Curso de actualización de Microcontroladores Atmega8 6 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA 1.4 ARQUITECTURA DE UN MICROCONTROLADOR Según la arquitectura interna de la memoria de un microcontrolador se puede clasificar considerando como el CPU accede a los datos e instrucciones, en 2 tipos: 1.4.1 Arquitectura Von Neumann Fue desarrollada por Jon Von Neumann, se caracteriza por tener una sola memoria principal donde se almacenan datos e instrucciones de forma indistinta. La CPU se conecta a través de un sistema de buses (direcciones, datos y control). Esta arquitectura es limitada cuando se demanda rapidez. Memoria Bus de direcciones CPU Instrucciones + Datos Bus de datos Fig.1.1 Arquitectura Von Neumann 1.4.2 Arquitectura Harvard Fue desarrollado en Harvard, por Howard Aiken, esta arquitectura se caracteriza por tener 2 memorias independientes una que contiene sólo instrucciones y otra, que contiene sólo datos. Ambas, disponen de sus respectivos sistemas de buses para el acceso y es posible realizar operaciones de acceso simultáneamente en ambas memorias. Existe una variante de esta arquitectura que permite el acceso a la tabla de datos desde la memoria de programas es la Arquitectura de Harvard Modificada. Esta última arquitectura es la dominante en los microcontroladores actuales ya que la memoria de programas es usualmente ROM, OTP, EPROM o FLASH, mientras que la memoria de Curso de actualización de Microcontroladores Atmega8 7 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA datos es usualmente RAM. Por ejemplo las tablas de datos pueden estar en la memoria de programa sin que sean perdidas cada vez que el sistema es apagado. Memoria de Bus de direcciones Instrucciones de instrucciones Bus de direcciones CPU de datos Bus de instrucciones Memoria de datos Bus de datos Fig. 1.2 Arquitectura Harvard Se puede observar claramente que las principales ventajas de esta arquitectura son: a) que el tamaño de las instrucciones no esta relacionado con el de los datos, y por lo tanto puede ser optimizado para que cualquier instrucción ocupe una sola posición de memoria de programa, logrando así mayor velocidad y menor longitud de programa, b) que el tiempo de acceso a las instrucciones puede superponerse con el de los datos, logrando una mayor velocidad de operación. 1.5 TIPOS DE MEMORIA • Memoria RAM (Random Access Memory) Memoria de Acceso Aleatorio) en esta memoria se guarda los datos que se está utilizando en el momento presente. El almacenamiento es considerado temporal por que los datos permanecen en ella mientras la memoria tiene una fuente de alimentación. La memoria de programas o de instrucciones contiene una serie de diferentes tipos de memoria: • Memoria ROM con máscara y es de solo lectura, cuyo contenido se graba durante la fabricación del chip. Es aconsejable cuando se precisan cantidades superiores a varios miles de unidades. Curso de actualización de Microcontroladores Atmega8 8 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA • Memoria OTP (One Line Programmable) es no volatile y de solo lectura y programmable una sola vez por el usuario. La grabación se realiza mediante un sencillo grabador controlado por una PC. • Memoria EPROM (Erasable Programmable Read Only Memory), pueden borrarse y grabarse muchas veces. La grabación se realiza, como en el caso de la memoria OTP. Si, posteriormente, se desea borrar el contenido, disponen de una ventana de cristal en su superficie por la que se somete a le EPROM a rayos ultravioleta por algunos minutos. • Memoria EEPROM (Electrical EPROM) es de sólo lectura, programable y borrable eléctricamente. Tanto la programación como el borrado, se realizan eléctricamente desde el propio grabador y bajo el control programado de un PC, y puede hacerse con el microcontrolador instalado en el circuito. Es muy cómoda y rápida la operación de grabado y la de borrado. • Memoria Flash La memoria Flash es no volátil, de bajo consumo y puede grabarse y borrarse eléctricamente. Funciona como una ROM y una RAM pero consume menos energía y es más pequeña. La memoria Flash también puede programarse “en circuito”, es decir, sin tener que sacar el circuito integrado de la tarjeta. además, es más rápida, tiene mayor densidad y tolera más ciclos de escritura/borrado que la EEPROM 1.6 ¿Qué microcontrolador elegir? Sin duda la elección del microcontrolador dependerá de la tarea o proyecto que se tiene en mente pues los fabricantes como se mencionó anteriormente son más de 50, estos tienen muchos modelos enfocados a tareas específicas. Esta selección deberá ir de la mano con factores económicos óptimos así como de la idea del controlador incrustado (embedded controller), el cual es un controlador dedicado a una sola tarea e incorporado al sistema que gobierna. Antes de seleccionar un microcontrolador es imprescindible analizar los requisitos de la aplicación: • Procesamiento de datos: Cuando se desea realizar cálculos complejos en un tiempo limitado, se debe seleccionar un microcontrolador suficientemente rápido para ello. Curso de actualización de Microcontroladores Atmega8 9 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Por otro lado, habrá que tener en cuenta la precisión de los datos a manejar: si no es suficiente con un microcontrolador de 8 bits, puede ser necesario acudir a microcontroladores de 16 ó 32 bits, o incluso a hardware de coma flotante. Una alternativa más barata y quizá suficiente es usar librerías para manejar los datos de alta precisión. • Entrada/Salida: Se debe identificar la cantidad y tipo de señales a controlar. Una vez realizado este análisis puede ser necesario añadir periféricos externos o cambiar a otro microcontrolador más adecuado a ese sistema. • Consumo: algunos productos que incorporan microcontroladores están alimentados con baterías, puede ser que el microcontrolador esté trabajando en estado de bajo consumo pero debe “despertar” ante la activación de una señal (por ejemplo una interrupción) y ejecutar el programa adecuadamente. • Memoria: para detectar las necesidades de memoria de una aplicación debemos saber la cantidad y el tipo de memoria necesaria para esto se debe tener una versión preliminar (pseudo-código) de la aplicación y escoger el microcontrolador apropiado. • Ancho de palabra: el criterio de diseño debe ser seleccionar el microcontrolador de menor ancho de palabra que satisfaga los requerimientos de la aplicación. Usar un microcontrolador de 4 bits supondrá reducir los costos, mientras que uno de 8 bits puede ser el más adecuado si el ancho de los datos es de un byte. Los microcontroladores de 16 y 32 bits, debido a su elevado costo, deben reservarse para aplicaciones que requieran altas prestaciones (Entrada/Salida grande o espacio de direccionamiento muy elevado). • Diseño de la placa: la selección de un microcontrolador concreto condicionará el diseño de la placa de circuitos impresos. Curso de actualización de Microcontroladores Atmega8 10 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA II. 2.1 EL MICROCONTROLADOR ATMEL AVR Introducción ATMEL fabrica los microcontroladores de la familia AVR, esta nueva tecnología proporciona todos los beneficios habituales de arquitectura RISC y memoria flash reprogramable eléctricamente. La característica que los identifica a estos microcontroladores de ATMEL es la memoria flash y eeprom que incorpora. AVR compite con varias familias de microcontroladores bien establecidas en el mercado, tales como 8051 de Intel, 68HC11 de motorola y la familia PIC de Microchip. La firma también produce y vende varios subproductos de la popular familia 8051 con la diferencia de que están basados en la memoria flash. El diseño AVR de ATMEL difiere de los demás microcontroladores de 8 bits por tener mayor cantidad de registros (32) y un conjunto ortogonal de instrucciones. AVR es mucho mas moderna que su competencia. Por ejemplo, los 8051, 6805 y los PIC, se los arreglan con un único acumulador, los 658HC11 y 68HC12 tienen simplemente 2. Esto hace que la arquitectura AVR sea más fácil de programar a nivel de lenguaje ensamblador y que sea fácil de optimizar con un compilador. El gran conjunto de registros disminuye la dependencia respecto a la memoria, lo cual mejora la velocidad y disminuye las necesidades de almacenamiento de datos. Además casi todas las instrucciones se ejecutan en 1 ó 2 ciclos de reloj versus 5-10 ciclos de reloj para los chips 8051, 6805, 68HC11 y PIC. Adicionalmente, ATMEL también proporciona en línea el entorno software (AVR estudio) que permite editar, ensamblar y simular el código fuente, (la explicación del Avr Studio 4.0, se explicará más adelante). Una vez ensamblado y depurado el código fuente del programa, se transferirá el código máquina a la memoria flash del microcontrolador para esto se debe disponer de otro entorno de desarrollo para programar en forma serial o paralelo la memoria flash. Las familias AVR rápidamente han crecido en el mercado y se dispone de las siguientes categorías: • TINY AVR: son microcontroladores de propósito general con memoria flash hasta 2 Kbytes y 128 bytes de memorias SRAM y EEPROM. Curso de actualización de Microcontroladores Atmega8 11 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA • AVR: Microcontroladores de propósito general con 8 Kbytes de memoria flash y 512 bytes de memoria SRAM y EEPROM. • Mega AVR Memoria flash hasta 256 Kbytes, 4 Kbytes de memoria EEPROM y SRAM Los tipos de encapsulado del microcontrolador del ATmega presenta desde 28 pines hasta 100 pines en la forma de DIP, TQFP y MLF y su voltaje de alimentación está en el rango de 1.8 a 5.5 voltios. Se presenta en la figura 2.1 sus características principales Fig.2.1 Características del microcontrolador ATmega AVR Curso de actualización de Microcontroladores Atmega8 12 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA 2.2 Descripción del ATMEGA8 El microcontrolador ATMEGA8(L) es de 8 bits, su procesador presenta características avanzadas de tipo RISC, segmentado y arquitectura Harvard. Fig.2.2 Diagrama de Bloques del Atmega8 La tecnología RISC (Reduced Instruction Set Computing), o sea presentan instrucciones con complejidad reducida, a diferencia de otros que tienen tecnología CISC (Complex Instrucción Curso de actualización de Microcontroladores Atmega8 13 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Set Computing), permite una rápida ejecución de las instrucciones que se ejecutan en un solo ciclo de reloj, el ATMEGA 8L consigue obtener 1 MIPS por Mhz, permitiendo al diseñador del sistema optimizar su consumo de energía versus la velocidad de procesamiento). Las instrucciones en la memoria de programas son ejecutados con estructura segmentada (pipeling), al mismo tiempo que una instrucción es ejecutado, se realiza la búsqueda de la próxima instrucción. Este concepto permite de habilitar instrucciones paras ser ejecutados con cada ciclo de reloj. Las características principales del microcontrolador (Ver el diagrama de bloques de. la Fig.2.2) son: • Tiene 32 registros de 8 bits de propósito general. Todos estos registros están conectados a la unidad aritmética lógica (ALU) para un rápido acceso, una instrucción es ejecutada con uno solo ciclo de reloj. • Tipos de Memoria: Memoria flash de 8 Kbytes EEPROM de 512 bytes SRAM de 1 Kbytes • Característica de los periféricos internos: • 2 temporizador/contador de 8 bits con pre-escalador y comparador • 1 temporizador/contador de 16 bits con pre-escalador, comparador y capturador • 8 canales de entrada para cada convertidor A/D (en TQFP y MLF) 6 canales A/D de 10 bits y 2 canales A/D de 8 bits • 6 canales de entrada para cada convertidor A/D (tipo PDIP) 4 canales A/D de 10 bits 2 canales A/D de 8 bits. • 1 USART (módulo programable para comunicación serial) • 1 módulo SPI, para interface serial (master/slave) • 1 perro guardián • 1 comparador analógico • Puertos programables de entrada/salida • Puerto B, con 8 líneas Curso de actualización de Microcontroladores Atmega8 14 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA • Puerto C, con 7 líneas • Puerto D, con 8 líneas • Velocidad de operación: 0 – 8 Mhz (ATMEGA8L) 0-16 MHZ (ATMEGA8) • Voltaje de alimentación: 2.7 a 5.5 voltios (ATMEGA 8L) 4.5 a 5.5 voltios (ATMEGA8) • Tipo de empaque: PDIP de 28 pines TQFP de 32 pines MLF de 32 pines • Otras características: Fuentes de interrupción internas y externas Oscilador interno de 1, 2, 4 y 8 Mhz. • Etc. Se puede configurar su frecuencia de trabajo a través de su oscilador interno a 1, 2, 4 y 8 MHz (Se pide revisar el manual del Atmega8, pagina No. 28), también el microcontrolador puede hacer uso de un cristal externo(revisar el manual del Atmega8). La memoria de programas y de datos están separadas (arquitectura Harvard). Para la memoria de programas, el microcontrolador maneja un bus de direcciones de 14 bits, por lo tanto puede direccionar hasta 4KB, dado que la memoria de programas (Flash de 8Kx8) está organizado en 4Kx16. Una instrucción tiene un formato de 16 bits. La memoria de datos tiene su propio bus de direcciones y datos. El bus de datos es de 8. ¿De cuántas líneas comprende el bus de direcciones, para la memoria de datos?. El Atmega8 además de poseer los 32 registros de propósito general, también dispone de 3 registros índices de 16 bits, X , Y, Z, un registro contador de programa PC y un puntero de pila, SP (stack pointer), también de 16 bits. El registro de estado, Curso de actualización de Microcontroladores Atmega8 contiene los 8 15 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA indicadores: C (bandera de acarreo), V (bandera de desbordamiento), Z (bandera de resultado cero), N (bandera negativo), H (bandera de acarreo a la mitad), I (habilitador de interrupciones), T (copia, almacena un bit), y S (bit de signo). 2.3 Descripción de los pines del ATMEGA8L Fig.2.3 Tipo PDIP • VCC y GND. Son los pines de alimentación (+5 v) y tierra (0 v). • XTAL1 y XTAL2. Conectores del cristal de reloj externo. • RESET. Corresponde a la línea de reset (entrada). • AVCC. Es el pin para conectar la fuente de alimentación al convertidor A/D. • AREF. Para conectar una tensión de referencia para el conversor A/D interno. • Puerto B(PB7 .. PB0). Compuesto de 8 bits, a cada pin le corresponde un bit, son bidireccionales con resistencia interna “pull up” para cada bit. Alternativamente, cada pin tiene otras funciones alternativas (ver el manual de Atmega8(L), página 56), por ejemplo PB6 y PB7, permiten la conexión a un cristal externo. • Puerto C(PC0 .. PC5). Tiene 7 bits, bidireccionales con resistencias internas pull up, para cada bit. • PC6/RESET. El bit 6, puede ser usado como entrada/salida si los fusibles han sido programados, en caso contrario, PC6 es usado para la entrada Reset. Un bajo nivel en este pin generará un reset. Las otras funciones de cada pin del puerto C, son descritos en la página 59, del manual Atmega8(L). Curso de actualización de Microcontroladores Atmega8 16 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA • Puerto D (PD0..PD7). Son 8 líneas bidireccionales de entrada/salida con resistencias internas pull up, para cada uno. Los pines del puerto D, también tiene otras funciones descritas en la página 61 del manual Atmega8, por ejemplo PD0 y PD1 permiten usar el periférico de comunicación serial USART, PD1 permite la transmisión de datos y PD0, permite la recepción de datos. 2.4 La Unidad Central de Procesos (CPU) La función de la CPU es controlar la operación del microcontrolador, permitiendo la ejecución correcta del programa, habilitando el acceso a las memorias, controlar los periféricos y manejar las interrupciones. Para obtener una mejor perfomance y paralelismo, el AVR, utiliza la arquitectura Harvard gracias a ella se puede acceder de forma simultánea e independiente a la memoria de datos y a la memoria de instrucciones (se estudiará más adelante). Los registros de archivo de acceso rápido contienen 32 registros de propósito general de 8 bits y son accesados con un solo ciclo de reloj. Esto permite usar un solo ciclo en una operación aritmética-lógica(ALU), por ejemplo en una operación típica ALU, 2 operandos son extraídos del archivo de Registros, y la operación es ejecutada, el resultado es almacenado de nuevo en el Registro de archivos(Rd), en un solo ciclo de reloj. Rd Rd + Rr De los 32 registros de 8 bits 6 pueden ser usados como 3 registros de 16 bits para direccionamiento indirecto apuntando el espacio de memoria de datos. Estos registros adicionales son X, Y, y Z, de 16 bits. La ALU, permite realizar las operaciones aritméticas y lógicas entre registros o entre un registro y una constante. Luego de una operación aritmética, el registro de estados es modificado para reflejar la información acerca del resultado de una operación. El flujo de un programa es variado por los saltos condicionales e incondicionales y las instrucciones de llamada para dirigirse a la nueva dirección en el espacio de memoria. Las instrucciones del AVR, tiene normalmente un formato de compuesto por una palabra de 16 Curso de actualización de Microcontroladores Atmega8 17 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA bits. Cada dirección en la memoria de programas contiene instrucciones de 16 ó 32 bits (el concepto de llamadas a subrutinas y ejecución de interrupciones se estudiará más adelante). Fig. 2.4 Arquitectura AVR 2.4 El Registro de estados El registro de estado contiene información acerca del resultado de la mas reciente instrucción ejecutada. Esta operación puede ser utilizada para alterar el flujo de un programa. El registro de estados es sobrescrito luego de ejecutarse una operación en la ALU. Bit Lectura/escritura Valor inicial • 7 6 5 4 3 2 1 0 I T H S V N Z C R/W 0 R/W 0 R/W 0 R/W 0 R/W R/W R/W 0 0 0 R/W 0 I: Global interrup enable El bit I permite habilitar las interrupciones con “1” lógico, si el bit es “0”, no se aceptará ningún pedido de interrupción. Se puede hacer esto usando las instrucciones SEI y CLI. Curso de actualización de Microcontroladores Atmega8 18 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA • T: Bit copy storage La posición del bit T, permite ser el destino o la fuente de un bit determinado (es como un lugar temporal para guardar un bit). Para esto se utiliza las instrucciones BLD(bit LoaD) y BST (Bit Store). Ejemplo: Bst R5,3 ; guarda el bit 3 del registro R5 en la bandera T Bld R0,4 ; carga la el valor de la bandera T dentro del bit 4 del registro R0. • H: Half carry flag Es la bandera de medio acarreo, se pone a “1” si en una suma de operandos de 8 bits, hay un acarreo del nible menos significativo, al más significativo. Se pone a “0” en caso contrario. • S: Sign Bit El bit S siempre es un or-exclusivo entre la bandera negativa “N” y la bandera de desborde “V”. • V: Two’s complement overflow flag La bandera V se hace 1 cuando el resultado de una instrucción excede el rango de las operaciones aritméticas, es decir, en el caso de operaciones de 8 bits cuando el resultado de una operación no está entre –128 y +127 decimal y en el caso de 16 bits entre –32768 y +32767 decimal. Esto es algo que sucede usualmente en el complemento a dos. • N: Negative flag La bandera N, se hace 1 cuando el resultado de una operación es un número negativo, o sea el bit mas significativo del resultado vale 1. Se pone a 0 en caso contrario. • Z: Zero flag Se hace “1” cuando el resultado de un operación es cero, de lo contrario es cero. • C: Carry flag La bandera de acarreo (C) se hace 1 cuando existe acarreo en el bit de mayor significado de una operación aritmética; de lo contrario es cero. Curso de actualización de Microcontroladores Atmega8 19 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA 2.5 Registros de propósito general Atmega8(L), dispone de 32 registros de propósito general 7 R0 0 Dirección 0x00 R1 0x01 R2 0x02 ... R13 0x0D R14 0x0E R15 0x0F R16 0x10 R17 0x11 ... R26 0x1A R27 0x1B R28 0x1C R29 0x1D R30 0x1E R31 0x1F Fig.2.5 Registros de propósito general Se observa en la figura, además que a cada registro le corresponde una dirección dentro de las 32 primeras posiciones en el espacio de memoria de datos. Los registros R26..R31 tienen algunas funciones adicionales. • Registros X, Y, Z Los registros R26 y R27 forman el registro X de 16 bits, los registros R28 y R29 forman el registro Y de 16 bits, los registros R30 y R31 forman el registro apuntador Z de 16 bits. XH 7 XL 0 R27 7 0 R26 YH YL Curso de actualización de Microcontroladores Atmega8 20 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA 7 0 7 R29 0 R28 ZH ZL 7 0 7 R31 0 R30 Fig.2.6 Los Registros X, Y, Z Puntero de Pila La pila es el área de espacio de memoria, utilizado temporalmente para guardar y recuperar datos y/o direcciones cuando el CPU está ejecutando una subrutina programada o una interrupción. El puntero de pila apunta (almacena la dirección) a la próxima dirección libre de la pila y que decrementa su valor en uno cada vez que se almacena un dato(de un byte) en ella, incrementándolo en uno cuando se retira este valor(de un byte). En el caso que se guarda la dirección de retorno cuando se atiende a una subrutina o una interrupción el puntero de pila es decrementado en 2 y luego de ejecutarse la última instrucción de retorno de la subrutina, el puntero de pila es incrementado en 2. El puntero de pila en el AVR es implementado con 2 registros de 8 bits en el espacio de memoria E/S. El programador debe darle el valor inicial al puntero de pila en la memoria de datos SRAM por encima de la dirección $60, Bit 2.6 15 14 13 12 11 10 9 8 SP15 SP14 SP13 SP12 SP11 SP10 SP9 SP8 SPH SP7 SP6 SP5 SP4 SP3 SP2 SP1 SP0 SPL 7 6 5 4 3 2 1 0 La arquitectura Harvard y RISC El microcontrolador ATmega8 utiliza la arquitectura conocida como Harvard, consiste simplemente en un esquema en el que el CPU está conectado a dos memorias por intermedio de dos buses separados. Una de las memorias contiene solamente las instrucciones del programa, y es llamada Memoria de Programa. La otra memoria solo almacena los datos y es llamada Memoria de Datos. Ambos buses son totalmente independientes y pueden ser de Curso de actualización de Microcontroladores Atmega8 21 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA distintos anchos. En cuanto a sus instrucciones es de tipo RISC (Reduced Instrucción Set Computer), esto permite que el set de instrucciones y el bus de la memoria de programa pueden diseñarse de manera tal que todas las instrucciones tengan una sola posición de memoria de programa de la misma longitud. Además, como los buses son independientes, el CPU del microcontrolador puede estar accediendo a los datos para completar la ejecución de una instrucción, y al mismo tiempo estar leyendo la próxima instrucción a ejecutar. En resumen Atmega8, maneja: • 130 instrucciones, la mayoría se ejecuta en un solo ciclo de reloj • 32 registros de propósito general de 8 bits • Hasta 16 MIPS si trabaja a 16 Mhz. 2.7 Memoria de programa y memoria de datos El microcontrolador ATmega8 define 2 tipos de espacio de memoria, el espacio de la memoria de datos y el espacio de memoria de programas. Además tiene una memoria EEPROM. La memoria flash del Atmega8 tiene una capacidad de 8K x 8, las instrucciones son de 16 bits o 32 bits, por tanto esta memoria es organizado como 4Kx16 bits. Para mayor seguridad el espacio de la memoria flash(memoria de programas) está dividido en 2 áreas: arranque y de aplicación. Para acceder al espacio comprendido entre 0 y 4095 ($FFF) direcciones, el tamaño del registro contador de programa (PC) será de 12 bits. Curso de actualización de Microcontroladores Atmega8 22 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Fig.2.8 Memoria de programas Memoria de datos En la memoria de datos residen los registros de propósito general (R0...R31), los registros de E/S y los registros de la SRAM interna. El espacio de EEPROM consta de 512 bytes, donde opcionalmente se pueden guardar datos que no se pierden al desconectar la alimentación. La siguiente figura muestra la organización de la memoria SRAM del Atmega8 Curso de actualización de Microcontroladores Atmega8 23 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Fig.2.9 Mapa de la memoria de datos Curso de actualización de Microcontroladores Atmega8 24 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA 2.8. Descripción de los Puertos de Entrada y Salida Los puertos son un conjunto de líneas (pines) programables como entrada ó salida que dispone el microcontrolador para comunicarse con el mundo exterior. El microcontrolador Atmega8(L), tiene 3 puertos de E/S (Puertos B, C D). Todos los pines de cada puerto son programables como entrada o salida de datos configurando el registro asociado respectivo. Cuando se programa el funcionamiento de un puerto como entrada tenemos que habilitar o deshabilitar las resistencias pull-up internas. Cada pin del puerto tiene independiente su resistencia pull-up como una resistencia invariante hacia la fuente de voltaje, además tiene 2 diodos de protección uno conectado a Vcc y el otro conectado a GND. (ver figura 4.1) Fig.4.1 Diagrama equivalente de un pin de E/S En resumen, para cada puerto del microcontrolador (puertos B, C y D) existen tres registros de E/S que permiten configurar cada pin del puerto como entrada o salida, enviar datos a los pines configurados como salidas, y recibir datos de los pines configurados como entradas. Estos registros son: • el Registro de Direcciones de Datos DDRx, • el Registro de Datos – PORTx, y • el registro – PINx, . Curso de actualización de Microcontroladores Atmega8 25 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA En el párrafo anterior, “x” puede ser B, C ó D. Es decir, si nos referimos al puerto B, los registros son DDRB, PORTB y PINB. Los registros PINx son de sólo lectura, mientras que los registros PORTx y DDRx son de lectura/escritura. Adicionalmente, el bit “Pull-up Disable” – PUD, en el registro SFIOR inhabilita la función Pull-up para todos los pines de todos los puertos cuando es puesto a nivel alto. (Ver Figura 4.2) Cada pin del puerto de E/S, está asociado a 3 registros DDxn, PORTxn, y PINxn, cuyas direcciones en el espacio de memoria están indicados por los Registros DDRx E/S, PORTxE/S y PINxE/S.(ver Register Descripción for E/S ports, pagina 63 del manual Atmega8(L)). El bit DDxn del Registro DDRx, establece la dirección de este pin. Si DDxn es escrito con “1” lógico, Pxn es configurado como un pin de salida. Si en DDxn es escrito un “0”, Pxn es configurado como un pin de entrada. Si el pin PORTxn está configurado como un pin de entrada y es escrito un “1” lógico, entonces la resistencia pull-up está activada. En cambio si en PORTxn está configurado como un pin de salida ó es escrito con un “0” lógico, la resistencia pull-up está desactivada. Si el pin PORTxn está configurado como un pin de salida y es escrito con un “1” lógico, el pin toma un valor alto, en cambio si es escrito con “0” lógico el pin toma un valor bajo(cero). Curso de actualización de Microcontroladores Atmega8 26 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Fig.4.2 Puertos de E/S Adicionalmente, se puede observar en el anterior diagrama que si el bit PUD(PULLUP DISABLE) del registro SFIOR, tiene un valor alto “1”, se deshabilitarán las resistencias pullup de todos los puertos. El funcionamiento de la configuración de los pines de un puerto se resume en la siguiente tabla: DDxn PORTxn PUD E/S Pull-up Comentario Tri-state (en SFIOR) 0 0 X Entrada No 0 1 0 Entrada Yes 0 1 1 Entrada No Tri-state 1 0 X Salida No Salida baja 1 1 X Salida No Salida alta Tabla: Configuración de los pines del puerto. Curso de actualización de Microcontroladores Atmega8 27 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA PRACTICA N° 1 MANEJO DE PUERTOS ENTRADA/SALIDA I. OBJETIVO Aprender a desarrollar programas con el microcontrolador Atmega8, utilizando instrucciones básicas. Aprender a manejar el entorno de desarrollo VMLAB Aprender a grabar la memoria flash del microcontrolador II. MATERIALES • 1 módulo de entrenamiento “AvrPUCP -Mega8”. • 1 Módulo de entrada/salida. • 1 Cable de programación • 1 computadora personal. • Entorno de desarrollo VMLAB • Cables de conexión III. PROCEDIMIENTO Ejemplo 1 Se desea escribir un programa que permita prender 2 leds, que están conectados a 2 pines de un puerto del microcontrolador Planteamiento • El microcontrolador ATmega8L tiene 23 pines programables E/S. Para la solución utilizaremos PB0 y PB1 de acuerdo al siguiente Circuito esquemático: • Para desarrollar el programa utilizaremos el entorno VMLAB y los módulos de entrenamiento del laboratorio, que explicaremos a continuación. Curso de actualización de Microcontroladores Atmega8 28 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA IV. MANEJO DEL VMLAB (VISUAL MICRO LAB) 4.1 Creación del primer proyecto: Edición y Compilación El problema planteado tiene como objetivo encender 2 leds, conectados a los pines PB0 y PB1 del microcontrolador ATmega8. Procedimiento: 1er Paso: Ejecutar el entorno VMLAB, y del menú principal, escoger Proyect, luego la opción New Proyect, y aparecen las siguientes figuras: Figura 1. Barra de herramientas del menú principal del VMLAB Figura 2. Pantalla para definir el nuevo proyecto Curso de actualización de Microcontroladores Atmega8 29 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA 2do.paso: Defina el proyecto con los parámetros correctos, activando las pestañas respectivas: 1. Project name and location: C:\CursoAtmega8\ejemplo1.prj 2. Luego seleccione el código del microcontrolador: Atmega8 3. Elija el modo estándar de compilación : Standart micro manufacturer assembler/linker (por defecto ya está marcado) 4. Añada el archivo ejemplo1.asm en la caja de archivos (Code files list), haciendo clic en el botón Add this: Figura 3: Definición de un proyecto. 5. Una vez completados todos los datos se hace clic en el botón OK, y aparecerá 3 ventanas de trabajo con líneas de texto predeterminadas (ver figura 4): • • • Ejemplo1.asm: Aquí escribiremos nuestro programa en lenguaje ensamblador Ejemplo1.prj: Esta ventana nos permite dibujar(mediante líneas de texto definidos) el hardware del circuito, para los cuáles debemos conocer la sintaxis de cada elemento. Ventana de mensajes: Nos mostrará si hubo o no errores en la compilación tanto del software como del hardware del proyecto. Curso de actualización de Microcontroladores Atmega8 30 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Figura 4: Ventanas de trabajo (*.hex y *.prj) y de mensajes 3er. Paso: Definiendo el hardware del proyecto Para construir nuestro circuito debemos usar la ayuda del menú principal Help, en su contenido muestra la lista de componentes que conforman toda la librería del hardware (abrir el enlace Hardware component) y aparece la figura siguiente. ( Debemos abrir el componente en particular y estudiar la sintaxis respectiva) Ejemplos: (a) Para definir el diodo led se debe tener que el ánodo siempre está conectado a la fuente VDD. La sintaxis es la siguiente: D{1-8} VDD (Nombre del nodo) Ejemplo: D1 VDD NODO1 ; el ánodo del diodo está conectado a la fuente VDD y el cátodo al nodo 1. (b) En la lista de componentes no existe la puerta inversora, pero sí existe la puerta NAND de 2 entradas con la cual se formará el inversor. La sintaxis de la compuerta NAND es la siguiente: Curso de actualización de Microcontroladores Atmega8 31 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA X(<nombre de la compuerta>) ND2 <entrada1><entrada2><salida> Ejemplo: X1 ND2 <nodo2><nodo3><nodo4> ( c) La resistencia tiene la siguiente sintaxis: R(<nombre de la resistencia>) <nodo1><nodo2> <valor> Ejemplo para definir una resistencia de 180 ohmios entre 2 nodos N1 y N2: R1 N1 N2 180. Figura 5: Se muestra una lista de componentes electrónicos que dispone VMLAB En el archivo de trabajo ejemplo1.prj, se observa algunas directivas y comentarios creados por defecto. Curso de actualización de Microcontroladores Atmega8 32 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Para nuestro caso se agrega las siguientes líneas de texto que definen el hardware del proyecto: 2 leds con 2 resistencias en serie conectados a los pines PB0 y PB1. D1 VDD N1 R1 N1 PB0 330 D2 VDD N2 R2 N2 PB1 330 ;Diodo led1 conectado a PB0 usando la resistencia R1 ; Diodo led2 conectado a PB1 usando la resistencia R2 Luego de escribir estas líneas de texto se compila (presionar la tecla F9), apareciendo una carita feliz en la ventana de mensajes. Si algo no está correcto debemos corregir y compilar otra vez. Figura 6: Se muestra las líneas de texto que define el Hardware del proyecto y su compilación. Cuarto Paso: EDICIÓN DEL PROGRAMA Abra la ventana de trabajo ejemplo1.hex, para escribir el programa (Antes de escribir el siguiente programa borre todas las líneas de texto que aparecen) Algoritmo del programa: Se configura 2 pines del puerto B como salida Se prende 2 leds con nivel bajo. A continuación se muestra el programa con las directivas necesarias del VMLAB, que permitirá compilar y simular su funcionamiento Curso de actualización de Microcontroladores Atmega8 33 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Figura 7. Se muestra el programa en leguaje ensamblador Quinto Paso: ENSAMBLAJE Y DEPURACIÓN DEL PROGRAMA Para ensamblar el programa presione la tecla F9 ó puede utilizar la opción (haciendo un clic) que se muestra en la siguiente figura. Build (F9) De la barra de herramientas Figura 8: Forma de ensamblar un programa Curso de actualización de Microcontroladores Atmega8 34 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Si al momento de compilar no existe ningún error aparecerá en la ventana de mensajes un símbolo similar a una carita feliz, con un texto Succes! All ready to run, como en la siguiente figura simplificada (Si hay errores se debe corregir el programa): Figura 9 4.2. USO DEL SIMULADOR Paso 1: Para observar nuestros resultados activaremos las siguientes opciones de la barra de herramientas View: Panel de control: Permite observar los leds, interruptores/pulsadores, potenciómetro I/O ports : Para observar las modificaciones de los puertos B, C y D y sus registros asociados. Register/flags: Para ver los registros de propósito general (R0 a R31) y de control, Flags, PC Figura 10. Se observan los leds, los registros y los puertos que presenta el VMLAB Curso de actualización de Microcontroladores Atmega8 35 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Paso 2: Podemos simular el funcionamiento del proyecto de 2 maneras: 1) Ejecutando el Programa paso a paso (instrucción por instrucción). Se utiliza las teclas F6 ó F7.(también se puede usar los botones del menú (Step Over) ó (Step into)) 2) Ejecutando todo el programa . Se utiliza la tecla F5 ò los botones del menú GO/Continue Go (F5) De la barra de herramientas Figura 11 Obteniéndose el siguiente resultado: se comprueba los valores de los registros R20,R16, DDRB, PORTB y se prenden 2 leds, como se observa en la siguiente figura: Figura 12: Se observa los resultados obtenidos Curso de actualización de Microcontroladores Atmega8 36 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Ejercicio 1: Modifique su programa para prender los leds, cuando los pines de salida del microcontrolador tienen un nivel alto “1”, para esto en el archivo ejemplo1.prj, introduzca el uso de la compuerta NAND de 2 entradas para simular un inversor y luego haga los cambios necesarios en el programa. Use la librería del VMLAB para la sintaxis respectiva. Figura No.13 Ejemplo No, 2: El objetivo de este proyecto es controlar 2 leds usando un interruptor. Condiciones: El interruptor está conectado al pin PB7, usando una resistencia pull up (resistencia a fuente de 5 V.) Los diodos leds están conectados a los pines PB0 y PB7. Se prenden cuando se cierra el interruptor. Circuito esquemático: Figura No.14 Programa: De acuerdo a los pasos anteriores, compruebe el funcionamiento del siguiente programa, creando un nuevo proyecto en el entorno VMLAB: ; ****************************************************** Curso de actualización de Microcontroladores Atmega8 37 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA ; * Laboratorio de sistemas digitales ; * El Programa prende 2 leds, mediante un interruptor ; * Entrada: 1 pulsador, conectado al pin PB7 ; * Salida: 2 leds, conectados a PB0 y PB1 ; ****************************************************** .include "C:\VMLAB\include\m8def.inc"; .cseg .org $0 rjmp inicio inicio: ldi R16,0b00000011 ; Configuro PB0 y PB1 como salida y PB7 como entrada out DDRB,R16 ;utilizando el registro DDRB lazo: in R16,PINB andi R16,0b10000000 ; ==> Filtro solo el pin PB7. ; Leo los pines del puerto B, pero solo interesa cpi R16,0b00000000 ; breq SWcerrado ldi R16,0b11111111 ; Si el interruptor esta abierto los leds están PB7 analizo si el interruptor está cerrado ¿PB7=0? ; Si el interruptor esta cerrado, prendo los leds ;apagados out PORTB,R16 rjmp lazo ; retorno para una nueva lectura SWcerrado: ldi R16,0b11111100 ;Se escribe "0" lógico para prender los leds out PORTB,R16 rjmp lazo Archivo que define el circuito esquemático del proyecto: D1 VDD N1 ; diodo led D1 conectado al pin PB0 usando la Resistencia R1 de 330Ω R1 N1 PB0 330; D2 VDD N2 R2 N2 PB1 K0 PB7 VSS R3 VDD PB7 ; diodo led D2 conectado a PB1 usando la Resistencia R2 de 330Ω 330 latched 10K ; interruptor K0 conectado al pin PB7 con una ; resistencia de 10K, conectado a la fuente VDD. Curso de actualización de Microcontroladores Atmega8 38 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Ejercicio 2 Ejecute nuevamente el programa pero borre la palabra latched en el archivo *.prj Con lo que tendremos un pulsador. Ensamble el programa y compruebe su funcionamiento usando el control panel del VMLAB Ejemplo No. 3: El objetivo de este proyecto es controlar 2 diodos leds usando un pulsador. Los leds, se prenden luego de presionar y soltar un pulsador Considere: Entrada: 1 pulsador conectado al pin PC5 Salida: 2 diodos leds conectados a PB0 y PB1 Circuito esquemático: Figura No.15 Diagrama de flujo Dibujar el diagrama de flujo Curso de actualización de Microcontroladores Atmega8 39 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA ;Programa ; ****************************************************** ;El programa prende 2 leds, luego de presionar y soltar un pulsador ;Entrada: 1 pulsador conectado al pin PC5 ;Salida: 2 leds conectados a PB0 y PB1 ; ****************************************************************** .include "C:\VMLAB\include\m8def.inc"; .cseg .org $0 rjmp inicio inicio: ldi R16,0b00000011 ; Configuro PB0 y PB1 como salida out DDRB,R16 ldi R18,0b11111111 ;inicialmente los leds están apagados out PORTB,R18 ;utilizando el registro DDRB ;el pulsador está conectado a PC5 PulsadorNoPresionado: in R20,PINC ;lectura del pulsador, para analizar si está presionado andi R20,0b00100000 ; ==> Filtro solo el pin PC5. cpi R20,0 ; breq PulsadorNoPresionado ; analizo el pin 5 (PC5) ¿El Pulsador está presionado? ;El pulsador está presionado, cuando PC5= 5 voltios (Ver el circuito) SoltarPulsador: in r20,PINC ;lectura del pulsador, para ver si soltó el pulsador andi R20,0b00100000 ; se filtra solo el pin PC5 cpi R20,0 ;¿Soltó el pulsador? brne SoltarPulsador ; todavía el pulsador sigue presionado ;Se soltó el pulsador ; Luego de presionar y soltar el pulsador se prende los 2 leds ldi R18,0b11111100 ;Se escribe "0" lógico para prender los leds ;(ver el circuito) out lazo: rjmp PORTB,R18 lazo Curso de actualización de Microcontroladores Atmega8 40 PONTIFICIA UNIVERSIDAD CATOLICA DEL PERU FACULTAD DE CIENCIAS E INGENIERIA SECCION ELECTRICIDAD Y ELECTRONICA Definición del circuito esquemático(*.prj): D1 VDD N1 R1 N1 PB0 D2 VDD N2 R2 N2 PB1 K3 VDD PC5 R3 PC5 VSS ; diodo D1 conectado al pin PB0 usando la Resistencia R1 de 330Ω 330; ; diodo led D2 conectado a PB1 usando la Resistencia R2 de 330Ω 330 ; pulsador conectado al pin PC5 10K ; usando la resistencia R3 de 10K, conectado a Tierra. . Material de trabajo elaborado por: Zenón Cucho Mendoza Diciembre de 2006 Curso de actualización de Microcontroladores Atmega8 41