

# Microcontroladores

Semestre: 2021-2

Profesor: Kalun José Lau Gan

Semana 7: Conversión A/D y Multitarea en microcontroladores

1

## ¿Preguntas previas?

- Si el PIC18F4550 esta entrando a la etapa de madurez. ¿Por qué no se usa el PIC18F45K50?

### Part Number: PIC18F4550-I/P

Upload your code to this device for as low as \$0.23

Lead Count: 40

Package Type: PDIP

Temp Range: -40C to +85C



#### Standard Pricing ?

(Buy Now Price, Any Volume)

#### \*Estimated Pricing ?

(Requires Approved Quote)

#### Product Details

#### Order Quantity

#### USD per Unit

|       |        |
|-------|--------|
| 1-24  | \$4.76 |
| 25-99 | \$4.64 |
| 100+  | \$4.54 |

#### Order Quantity

#### USD per Unit

|           |         |
|-----------|---------|
| 1000-4999 | *\$4.17 |
| 5000+     | *\$3.96 |

\*Request Quote for Larger Quantities

### Part Number: PIC18F45K50-I/P

Upload your code to this device for as low as \$0.23

Lead Count: 40

Package Type: PDIP

Temp Range: -40C to +85C



#### Standard Pricing ?

(Buy Now Price, Any Volume)

#### \*Estimated Pricing ?

(Requires Approved Quote)

#### Product Details

#### Order Quantity

#### USD per Unit

|       |        |
|-------|--------|
| 1-24  | \$2.93 |
| 25-99 | \$2.69 |
| 100+  | \$2.43 |

#### Order Quantity

#### USD per Unit

|           |         |
|-----------|---------|
| 1000-4999 | *\$2.24 |
| 5000+     | *\$2.13 |

\*Request Quote for Larger Quantities

2

## Agenda:

- Conversión A/D
- Multitarea
- Múltiples interrupciones
- Ejemplos de multitarea

3

## Diseño: Reloj en el PIC18F4550



4

Diseño: Reloj en el PIC18F4550

- El display es del tipo multiplexado de 4 dígitos de siete segmentos cátodo común.
    - Revisar rutina para la decodificación de números en siete segmentos (se recomienda el empleo de TBLPTR).
    - Revisar rutina de multiplexación en displays de siete segmentos.
    - Revisar rutina de individualización de dígitos de un registro de 8 bits.
  - El módulo Timer1 en modo RTC.
    - Contemplar el uso del cristal 32.768KHz (en implementación) o fuente de reloj de 32.768KHz (en simulación en Proteus)
    - Revisar rutina de interrupción para asegurarse de que se cumpla la carga de cuenta inicial dentro de los 15.25μs.
  - Sistema de cuenta del reloj.
    - Considerando Sistema 24H: 00:00:00 – 23:59:59
    - Opción de ingreso de la hora actual (ej: Interrupciones externas)
    - Estrategia para poder visualizar el formato completo de la hora

5

## Avance del código:

6

## Repaso de conocimientos:

¿Tipos de señales? → Continuo  
Discretas

¿Por qué digitalizamos señales?

procesar ✓  
almacenar ✓  
transfuir

Mejor que  
en analógico



Audios:  $20\text{Hz} \sim 20\text{kHz}$  → Calidad CD en audio digital  
 $f_s = 44100\text{Hz}$  16 bits

7

## Conversor A/D

Revisar Capítulo 21 de la hoja técnica del PIC18F4550

- Resolución:
- Cantidad de canales analógicos:
- Tiempo de adquisición:
- Rango de voltaje de entrada:
- ¿Cuáles son los valores límites de Vref+ y Vref-?
- Proceso de adquisición de una señal analógica
- ¿Interviene el teorema de muestreo?
- ¿Hay interrupciones?

8

## Conversor A/D

- Resolución: 10bits (ADRESH:ADRESL)
  - Posee un bit ADFM (justificación del resultado)
- Cantidad de canales analógicos: 13
  - **Se lee un canal analógico a la vez**
- ¿Interviene el teorema de muestreo? Si.
- Tiempo de adquisición: se configura en reg. ADCON2
- Rango de voltaje de entrada: 0-5V? ( $V_{ref+} = VDD$ ,  $V_{ref-} = VSS$ )
- Proceso de adquisición de una señal analógica (ver datasheet)
- ¿Hay interrupciones? Si. ADIE, ADIF

9

## Conversor A/D: Diagrama de bloques



10

## Registros de configuración para el A/D:

| REGISTER 21-1: ADCON0: A/D CONTROL REGISTER 0 |                                                                                                               |                                    |       |                    |       |         |       |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------|------------------------------------|-------|--------------------|-------|---------|-------|
| U-0                                           | U-0                                                                                                           | R/W-0                              | R/W-0 | R/W-0              | R/W-0 | R/W-0   | R/W-0 |
| —                                             | —                                                                                                             | CHS3                               | CHS2  | CHS1               | CHS0  | GO/DONE | ADON  |
| bit 7                                         |                                                                                                               |                                    |       |                    |       | bit 0   |       |
| <b>Legend:</b>                                |                                                                                                               |                                    |       |                    |       |         |       |
| R = Readable bit                              | W = Writable bit                                                                                              | U = Unimplemented bit, read as '0' |       |                    |       |         |       |
| -n = Value at POR                             | '1' = Bit is set                                                                                              | '0' = Bit is cleared               |       | x = Bit is unknown |       |         |       |
| bit 7-6                                       | <b>Unimplemented:</b> Read as '0'                                                                             |                                    |       |                    |       |         |       |
| bit 5-2                                       | <b>CHS3:CHS0:</b> Analog Channel Select bits                                                                  |                                    |       |                    |       |         |       |
| 0000                                          | Channel 0 (AN0)                                                                                               |                                    |       |                    |       |         |       |
| 0001                                          | Channel 1 (AN1)                                                                                               |                                    |       |                    |       |         |       |
| 0010                                          | Channel 2 (AN2)                                                                                               |                                    |       |                    |       |         |       |
| 0011                                          | Channel 3 (AN3)                                                                                               |                                    |       |                    |       |         |       |
| 0100                                          | Channel 4 (AN4)                                                                                               |                                    |       |                    |       |         |       |
| 0101                                          | Channel 5 (AN5) <sup>(1,2)</sup>                                                                              |                                    |       |                    |       |         |       |
| 0110                                          | Channel 6 (AN6) <sup>(1,2)</sup>                                                                              |                                    |       |                    |       |         |       |
| 0111                                          | Channel 7 (AN7) <sup>(1,2)</sup>                                                                              |                                    |       |                    |       |         |       |
| 1000                                          | Channel 8 (AN8)                                                                                               |                                    |       |                    |       |         |       |
| 1001                                          | Channel 9 (AN9)                                                                                               |                                    |       |                    |       |         |       |
| 1010                                          | Channel 10 (AN10)                                                                                             |                                    |       |                    |       |         |       |
| 1011                                          | Channel 11 (AN11)                                                                                             |                                    |       |                    |       |         |       |
| 1100                                          | Channel 12 (AN12)                                                                                             |                                    |       |                    |       |         |       |
| 1101                                          | Unimplemented <sup>(2)</sup>                                                                                  |                                    |       |                    |       |         |       |
| 1110                                          | Unimplemented <sup>(2)</sup>                                                                                  |                                    |       |                    |       |         |       |
| 1111                                          | Unimplemented <sup>(2)</sup>                                                                                  |                                    |       |                    |       |         |       |
| bit 1                                         | <b>GO/DONE:</b> A/D Conversion Status bit<br>When ADON = 1:<br>1 = A/D conversion in progress<br>0 = A/D Idle |                                    |       |                    |       |         |       |
| bit 0                                         | <b>ADON:</b> A/D On bit<br>1 = A/D converter module is enabled<br>0 = A/D converter module is disabled        |                                    |       |                    |       |         |       |

| REGISTER 21-2: ADCON1: A/D CONTROL REGISTER 1 |                                                                                                |                                    |                 |                      |                    |                    |                    |
|-----------------------------------------------|------------------------------------------------------------------------------------------------|------------------------------------|-----------------|----------------------|--------------------|--------------------|--------------------|
| U-0                                           | U-0                                                                                            | R/W-0                              | R/W-0           | R/W-0 <sup>(1)</sup> | R/W <sup>(1)</sup> | R/W <sup>(1)</sup> | R/W <sup>(1)</sup> |
| —                                             | —                                                                                              | VCFG1                              | VCFG0           | PCFG3                | PCFG2              | PCFG1              | PCFG0              |
| bit 7                                         |                                                                                                |                                    |                 |                      |                    |                    | bit 0              |
| <b>Legend:</b>                                |                                                                                                |                                    |                 |                      |                    |                    |                    |
| R = Readable bit                              | W = Writable bit                                                                               | U = Unimplemented bit, read as '0' |                 |                      |                    |                    |                    |
| -n = Value at POR                             | '1' = Bit is set                                                                               | '0' = Bit is cleared               |                 | x = Bit is unknown   |                    |                    |                    |
| bit 7-6                                       | <b>Unimplemented:</b> Read as '0'                                                              |                                    |                 |                      |                    |                    |                    |
| bit 5                                         | <b>VCFG1:</b> Voltage Reference Configuration bit (VREF- source)<br>1 = VREF- (AN2)<br>0 = VSS |                                    |                 |                      |                    |                    |                    |
| bit 4                                         | <b>VCFG0:</b> Voltage Reference Configuration bit (VREF+ source)<br>1 = VREF+ (AN3)<br>0 = VDD |                                    |                 |                      |                    |                    |                    |
| bit 3-0                                       | <b>PCFG3:PCFG0:</b> A/D Port Configuration Control bits:                                       |                                    |                 |                      |                    |                    |                    |
|                                               | <b>PCFG3:</b>                                                                                  | A <sub>12</sub>                    | A <sub>11</sub> | A <sub>10</sub>      | A <sub>9</sub>     | A <sub>8</sub>     | A <sub>7(2)</sub>  |
|                                               | <b>PCFG0:</b>                                                                                  | A                                  | A               | A                    | A                  | A                  | A                  |
| 0000 <sup>(1)</sup>                           | A                                                                                              | A                                  | A               | A                    | A                  | A                  | A                  |
| 0001                                          | A                                                                                              | A                                  | A               | A                    | A                  | A                  | A                  |
| 0010                                          | A                                                                                              | A                                  | A               | A                    | A                  | A                  | A                  |
| 0011                                          | D                                                                                              | A                                  | A               | A                    | A                  | A                  | A                  |
| 0100                                          | D                                                                                              | D                                  | A               | A                    | A                  | A                  | A                  |
| 0101                                          | D                                                                                              | D                                  | A               | A                    | A                  | A                  | A                  |
| 0110                                          | D                                                                                              | D                                  | D               | A                    | A                  | A                  | A                  |
| 0111 <sup>(1)</sup>                           | D                                                                                              | D                                  | D               | D                    | A                  | A                  | A                  |
| 1000                                          | D                                                                                              | D                                  | D               | D                    | A                  | A                  | A                  |
| 1001                                          | D                                                                                              | D                                  | D               | D                    | D                  | A                  | A                  |
| 1010                                          | D                                                                                              | D                                  | D               | D                    | D                  | A                  | A                  |
| 1011                                          | D                                                                                              | D                                  | D               | D                    | D                  | D                  | A                  |
| 1100                                          | D                                                                                              | D                                  | D               | D                    | D                  | D                  | A                  |
| 1101                                          | D                                                                                              | D                                  | D               | D                    | D                  | D                  | A                  |
| 1110                                          | D                                                                                              | D                                  | D               | D                    | D                  | D                  | A                  |
| 1111                                          | D                                                                                              | D                                  | D               | D                    | D                  | D                  | D                  |
| A = Analog input                              |                                                                                                |                                    |                 |                      |                    |                    |                    |
| D = Digital I/O                               |                                                                                                |                                    |                 |                      |                    |                    |                    |

11

## Registros de configuración para el A/D:

| REGISTER 21-3: ADCON2: A/D CONTROL REGISTER 2 |                                                                                                                                                                                                                                                                                               |                                    |       |                    |       |       |       |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-------|--------------------|-------|-------|-------|
| R/W-0                                         | U-0                                                                                                                                                                                                                                                                                           | R/W-0                              | R/W-0 | R/W-0              | R/W-0 | R/W-0 | R/W-0 |
| ADFM                                          | —                                                                                                                                                                                                                                                                                             | ACQT2                              | ACQT1 | ACQT0              | ADCS2 | ADCS1 | ADCS0 |
| bit 7                                         |                                                                                                                                                                                                                                                                                               |                                    |       |                    |       |       | bit 0 |
| <b>Legend:</b>                                |                                                                                                                                                                                                                                                                                               |                                    |       |                    |       |       |       |
| R = Readable bit                              | W = Writable bit                                                                                                                                                                                                                                                                              | U = Unimplemented bit, read as '0' |       |                    |       |       |       |
| -n = Value at POR                             | '1' = Bit is set                                                                                                                                                                                                                                                                              | '0' = Bit is cleared               |       | x = Bit is unknown |       |       |       |
| bit 7                                         | <b>ADFM:</b> A/D Result Format Select bit<br>1 = Right justified<br>0 = Left justified                                                                                                                                                                                                        |                                    |       |                    |       |       |       |
| bit 6                                         | <b>Unimplemented:</b> Read as '0'                                                                                                                                                                                                                                                             |                                    |       |                    |       |       |       |
| bit 5-3                                       | <b>ACQT2:ACQT0:</b> A/D Acquisition Time Select bits                                                                                                                                                                                                                                          |                                    |       |                    |       |       |       |
| 111                                           | 20 TAD                                                                                                                                                                                                                                                                                        |                                    |       |                    |       |       |       |
| 110                                           | 16 TAD                                                                                                                                                                                                                                                                                        |                                    |       |                    |       |       |       |
| 101                                           | 12 TAD                                                                                                                                                                                                                                                                                        |                                    |       |                    |       |       |       |
| 100                                           | 8 TAD                                                                                                                                                                                                                                                                                         |                                    |       |                    |       |       |       |
| 011                                           | 6 TAD                                                                                                                                                                                                                                                                                         |                                    |       |                    |       |       |       |
| 010                                           | 4 TAD                                                                                                                                                                                                                                                                                         |                                    |       |                    |       |       |       |
| 001                                           | 2 TAD                                                                                                                                                                                                                                                                                         |                                    |       |                    |       |       |       |
| 000                                           | 0 TAD <sup>(1)</sup>                                                                                                                                                                                                                                                                          |                                    |       |                    |       |       |       |
| bit 2-0                                       | <b>ADCS2:ADCS0:</b> A/D Conversion Clock Select bits<br>111 = FRC (clock derived from A/D RC oscillator) <sup>(1)</sup><br>110 = Fosc/64<br>101 = Fosc/16<br>100 = Fosc/4<br>011 = FRC (clock derived from A/D RC oscillator) <sup>(1)</sup><br>010 = Fosc/32<br>001 = Fosc/8<br>000 = Fosc/2 |                                    |       |                    |       |       |       |

Procedimiento para adquirir una muestra de una señal analógica:

- Configure el A/D module:
  - Configure analog pins, voltage reference and digital I/O (ADCON1)
  - Select A/D input channel (ADCON2)
  - Select A/D acquisition time (ADCON2)
  - Select A/D conversion clock (ADCON2)
  - Turn on A/D module (ADCON0)
- Configure A/D interrupt (if desired):
  - Clear ADIF bit
  - Set ADIE bit
  - Set GIE bit
- Wait the required acquisition time (if required).
- Start conversion:
  - Set GO/DONE bit (ADCON0 register)
- Wait for A/D conversion to complete, by either:
  - Polling for the GO/DONE bit to be cleared
  - Waiting for the A/D interrupt
- Read A/D Result registers (ADRESH:ADRESL); clear bit ADIF, if required.
- For next conversion, go to step 1 or step 2, as required. The A/D conversion time per bit is defined as TAD. A minimum wait of 3 TAD is required before the next acquisition starts.

12

Para obtener el resultado de la conversión A/D:

FIGURE 11-4: A/D RESULT JUSTIFICATION



13

Ejemplo, leer en AN0 el valor de voltaje de un potenciómetro configurado como divisor de tensión y el resultado en 8 bits emitirlo por el puerto D

Recordando:

$$V_o = V_i \left( \frac{R_2}{R_1+R_2} \right)$$

$V_o = 5 \left( \frac{1k}{2k} \right) = 2.5V$



Diagrama de flujo:



14

## Configuración para el A/D para AN.0:

| REGISTER 21-1: ADCON0: A/D CONTROL REGISTER 0 |       |       |       |       |       |       |        |
|-----------------------------------------------|-------|-------|-------|-------|-------|-------|--------|
| U-0                                           | U-0   | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0  |
| —                                             | —     | CHS0  | CHS1  | CHS2  | CHS3  | CHS0  | G/DONE |
| bit 7                                         | bit 0 |       |       |       |       |       |        |

**Legend:**  
 R = Readable bit      W = Writable bit      U = Unimplemented bit, read as '0'  
 -n = Value at POR      '1' = Bit is set      '0' = Bit is cleared      x = Bit is unknown

bit 7-6      **Unimplemented:** Read as '0'  
 bit 5-2      **CHS3:CHS0:** Analog Channel Select bits  
 0000 = Channel 0 (AN0)  
 0001 = Channel 1 (AN1)  
 0010 = Channel 2 (AN2)  
 0011 = Channel 3 (AN3)  
 0100 = Channel 4 (AN4)  
 0101 = Channel 5 (AN5)<sup>(1)</sup>  
 0110 = Channel 6 (AN6)<sup>(1)</sup>  
 0111 = Channel 7 (AN7)<sup>(1)</sup>  
 1000 = Channel 8 (AN8)  
 1001 = Channel 9 (AN9)  
 1010 = Channel 10 (AN10)  
 1011 = Channel 11 (AN11)  
 1100 = Channel 12 (AN12)  
 1101 = Unimplemented<sup>(2)</sup>  
 1110 = Unimplemented<sup>(2)</sup>  
 1111 = Unimplemented<sup>(2)</sup>

bit 1      **GO/DONE:** A/D Conversion Status bit  
 When ADON = 1:  
 1 = A/D conversion in progress  
 0 = A/D Idle

bit 0      **ADON:** A/D On bit  
 1 = A/D converter module is enabled ✓  
 0 = A/D converter module is disabled

| REGISTER 21-2: ADCON1: A/D CONTROL REGISTER 1 |       |       |       |                      |                    |                    |                    |
|-----------------------------------------------|-------|-------|-------|----------------------|--------------------|--------------------|--------------------|
| U-0                                           | U-0   | R/W-0 | R/W-0 | R/W-0 <sup>(1)</sup> | R/W <sup>(1)</sup> | R/W <sup>(1)</sup> | R/W <sup>(1)</sup> |
| —                                             | —     | VCFG3 | VCFG2 | VCFG1                | PCFG3              | PCFG2              | PCFG1              |
| bit 7                                         | bit 0 |       |       |                      |                    |                    |                    |

**Legend:**  
 R = Readable bit      W = Writable bit      U = Unimplemented bit, read as '0'  
 -n = Value at POR      '1' = Bit is set      '0' = Bit is cleared      x = Bit is unknown

bit 7-6      **Unimplemented:** Read as '0'  
 bit 5      **VCFG1:** Voltage Reference Configuration bit (VREF- source)  
 1 = VREF- (AN2)  
 0 = VSS

bit 4      **VCFG0:** Voltage Reference Configuration bit (VREF+ source)  
 1 = VREF+ (AN3)  
 0 = VDD

bit 3-0      **PCFG3:PCFG0:** A/D Port Configuration Control bits:

| PCFG3:<br>PCFG0     | AN2 | AN1 | AN10 | AN9 | AN8 | AN7 <sup>(2)</sup> | AN6 <sup>(2)</sup> | AN5 <sup>(2)</sup> | AN4 | AN3 | AN2 | AN1 | AN0 |
|---------------------|-----|-----|------|-----|-----|--------------------|--------------------|--------------------|-----|-----|-----|-----|-----|
| 0000 <sup>(1)</sup> | A   | A   | A    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0001                | A   | A   | A    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0010                | A   | A   | A    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0011                | D   | A   | A    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0100                | D   | D   | A    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0101                | D   | D   | D    | A   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0110                | D   | D   | D    | D   | A   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 0111 <sup>(1)</sup> | D   | D   | D    | D   | D   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 1000                | D   | D   | D    | D   | D   | A                  | A                  | A                  | A   | A   | A   | A   | A   |
| 1001                | D   | D   | D    | D   | D   | D                  | A                  | A                  | A   | A   | A   | A   | A   |
| 1010                | D   | D   | D    | D   | D   | D                  | D                  | A                  | A   | A   | A   | A   | A   |
| 1011                | D   | D   | D    | D   | D   | D                  | D                  | D                  | A   | A   | A   | A   | A   |
| 1100                | D   | D   | D    | D   | D   | D                  | D                  | D                  | D   | A   | A   | A   | A   |
| 1101                | D   | D   | D    | D   | D   | D                  | D                  | D                  | D   | D   | A   | A   | A   |
| 1110                | D   | D   | D    | D   | D   | D                  | D                  | D                  | D   | D   | D   | A   | A   |
| 1111                | D   | D   | D    | D   | D   | D                  | D                  | D                  | D   | D   | D   | D   | D   |

A = Analog input      D = Digital I/O

$\text{ADCON1} = \text{\textcircled{0}}\text{\textcircled{X}}\text{\textcircled{0}}$

15

## Conf. del A/D para AN0: (tiempo de adq y just res)

| REGISTER 21-3: ADCON2: A/D CONTROL REGISTER 2 |       |       |       |       |       |       |       |
|-----------------------------------------------|-------|-------|-------|-------|-------|-------|-------|
| R/W-0                                         | U-0   | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| 00                                            | —     | ACQT2 | 00    | ACQT1 | 00    | ACQT0 | 00    |
| bit 7                                         | bit 0 |       |       |       |       |       |       |

**Legend:**  
 R = Readable bit      W = Writable bit      U = Unimplemented bit, read as '0'  
 -n = Value at POR      '1' = Bit is set      '0' = Bit is cleared      x = Bit is unknown

bit 7      **ADFM:** A/D Result Format Select bit  
 1 = Right justified  
 0 = Left justified

bit 6      **Unimplemented:** Read as '0'

bit 5-3      **ACQT2:ACQT0:** A/D Acquisition Time Select bits  
 111 = 20 TAD  
 110 = 16 TAD  
 101 = 12 TAD  
 100 = 8 TAD ✓  
 011 = 6 TAD  
 010 = 4 TAD  
 001 = 2 TAD  
 000 = 0 TAD<sup>(1)</sup>

bit 2-0      **ADCS2:ADCS0:** A/D Conversion Clock Select bits  
 111 = Frc (clock derived from A/D RC oscillator)<sup>(1)</sup>  
 110 = Fosc/64  
 101 = Fosc/16  
 100 = Fosc/4 ✓  
 011 = Frc (clock derived from A/D RC oscillator)<sup>(1)</sup>  
 010 = Fosc/32  
 001 = Fosc/8  
 000 = Fosc/2

$\text{ADCON2} = \text{\textcircled{0}}\text{\textcircled{X}}\text{\textcircled{4}}$

16

## Código en MPASM

```

1 ;Este es un comentario, se le antecede un punto y coma
2 list p=18f4550      ;Modelo del microcontrolador
3 #include <p18f4550.inc>    ;Llamada a la librería de nombre de
4
5 ;Directivas de preprocesador o bits de configuración
6 CONFIG PLLDIV = 1          ; PLL Prescaler Selection bits (N)
7 CONFIG CPUDIV = OSC1_PLL2   ; System Clock Postscaler Selection
8 CONFIG FOSC = XT_XT        ; Oscillator Selection bits (XT or
9 CONFIG FWRT = ON            ; Power-up Timer Enable bit (FWRT)
10 CONFIG BOR = OFF           ; Brown-out Reset Enable bits (BOR)
11 CONFIG WDT = OFF           ; Watchdog Timer Enable bit (WDT)
12 CONFIG CCP2MX = ON          ; CCP2 MUX bit (CCP2 input/output)
13 CONFIG PBADEN = OFF         ; PORTB A/D Enable bit (PORTB<4:0>
14 CONFIG MCORE = ON           ; MCORE Pin Enable bit (MCORE pin enable)
15 CONFIG LVP = OFF            ; Single-Supply ICSP Enable bit (LVP)
16
17 org 0x0000
18 goto init_conf
19
20 org 0x0020
21 init_conf: clrf TRISD      ; RD como salidas
22           movlw 0x24
23           movwf ADCON2      ; 8TAD, FOSC/4 ADFM=0
24           movlw 0x0E
25           movwf ADCON1      ; AN0 habilitado
26           movlw 0x01
27           movwf ADCON0      ; AN0 seleccionado y AD funcionando
28 loop:    bsf ADCON0, 1       ; Inicio la conversion en AN0
29 otro:    btfsc ADCON0, 1     ; Pregunto si ya termino de convertir
30         goto otro
31         movff ADRESH, LATD
32         goto loop
33         end

```

17

## Simulación en Proteus



18

## El sensor de temperatura LM35

- Sensor de temperatura de rampa lineal
- Pendiente de 10mv/°C
- Alimentación 5V
- Reacción lenta ante cambios bruscos de temperatura



### 1 Features

- Calibrated Directly in Celsius (Centigrade)
- Linear + 10-mV/°C Scale Factor
- 0.5°C Ensured Accuracy (at 25°C)
- Rated for Full -55°C to 150°C Range
- Suitable for Remote Applications
- Low-Cost Due to Wafer-Level Trimming
- Operates From 4 V to 30 V
- Less Than 60- $\mu$ A Current Drain
- Low Self-Heating, 0.08°C in Still Air
- Non-Linearity Only  $\pm\frac{1}{4}\%$  Typical
- Low-Impedance Output, 0.1 Ω for 1-mA Load

### 2 Applications

- Power Supplies
- Battery Management
- HVAC
- Appliances

19

## Consideraciones para usar el LM35 con el microcontrolador PIC18F4550

- Recortar la escala para una mayor facilidad en el tratamiento numérico. Ej 0°C a 100°C
- Si recortamos a ese rango (recordando 10mv/°C):
  - 0°C = 0V
  - 100°C = 1V
- El conversor A/D se deberá ajustar el Vref+ a un valor de 1V para que la señal adquirida obtenga todo el rango del A/D.

20

## Circuito de interface del PIC18F4550 con el LM35



Escalamiento de medidas:

| T               | LM35 | A/D (10bits) |
|-----------------|------|--------------|
| 0°C             | 0V   | 0            |
| 100°C           | 1V   | 1023         |
| (ADRESH:ADRESL) |      |              |

21

## Ejemplo: Termómetro con LM35 y display multiplexado de 4 dígitos



22

## (cont...)

- El resultado del A/D en 7 bits nos da el valor de la temperatura sin necesidad de hacer cálculos adicionales si es que ajustamos el Vref+ a 1.27V
- Se requiere de un algoritmo (digbyte) que me permita obtener los dígitos centena, decena y unidad de manera independiente para que en el proceso de multiplexación los tome y se visualice.
  - Digbyte.inc deberá ser incluido en la carpeta Header Files del árbol del proyecto
- Para poder simular el ejemplo en Proteus:
  - Desactivar el T1OSCEN para que el PIC18F4550 reciba una señal cuadrada en T13CKI de 32.768KHz y tener así el RTC

```

1 digbyte MACRO arg0
2   LOCAL    Exit0
3   LOCAL    Exit1
4   LOCAL    Exit2
5
6   clrf     Dig0
7   clrf     Dig1
8   clrf     Dig2
9
10  movf    arg0, w
11  movwf   Digtemp
12  movlw   .100
13  Exit2
14  incf     Dig2, f
15  subwf   Digtemp, f
16  btfsc   STATUS, C
17  goto    Exit2
18  decf     Dig2, f
19  addwf   Digtemp, f
20  Exit1
21  movlw   .10
22  incf     Dig1, f
23  subwf   Digtemp, f
24  btfsc   STATUS, C
25  goto    Exit1
26  decf     Dig1, f
27  addwf   Digtemp, f
28  Exit0
29  movf    Digtemp, w
30  movwf   Dig0
31  ENDM

```

23

## (cont...)

## • Código en MPASM:

```

1 ;Este es un comentario, se le antecede un punto y coma
2 list p=18f4550           ;Modelo del microcontrolador
3 #include <p18f4550.inc>       ;Llamada a la librería de nombre de lo
4 include "digbyte.inc"      ;Llamada a la librería de obtención de
5
6 ;Directivas de preprocesador o bits de configuración
7 CONFIG PLLDIV = 1          ; PLL Prescaler Selection bits (No pa
8 CONFIG CPUDIV = OSC1_PLL2   ; System Clock Postscaler Selection
9 CONFIG FOSC = XT_XT        ; Oscillator Selection bits (XT oscil
10 CONFIG PWRT = ON           ; Power-up Timer Enable bit (PWRT en
11 CONFIG BOR = OFF            ; Brown-out Reset Enable bits (Brown
12 CONFIG WDT = OFF            ; Watchdog Timer Enable bit (WDT disa
13 CONFIG CCP2MX = ON          ; CCP2 MUX bit (CCP2 input/output is
14 CONFIG PBADEN = OFF         ; PORTB A/D Enable bit (PORTB<4:0> p
15 CONFIG MCRL = ON            ; MCRL Pin Enable bit (MCRL pin enable
16 CONFIG LVP = OFF             ; Single-Supply ICSP Enable bit (Sinc
17
18 cblock 0x000
19 temporal                 ;almacenamiento temporal del resultado
20 Dig0
21 Digi
22 Dig2
23 Digtemp                  ;utilizados en la macro digbyte
24 var_lms_x
25 var_lms_y                  ;utilizados en el pequeño retardo
26 endc
27
28 ;Valores de la tabla de búsqueda para el siete segmentos
29 org 0x0400
30 tabla_7s db 0x3F, 0x06, 0x5B, 0x4F, 0x66, 0x6D, 0x7D, 0x07, 0x7E, 0x67
31
32 org 0x0000                ;vector de reset
33 goto init_conf
34
35 org 0x0008                ;vector de interrupción
36 goto TMRI_ISR
37
38 org 0x0020                ;zona de programa de usuario

```

```

40 ;Configuración inicial
41 init_conf: clrf TRISD
42           movlw 0xF0
43           movwf TRISB
44           movlw 0x24
45           movwf ADCON2
46           movlw 0x1E
47           movwf ADCON1
48           movlw 0x01
49           movwf ADCON0
50           movlw 0x04
51           movwf TBLPTRH
52           clrf TBLPTRL
53           movlw 0x0F
54           movwf TICON
55           bcf TICON, TIOSCEN
56           movlw 0xC0
57           movwf THRIH
58           clrf THRL
59           bcf PIE1, THRIIE
60           bcf INTCON, PIE1
61           bcf INTCON, GIE

```

```

63 ;Rutina principal
64 loop:
65   digbyte temporal
66   movff Dig2, TBLPTRL
67   TBLRD*
68   movff TABLAT, LATD
69   bcf LATB, 0
70   call delay_mux
71   bcf LATB, 0
72   movff Digi, TBLPTRL
73   TBLRD*
74   movff TABLAT, LATD
75   baf LATB, 1
76   call delay_mux
77   baf LATB, 1
78   movff Digo, TBLPTRL
79   TBLRD*
80   movff TABLAT, LATD
81   baf LATB, 2
82   call delay_mux
83   baf LATB, 2
84   movlw 0x39
85   movwf LATD
86   baf LATB, 3
87   call delay_mux
88   baf LATB, 3
89   goto loop

```

```

90 ;Rutina pequeño retardo
91 delay_mux: movlw .80
92           movwf var_lms_x
93           aun_no1: call anid1
94           decfsz var_lms_x, f
95           goto aun_no1
96           return
97           anid1: movlw .10
98           movwf var_lms_y
99           aun_no2: nop
100          decfsz var_lms_y, f
101          goto aun_no2
102          return

```

```

104 ;Rutina de interrupcion
105 TMRI_ISR: movlw 0xC0
106           movwf THRIH
107           clrf TMRI
108           bsf ADCON0, GO
109           otro9: btfsc ADCON0, DONE
110           goto otro9
111           rrcf ADRESH, W
112           andlw 0x7F
113           movwf temporal
114           bcf PIR1, TMRIIF
115           retfie
116
117           end

```

24

## Circuito en Proteus



25

## ¿Multitarea?

- Ejecución de varias tareas a la vez en el microcontrolador
- Sistemas RTOS (Real Time Operating System), relacionado con lenguajes de alto nivel generalmente.
- En assembler la multitarea esta relacionado con el uso de interrupciones.
- Ejecución de una instrucción ≠ ejecución de una tarea

26

## Ejemplo: Generación de dos ondas cuadradas de 1.5KHz y 3.5KHz (asíncronas)

- Se usarán dos temporizadores: Timer0 (señal 1.5KHz) y Timer1 (señal 3.5KHz)
- Al presionar BTN (INT0) se intercambiarán (swap) la salida de las señales.
- Se activarán interrupciones por desborde de ambos temporizadores y la INT0
- Se emplearán prioridades en las interrupciones (a escoger)



27

## Análisis de las señales a reproducir (50% DC):



28

## Configuración del Timer0 para temporizar 0.333ms

FIGURE 11-2: TIMER0 BLOCK DIAGRAM (16-BIT MODE)



29

## Configuración del Timer0 para temporizar 0.333ms

REGISTER 11-1: T0CON: TIMER0 CONTROL REGISTER

|        |        |       |      |       |       |       |       |
|--------|--------|-------|------|-------|-------|-------|-------|
| R/W-1  | R/W-1  | R/W-1 | R/W- | R/W-1 | R/W-1 | R/W-1 | R/W-1 |
| TMR0ON | TOPBIT | TOCS  | TOSE | PSA   | TOPS2 | TOPS1 | TOPS0 |
| bit 7  |        |       |      |       |       |       | bit 0 |

Legend:

|                   |                  |                                    |
|-------------------|------------------|------------------------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read as '0' |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared               |
|                   |                  | x = Bit is unknown                 |

|         |                                                                                                                                                                                                                                                                                         |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 7   | <b>TMR0ON:</b> Timer0 On/Off Control bit<br>1 = Enables Timer0<br>0 = Stops Timer0                                                                                                                                                                                                      |
| bit 6   | <b>T08BIT:</b> Timer0 8-Bit/16-Bit Control bit<br>1 = Timer0 is configured as an 8-bit timer/counter<br>0 = Timer0 is configured as a 16-bit timer/counter                                                                                                                              |
| bit 5   | <b>TOCS:</b> Timer0 Clock Source Select bit<br>1 = Transition on TOCKI pin<br>0 = Internal instruction cycle clock (CLKO) $\rightarrow FOSC/4$                                                                                                                                          |
| bit 4   | <b>TOSE:</b> Timer0 Source Edge Select bit<br>1 = Increment on high-to-low transition on TOCKI pin<br>0 = Increment on low-to-high transition on TOCKI pin                                                                                                                              |
| bit 3   | <b>PSA:</b> Timer0 Prescaler Assignment bit<br>1 = Timer0 prescaler is NOT assigned. Timer0 clock input bypasses prescaler.<br>0 = Timer0 prescaler is assigned. Timer0 clock input comes from prescaler output.                                                                        |
| bit 2-0 | <b>TOPS2:TOPS0:</b> Timer0 Prescaler Select bits<br>111 = 1:256 Prescale value<br>110 = 1:128 Prescale value<br>101 = 1:64 Prescale value<br>100 = 1:32 Prescale value<br>011 = 1:16 Prescale value<br>010 = 1:8 Prescale value<br>001 = 1:4 Prescale value<br>000 = 1:2 Prescale value |

$T0CON = \emptyset \times 88$

30

## Configuración del Timer1 para temporizar 143us

| REGISTER 12-1: T1CON: TIMER1 CONTROL REGISTER |                                                                                        |                                    |         |         |        |                    |         |
|-----------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------|---------|---------|--------|--------------------|---------|
| R/W-0                                         | R-0                                                                                    | R/W-0                              | R/W-0   | R/W-0   | R/W-0  | R/W-0              | R/W-0   |
| RD <sub>16</sub>                              | T1RUN                                                                                  | T1CKPS1                            | T1CKPS0 | T1OSCEN | T1SYNC | TMR1CS             | TMRIQON |
| bit 7                                         |                                                                                        |                                    |         |         |        | X                  | bit 0   |
| <b>Legend:</b>                                |                                                                                        |                                    |         |         |        |                    |         |
| R = Readable bit                              | W = Writable bit                                                                       | U = Unimplemented bit, read as '0' |         |         |        |                    |         |
| -n = Value at POR                             | '1' = Bit is set                                                                       | '0' = Bit is cleared               |         |         |        | x = Bit is unknown |         |
| bit 7                                         | <b>RD16:</b> 16-Bit Read/Write Mode Enable bit                                         |                                    |         |         |        |                    |         |
|                                               | 1 = Enables register read/write of Timer1 in one 16-bit operation                      |                                    |         |         |        |                    |         |
|                                               | 0 = Enables register read/write of Timer1 in two 8-bit operations                      |                                    |         |         |        |                    |         |
| bit 6                                         | <b>T1RUN:</b> Timer1 System Clock Status bit                                           |                                    |         |         |        |                    |         |
|                                               | 1 = Device clock is derived from Timer1 oscillator                                     |                                    |         |         |        |                    |         |
|                                               | 0 = Device clock is derived from another source                                        |                                    |         |         |        |                    |         |
| bit 5-4                                       | <b>T1CKPS1:T1CKPS0:</b> Timer1 Input Clock Prescale Select bits                        |                                    |         |         |        |                    |         |
|                                               | 11 = 1:8 Prescale value                                                                |                                    |         |         |        |                    |         |
|                                               | 10 = 1:4 Prescale value                                                                |                                    |         |         |        |                    |         |
|                                               | 01 = 1:2 Prescale value                                                                |                                    |         |         |        |                    |         |
|                                               | 00 = 1:1 Prescale value                                                                |                                    |         |         |        |                    |         |
| bit 3                                         | <b>T1OSCEN:</b> Timer1 Oscillator Enable bit                                           |                                    |         |         |        |                    |         |
|                                               | 1 = Timer1 oscillator is enabled                                                       |                                    |         |         |        |                    |         |
|                                               | 0 = Timer1 oscillator is shut off                                                      |                                    |         |         |        |                    |         |
|                                               | The oscillator inverter and feedback resistor are turned off to eliminate power drain. |                                    |         |         |        |                    |         |
| bit 2                                         | <b>T1SYNC:</b> Timer1 External Clock Input Synchronization Select bit                  |                                    |         |         |        |                    |         |
|                                               | When TMR1CS = 1:                                                                       |                                    |         |         |        |                    |         |
|                                               | 1 = Do not synchronize external clock input                                            |                                    |         |         |        |                    |         |
|                                               | 0 = Synchronize external clock input                                                   |                                    |         |         |        |                    |         |
|                                               | When TMR1CS = 0:                                                                       |                                    |         |         |        |                    |         |
|                                               | This bit is ignored. Timer1 uses the internal clock when TMR1CS = 0.                   |                                    |         |         |        |                    |         |
| bit 1                                         | <b>TMR1CS:</b> Timer1 Clock Source Select bit                                          |                                    |         |         |        |                    |         |
|                                               | 1 = External clock from RCO/T1OSO/T1CKI pin (on the rising edge)                       |                                    |         |         |        |                    |         |
|                                               | 0 = Internal clock (Fosc/4)                                                            |                                    |         |         |        |                    |         |
| bit 0                                         | <b>TMRIQON:</b> Timer1 On bit                                                          |                                    |         |         |        |                    |         |
|                                               | 1 = Enables Timer1                                                                     |                                    |         |         |        |                    |         |
|                                               | 0 = Stops Timer1                                                                       |                                    |         |         |        |                    |         |

$$T1CON = \emptyset \times \emptyset 1$$

31

## Desarrollo del algoritmo en diagrama de flujo

5º Hay tres fuentes de interrupción:

- **INT0** → alta prioridad
  - **Timer0** → baja prioridad
  - **Timer1** → baja prioridad

## 2º Diagrama de flujo:



32

## Código en MPASM:

```

1 ;Este es un comentario, se le antecede
2      list p=18f4550      ;Modelo del microcontrolador
3      #include <p18f4550.inc>    ;Llamada al archivo de configuración
4
5      ;Directivas de preprocesador o bien
6      CONFIG FLLDIV = 1      ; FLL divisor
7      CONFIG CUDIV = OSC1_PLL2 ; CUDIV divisor
8
9      CONFIG FOSC = XT_XT    ; FOSC: XT oscillator, XT external
10     CONFIG PWRT = ON       ; PWRT: Power-up timer enable
11     CONFIG BOR = OFF       ; BOR: Brown-out reset enable
12     CONFIG WDT = OFF       ; WDT: Watchdog timer enable
13     CONFIG CCP2MX = ON     ; CCP2MX: CCP2 output mode
14     CONFIG PBADEN = OFF    ; PBADEN: Port B analog pins enable
15     CONFIG MCORE = ON      ; MCORE: Microcontroller enable
16     CONFIG LVP = OFF       ; LVP: Low-voltage programming enable
17
18 ;Aquí va el cblock o decl
19     cblock 0x0000           ; Cblock: Global memory block
20     ESTADO
21     endc
22     org 0x0000
23     goto init_conf
24
25     org 0x0008
26     goto INTO_ISR
27
28     org 0x0018
29     goto TMRO_TMR1_ISR

```

**Nota: Cuentas iniciales de TMR1 y TMRO compensadas para obtener 1.5KHz y 3.5KHz**

```

60 TMRO_TMR1_ISR:
61     btfs INTCON, TMROIF      ;Pregunto si ocurrió TMRO
62     goto fue_el_otro
63     movlw 0xFF
64     movwf TMROH
65     movlw 0xC2
66     movwf TMROL          ;Cargo cuenta inicial en TMRO
67     btfs ESTADO, 0          ;Pregunto el ESTADO
68     goto estado_cero_a
69     btg LATD, 1            ;Basculo RD1
70     goto final_1
71 estado_cero_a:
72     btg LATD, 0            ;Basculo RD0
73
74 final_1:
75     bcf INTCON, TMRIIF      ;Bajamos bandera de TMRI
76     retfie
77
78     movlw 0xFF
79     movwf TMRIH
80     movlw 0x80
81     movwf TMRL          ;Cargo cuenta inicial en TMRI
82     btfs ESTADO, 0          ;Pregunto el ESTADO
83     goto estado_cero_b
84     btg LATD, 0            ;Basculo RD0
85     goto final_2
86 estado_cero_b:
87     btg LATD, 1            ;Basculo RD1
88 final_2:
89     bcf PIR1, TMRIIF      ;Bajo bandera de TMRI
90     retfie
91 end

```

33

## Simulación:



34

## Modificación al ejemplo: Cambiando las prioridades de las fuentes de interrupción

### Fuentes de interrupción:

- INT0 ← alta prioridad
- Timer0 ← alta prioridad
- Timer1 ← baja prioridad



35

### Código en MPASM: Configuración y rutina principal

```

1 ;Este es un comentario, se le antecede un
2 list p=18f4550 ;Modelo del micro
3 #include <p18f4550.inc> ;Llamada a la biblioteca
4
5 ;Directivas de preprocesador o bits de configuración
6 CONFIG PLLDIV = 1 ; PLL Prescaler
7 CONFIG CPUDIV = OSC1_PLL2 ; System Clock Prescaler
8 CONFIG FOSC = XT_XT ; Oscillator Selection
9 CONFIG FWRT = ON ; Power-up Timer
10 CONFIG BOR = OFF ; Brown-out Reset
11 CONFIG WDT = OFF ; Watchdog Timer
12 CONFIG CCP2MX = ON ; CCP2 Mode Selection
13 CONFIG PBADEN = OFF ; PORTB Pin Function Selection
14 CONFIG MCLRE = ON ; MCLR Pin Function Selection
15 CONFIG LVP = OFF ; Single-supply Programming
16
17 ;Aqui va el cblock o declaración de nombre de memoria
18 cblock 0x000
19 ESTADO
20 endc
21
22 org 0x0000 ;Vector de RE
23 goto init_conf
24
25 org 0x0008 ;Vector de INT0
26 goto INT0_TMRO_ISR
27
28 org 0x0018 ;Vector de INT1
29 goto TMRI_ISR
  
```

```

30
31 org 0x0020 ;Zona de configuración
32 init_conf:
33 bcf TRISD, 0
34 bcf TRISD, 1
35 movlw 0x88
36 movwf TOCON ;Configuración de TOCON
37 movlw 0x01
38 movwf TICON ;Configuración de TICON
39 bsf RCON, IPEN ;Activar el reloj
40 bcf IFR1, TMRIIP ;Mandar una interrupción
41 bsf PIE1, TMRIIE ;Activar el timer
42 movlw 0xF0
43 movwf INTCON ;Activar el timer
44 clrf ESTADO ;Forzar el estado
45 loop:
46 nop
47 goto loop
  
```

36

## Código en MPASM: Rutinas de interrupción

```

50    INTO_TMR0_ISR:           ;Rutina de interrupcion high priority
51    ; bcf INTCON, GIEH      ;Apagamos temporalmente el interrupcion GIEH para
52    btfss INTCON, INTOIF   ;Pregunto si ocurrio INTO
53    goto el_otro
54    btfss ESTADO, 0        ;Basculo el estado
55    bcf INTCON, INTOIF   ;Bajo la bandera de INTO
56    el_otro:
57    btfss INTCON, TMROIF  ;Pregunto si se desbordo TMRO
58    goto nada_masl
59    btfss ESTADO, 0        ;Pregunto a que puerto debe de salir la señal SIG1
60    goto para_RDO
61    btg LATD, 1
62    goto nada_masl
63    para_RDO:
64    btg LATD, 0
65    nada_masl:
66    movlw 0xFE
67    movwf TMROH
68    movlw 0xB3
69    movwf TMROL
70    bcf INTCON, TMROIF
71    ; bsf INTCON, GIEH
72    retfie
73
74    TMR1_ISR:              ;Rutina de interrupcion low priority
75    btfss ESTADO, 0
76    goto para_RD1
77    btg LATD, 0
78    goto nada_mas2
79    para_RD1:
80    btg LATD, 1
81    nada_mas2:
82    movlw 0xFF
83    movwf TMR1H
84    movlw 0x72
85    movwf TMR1L
86    bcf PIR1, TMR1IF
87    retfie
88    end

```

37

## Simulación en Proteus



38

## Cuestionario:

- Modificar el ejemplo anterior para que se pueda modificar el duty cycle de ambas ondas de manera independiente empleando un teclado matricial para ello.

39

## Fin de la sesión

40