

# Sistemas Digitales: Introducción a los microcontroladores Parte 1

Ingeniería Electrónica  
UPC 2018

Por Kalun Lau

# Microcontroladores



- Dispositivo programable "todo en uno" para desarrollar aplicaciones en electrónica.
- Es "la solución en un chip"  muy específicos

Ej.:



Tiene un montón de periféricos :-

- Mouse - Sound card
- Keyboard - Video card
- HDD - DVD
- Ethernet - USB

Fabricantes: (Microchip, Renesas, NXP, ST, etc)



↳ se desarrollaron muchas aplicaciones (IN)

↳ bajo costo

↳ muchos desarrolladores lo emplean para aplicaciones de control de procesos industriales y comerciales

# Arquitectura Von Neumann



# Arquitectura Harvard:



Nosotros usaremos el PIC18F4550!

40-Pin PDIP → cuarenta pines!



Tecnología  
CMOS

VDD = 5V  
VSS = 0V

VDD mínimo:  
3.0V (F)  
2.0V (LF)

VDD máximo:  
5.5V (F y LF)

# Características Especiales PIC18F

- Amplio Voltaje de operación: 2.0V a 5.5V
- Memoria de Programa Flash Mejorada con 100,000 ciclos de borrado/escritura
- Memoria de Datos EEPROM con 1,000,000 de ciclos de borrado/escritura
- Retención de Datos en Memoria EEPROM Flash/Data : 100 años típico

# Watchdog Timer

- Ayuda al software a recuperarse de un mal funcionamiento
- Usa un oscilador libre RC en el chip
- WDT es borrado por la instrucción CLRWDT
- WDT Habilitable (WDTEN) no puede ser borrado por soft
- el overflow (desborde) del WDT reeeeta al chip
- Período del timeout programable : 18ms a 3.0s típico
- Opera en modo SLEEP; sobre el time out, despierta la CPU.



# Generador de Reset Interno

## ■ POR: Power On Reset

- con MCLR atado a  $V_{DD}$ , es generado un pulso de RESET cuando el flanco de subida a  $V_{DD}$  es detectado

## ■ PWRT: Power Up Timer

- 72 ms (nominal)
- Desacoplado del BOR

## ■ OST: Oscillator Startup Timer

- Mantiene en RESET al dispositivo por 1024 cyclos de maquina (TCYs)
- Le permite al cristal o al resonador estabilizarse
- Bypaseado en: Two Speed Startup Mode
  - INTOSC usa un clock para el procesador no estable



# **BOR –Brown Out Reset**

- Cuando el voltaje cae por debajo de un umbral particular, el dispositivo se pone en RESET
- Impide el funcionamiento irregular o inesperado
- Elimina la necesidad de un circuito externo BOR

# PBOR – Programmable Brown Out Reset

- Opción de configuración (fijado en tiempo de programa)
  - No puede ser activado/desactivado por software
- Cuatro puntos de disparo BVDD seleccionables
  - 2.5V – Mini V<sub>DD</sub> para OTP MCUs PICmicro®
  - 2.7V
  - 4.2V
  - 4.5V
- Para otros umbrales use un supervisor externo (MCP1xx, MCP8xx/TCM8xx, or TC12xx)

## Fuentes de reloj:

- Cristal externo:

4 MHz, 8 MHz, 10 MHz  
20 MHz hasta 48 MHz



- Oscilador interno: 8 MHz  
configurable



oscilador RC  
varía su presión  
con la temperatura

Configuración inicial a detalle:



FOSC: XT-XT  
(bit de configuración)

Opción para usar el  
oscilador interno:

FOSC: INTOSC50-EC  
(bit de configuración)



PLL: Sistema que permite multiplicar la frecuencia del cristal externo.

Ojo: Solo se puede usar una fuente de reloj

¿Cómo se programa?

→ Lenguaje ensamblador (MPASM) ✓

→ PBasic compiler ([melabs.com](http://melabs.com), USD249.99)

→ C → XC8 ([microchip.com](http://microchip.com))

→ CCS C Compiler

→ mikroC compiler ([mikroe.com](http://mikroe.com))

# Herramientas de desarrollo para el microcontrolador PIC18F4550



Microchip:  
MPLAB X (última versión: 5.05)  
([www.microchip.com/mplab-x-ide](http://www.microchip.com/mplab-x-ide))

Labcenter:  
Proteus VSM (virtual system modelling)  
Se desarrollará el código  
Se harán las simulaciones

# Manejo de puertos de E/S en el microcontrolador PIC18F4550:

|                                    |    |  |    |                                  |
|------------------------------------|----|--|----|----------------------------------|
| MCLR/VPP/RE3                       | 1  |  | 40 | RB7/KBI3/PGD                     |
| RA0/AN0                            | 2  |  | 39 | RB6/KBI2/PGC                     |
| RA1/AN1                            | 3  |  | 38 | RB5/KBI1/PGM                     |
| RA2/AN2/VREF-/CVREF                | 4  |  | 37 | RB4/AN11/KBI0/CSSPP              |
| RA3/AN3/VREF+                      | 5  |  | 36 | RB3/AN9/CCP2 <sup>(1)</sup> /VPO |
| RA4/T0CKI/C1OUT/RCV                | 6  |  | 35 | RB2/AN8/INT2/VMO                 |
| RA5/AN4/SS/HVDIN/C2OUT             | 7  |  | 34 | RB1/AN10/INT1/SCK/SCL            |
| RE0/AN5/CK1SPP                     | 8  |  | 33 | RB0/AN12/INT0/FLT0/SDI/SDA       |
| RE1/AN6/CK2SPP                     | 9  |  | 32 | VDD                              |
| RE2/AN7/OESPP                      | 10 |  | 31 | Vss                              |
| VDD                                | 11 |  | 30 | RD7/SPP7/P1D                     |
| Vss                                | 12 |  | 29 | RD6/SPP6/P1C                     |
| OSC1/CLKI                          | 13 |  | 28 | RD5/SPP5/P1B                     |
| OSC2/CLKO/RA6                      | 14 |  | 27 | RD4/SPP4                         |
| RC0/T1OSO/T13CKI                   | 15 |  | 26 | RC7/RX/DT/SDO                    |
| RC1/T1OSI/CCP2 <sup>(1)</sup> /UOE | 16 |  | 25 | RC6/TX/CK                        |
| RC2/CCP1/P1A                       | 17 |  | 24 | RC5/D+/VP                        |
| VUSB                               | 18 |  | 23 | RC4/D-/VM                        |
| RD0/SPP0                           | 19 |  | 22 | RD3/SPP3                         |
| RD1/SPP1                           | 20 |  | 21 | RD2/SPP2                         |

PIC18F4455

PIC18F4550

TIP: Declarar si es E o S antes de usar el puerto.



Registros para manejar los puertos de E/S.

- En modo digital E/S: R<sub>X</sub>Y<sub>Y</sub>, donde Y es el número del puerto, X es la letra del puerto.
- Algunos puertos son o solo "E" o solo "S".

# Ruta de datos del PIC18F4550



Registros  
y  
Memoria de  
datos (RSM)

# MPASM: Instrucciones de movimiento de datos

## MOVLW Move literal to W

Syntax: [label] MOVLW k

Operands:  $0 \leq k \leq 255$

Operation:  $k \rightarrow W$

Status Affected: None

Encoding: 

|      |      |      |      |
|------|------|------|------|
| 0000 | 1110 | kkkk | kkkk |
|------|------|------|------|

Description: The eight-bit literal 'k' is loaded into W.

Words: 1

Cycles: 1

Q Cycle Activity:

| Q1     | Q2               | Q3           | Q4         |
|--------|------------------|--------------|------------|
| Decode | Read literal 'k' | Process Data | Write to W |

Example: MOVLW 0x5A

After Instruction

W = 0x5A



mueve el numero literal 0x5A a W reg

# MPASM: Instrucciones de movimiento de datos

| MOVWF             | Move W to f                                                                                                                                                                                                                              |              |                    |      |      |        |                   |              |                    |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------------|------|------|--------|-------------------|--------------|--------------------|
| Syntax:           | [label] MOVWF f [,a]                                                                                                                                                                                                                     |              |                    |      |      |        |                   |              |                    |
| Operands:         | $0 \leq f \leq 255$<br>$a \in [0,1]$                                                                                                                                                                                                     |              |                    |      |      |        |                   |              |                    |
| Operation:        | $(W) \rightarrow f$                                                                                                                                                                                                                      |              |                    |      |      |        |                   |              |                    |
| Status Affected:  | None                                                                                                                                                                                                                                     |              |                    |      |      |        |                   |              |                    |
| Encoding:         | <table border="1"><tr><td>0110</td><td>111a</td><td>ffff</td><td>ffff</td></tr></table>                                                                                                                                                  | 0110         | 111a               | ffff | ffff |        |                   |              |                    |
| 0110              | 111a                                                                                                                                                                                                                                     | ffff         | ffff               |      |      |        |                   |              |                    |
| Description:      | Move data from W to register 'f'. Location 'f' can be anywhere in the 256 byte bank. If 'a' is 0, the Access Bank will be selected, overriding the BSR value. If 'a' = 1, then the bank will be selected as per the BSR value (default). |              |                    |      |      |        |                   |              |                    |
| Words:            | 1                                                                                                                                                                                                                                        |              |                    |      |      |        |                   |              |                    |
| Cycles:           | 1                                                                                                                                                                                                                                        |              |                    |      |      |        |                   |              |                    |
| Q Cycle Activity: |                                                                                                                                                                                                                                          |              |                    |      |      |        |                   |              |                    |
|                   | <table border="1"> <tr> <th>Q1</th><th>Q2</th><th>Q3</th><th>Q4</th> </tr> <tr> <td>Decode</td><td>Read register 'f'</td><td>Process Data</td><td>Write register 'f'</td></tr> </table>                                                  | Q1           | Q2                 | Q3   | Q4   | Decode | Read register 'f' | Process Data | Write register 'f' |
| Q1                | Q2                                                                                                                                                                                                                                       | Q3           | Q4                 |      |      |        |                   |              |                    |
| Decode            | Read register 'f'                                                                                                                                                                                                                        | Process Data | Write register 'f' |      |      |        |                   |              |                    |

Example: MOVWF REG, 0

Before Instruction

|     |   |      |
|-----|---|------|
| W   | = | 0x4F |
| REG | = | 0xFF |

After Instruction

|     |   |      |
|-----|---|------|
| W   | = | 0x4F |
| REG | = | 0x4F |

mueve el contenido de W hacia REG



# MPASM: Instrucciones de movimiento de datos

| MOVF              | Move f                                                                                                                                                                                                                                                                                                                                                                                                     |                   |              |         |      |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------|---------|------|
| Syntax:           | [label] MOVF f [,d [,a]]                                                                                                                                                                                                                                                                                                                                                                                   |                   |              |         |      |
| Operands:         | $0 \leq f \leq 255$<br>$d \in [0,1]$<br>$a \in [0,1]$                                                                                                                                                                                                                                                                                                                                                      |                   |              |         |      |
| Operation:        | $f \rightarrow \text{dest}$                                                                                                                                                                                                                                                                                                                                                                                |                   |              |         |      |
| Status Affected:  | N, Z                                                                                                                                                                                                                                                                                                                                                                                                       |                   |              |         |      |
| Encoding:         | <table border="1"> <tr> <td>0101</td> <td>00da</td> <td>ffff</td> <td>ffff</td> </tr> </table>                                                                                                                                                                                                                                                                                                             | 0101              | 00da         | ffff    | ffff |
| 0101              | 00da                                                                                                                                                                                                                                                                                                                                                                                                       | ffff              | ffff         |         |      |
| Description:      | The contents of register 'f' are moved to a destination dependent upon the status of 'd'. If 'd' is 0, the result is placed in W. If 'd' is 1, the result is placed back in register 'f' (default). Location 'f' can be anywhere in the 256 byte bank. If 'a' is 0, the Access Bank will be selected, overriding the BSR value. If 'a' = 1, then the bank will be selected as per the BSR value (default). |                   |              |         |      |
| Words:            | 1                                                                                                                                                                                                                                                                                                                                                                                                          |                   |              |         |      |
| Cycles:           | 1                                                                                                                                                                                                                                                                                                                                                                                                          |                   |              |         |      |
| Q Cycle Activity: |                                                                                                                                                                                                                                                                                                                                                                                                            |                   |              |         |      |
|                   | Q1      Q2      Q3      Q4                                                                                                                                                                                                                                                                                                                                                                                 |                   |              |         |      |
|                   | Decode                                                                                                                                                                                                                                                                                                                                                                                                     | Read register 'f' | Process Data | Write W |      |

Example: MOVF REG, 0, 0

|                    |        |
|--------------------|--------|
| Before Instruction |        |
| REG                | = 0x22 |
| W                  | = 0xFF |
| After Instruction  |        |
| REG                | = 0x22 |
| W                  | = 0x22 |



mueve el contenido  
de REG hacia W ( $d=0$ )

si movf REG,1 : moverá el  
contenido hacia si mismo!  
actualizará el estado de las banderas!

# MPASM: Instrucciones de movimiento de datos

| MOVFF              | Move f to f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |              |                          |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------------------|
| Syntax:            | [label] MOVFF f <sub>s</sub> ,f <sub>d</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |              |                          |
| Operands:          | 0 ≤ f <sub>s</sub> ≤ 4095<br>0 ≤ f <sub>d</sub> ≤ 4095                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |              |                          |
| Operation:         | (f <sub>s</sub> ) → f <sub>d</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |              |                          |
| Status Affected:   | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |              |                          |
| Encoding:          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |                          |
| 1st word (source)  | 1100 ffff ffff fffff <sub>s</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                          |
| 2nd word (destin.) | 1111 ffff ffff fffff <sub>d</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                          |
| Description:       | The contents of source register 'f <sub>s</sub> ' are moved to destination register 'f <sub>d</sub> '. Location of source 'f <sub>s</sub> ' can be anywhere in the 4096 byte data space (000h to FFFh), and location of destination 'f <sub>d</sub> ' can also be anywhere from 000h to FFFh. Either source or destination can be W (a useful special situation). MOVFF is particularly useful for transferring a data memory location to a peripheral register (such as the transmit buffer or an I/O port). The MOVFF instruction cannot use the PCL, TOSU, TOSH or TOSL as the destination register. |              |                          |
| Note:              | The MOVFF instruction should not be used to modify interrupt settings while any interrupt is enabled. See Section 8.0 for more information.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |              |                          |
| Words:             | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                          |
| Cycles:            | 2 (3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |              |                          |
| Q Cycle Activity:  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |                          |
| Q1                 | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Q3           | Q4                       |
| Decode             | Read register f' (src)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Process Data | No operation             |
| Decode             | No operation<br>No dummy read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | No operation | Write register f' (dest) |

Example: MOVFF REG1, REG2

Before Instruction  
REG1 = 0x33  
REG2 = 0x11

After Instruction  
REG1 = 0x33  
REG2 = 0x33

Mueve el contenido de REG1 hacia REG2



ojo: MOVFF demora dos ciclos en ejecutarse

# Estructura de la memoria de programa



- Memoria de programa de 8 bits de ancho, 32K de capacidad.
- Los instrucciones ocupan 2 bytes (cada una)
- El contador de programa (PC) se incrementa de 2 en 2.
- Se puede usar la memoria de programa para almacenar datos (8 bits)

- # MPASM - Instrucciones
- Manipulación de bit en un registro (bsf, bcf)
  - Pregunta de bit en un registro (btfs, btfsc)
  - Salto incondicional (goto)



# Simulación en Proteus



# Usando el “stopwatch” del modo simulador del MPLAB X para obtener la duración de la subrutina de retardo



Ventana de propiedades del proyecto

10  
Selecciónas "Simulator"



20  
Frecuencia del