Download Microcontroladores Atmega8

Document related concepts
no text concepts found
Transcript
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