

# Microcontroladores

Semestre: 2021-2

Profesor: Kalun José Lau Gan

Semana 9: Lenguajes de alto nivel en microcontroladores

1

## ¿Preguntas previas?

- Sobre el TF
  - Se estará publicando mas tarde la “guía del trabajo final” en el AV
- ¿Cómo se trabajarán en los laboratorios siguientes?
  - De manera individual
- ¿Se requerirán mas materiales para los laboratorios?
  - Solo los de la lista publicada a inicios del curso
- El hecho de usar C lo hace mas fácil?
  - El proceso de diseño es el mismo tanto para lenguaje Assembler como en lenguaje C, se tiene que implementar primero el hardware, desarrollar el algoritmo y finalmente aterrizar el algoritmo en un lenguaje de programación.
  - El lenguaje XC se va a permitir el uso de librerías y funciones especializadas, además de manejar mejor las operaciones matemáticas y manipulación de datos

2

## Agenda:

- Resolución del EA
- Lineamientos de TF
- Los lenguajes de alto nivel, en nuestro caso el XC8
- El MPLAB Xpress
- Desarrollo de una plantilla en el MPLAB X para el XC8
- Ejemplos iniciales en XC8

3

## Panorama de los lenguajes de alto nivel para microcontroladores

Cada dispositivo microcontrolador tendrá sus propias plataformas de lenguaje de programación.

Va a depender del desarrollador del lenguaje de alto nivel para determinado microcontrolador (No todos los desarrolladores soportan todos los dispositivos de un fabricante)

Hay varias compañías que desarrollan lenguajes de alto nivel para un microcontrolador.  
Problema de compatibilidad entre distintas plataformas de desarrollo aún empleando un mismo lenguaje.

- Basic
- C
- Java (muy poco utilizado y soportado)
- Python

4

# Panorama de los lenguajes de alto nivel para microcontroladores



**mikroC PRO for PIC**

\$269.00

[BUY NOW](#) [Download](#)

  


**PCWHD IDE Compiler for Microchip PIC10/12/16/18/24/dsPIC Devices**

Sku: 52202-588

**Devices Supported:** PIC10, PIC12, PIC16, PIC18, dsPIC, PCW, PCWH, PCWHD

In stock (ships immediately)

Download version available \$600.00 [Add to Cart](#)

Starting at \$100 more, buy a complete development kit [Buy Now](#)

  


**PBP3**  
PICBASIC PRO™ Compiler

PPB is the industry standard BASIC programming language for Microchip's PIC microcontrollers.

No other BASIC compiler for PIC MCUs boasts the 15-year success in both commercial and non-commercial environments.

See the [PBP3 website](#) for complete product information and FREE TRIAL download!

- Supports more than 800 microcontrollers. [complete list...](#)
- Newly revised 300-page manual.
- MPLAB® and MPLAB® X compatible
- May be purchased as download-only or CD with printed manual.

**Purchase Incrementally with no price penalty:**

|                                               |   |                                             |   |          |
|-----------------------------------------------|---|---------------------------------------------|---|----------|
| <b>PBP3</b><br>PICBASIC PRO™<br><b>SILVER</b> | → | <b>PBP3</b><br>PICBASIC PRO™<br><b>GOLD</b> |   |          |
| \$119.95                                      | + | \$150                                       | = | \$269.95 |

\*Incremental prices are shown as upgrades when signed-in with qualified account.

5

## El compilador XC de Microchip

- Disponible versión gratis sin límite.
- La versión PRO no es gratis. Provee optimización de código compilado para que ocupe menos espacio.
- Tres versiones:
  - XC8 – PIC10, PIC12, PIC16, PIC18
  - XC16 – PIC24, dsPIC
  - XC32 – PIC32



**DEV TOOL DEALS SPRING SALE**

[Click for Deals](#)

  

**MPLAB® XC Compilers**

Available as free, unrestricted-use downloads, our award-winning MPLAB® XC Compilers are comprehensive solutions for your project's software development. Finding the right compiler to support your device is simple:

- MPLAB XC8 supports all 8-bit PIC® and AVR® microcontrollers (MCUs)
- MPLAB XC16 supports all 16-bit PIC MCUs and dsPIC® Digital Signal Controllers (DSCs)
- MPLAB XC32/32+ supports all 32-bit PIC and SAM MCUs and MPUs

**MPLAB® XC COMPILER**

6

# El compilador XC de Microchip

- Los XC8, XC16 y XC32 vienen separados...
- Ej. El bootloader HID para el microcontrolador PIC18F4550 requiere que se compile el código en XC8 PRO para que entre en su memoria.



Part Number: SW006021-DGL - MPLAB XC8 Compiler PRO Dongle License

The MPLAB XC8 is a full-featured, highly-optimized ANSI C compiler for all 8-bit AVR® and PIC® MCUs. This compiler integrates into Microchip's MPLAB(R) X IDE, is compatible with all Microchip debuggers and emulators, and runs on Windows, Linux and Mac OS X.

The dongle license is a USB flash drive that contains a single-user encrypted license. It is a perpetual license and unlocks PRO optimizations for all versions of the MPLAB XC8 compilers, **version 1.41 and later**, and does not include High Priority Access (HPA). The Dongle License allows a user to unlock PRO optimizations on any computer it is plugged into. If lost, the Dongle License can be replaced one time for a processing fee of \$200 and the dongle must be registered to the user.

[More Info »](#)

Standard Pricing:

Order Quantity

1+

USD per Unit

\$1,695.00

In Stock: 9  
Delivery and scheduling options available in the cart [»](#)

Order now, up to 9 can ship on 20-May-2020

Lead Time For Additional Quantities [»](#)  
Additional quantities can ship by 11-Aug-2020

Quantity:



7

## Caso:



8

## Optimización en el compilador XC

- **Optimization levels:**
  - Level 0: Fastest compilation time, minimal optimizations
  - Level 1: Optimizations with low debugging impact
  - Level 2: All optimizations that give the best balance between speed and size
  - Level 3: Program execution will be as fast as possible
  - Level s: Code size will be as small as possible
- **Where available use:**
  - Use Whole-program and Link-time setting
  - Procedural abstraction

- En la versión gratuita del XC tenemos optimización hasta el nivel 2
- Para acceder al nivel 3 o nivel s requerimos tener la licencia PRO

9

## Optimización en el compilador XC

- Para acceder a las opciones de optimización ingresamos a las propiedades del proyecto:



10

## Eficiencia de código en Assembler vs C

¿Por qué Assembler y por qué C?



11

## El MPLAB Xpress

- Link:  
[https://www.microchip.com  
/en-us/development-tools-tools-and-software/mplab-xpress](https://www.microchip.com/en-us/development-tools-tools-and-software/mplab-xpress)
- Entorno de trabajo online
- Permite realizar proyectos en XC sin tener que instalar el MPLAB X en el computador.



12

## El MPLAB Xpress

- Los proyectos se almacenan en la nube de Microchip
- Soporte solo para algunos modelos de microcontrolador PIC



13

## MPLAB X: Creación de un proyecto en XC8

- Link del manual de XC8:
  - <http://ww1.microchip.com/downloads/en/devicedoc/50002053g.pdf>
- Link de descarga del XC8 v2.32:
  - <https://www.microchip.com/mplabxc8windows>

14

## Plantilla de código en XC8:

```

10  #pragma config PLLDIV = 1           // PLL Prescaler Selection bit
11  #pragma config CPUDIV = OSC1_PLL2 // System Clock Postscaler Selection
12  #pragma config FOSC = XTPLL_XT   // Oscillator Selection bits
13  #pragma config PWRT = ON          // Power-up Timer Enable bit
14  #pragma config BOR = OFF          // Brown-out Reset Enable bit
15  #pragma config BORV = 3           // Brown-out Reset Voltage bit
16  #pragma config WDT = OFF          // Watchdog Timer Enable bit
17  #pragma config WDTPS = 32768      // Watchdog Timer Postscale Selection
18  #pragma config CCP2MX = ON         // CCP2 MUX bit (CCP2 input/output)
19  #pragma config PBADEN = OFF        // PORTB A/D Enable bit (PORTB P
20  #pragma config MCLRE = ON          // MCLR Pin Enable bit (MCLR pin enable)
21  #pragma config LVP = OFF           // Single-Supply ICSP Enable bit
22
23  #include <xc.h>
24
25  #define _XTAL_FREQ 48000000UL     //Frecuencia de trabajo 48MHz
26
27  void configuracion(void) {
28      //Aqui colocas las configuraciones iniciales
29  }
30
31  void main(void) {
32      configuracion();
33      while (1) {
34          //Tu programa de usuario
35      }
36  }

```

15

## Ejemplo en XC8: Titileo de LED



16

## Ejemplo en XC8: Negador lógico de un bit

```

2 #pragma config PLLDIV = 1           // PLL Prescaler Selection bits (No pre
3 #pragma config CFUDIV = OSC1_PLL2 // System Clock Postscaler Selection b
4 #pragma config FOSC = XTPLL_XT  // Oscillator Selection bits (XT oscill
5 #pragma config PWRT = ON          // Power-up Timer Enable bit (PWRT enab
6 #pragma config BORV = 3            // Brown-out Reset Enable bits (Brown-o
7 #pragma config WDT = OFF          // Watchdog Timer Enable bit (WDT disab
8 #pragma config WDTPS = 32768       // Watchdog Timer Postscale Select bits
10 #pragma config CCP2MX = ON         // CCP2 MUX bit (CCP2 input/output is m
11 #pragma config PBADEN = OFF        // PORTB A/D Enable bit (PORTB<4:0> pin
12 #pragma config MCLE = ON          // MCLR Pin Enable bit (MCLR pin enable
13 #pragma config LVP = OFF          // Single-Supply ICSP Enable bit (Singl
14
15 #include <xc.h>
16 #define _XTAL_FREQ 48000000UL
17
18 void init_conf(void){
19     //Aca colocaremos las configuraciones iniciales de la aplicacion
20     //TRISDbits.RD0 = 0;           // RD0 como salida
21     asm("bcf TRISD, 0");        // Escribiendo instrucciones en mpasm
22 }
23
24 void main(void) {
25     init_conf();
26     while(1){
27         if (PORTBbits.RB0 == 1) {
28             LATDbits.LD0 = 0;
29         }
30         else{
31             LATDbits.LD0 = 1;
32         }
33     }
34 }
```



17

## Ejemplo en XC8: Compuerta XOR



18

## 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

19

## 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?

20

## 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

21

## Conversor A/D: Diagrama de bloques



22

## 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                                                                                |                                    |                 |                      |                    |                    |                    |

23

## 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  
OR
  - 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.

24

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

FIGURE 11-4: A/D RESULT JUSTIFICATION



25

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:



26

## 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 |
| —                                             | —                                                    | CHS <sub>3</sub>                   | CHS <sub>2</sub>   | CHS <sub>1</sub> | CHS <sub>0</sub> | G/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>CHS<sub>3:0</sub>:</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)</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                                         | <b>GO/DONE:</b> A/D Conversion Status bit            |                                    |                    |                  |                  |        |       |
| When ADON = 1:                                |                                                      |                                    |                    |                  |                  |        |       |
| 1 = A/D conversion in progress                |                                                      |                                    |                    |                  |                  |        |       |
| 0 = A/D Idle                                  |                                                      |                                    |                    |                  |                  |        |       |
| bit 0                                         | <b>ADON:</b> 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                | PFG2               | PFG1               | PFG0               |
| 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) |                                    |                    |                      |                    |                    |                    |
| 1 = VREF- (AN2)                               |                                                                  |                                    |                    |                      |                    |                    |                    |
| 0 = VSS                                       |                                                                  |                                    |                    |                      |                    |                    |                    |
| bit 4                                         | <b>VCFG0:</b> Voltage Reference Configuration bit (VREF+ source) |                                    |                    |                      |                    |                    |                    |
| 1 = VREF+ (AN3)                               |                                                                  |                                    |                    |                      |                    |                    |                    |
| 0 = VDD                                       |                                                                  |                                    |                    |                      |                    |                    |                    |
| bit 3-0                                       | <b>PCFG3:PCFG0:</b> A/D Port Configuration Control bits:         |                                    |                    |                      |                    |                    |                    |
| PCFG3:<br>PCFG0                               | AN2                                                              | AN1                                | AN10               | AN9                  | AN8                | AN7 <sup>(2)</sup> | AN6 <sup>(2)</sup> |
| 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                               |                                                                  |                                    |                    |                      |                    |                    |                    |

27

## 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               |
| 0000 <sup>(1)</sup>                                             | 1                                                    | ACQT2                              | 0000 <sup>(1)</sup> | ACQT1 | 0000 <sup>(1)</sup> | ADCS2 | 0000 <sup>(1)</sup> |
| 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            |                                    |                     |       |                     |       |                     |
| 1 = Right justified                                             |                                                      |                                    |                     |       |                     |       |                     |
| 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 |                                    |                     |       |                     |       |                     |
| 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                                                    |                                                      |                                    |                     |       |                     |       |                     |

28

## 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}$ °C Typical
- Low-Impedance Output, 0.1 Ω for 1-mA Load

### 2 Applications

- Power Supplies
- Battery Management
- HVAC
- Appliances

29

## 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.

30

# Circuito de interface del PIC18F4550 con el LM35



## Evoluções de medidas:

T      Lm3S      AD (10 bits)  
 $100^{\circ}\text{C}$        $\text{LV}$        $1023$   
 ↓      ↓      ↓  
 (ADRESH:ADRESL)

31

## Ejemplo: Uso del A/D en XC8 y MPASM

- XC8 vs MPASM
  - Se puede apreciar que aparentemente hay menos líneas en XC8
  - Al compilar el programa en XC8 se puede ver que ocupa 60bytes en memoria de programa, en MPASM ocupa una cuarta parte

```
list priorwrote ;modo de microcontrolador
#include <p18f4550.h> ;llamada a la libreria de nombre de los regist
;Directivas de preprocesador o bits de configuración
CONFIG PLLDIV = 1 ;PLL Prescaler Selection bits (No prescale
CONFIG CPUDIV = 0 ;System Clock Postscaler Selection bits (IP
CONFIG FOSC = XT_XT ;Oscillator Selection bits (XT oscillator (
CONFIG PWRT = ON ;Power-up Timer Enable bit (PWRT enabled
CONFIG BOR = OFF ;Brown-out Reset Enable bits (Brown-out Res
CONFIG WDTPS = 3 ;Watchdog Timer Enable bit (WDTPS[3:0] bits)
CONFIG CCP2MX = ON ;CCP2 MUX bit (CCP2 input/output is multip
CONFIG PBADEN = OFF ;PORTB A/D Enable bit (PBADEN=0: pins are
CONFIG MCRLRE = ON ;MCRL Pin Enable bit (MCRL pin enabled; RE3
CONFIG LVP = OFF ;Single-Supply ICSP Enable bit (Single-Supp
;include <xc.h>
#define _XTAL_FREQ 48000000UL

void init(void){
    //ACB colocaremos las CONFIGURACIONES ANI
    TRISD = 0x00; ;RD como salida
    ADCON2 = 0x24; ;STAD, FOSC/4 ADFM=0
    ADCON1 = 0x0E; ;AN0 habilitado
    ADCON0 = 0x01; ;AN0 seleccionado y AD f
}
void main(void){
    //ACB es la rutina principal
    init();
    while(1){
        ADCONbits.GDON0 = 1; ;Inicio la c
        while(ADCONbits.GDON0 == 1);
        LATD = ADRESH;
    }
}

org 0x0000
goto init_conf

org 0x0020
init_conf: clrf TRISD ;RD como salidas
        movwf ADCON0 ;STAD, FOSC/4 ADFM=0
        movwf ADCON1 ;AN0 habilitado
        movwf ADCON0 ;AN0 seleccionado y AD f
        movwf ADCON0 ;AN0 seleccionado y AD funcionando

loop: bsf ADCON0, GO ;Inicio la conversion en AN0
otro: btfsc ADCON0, DONE ;Pregunto si ya termino de convertir
        goto otro ;Aun el ADC se encuentra en proceso de con
        movff ADRESH, LATD ;Ya termino de convertir y envia el result
        goto loop
end
```

32

## Ejemplo: Uso del A/D en XC8 y MPASM



33

## Cuestionario:

- Ventajas y desventajas entre: XC8, CCS-C, mikroC

34

## Fin de la sesión

- Laboratorio: Potenciómetros 10Kohm, LCD 16x2