

# Tecnicatura Superior en Telecomunicaciones

## Electrónica Microcontrolada-TST-2022

### Grupo # 4

#### ➤ Profesores:

- Jorge Morales
- Gonzalo Vera

#### ➤ Integrantes:

- Daniella Mazzini
- Ivan Exequiel Gomez
- Roxana Vicentelo
- Alfredo Palacios
- Matias Lujan
- Maximo Santillan

#### ➤ Repositorio:

- <https://github.com/EMTSTISPC/Grupo4>

## Familia de gama media mejorada

### MCU PIC® de 8 bits de rango medio mejorado

**PIC12F1 xxx, PIC16F1 xxx**

- 49 (14 bits de ancho) instrucciones fáciles de aprender
- Memoria de programa direccionable de 32 K palabras (56 KB)
- 4 KB de RAM (máx.)
- Pila de hardware de 16 niveles
- 2 registros de selección de archivos (16 bits)
- Manejo de interrupciones de hardware con guardado de contenido
- Conjunto de funciones avanzadas, múltiples comunicaciones en serie y capacidad de control de motores



Microchip sigue invirtiendo en su línea de microcontroladores PIC de 8 bits para ofrecer una amplia cartera de productos que satisfaga las necesidades de los clientes actuales y futuros. El nuevo núcleo de rango medio mejorado se basa en los mejores elementos del núcleo de rango medio y proporciona un rendimiento adicional, al tiempo que mantiene la compatibilidad con MCU PIC de rango medio para una verdadera migración de productos.

## Descripción general de la arquitectura MCU PIC de gama media mejorada

### Resumen

#### Familias de MCU de 8 bits de Microchip



La familia de MCU PIC® de 8 bits de rango medio mejorado PIC16F1xxx <sup>abarcá</sup> una amplia variedad de tamaños de memoria y pines de E/S.

Esta página presenta las características arquitectónicas clave de la familia de MCU PIC16F1xxx. En esta página se proporcionan enlaces a los detalles técnicos necesarios para implementar aplicaciones en la familia de microcontroladores PIC de gama media mejorada.

### Arquitectura de Harvard

Los microcontroladores PIC® de gama media mejorados utilizan una arquitectura Harvard de doble bus.



autobús de instrucción

Las instrucciones del programa se introducen en la ALU desde la memoria del programa FLASH a través del bus de instrucciones de 14 bits. En cada ciclo de reloj de instrucción, se lee una palabra de programa de 14 bits en la ALU.

### Bus de datos

Un bus de datos de 8 bits conecta la ALU al espacio de memoria de datos. Durante cada instrucción, la ALU puede leer datos desde la ubicación de la memoria de datos, modificar los datos y luego volver a escribir los datos en la memoria.

### Canalización de instrucciones

La arquitectura de doble bus del PIC de rango medio mejorado proporciona una línea de instrucción de dos etapas. Una cada ciclo de reloj ejecuta dos fases de instrucción:

1. La siguiente instrucción se "**obtiene**" de la memoria del programa
2. La instrucción actual se "**ejecuta**" y lee/modifica/escribe la memoria de datos (si es necesario)



### Periféricos asignados a la memoria

Una mirada más cercana a la sección de memoria de datos de la MCU PIC® de gama media mejorada muestra que se accede a los registros que controlan los periféricos y a los puertos de E/S leyendo o escribiendo en direcciones de memoria de datos específicas. Esta asignación de periféricos a la dirección de la memoria simplifica enormemente el aprendizaje de cómo programar el PIC mejorado de rango medio.



La [página de memoria](#) de datos del tutorial mejorado de gama media ofrece una descripción completa junto con ejemplos de programas que acceden a los periféricos asignados a la memoria.

### Conjunto de instrucciones ortogonales

Cada MCU PIC® de gama media mejorada tiene 49 instrucciones. Las instrucciones que acceden directamente a las direcciones de la memoria de datos se ejecutan en un ciclo de instrucción. Las instrucciones que provocan un cambio en el contador del programa BRA, GOTO, RETURN, CALL, ..etc) tardan dos ciclos de instrucción en ejecutarse.

Al mapear los registros de E/S y periféricos a direcciones de memoria, las MCU PIC no necesitan instrucciones especiales para las operaciones de E/S o para establecer registros periféricos. Escribir en un puerto de E/S o configurar un periférico es una simple escritura en una ubicación de memoria. Leer el valor de un pin de entrada, registro de resultado ADC o temporizador es una simple lectura de una ubicación de memoria. Mediante el uso de una pequeña cantidad de instrucciones ortogonales, los MCU PIC de rango medio mejorado son fáciles de programar, usan menos silicio para construir y consumen menos energía.

## Ejemplos de implementación de instrucciones

| Task                                | C Language                    | Assembly                                  |
|-------------------------------------|-------------------------------|-------------------------------------------|
| <b>WRITE</b> a value to a variable  | <code>var1 = 7 ;</code>       | <code>movlw 7<br/>movf var1</code>        |
| <b>WRITE</b> a value to a Register  | <code>T1CON = 0x72;</code>    | <code>movlw 0x72<br/>movf T1CON</code>    |
| <b>WRITE</b> to an Output Latch     | <code>LATD = 0xFF ;</code>    | <code>movlw 0xFF<br/>movf LATD</code>     |
| <b>READ</b> an input PORT           | <code>var1 = PORTB;</code>    | <code>movf PORTB<br/>movwf var1</code>    |
| <b>READ</b> a variable's value      | <code>var1 = var2;</code>     | <code>movf var2<br/>movwf var1</code>     |
| <b>READ</b> an SFR into another SFR | <code>CCPR1L = ADRESH;</code> | <code>movf ADRESH<br/>movwf CCPR1L</code> |

Para obtener una lista detallada del conjunto de instrucciones y una discusión completa del tiempo de instrucción, consulte la página [Conjunto](#) de instrucciones del tutorial de rango medio mejorado.

## Opciones de reloj flexibles (hasta 32 MHz)

Seleccionado por los [bits de configuración](#) del PIC® MCU, el reloj del sistema tiene las siguientes propiedades:

- Fuente opcional ( **oscilador interno o circuito externo** )
- Opciones de velocidad flexibles **hasta 32MHz**
- **Arranque de dos velocidades** : permite que el sistema ejecute el software de inicialización mientras el oscilador externo se estabiliza
- **Cambio** de reloj: la fuente de reloj del sistema se puede cambiar entre fuentes de reloj externas e internas a través del software.
- **Monitor de reloj** a prueba de fallas: cambia al oscilador interno en caso de falla del reloj externo



Para obtener una descripción detallada de las opciones de configuración del oscilador, consulte la [página del oscilador de 8 bits](#) en el Tutorial mejorado de rango medio.

### E/S digitales

Casi todos los pines de la MCU PIC Enhance de rango medio se pueden usar como pines de entrada o salida digital. Los pines digitales comparten estos atributos:

- Supervisión de entradas digitales
- Controlar dispositivos digitales
- Dominadas débiles internas
- Multiplexado con Periféricos
- Alta capacidad de accionamiento (hasta 25 mA sumidero/fuente en muchos pines de E/S)
- Manipulación directa de bit de ciclo único
- Diodos de protección ESD de 4kV

Al reiniciar:

- Los pines digitales vuelven a la entrada (Hi-Z)
- Los pines con capacidad analógica vuelven a ser analógicos

### Estructura típica de pines digitales

Cinco registros controlan el funcionamiento de un pin digital. Estos registros de 8 bits controlan 8 pines de un PUERTO. Usando los registros **TRISx**, **PORTx**, **LATx**, **WPUx** y **ANSEL**, el programa puede:

- Configure el pin a como entrada o salida **TRISx**
- Leer un pin de entrada (o los 8 pines PORT) **PORTx**
- Envía un 1 o 0 a un pin **LATx**
- Habilitar o deshabilitar la resistencia pull up interna **WPUx**
- Determine si los pines con capacidad analógica funcionan en modo analógico o digital **ANSEL**



Para una discusión completa de la E/S digital PIC mejorada de rango medio, incluidos los detalles sobre la programación de las operaciones de entrada y salida digital, consulte la sección de [E/S digital](#) de este tutorial mejorado de rango medio.

### Pines multiplexados

Además de configurarse como E/S digitales, los pines de los MCU PIC mejorados de rango medio pueden tener varias funciones posibles. El diagrama de pines en la hoja de datos muestra las opciones para cada pin. Al inicio, el programa tiene la opción de configurar los pines.

|    |                          |   |                                     |
|----|--------------------------|---|-------------------------------------|
| 40 | <input type="checkbox"/> | ↔ | RB7/ICSPDAT/ICDDAT/SEG13            |
| 39 | <input type="checkbox"/> | ↔ | RB6/ICSPCLK/ICDCLK/SEG14            |
| 38 | <input type="checkbox"/> | ↔ | RB5/AN13/CPS5/CCP3/P#A/T1G/COM1     |
| 37 | <input type="checkbox"/> | ↔ | RB4/AN11/CPS4/COM0                  |
| 36 | <input type="checkbox"/> | ↔ | RB3/AN9/C12IN2-/CPS3/CCP2/P2A/VLCD3 |
| 35 | <input type="checkbox"/> | ↔ | RB2/AN8/CPS2/VLCD2                  |
| 34 | <input type="checkbox"/> | ↔ | RB1/AN10/C12IN3/CPS1/VLCD1          |
| 33 | <input type="checkbox"/> | ↔ | RB0/AN12/CPS0/SRI/INT/SEG0          |

Para una discusión completa de la E/S digital PIC mejorada de rango medio, incluidos los detalles sobre la configuración de los pines, consulte la [sección Periféricos](#) del tutorial de rango medio mejorado.

### Periféricos avanzados

Además de las E/S digitales mejoradas, los miembros de la familia de MCU PIC de rango medio tienen una variedad de periféricos avanzados. Estos periféricos incluyen periféricos para conversión de datos, comunicación y acondicionamiento de señales.



Para obtener una lista completa de los periféricos disponibles, consulte la [sección Periféricos](#) del tutorial .

### Interrupciones

Los microcontroladores PIC de rango medio mejorados utilizan una estructura de interrupción preventiva de un solo vector.

Cada periférico en el PIC es capaz de generar una solicitud de interrupción. Cuando ocurre una solicitud de interrupción Y las interrupciones para el dispositivo solicitante están habilitadas, se producirá una interrupción.

El PIC de rango medio mejorado utiliza una pila de hardware de 16 niveles para almacenar el contenido actual de la PC cuando ocurre una interrupción. El contexto del programa se guarda en registros sombra y el control se pasa a la dirección de memoria del programa 0x04.

### Rutina de servicio de interrupción (ISR)

El usuario es responsable de escribir el código para dar servicio a la interrupción y colocar el código en la dirección 0x04. Esta Rutina de Servicio de Interrupción (ISR) determina la fuente de la interrupción, luego realiza la tarea necesaria para dar servicio al periférico interrumpido. La instrucción final de un ISR es la instrucción Return From Interrupt (RETFIE).

### Guardado automático de contexto

Los siguientes registros se guardan en un registro de sombra de un solo nivel establecido en caso de una interrupción

- registro W
- BSR
- ESTADO
- FSR
- PCLATH

Cuando el ISR ejecuta la instrucción RETFIE, estos registros se restauran al valor anterior a la interrupción.

#### **Prioridad de interrupción de un solo nivel**

Cuando ocurre una interrupción, el bit de habilitación de interrupción global (GIE) en el registro de estado está deshabilitado. Esto evitará que una interrupción sea reemplazada por otra interrupción.

Al ejecutar un RETFIE, el estado del bit de control GIE se restaura a su valor previo a la interrupción.

Para obtener una descripción completa del proceso de interrupción y ejemplos de programación, consulte la [sección](#) de interrupción del tutorial de rango medio mejorado.

#### **Qué sucede en el inicio del sistema (RESET)**

Hay varias fuentes de un REINICIO en la MCU PIC mejorada de rango medio. Las fuentes de RESET comunes a casi todas las aplicaciones son Power On Reset (POR) y Brown Out Reset (BOR) debido a una caída del voltaje de la fuente de alimentación (es decir, caída de tensión). Hay varios otros métodos para restablecer la MCU, incluido el tiempo de espera de Watchdog y el acceso directo al pin MCLR.

#### **El contador de programa se establece en 0x00.**

Después de un RESET, la instrucción ubicada en la dirección 0 es la primera instrucción ejecutada. El desarrollador de la aplicación es responsable de colocar el código en esta dirección para "iniciar" el PIC. El compilador MPLAB® XC8 de Microchip insertará las instrucciones apropiadas para poner en marcha el PIC y transferir el control a **main**. Los programadores de nivel de ensamblaje tendrán que escribir el código para inicializar el PIC y pasar el vector de interrupción ubicado en la dirección 0x04.

#### **Todos los registros de funciones especiales se establecen en un valor predeterminado**

La hoja de datos para cada MCU PIC de rango medio mejorado muestra los valores que contendrán los registros en RESET.

## Sample Register

| R/W-0/u | R/W-0/u | R/W-0/u | R/W-0/u | R/W/HC-0/u     | R-x/x  | R/W-0/u    | R/W-0/u |
|---------|---------|---------|---------|----------------|--------|------------|---------|
| TMR1GE  | T1GPOL  | T1GTM   | T1GSPM  | T1GGO/<br>DONE | T1GVAL | T1GSS<1:0> |         |
| bit 7   |         |         |         |                |        |            | bit 0   |

**Legend:**

|                      |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared | HC = Bit is cleared by hardware                       |

### Conjunto de instrucciones de rango medio mejorado

Esto se aplica a las familias de microcontroladores PIC® PIC16F1xxx y PIC16LF1xxx .

#### Operaciones orientadas a bytes

| Mnemónicos,<br>Operandos | Descripción                               |  | Ciclos | Código de<br>operación de 14 bits | Estado<br>Afectado | notas |
|--------------------------|-------------------------------------------|--|--------|-----------------------------------|--------------------|-------|
|                          |                                           |  |        | MSb.....LSb                       |                    |       |
| ADDWF f, d               | Añadir W y f                              |  | 1      | 00 0111 ffff ffff                 | C, CC, Z           | 2     |
| AÑADIRWFC f, d           | Suma con Carry W y f                      |  | 1      | 11 1101 ffff ffff                 | C, CC, Z           | 2     |
| ANDWF f, d               | Y W con f                                 |  | 1      | 00 0101 ffff ffff                 | Z                  | 2     |
| ASRF f, d                | Desplazamiento<br>aritmético a la derecha |  | 1      | 11 0111 ffff ffff                 | C, Z               | 2     |
| LSLF f, d                | Desplazamiento lógico a la<br>izquierda   |  | 1      | 11 0101 ffff ffff                 | C, Z               | 2     |
| LSRF f, d                | Desplazamiento lógico a la<br>derecha     |  | 1      | 11 0110 ffff ffff                 | C, Z               | 2     |
| CLRF F                   | Borrar f                                  |  | 1      | 00 0001 1fffffff                  | Z                  | 2     |

|        |      |                                          |   |                   |          |   |
|--------|------|------------------------------------------|---|-------------------|----------|---|
| CLRW   |      | Borrar W                                 | 1 | 00 0001 0000 00xx | Z        |   |
| COMF   | f, d | Complemento f                            | 1 | 00 1001 ffff ffff | Z        | 2 |
| DECF   | f, d | Decremento f                             | 1 | 00 0011 ffff ffff | Z        | 2 |
| FIN    | f, d | Incremento f                             | 1 | 00 1010 ffff ffff | Z        | 2 |
| IORWF  | f, d | Inclusivo OR W con f                     | 1 | 00 0100 dfff ffff | Z        | 2 |
| MOVF   | f, d | Mover f                                  | 1 | 00 1000 ffff ffff | Z        | 2 |
| MOVWF  | F    | Mover W a f                              | 1 | 00 0000 1fffffff  | Ninguna  | 2 |
| RLF    | f, d | Girar a la izquierda f a través de Carry | 1 | 00 1101 ffff ffff | C        | 2 |
| FRR    | f, d | Girar a la derecha f a través de Carry   | 1 | 00 1100 dfff ffff | C        | 2 |
| SUBWF  | f, d | Reste con Préstamo W de f                | 1 | 11 1011 ffff ffff | C, CC, Z | 2 |
| SUBWFB | f, d | Restar W de f                            | 1 | 00 0010 ffff ffff | C, CC, Z | 2 |
| SWAPF  | f, d | Intercambiar mordiscos en f              | 1 | 00 1110 ffff ffff | Ninguna  |   |
| XORWF  | f, d | Exclusivo OR W con f                     | 1 | 00 0110 ffff ffff | Z        | 2 |

#### Instrucciones de omisión orientadas a bytes

| Mnemónicos,<br>Operandos | Descripción | Ciclos | Código de<br>operación de 14 bits | Estado<br>Afectado | notas |
|--------------------------|-------------|--------|-----------------------------------|--------------------|-------|
|                          |             |        | MSb.....LSb                       |                    |       |

|        |      |                            |      |                   |         |     |
|--------|------|----------------------------|------|-------------------|---------|-----|
| DECFSZ | f, d | Decrementar f, Saltar si 0 | 1(2) | 00 1011 ffff ffff | Ninguna | 1,2 |
| INCFSZ | f, d | Incrementar f, Saltar si 0 | 1(2) | 00 1111 ffff ffff | Ninguna | 1,2 |

#### Operaciones de registro de archivos orientados a bits

| Mnemónicos,<br>Operandos | Descripción      | Ciclos          | Código de<br>operación de 14 bits | Estado<br>Afectado | notas   |   |
|--------------------------|------------------|-----------------|-----------------------------------|--------------------|---------|---|
| FCB                      | pensión completa | poco claro f    | 1                                 | 01 00bb bff ffff   | Ninguna | 2 |
| BSF                      | pensión completa | Juego de bits f | 1                                 | 01 01bb bfff ffff  | Ninguna | 2 |

#### Operaciones de salto orientadas a bits

| Mnemónicos,<br>Operandos | Descripción      | Ciclos                                   | Código de<br>operación de 14 bits | Estado<br>Afectado | notas   |     |
|--------------------------|------------------|------------------------------------------|-----------------------------------|--------------------|---------|-----|
| BTFSZ                    | pensión completa | Bit Test f, Saltar si Borrar             | 1(2)                              | 01 10bb bfff ffff  | Ninguna | 1,2 |
| BTFSZ                    | pensión completa | Prueba de bits f, omitir si se establece | 1(2)                              | 01 11bb bfff ffff  | Ninguna | 1,2 |

#### operaciones literales

| Mnemónicos,<br>Operandos | Descripción | Ciclos              | Código de<br>operación de 14 bits | Estado<br>Afectado | notas    |
|--------------------------|-------------|---------------------|-----------------------------------|--------------------|----------|
| ADDLW                    | k           | Agregar literal y W | 1                                 | 11 1110 kkkk kkkk  | C, CC, Z |
| ANDLW                    | k           | AND literal con W   | 1                                 | 11 1001 kkkk kkkk  | Z        |

|       |   |                            |   |                   |          |
|-------|---|----------------------------|---|-------------------|----------|
| IORLW | k | literal OR inclusivo con W | 1 | 11 1000 kkkk kkkk | Z        |
| MOVLB | k | Mover literal a BSR        | 1 | 00 0000 001k kkkk | Ninguna  |
| MOVLP | k | Mover literal a PCLATH     | 1 | 11 0001 1kkk kkkk | Ninguna  |
| MOVLW | k | Mover literal a W          | 1 | 11 0000 kkkk kkkk | Ninguna  |
| SUBLW | k | Restar W de literal        | 1 | 11 1100 kkkk kkkk | C, CC, Z |
| XORLW | k | Exclusivo OR literal con W | 1 | 11 1010 kkkk kkkk | Z        |

#### operaciones de control

| Mnemónicos,<br>Operandos |   | Descripción                     | Ciclos | Código de<br>operación de 14 bits | Estado<br>Afectado | notas |
|--------------------------|---|---------------------------------|--------|-----------------------------------|--------------------|-------|
| MSb.....LSb              |   |                                 |        |                                   |                    |       |
| SOSTÉN                   | k | Rama relativa                   | 2      | 11 001k kkkk kkkk                 | Ninguna            |       |
| BRW                      |   | Rama relativa con W             | 2      | 00 0000 0000 1011                 | Ninguna            |       |
| LLAMAR                   | k | Subrutina de llamada            | 2      | 10 0kkk kkkk kkkk                 | Ninguna            |       |
| LLAMAR                   |   | Subrutina de llamada con<br>W   | 2      | 00 0000 0000 1010                 | Ninguna            |       |
| IR                       | k | Ir a dirección                  | 2      | 10 1kkk kkkk kkkk                 | Ninguna            |       |
| RECUPERAR                | k | Regreso de interrupción         | 2      | 00 0000 0000 1001                 | Ninguna            |       |
| RETLW                    | k | Volver, colocar literal en<br>W | 2      | 11 0100 kkkk kkkk                 | Ninguna            |       |
| DEVOLVER                 | k | Regreso de subrutina            | 2      | 00 0000 0000 1000                 | Ninguna            |       |

### Operaciones inherentes

| Mnemónicos,<br>Operandos | Descripción                         | Ciclos | Código de<br>operación de 14 bits | Estado<br>Afectado | notas |
|--------------------------|-------------------------------------|--------|-----------------------------------|--------------------|-------|
|                          |                                     |        | MSb.....LSb                       |                    |       |
| CLRWDT                   | Borrar temporizador de vigilancia   | 1      | 00 0000 0110 0100                 | A , PD             |       |
| NOP                      | No operacion                        | 1      | 00 0000 0000 0000                 | Ninguna            |       |
| OPCIÓN                   | Cargue el registro de OPCIÓN con W  | 1      | 00 0000 0110 0010                 | Ninguna            |       |
| REINICIAR                | Restablecer dispositivo de software | 1      | 00 0000 0000 0001                 | Ninguna            |       |
| DORMIR                   | Entrar en modo de espera            | 1      | 00 0000 0110 0011                 | A , PD             |       |
| TRIS F                   | Cargar registro TRIS                | 1      | 00 0000 0110 0fff                 | Ninguna            |       |

### Compilador C optimizado

| Mnemónicos,<br>Operandos | Descripción              | Ciclos | Código de<br>operación de 14 bits | Estado<br>Afectado | notas |
|--------------------------|--------------------------|--------|-----------------------------------|--------------------|-------|
|                          |                          |        | MSb.....LSb                       |                    |       |
| ADDFSR                   | Agregar literal a FSRn   | 1      | 11 0001 Onkk kkkk                 | Ninguna            |       |
| PELÍCULA                 | Mover FSRn indirecto a W | 1      | 00 0000 0001 0nnn                 | Z                  | 2     |
| MOVWI                    | Mover W a FSRn indirecto | 1      | 00 0000 0001 1nnnn                | Z                  | 2     |

### notas

- Si se modifica el contador de programa (PC), o si una prueba condicional es verdadera, la instrucción requiere dos ciclos. El segundo ciclo se ejecuta como NOP .
- Si esta instrucción direcciona un registro INDF y se establece el MSb del FSR correspondiente, la instrucción requiere un ciclo de instrucción adicional.

Los bits de configuración son una colección de datos binarios ubicados en la memoria flash de un microcontrolador <sup>PIC</sup>® (MCU). Los bits de configuración se programan en la MCU PIC con el código de la aplicación. No son código ejecutable ya que el Contador de programa (PC) no puede acceder a su dirección. Cuando se programan en una MCU PIC, los bits de configuración completan el circuito que activa o desactiva las funciones de hardware de la MCU.

Los bits de configuración se leen al salir de un restablecimiento y no se pueden modificar durante el tiempo de ejecución.

Las características especiales de la operación de MCU controladas por los bits de configuración incluyen:

1. Reloj del sistema
2. Administración de energía
3. Seguridad del dispositivo
4. Características de funcionamiento

Los bits de configuración se generan a partir de directivas de compilador/ensamblador incluidas en los archivos de código fuente.

Esta página describe qué funciones están controladas por bits de configuración y cómo generarlas en el código fuente.

Los bits de configuración y las configuraciones para dispositivos PIC16F1xxx individuales pueden variar. Consulte su hoja de datos para conocer los detalles de los bits de configuración de PIC MCU que está utilizando.

### **Ubicación y formato**

Los bits de configuración para la familia de MCU PIC16F1 se combinan en dos palabras de 14 bits denominadas CONFIG1 y CONFIG2. Las palabras de configuración están ubicadas fuera del alcance de la PC en las direcciones 0x8007 y 0x8008 en la memoria flash de la MCU.

## REGISTER 10-1: CONFIGURATION WORD 1

| R/P-1/1 | R/P-1/1 | R/P-1/1         | R/P-1/1 | R/P-1/1 | R/P-1/1    | R/P-1/1   |
|---------|---------|-----------------|---------|---------|------------|-----------|
| FCMEN   | IESO    | <u>CLKOUTEN</u> | BOREN1  | BOREN0  | <u>CPD</u> | <u>CP</u> |
| bit 13  |         |                 |         |         |            |           |

| R/P-1/1 | R/P-1/1      | R/P-1/1 | R/P-1/1 | R/P-1/1 | R/P-1/1 | R/P-1/1 |
|---------|--------------|---------|---------|---------|---------|---------|
| MCLRE   | <u>PWRTE</u> | WDTE1   | WDTE0   | FOSC2   | FOSC1   | FOSC0   |
| bit 6   |              |         |         |         |         |         |

## REGISTER 10-2: CONFIGURATION WORD 2

| R/P-1/1 | R/P-1/1      | U-1 | R/P-1/1 | R/P-1/1 | R/P-1/1 | U-1 |
|---------|--------------|-----|---------|---------|---------|-----|
| LVP     | <u>DEBUG</u> | -   | BORV    | STVREN  | PLLEN   | -   |
| bit 13  |              |     |         |         |         |     |

| U-1   | R/P-1/1 | R/P-1/1 | U-1 | U-1 | R/P-1/1 | R/P-1/1 |
|-------|---------|---------|-----|-----|---------|---------|
| -     | VCAPEN1 | VCAPENO | -   | -   | WRT1    | WRT0    |
| bit 6 |         |         |     |     |         |         |

Los bits de configuración se insertan en el código fuente de la aplicación. Cuando se construye un proyecto PIC MCU, los ajustes de bits de configuración se cargan en el archivo de salida HEX. Los bits de configuración se programan en el PIC con el programa de aplicación.

### **Generación de bits de configuración en código C**

El compilador MPLAB® XC8 C de Microchip acepta directivas #pragma para establecer los bits de configuración.

La sintaxis para generar bits de configuración:

**#pragma config CONFIG\_BIT\_NAME = CONFIG\_VALUE**

### **Ejemplo de establecimiento de bits de configuración en C**

Cuando se configuran los bits de configuración usando C, no es necesario conocer la palabra que contiene el bit que se está configurando. Todo lo que se necesita es el nombre del bit de configuración y el valor deseado.

Los archivos de encabezado para cada dispositivo PIC16F1xx contienen CONFIG\_BIT\_NAME y CONFIG\_VALUE . Puede encontrar una lista completa de los ajustes en el [resumen de bits de configuración](#) .

**Una vez escritas, las directivas del compilador deben agregarse al proyecto PIC MCU de una de estas tres maneras:**

1. En un archivo fuente C independiente que se agrega al proyecto
2. En un archivo de encabezado ( .h ) colocado en el proyecto con una instrucción #include
3. Colocado directamente dentro de uno de los archivos de código fuente que ya están en el proyecto

Los desarrolladores que utilizan el compilador XC8 pueden consultar la sección de [bits de configuración](#) del tutorial MPLAB X para ver accesos directos en la generación del código necesario para establecer los bits de configuración.

### **Generación de bits de configuración en ensamblaje**

Cuando se trabaja con lenguaje ensamblador, se requiere que el programador genere los valores específicos de 14 bits para cada una de las dos direcciones de configuración. Una vez que se generan los patrones, el programa realiza una llamada a la directiva CONFIG para establecer cada una de las palabras de configuración.

En el archivo .INC de cada MCU de PIC se incluye un patrón de 14 bits para cada configuración de bit de configuración individual. El valor de 14 bits que se pasa a la directiva CONFIG se genera mediante la combinación lógica AND de la configuración de bits en el archivo .INC.

El código para generar y cargar los bits de configuración se puede colocar en cualquier archivo de origen de ensamblado del proyecto.

### **Reloj del sistema**

#### **Fuente de reloj (FOSC)**

FOSC consta de tres bits de configuración individuales: FOSC2 , FOSC1 y FOSC0 . El campo de bits FOSC se encuentra en CONFIG1 .

FOSC selecciona la fuente de reloj para MCU.

Las opciones para FOSC son:

| <b>FOSC&lt;2:0&gt;</b> | <b>Ajuste</b> | <b>reloj agrio</b>                                |
|------------------------|---------------|---------------------------------------------------|
| 0 0 0                  | INTOSC        | oscilador interno                                 |
| 0 0 1                  | EXTRC         | Oscilador RC externo                              |
| 0 1 0                  | SA            | Oscilador de cristal externo de alta velocidad    |
| 0 1 1                  | XT            | Oscilador de cristal externo                      |
| 1 0 0                  | LP            | Oscilador de cristal externo de baja potencia     |
| 1 0 1                  | ECH           | Reloj externo con rango de frecuencia 4 - 32 MHz  |
| 1 1 0                  | ECM           | Reloj externo con rango de frecuencia 0,5 - 4 MHz |
| 1 1 1                  | ECL           | Reloj externo con rango de frecuencia 0 - 0,5 MHz |

#### **Ejemplo: Selección del reloj del sistema**

### **Monitor de reloj a prueba de fallas (FCMEN)**

El FCMEN es un único bit de configuración que reside en CONFIG1 .

FCMEN controla el funcionamiento del monitor de reloj a prueba de fallas, lo que permite que el reloj cambie de externo a interno en caso de falla del reloj externo.

Las opciones para FCMEN son:

| <b>FCMEN</b> | <b>Ajuste</b> | <b>Función de monitor de reloj a prueba de fallas</b> |
|--------------|---------------|-------------------------------------------------------|
| 0            | APAGADO       | Desactivado                                           |
| 1            | EN            | Activado                                              |

#### **Ejemplo: Habilitación del monitor de reloj a prueba de fallas**

### **Comutación interna/externa (IESO)**

El IESO es un único bit de configuración que reside en CONFIG1 .

IESO establece el modo de cambio de reloj y arranque de dos velocidades. Con IESO habilitado, la fuente del reloj puede controlarse mediante el programa de aplicación.

Las opciones para IESO son:

| <b>IESO</b> | <b>Ajuste</b> | <b>Función de puesta en marcha de dos velocidades</b> |
|-------------|---------------|-------------------------------------------------------|
| 0           | APAGADO       | Desactivado                                           |
| 1           | EN            | Activado                                              |

#### **Ejemplo: Habilitación del arranque de dos velocidades**

### **Habilitación de salida de reloj ( CLKOUTEN )**

CLKOUTEN es un único bit de configuración que reside en CONFIG1 .

CLKOUTEN permite que el pin OSCx/CLKOUT emita el reloj del sistema interno. Esto permite que el reloj del sistema PIC16F1xxx controle otros componentes.

Las opciones para CLKOUTEN son:

| CLKOUTEN | Ajuste  | Función CLKOUT                                         |
|----------|---------|--------------------------------------------------------|
| 0        | EN      | Fosc se enviará a OSCx/CLKOUT                          |
| 1        | APAGADO | OSCx/CLKOUT será el oscilador o una función periférica |

#### Ejemplo: salida del reloj del sistema interno

#### Habilitación de bucle de bloqueo de fase (PLLEN)

PLLEN es un único bit de configuración que reside en CONFIG2 .

El bucle de bloqueo de fase (PLL) de 4 X del oscilador interno se controla mediante una combinación del bit de configuración PLLEN y el bit SPLLEN en el registro OSCON.

Las opciones para PLLEN son:

| PLLEN | Ajuste  | Función PLL interna                                 |
|-------|---------|-----------------------------------------------------|
| 0     | EN      | 4 X PLL siempre está habilitado                     |
| 1     | APAGADO | 4 X PLL está controlado por el bit SPLLEN en OSCCON |

No todos los MCU PIC16F1xxx tienen las mismas opciones para el PLL. Consulte la hoja de datos de la MCU PIC que está utilizando para determinar los ajustes de configuración de PLL específicos.

#### Ejemplo: Habilitación del bucle de bloqueo de fase interno

#### Administración de energía

### **Habilitación de restablecimiento de caída de tensión (BOREN)**

El ajuste de configuración de BOREN consta de dos bits individuales: BOREN1 y BOREN0 . El campo de bits BOREN reside en CONFIG1 .

BOREN permite que ocurra un REINICIO DE MCU si  $V_{dd}$  cae por debajo de un valor preestablecido. El nivel de voltaje que precipita el RESET está determinado por el bit de configuración BORV .

Hay cuatro opciones para los dos bits BOREN :

1. Brown-out Reset siempre está habilitado
2. Brown-out Reset siempre está deshabilitado
3. Brown-out Reset está habilitado cuando se está ejecutando pero deshabilitado cuando MCU ingresa al modo SLEEP
4. Brown-out Reset es controlado en tiempo de ejecución por el bit SBORN del registro PCON.

| <b>ABURRIDO</b> | <b>Ajuste</b> | <b>Función de reinicio de oscurecimiento</b>                 |
|-----------------|---------------|--------------------------------------------------------------|
| 1 1             | EN            | Siempre habilitado                                           |
| 0 0             | APAGADO       | Siempre deshabilitado                                        |
| 1 0             | NSLEEP        | Habilitado mientras está ACTIVO, deshabilitado en modo SLEEP |
| 0 1             | SBODEN        | controlado por el bit SBORN del registro PCON                |

### **Ejemplo: Desactivación de RESET de Brown-out**

### **Nivel de voltaje de caída de voltaje (BORV)**

BORV es un único bit de configuración que reside en CONFIG2 .

BORV solo es aplicable cuando el reinicio de Brown-out (controlado por el bit de configuración BOREN ) está activo.

BORV selecciona uno de los dos niveles de voltaje preestablecidos como el voltaje de restablecimiento de Brown-out.

Los niveles de voltaje establecidos por BORV son:

| BORV | Ajuste | Voltaje de caída de tensión |
|------|--------|-----------------------------|
| 0    | L0     | 1,9 voltios                 |
| 1    | HOLA   | 2,5 voltios                 |

El nivel de voltaje de caída de voltaje establecido por BORV puede variar según la MCU de PIC en particular. Consulte la hoja de datos para conocer las opciones de voltaje de reducción de voltaje.

**Ejemplo: Permita que Brown-out RESET esté siempre activo y activado a 2,5 V.**

**Ejemplo: habilite el REINICIO de Brown-out a 1,9 V mientras la MCU está ACTIVA y deshabilite Brown-out en el modo SLEEP.**

#### Regulador de Voltaje (VCAPEN - LDO)

El ajuste de configuración de VCAPEN consta de dos bits individuales: VCAPEN1 y VCAPENO . El campo de bits VCAPEN reside en CONFIG2 .

Para dispositivos con un regulador LDO interno, VCAPEN determina qué pin se asigna como pin de <sub>tapa en V</sub>.

Los ajustes para VCAPEN son:

| VCAPEN | Ajuste  | Función                                                      |
|--------|---------|--------------------------------------------------------------|
| 0 0    | RA6     | RA6 se asigna como <sub>tapa V</sub>                         |
| 0 1    | RA5     | RA5 se asigna como <sub>tapa V</sub>                         |
| 1 0    | RA0     | RA0 se asigna como <sub>tapa V</sub>                         |
| 1 1    | APAGADO | La <sub>tapa en V</sub> está desconectada de todos los pines |

No todas las MCU PIC16F1xxx tienen un regulador LDO interno. Consulte la hoja de datos de la MCU PIC que está utilizando para determinar si hay un LDO y qué pines están disponibles como  $V_{cap}$ .

#### Ejemplo: Asignación de $V_{cap}$ a RA6

#### Deshabilitar la funcionalidad de tapa en V

#### Programación de bajo voltaje (LVP)

LVP es un único bit de configuración que reside en CONFIG2.

El modo de entrada de programación de bajo voltaje permite que las MCU PIC16F1xxx se programen con solo  $V_{dd}$ . El uso de LVP elimina la necesidad de suministrar un voltaje superior a  $V_{dd}$  en MCLR /V<sub>pp</sub>.

Los ajustes para LVP son:

| LVP | Ajuste  | Función de programación |
|-----|---------|-------------------------|
| 1   | EN      | Activado                |
| 0   | APAGADO | Desactivado             |

#### Ejemplo: deshabilitar las lecturas de EEPROM desde fuentes externas

#### Seguridad del dispositivo

##### CPD - Protección de lectura de EEPROM de datos

CPD es un único bit de configuración que reside en CONFIG1.

La memoria EEPROM de datos internos se puede proteger de lecturas externas con CPD. Los programadores externos tienen prohibido leer la EEPROM protegida. El contenido de EEPROM todavía está disponible para lecturas desde fuentes internas.

Los ajustes para CPD son:

| DPC | Ajuste  | Función de protección de lectura de EEPROM |
|-----|---------|--------------------------------------------|
| 0   | EN      | Habilitado - EEPROM no es legible          |
| 1   | APAGADO | Deshabilitado - EEPROM es legible          |

**Ejemplo: deshabilitar las lecturas de EEPROM desde fuentes externas**

### Protección de lectura de memoria de programa ( CP )

CP es un único bit de configuración que reside en CONFIG1 .

Todo el espacio de la memoria del programa se puede proteger de lecturas externas con CP .

Verá todos los 0 cuando lea la memoria del programa protegido. El contenido de la memoria del programa todavía está disponible para lecturas desde fuentes internas.

Los ajustes para CP son:

| PC | Ajuste  | Función de protección de lectura      |
|----|---------|---------------------------------------|
| 0  | EN      | Habilitado - la memoria no es legible |
| 1  | APAGADO | Deshabilitado - la memoria es legible |

**Ejemplo: deshabilitar las lecturas de la memoria del programa externo**

### Activación de autoescritura flash (WRT)

WRT consta de dos bits de configuración individuales: WRT1 y WRT0 . El campo de bits WRT se encuentra en CONFIG2 .

WRT establece el rango de direcciones en el que el programa de usuario puede escribir la memoria del programa.

Los ajustes para WRT son:

| WRT | Ajuste | Funcionalidad Flash Self Right |
|-----|--------|--------------------------------|
|     |        |                                |

|   |   |         |                                                                                 |
|---|---|---------|---------------------------------------------------------------------------------|
| 1 | 1 | TODOS   | El programa de usuario no puede escribir en la memoria                          |
| 1 | 0 | BOTA    | Rango de direcciones 0 - 0x1FF protegido contra escritura 200 h - FFFn grabable |
| 0 | 1 | MITAD   | Rango de direcciones 0 - 0x7FF protegido contra escritura 800 h - FFFn grabable |
| 0 | 0 | APAGADO | El programa de usuario puede escribir en todas las direcciones de memoria       |

No todas las MCU PIC16F1xxx tienen las mismas opciones de WRT que se muestran. Consulte la hoja de datos de la MCU PIC que está utilizando para determinar las opciones de WRT para el dispositivo.

### Características de funcionamiento

#### Control de clavijas para MCLR (MCLRE)

MCLRE es un único bit de configuración que reside en CONFIG1 .

MCLRE controla la función del pin MCLR /V<sub>pp</sub> .

MCLRE se ignora si la programación de bajo voltaje (establecida por el bit de configuración LVP ) no está habilitada.

Los ajustes para MCRLE son:

| MCLRE | Ajuste  | Función                                                                          |
|-------|---------|----------------------------------------------------------------------------------|
| 1     | EN      | La función de pin es MCLR /V <sub>pp</sub> con pull-up débil interno habilitado  |
| 0     | APAGADO | La función de pin es una entrada digital con pull-up interno controlado por WPUx |

**Ejemplo: Dejar MCRL /V<sub>pp</sub> como pin RESET.**

**Haciendo MCRL /V<sub>pp</sub> un pin de entrada digital.**

#### Temporizador de encendido (PWRTE)

PWRTE es un único bit de configuración que reside en CONFIG2 .

El tiempo de encendido proporciona un retraso nominal de 72 ms después de un reinicio de encendido o un reinicio de apagón para permitir que V<sub>dd</sub> se estabilice. La activación o desactivación de este retraso está controlada por PWRTE .

Las opciones para PWRTE son:

| PWRTE | Ajuste  | Función de temporizador de encendido |
|-------|---------|--------------------------------------|
| 0     | EN      | Desactivado                          |
| 1     | APAGADO | Activado                             |

#### Ejemplo de activación del temporizador de encendido

#### Habilitación del temporizador de vigilancia (WDTE)

El ajuste de configuración de WDTE consta de dos bits individuales: WDTE1 y WDTE0 . El campo de bits WDTE reside en CONFIG1 .

WDTE permite que se produzca un REINICIO de MCU si el temporizador de vigilancia interno pasa de 0xFF a 0x00 antes de que la MCU pueda ejecutar una instrucción CLRWD .

Hay cuatro opciones para los dos bits WDTE :

1. El restablecimiento del temporizador de vigilancia siempre está habilitado
2. El restablecimiento del temporizador de vigilancia siempre está deshabilitado
3. El restablecimiento del temporizador de vigilancia está habilitado cuando se está ejecutando pero deshabilitado cuando la MCU ingresa al modo SUSPENSIÓN
4. El restablecimiento del temporizador de vigilancia se controla en tiempo de ejecución mediante el bit SWDTEN del registro WDTCON

| WDTE | Ajuste | Función de reinicio del perro guardián |
|------|--------|----------------------------------------|
| 1 1  | EN     | Siempre habilitado                     |

|     |         |                                                                          |
|-----|---------|--------------------------------------------------------------------------|
| 0 0 | APAGADO | Siempre deshabilitado                                                    |
| 1 0 | NSLEEP  | Habilitado mientras está ACTIVO, deshabilitado cuando está en modo SLEEP |
| 0 1 | SBODEN  | Controlado por bit SBOREN de registro PCON                               |

### Desbordamiento de pila de hardware (STVREN)

STVREN es un único bit de configuración que reside en CONFIG2 .

El bit de configuración STVREN habilita o deshabilita un REINICIO en un desbordamiento o subdesbordamiento de la pila.

Un desbordamiento o subdesbordamiento de pila siempre establece el bit STKOVF o STKUNF en el registro PCON independientemente del valor de STVREN .

Las opciones para STVREN son:

| STVREN | Ajuste  | Función                                                                   |
|--------|---------|---------------------------------------------------------------------------|
| 1      | EN      | El REINICIO del flujo excesivo/insuficiente de la pila está HABILITADO    |
| 0      | APAGADO | El REINICIO del flujo excesivo/insuficiente de la pila está DESHABILITADO |

Los bits de configuración y los ajustes para dispositivos PIC16F1xxx individuales pueden ser diferentes. Consulte su hoja de datos para conocer los detalles de los bits de configuración de PIC MCU que está utilizando.

### DEPURACIÓN - Modo de depuración

El bit DEBUG en la palabra de configuración 2 es administrado automáticamente por MPLAB X IDE.

¡Para garantizar el correcto funcionamiento del dispositivo, este bit no debe modificarse!

## Resumen de los ajustes de bits de configuración para el MCU PIC® de rango medio mejorado mediante el compilador XC8

A continuación se muestra un resumen de las directivas de bits de configuración PIC16F1xxx aceptadas por el compilador MPLAB® XC8 C de Microchip.

En la página "[Bits de configuración](#)" del tutorial mejorado de rango medio se presenta una descripción completa de estos ajustes de bits de configuración .

Algunos microcontroladores PIC® de rango medio mejorados <sup>pueden</sup> tener un conjunto diferente de bits de configuración.

Consulte la hoja de datos de la MCU que está utilizando para obtener una lista completa.

### Sintaxis

```
#pragma config CONFIG_BIT_NAME = CONFIG_VALUE
```

| CONFIG_BIT_NOMBRE | CONFIG_VALUE                      | Función de los bits de configuración                                                                                                                                                                                                                |
|-------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FOSC              | INTOSC EXTRC HS XT LP ECH ECM ECL | El oscilador interno es la fuente del reloj.<br>El oscilador RC externo es la fuente del reloj .<br>Cristal/ oscilador externo de semilla alta.<br>Cristal/oscilador externo. Oscilador externo de baja potencia ./ rango de frecuencia 0 - 0,5 MHz |
| WDTE              | ON OFF NSLEEP SWDTEN              | El temporizador de vigilancia (WDT) está deshabilitado.<br>WDT está habilitado .<br>WDT está habilitado cuando está en funcionamiento y                                                                                                             |

|          |                          |                                                                                                                             |
|----------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------|
|          | <b>ENCENDIDO APAGADO</b> | deshabilitado cuando está en modo SLEEP.<br>WDT controlado por el bit SWDTEN en el registro WDTCON.                         |
| PWRTE    | <b>ENCENDIDO APAGADO</b> | Temporizador de encendido activado<br>Temporizador de encendido desactivado                                                 |
| MCLRE    | <b>ENCENDIDO APAGADO</b> | La función pin es MCLR La función pin es entrada digital                                                                    |
| PC       | <b>ENCENDIDO APAGADO</b> | La protección de código está habilitada<br>La protección de código está deshabilitada                                       |
| DPC      | <b>ENCENDIDO APAGADO</b> | La protección del código de memoria de datos está activada<br>La protección del código de memoria de datos está desactivada |
| ABURRIDO | <b>ENCENDIDO APAGADO</b> | Brown-Out Reset está habilitado<br>Brown-Out Reset está deshabilitado                                                       |
| CLKOUTEN |                          |                                                                                                                             |

|       |                          |                                                                                                                                                                 |
|-------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <b>ENCENDIDO APAGADO</b> | La función CLKOUT está habilitada en el pin CLKOUT La función CLKOUT está deshabilitada. Función I/O u osc en el pin CLKOUT                                     |
| IESO  | <b>ENCENDIDO APAGADO</b> | El modo de cambio de reloj interno/externo está habilitado El modo de cambio de reloj interno/externo está deshabilitado                                        |
| FCMEN | <b>ENCENDIDO APAGADO</b> | El monitor de reloj a prueba de fallas está habilitado<br>El monitor de reloj a prueba de fallas está deshabilitado                                             |
| WRT   | <b>ENCENDIDO APAGADO</b> | La protección contra escritura automática de la memoria flash está habilitada<br>La protección contra escritura automática de la memoria flash está desactivada |
| PLÉN  | <b>ENCENDIDO APAGADO</b> | PLL interno 4X está habilitado<br>PLL interno 4X está deshabilitado                                                                                             |

|        |                          |                                                                                                                                                          |
|--------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| STVREN | <b>ENCENDIDO APAGADO</b> | El desbordamiento o subdesbordamiento de pila provocará un reinicio<br>El desbordamiento o subdesbordamiento de pila NO provocará un reinicio            |
| BORV   | <b>LO HOLA</b>           | Restablecimiento de voltaje Brown-Out - Punto de disparo bajo seleccionado<br>Restablecimiento de voltaje Brown-Out - Punto de disparo alto seleccionado |
| LVP    | <b>ENCENDIDO APAGADO</b> | Programación de bajo voltaje habilitada<br>Se debe usar alto voltaje en MCLR/VPP para la programación                                                    |

### **Memoria de programa MCU PIC® de gama media mejorada**

La memoria de programa en la MCU PIC® de gama media mejorada consta de hasta 32 MB de memoria Flash de 14 bits de ancho. Después de programar la MCU, la memoria del programa contiene el código de aplicación del usuario. Se accede a la memoria de programa mediante un registro de contador de programa (PC) de 15 bits.



### REINICIO vectorial

En RESET, el contador del programa se borra, dando como resultado todo ceros. Esto permite que la dirección de memoria de programa 0h sea la ubicación de la primera instrucción ejecutada después de una condición de REINICIO.

### Vector de interrupción

Cuando ocurre una interrupción, el control del programa se transfiere a la dirección 04h. La sección "["Interrupciones"](#)" proporciona una descripción completa del proceso de interrupción



### Pila de retorno

Una pila de retorno de hardware de 16 entradas y 15 bits de ancho almacena la PC en caso de una interrupción o llamada a una subrutina. La pila de retorno funciona sobre la base de que el último en entrar es el primero en salir.

Al ejecutar una instrucción RETURN, ( RETFIE o RETURN ), el elemento superior de la pila se elimina de la pila y se coloca en el contador del programa.

Para leer o modificar la PC de 14 bits con una MCU de 8 bits, se utilizan dos registros de funciones especiales (SFR):

- PCL : contiene los 8 bits inferiores del contador de programa <PC7:0>
- PCLATH : el contenido depende de la operación de MCU que se esté realizando

PCL y PCLATH se utilizan cuando el programa escribe en la PC, lee el contador del programa o ejecuta una instrucción GOTO o CALL .

## Escribir en la PC

Cuando la aplicación escribe en PCL , el contenido actual de PCLATH<5:0> se escribirá en PC<14:8> . Debido a esto, el contenido de PCLATH<5:0> siempre DEBE ser correcto ANTES de escribir en PCL .



## Leyendo la computadora

Cuando una aplicación lee PCL , PC<14:8> se captura en PCLATH .



### Ejecución de una instrucción CALL o GOTO

Las instrucciones CALL y GOTO solo tienen 11 bits disponibles para especificar la dirección de destino. PCLATH se usa para extender el operando para acceder a todas las direcciones de memoria del programa. Cuando se ejecuta CALL o GOTO , la dirección de 11 bits del operando se carga en PC<10:0> y PCLATH<6:3> se carga en PC<14:11> .



### Periféricos de la familia de microcontroladores <sup>PIC®</sup> de gama media mejorada de 8 bits

| Módulo                     | Nombre                                     |
|----------------------------|--------------------------------------------|
| <a href="#"><u>ADC</u></a> | Convertidor analógico a digital de 10 bits |
| <a href="#"><u>CVX</u></a> | Celda lógica configurable                  |
| <a href="#"><u>CMP</u></a> | Comparadores analógicos                    |
| <a href="#"><u>CPS</u></a> | Módulo de detección capacitiva             |
| <a href="#"><u>CAD</u></a> | Convertidor digital a analógico de 5 bits  |
| <a href="#"><u>DSM</u></a> | Modulador de señal de datos                |

|                   |                                                      |
|-------------------|------------------------------------------------------|
| <u>ECCP</u>       | Captura, comparación y PWM mejorados                 |
| <u>EUSART</u>     | Transmisor receptor asíncrono universal mejorado     |
| <u>RVF</u>        | Referencia de voltaje fijo                           |
| <u>MI2C</u>       | Circuito Interintegrado Maestro (I <sup>2</sup> C)   |
| <u>MSSP</u>       | Puerto serie síncrono maestro (SPI/I <sup>2</sup> C) |
| <u>suboficial</u> | Oscilador controlado numéricamente                   |
| <u>SPI</u>        | Interfaz de periféricos en serie (SPI)               |
| <u>TMRO</u>       | Temporizador 0 (8 bits)                              |
| <u>TMR1</u>       | Temporizador 1 (16 bits)                             |
| <u>TMR2</u>       | Temporizador 2 (8 bits)                              |
| <u>UART</u>       | Transmisor receptor asíncrono universal              |

### **E/S digital de gama media mejorada de 8 bits**

#### **Estructura básica de E/S**

Casi todos los pines del microcontrolador PIC® de rango medio mejorado (MCU) se pueden usar como pines de entrada o salida digital. Los pines digitales comparten estos atributos:

- Capacidad para monitorear entradas digitales
- Señales de salida digital de control
- Dominadas débiles internas
- Multiplexado con periféricos

- Alta capacidad de accionamiento (hasta 25 mA disipador/fuente en muchos pines de E/S)
- Manipulación directa de bit de ciclo único
- Diodos de protección ESD de 4 kV

En REINICIO:

- Los pines digitales vuelven a la entrada (Hi-Z)
- Los pines con capacidad analógica vuelven a ser analógicos

Las E/S digitales están controladas por software en la MCU. El programa MCU configura, lee y envía los valores a los pinos digitales.

### Puertos de E/S

#### Puertos de E/S

Figura 1. Puerto de E/S.

Los pines de E/S digitales individuales se combinan en grupos llamados puertos. Los puertos de E/S contienen hasta ocho pines digitales. Se puede acceder a los pines de E/S digital individualmente pin por pin. También se puede acceder a todos los miembros de un puerto de E/S particular en un ciclo de instrucción mediante una de las instrucciones de acceso a bytes de la MCU.

Los puertos de E/S se denominan por letras (p. ej., PORTA, PORTB, PORTC). El número de puertos de E/S variará según el MCU de PIC que se utilice. Consulte la hoja de datos individual para determinar las asignaciones de PUERTO para una MCU PIC.

## **Pin típico de E/S digital**

Figura 2. E/S de pin digital.

Hay cinco registros disponibles para configurar y controlar los pines de E/S digitales.

1. TRISx: establece la dirección como entrada o salida.
2. ANSELx: determina si un pin con capacidad analógica funciona como entrada analógica o E/S digital.
3. LATx: se utiliza para generar valores para un pin digital.
4. PORTx- Lee el valor de entrada de un pin digital.
5. WPUx- Habilita el pull up débil interno.

Hay cinco registros de control de E/S para cada puerto.

- Para el puerto A los registros de control son: TRISA, ANSELA, LATA, PORTA y WPUA.
- Para el puerto B los registros de control son: TRISB, ANSELB, LATB, PORTB y WPUB.

A lo largo de esta página se proporcionan ejemplos de programas que muestran cómo utilizar los registros de control de E/S.

### **Identificación de los pines de E/S en la hoja de datos**

Las E/S digitales pueden compartir pines con otros periféricos y líneas de control de MCU. Algunos pines de E/S digitales tienen capacidad analógica y se pueden configurar para

operar como pines de entrada analógica. Consulte el diagrama de pines de la hoja de datos del dispositivo para determinar qué pines están disponibles como E/S digital.

Los pines digitales se identifican mediante tres identificadores secuenciales:

- El primer identificador de un pin digital es la letra R.
- El segundo identificador es una letra del PUERTO en el que está asociado el pin (como A para PORTA , B para PORTB , etc.).
- El identificador final es un número del 0 al 7 que indica la posición en el PUERTO que ocupa el PIN.



Figura 3. Todos los pines digitales asociados con PORTB están resaltados en amarillo.

Los miembros de PORTB van desde RB0 - RB7.

Para los otros pines en la MCU:

- Los pines con capacidad analógica se designan con las dos letras AN seguidas de un número.
- Los pines periféricos y de control de MCU están designados por nombre en la hoja de datos.



Figura 4. En el primer plano del RB3/pin 24, se muestran las opciones para el PIC16L/F1936.

El pin 24 se puede configurar como pin digital PORTB bit 3, canal analógico 9 o uno de varios periféricos

Para que un pin funcione como un pin digital, todos los periféricos asociados con el pin NO deben estar habilitados.

Si se va a utilizar un pin con capacidad analógica como pin digital, además de no habilitar el periférico, el pin *debe* configurarse específicamente como un pin digital.

#### **Configuración analógica vs digital**

Dependiendo de qué MCU PIC de rango medio mejorado se utilice, se pueden configurar hasta 30 pines digitales para que sean pines analógicos. Los registros ANSELx se utilizan para configurar el modo de los pines con capacidad analógica. (ANSELA controla el modo de todos los pines con capacidad analógica en PORTA , ANSELB controla el modo para PORTB , ANSELD para PORTD , etc.).

Los pines con capacidad analógica en el puerto se asignan a bits individuales en un registro ANSELx. Un valor de 1 en un bit de un registro ANSELx habilitará el modo analógico del pin del puerto correspondiente. Un valor de 0 configura el pin para que sea digital.

En RESET, todos los pines con capacidad analógica vuelven al modo analógico. La MCU establece todos los bits ANSELx relevantes en 1.

#### **Ejemplo:**

El pin 24, en la Figura 4, puede configurarse como canal analógico 9 o como pin digital RB3. Para usar este pin como pin digital, se debe borrar el bit 3 de ANSELB.

Cuando trabaje con pines digitales con capacidad analógica, recuerde:

- Si se intenta una conversión de analógico a digital (ADC) en un pin con capacidad analógica configurado como digital, la conversión devolverá un valor invariable que no refleja el voltaje en el pin.
- Si un pin está configurado como un pin analógico, cualquier valor digital leído del pin siempre será 1, independientemente del voltaje en el panel de entrada.
- Si se escribe un pin analógico configurado como si fuera un pin digital, el nivel de salida del pin no cambiará.

#### **Salidas digitales**

El registro TRISx controla la dirección de los datos en cada bit de un puerto. Cada pin en un puerto se asigna a un bit en un registro TRIS. La dirección de datos para cada pin se puede configurar escribiendo un valor de 8 bits en el registro TRIS individualmente, configurando/borrando un bit de registro TRIS o la dirección de todos los bits en un puerto.

En RESET, todos los bits asociados con los pines en los registros TRIS se establecen en 1, lo que hace que todos los pines sean entradas High-Z.

#### **Convertir un pin en un pin de salida digital**

Para configurar un pin como salida digital, se deben colocar 0 en los bits de registro TRISx correspondientes.

#### **Escribir en un pin digital**

El valor de salida para cada puerto se puede cargar escribiendo en el registro LAT del puerto. (Al igual que todos los demás registros de control de puertos, los nombres de los registros LATx están escritos con letras. Los registros LATx comienzan con LATA y continúan con LATB, LATC...)

Escribir un 1 a un bit en el registro LAT conducirá el pin a Vdd. Un 0 en un bit LAT llevará el pin a Vss.

Escribir en el registro POTRTx también impulsará la señal de salida al igual que escribir en el registro LATx.

Sin embargo, bajo cargas altas o alta frecuencia, si se escriben secuencialmente varios comandos de modificación de bits (BSF, BCF) en un registro de PUERTO de salida, es posible que la última instrucción de manipulación de bits sobrescriba una instrucción anterior, dando como resultado un valor incorrecto en el puerto de salida. Para evitar la posibilidad de que esto ocurra, se recomienda encarecidamente que la salida siempre se realice en el registro LATx.

#### **Código de ejemplo:**

El código que se muestra aquí es un ejemplo de configuración de todos los pines en PORTB como salidas digitales. Una vez configurados como pines de salida, los cuatro bits inferiores del puerto se elevan mientras que los cuatro bits superiores se establecen en 0.

¿Por qué se borró el registro LAT antes de configurar el registro TRIS?

En RESET se desconoce el contenido de los registros LATx. Se recomienda que el valor de todos los bits de registro LAT de salida se establezca en un valor conocido (y seguro) antes de habilitar los pines de salida. Esto evitará pulsos de salida espurios e involuntarios.

En este ejemplo, solo la configuración de RB3 se cambia a una salida digital. Una vez configurado, RB3 se eleva. Todos los demás pines (y sus respectivos bits de registro de control) se dejan sin cambios.

## **Entradas digitales**

#### **Convertir un pin en un pin de entrada digital:**

Para configurar un pin como entrada digital, se deben colocar 1 en los bits de registro TRISx correspondientes.

#### **Lectura de un pin digital**

El valor de cada pin de entrada se puede observar leyendo el registro PORTx correspondiente. Si el nivel de voltaje en un pin en particular está por encima del umbral de entrada, el bit en el registro PORTx asociado con el pin contendrá un 1. Los voltajes por debajo del umbral contendrán un 0.

Escribir en un bit de registro LATx de un pin configurado como entrada no afectará el valor del pin.

#### **Código de ejemplo:**

Este programa de muestra configura RA3 ( PORTA bit 3) como un pin de entrada digital. Luego, el programa monitorea continuamente el valor de RA3. Cuando RA3 sube, el control del programa se transfiere a una rutina de excepción.

#### **Dominadas débiles internas**

Las resistencias pull-up débiles internas están habilitadas para cada pad de E/S mediante el registro WPUx.

El pull-up se desactivará automáticamente cuando TRIS se configure como una salida o el pin se configure como una entrada analógica. Estos cambios en TRIS y ANSEL anularán la configuración de WPU.

#### **Habilitación de pull-ups**

El pull-up interno para un pin de entrada digital se habilita escribiendo un 1 en el registro WPUX apropiado. Escribir un 0 en el registro WPUX deshabilita el pull-up.

### Convertidor analógico a digital (ADC)

El convertidor de analógico a digital (ADC) puede convertir una señal de entrada analógica en una representación digital binaria de 10 bits de esa señal. Las entradas analógicas de los microcontroladores de Microchip, que se multiplexan en un solo circuito de muestra y retención. La salida de la muestra y retención está conectada a la entrada del ADC. El ADC genera el resultado binario de 10 bits a través de aproximaciones sucesivas y almacena el resultado de la conversión en los registros de resultados del ADC.



El ADC utiliza una referencia de voltaje que es seleccionable por software para generarse internamente o suministrarse externamente.

El ADC también puede generar una interrupción al finalizar una conversión. Esta interrupción se puede utilizar para despertar el dispositivo de SLEEP.

### Configuración ADC

Cuando el ADC se configura por primera vez, debe tener varios ajustes de configuración habilitados. Éstos incluyen:

- Configuración del puerto ADC
- Selección de canal ADC
- Selección de referencia de voltaje ADC
- Fuente de reloj de conversión ADC
- control de interrupción ADC
- formato de resultado ADC

Veremos paso a paso cada uno de estos a continuación.

---

### **Configuración del puerto ADC**

El primer ajuste de configuración es la configuración de pines de E/S. La mayoría de los pines de E/S del ADC se pueden usar como entrada analógica o entrada digital. Al convertir señales analógicas usando el ADC, el pin de E/S debe configurarse para entrada analógica configurando los bits asociados en el registro TRIS y el registro ANSEL.

El registro TRIS para el pin de E/S debe tener su bit asociado establecido en 1 para convertirlo en una entrada. Si el pin de E/S es parte del bloque PORTA, el registro TRISA contiene el bit.

## **REGISTER 64: TRISA: PORTA TRI-STATE REGISTER**



El siguiente paso es establecer el bit en el registro ANSEL para el pin de E/S y establecer el bit en 1 para habilitar el ADC en ese pin. Si el pin de E/S es parte del bloque PORTA, el registro ANSELA contiene el bit.

**REGISTER 6-5: ANSELA: PORTA ANALOG SELECT REGISTER**

| U-0 | U-0 | RW-1/1 | RW-1/1 | RW-1/1 | RW-1/1 | RW-1/1 | RW-1/1 |
|-----|-----|--------|--------|--------|--------|--------|--------|
| -   | -   | ANSA5  | ANSA4  | ANSA3  | ANSA2  | ANSA1  | ANSA0  |

## Selección de canal ADC

El multiplexor ADC debe conectarse al pin de E/S antes de iniciar el proceso de muestreo y retención. Esto se hace con un conjunto de bits en el registro ADCON0. Antes de que se solicite una muestra de ADC, estos bits de selección de canal se configuran para conectarse al pin de E/S deseado. Solo se puede conectar un pin al ADC a la vez. Una vez que se completa el proceso, los bits de selección se pueden cambiar para conectarse al siguiente pin y el proceso ADC comienza de nuevo.

## REGISTER 11-1: ADCONO: A/D CONTROL REGISTER 0

|         |                                                                      |
|---------|----------------------------------------------------------------------|
| bit 6-2 | <b>CHS&lt;4:0&gt;: Analog Channel Select bits</b>                    |
|         | 00000 = AN0                                                          |
|         | 00001 = AN1                                                          |
|         | 00010 = AN2                                                          |
|         | 00011 = AN3                                                          |
|         | 00100 = AN4                                                          |
|         | 00101 = AN5                                                          |
|         | 00110 = AN6                                                          |
|         | 00111 = AN7                                                          |
|         | 01000 = AN8 <sup>(1)</sup>                                           |
|         | 01001 = AN9 <sup>(1)</sup>                                           |
|         | 01010 = AN10 <sup>(1)</sup>                                          |
|         | 01011 = AN11 <sup>(1)</sup>                                          |
|         | 01100 = Reserved. No channel connected.                              |
|         | •                                                                    |
|         | •                                                                    |
|         | •                                                                    |
|         | 11100 = Reserved. No channel connected.                              |
|         | 11101 = Temperature Indicator <sup>(4)</sup>                         |
|         | 11110 = DAC output <sup>(2)</sup>                                    |
|         | 11111 = FVR (Fixed Voltage Reference) Buffer 1 Output <sup>(3)</sup> |

Algunos dispositivos pueden tener menos canales

- Consulte la página "["Módulo convertidor de digital a analógico \(DAC\) \(MCU de 8 bits\)"](#)" para obtener más información.
  - Consulte la página "["Referencia de voltaje fijo \(FVR\)"](#)" para obtener más información.
  - Consulte la página "["Indicador de temperatura"](#)" para obtener más información.
- 

### Selección de referencia de voltaje ADC

El ADC puede usar varias fuentes de referencia de voltaje como base para las mediciones de voltaje analógico.

$$\text{Valor digital} = [\text{Tensión analógica} / (\text{V}_{\text{REF+}} - \text{V}_{\text{REF-}})] * 1024$$

Los bits ADPREF del registro ADCON1 proporcionan control de la referencia de voltaje positivo. La referencia de tensión positiva puede ser:

- $\text{V}_{\text{REF+}}$
- $\text{VDD}_-$
- Referencia de voltaje fijo (FVR)

Los bits ADNREF del registro ADCON1 proporcionan control de la referencia de voltaje negativo. La referencia de tensión negativa puede ser:

- $\text{V}_{\text{REF-}}$
- $\text{V}_{\text{SS}}$

$V_{DD}$  y  $V_{SS}$  son las conexiones al bus de voltaje que alimenta el dispositivo.

$V_{REF}$  + y  $V_{REF}$  - son pines de E/S específicos en el dispositivo. Una referencia de voltaje externo está conectada a estos pines.

FVR es una función en muchos dispositivos PIC®, aunque no en todos. Puede incluir un solo voltaje o, a veces, más de un nivel de voltaje está disponible.

Los bits de selección de referencia de voltaje están en el registro ADCON1 y las opciones de selección se muestran a continuación.

## REGISTER 16-2: ADCON1: A/D CONTROL REGISTER 1



|         |                                                                                                          |
|---------|----------------------------------------------------------------------------------------------------------|
| bit 2   | <b>ADNREF: A/D Negative Voltage Reference Configuration bit</b>                                          |
|         | <b>0 = V<sub>REF-</sub> is connected to V<sub>ss</sub></b>                                               |
|         | <b>1 = V<sub>REF-</sub> is connected to external V<sub>REF-</sub> pin<sup>(1)</sup></b>                  |
| bit 1:0 | <b>ADPREF&lt;1:0&gt;: A/D Positive Voltage Reference Configuration bits</b>                              |
|         | <b>00 = V<sub>REF+</sub> is connected to V<sub>dd</sub></b>                                              |
|         | <b>01 = Reserved</b>                                                                                     |
|         | <b>10 = V<sub>REF+</sub> is connected to external V<sub>REF+</sub> pin<sup>(1)</sup></b>                 |
|         | <b>11 = V<sub>REF+</sub> is connected to internal Fixed Voltage Reference (FVR) module<sup>(1)</sup></b> |

---

#### Fuente de reloj de conversión ADC

La fuente del reloj de conversión es seleccionable por software a través de los bits ADCS del registro ADCON1. Hay hasta siete opciones de reloj posibles según el dispositivo que se utilice:

- FOSC/2
- FOSC/4
- FOSC/8
- FOSC/16
- FOSC/32
- FOSC/64
- FRC (oscilador interno dedicado)

F<sub>osc</sub> es el oscilador del sistema que ejecuta el reloj de instrucciones del dispositivo.

El reloj es fundamental para producir la conversión analógica a digital más rápida pero también precisa.

El tiempo para completar la conversión de un bit se define como T<sub>AD</sub>. Una conversión completa de 10 bits requiere períodos de 11,5 T<sub>AD</sub>, como se muestra aquí:



Para una conversión correcta, se debe cumplir con la especificación  $T_{AD}$  adecuada. Un reloj ADC se puede seleccionar fácilmente de la tabla a continuación. Aparece un gráfico similar en la hoja de datos del dispositivo. Los mejores valores se muestran en el medio del gráfico con un fondo blanco.

| ADC Clock Period (T <sub>AD</sub> ) |            | Device Frequency (F <sub>osc</sub> ) |                             |                             |                             |                             |                             |
|-------------------------------------|------------|--------------------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|
| ADC Clock Source                    | ADC\$<2:0> | 32 MHz                               | 20 MHz                      | 16 MHz                      | 8 MHz                       | 4 MHz                       | 1 MHz                       |
| Fosc/2                              | 000        | 62.5 ns <sup>(2)</sup>               | 100 ns <sup>(2)</sup>       | 125 ns <sup>(2)</sup>       | 250 ns <sup>(2)</sup>       | 500 ns <sup>(2)</sup>       | 2.0 µs                      |
| Fosc/4                              | 100        | 125 ns <sup>(2)</sup>                | 200 ns <sup>(2)</sup>       | 250 ns <sup>(2)</sup>       | 500 ns <sup>(2)</sup>       | 1.0 µs                      | 4.0 µs                      |
| Fosc/8                              | 001        | 0.5 µs <sup>(2)</sup>                | 400 ns <sup>(2)</sup>       | 0.5 µs <sup>(2)</sup>       | 1.0 µs                      | 2.0 µs                      | 8.0 µs <sup>(3)</sup>       |
| Fosc/16                             | 101        | 800 ns                               | 800 ns                      | 1.0 µs                      | 2.0 µs                      | 4.0 µs                      | 16.0 µs <sup>(3)</sup>      |
| Fosc/32                             | 010        | 1.0 µs                               | 1.6 µs                      | 2.0 µs                      | 4.0 µs                      | 8.0 µs <sup>(3)</sup>       | 32.0 µs <sup>(3)</sup>      |
| Fosc/64                             | 110        | 2.0 µs                               | 3.2 µs                      | 4.0 µs                      | 8.0 µs <sup>(3)</sup>       | 16.0 µs <sup>(3)</sup>      | 64.0 µs <sup>(3)</sup>      |
| FRC                                 | x11        | 1.0-6.0 µs <sup>(1,4)</sup>          | 1.0-6.0 µs <sup>(1,4)</sup> | 1.0-6.0 µs <sup>(1,4)</sup> | 1.0-6.0 µs <sup>(1,4)</sup> | 1.0-6.0 µs <sup>(1,4)</sup> | 1.0-6.0 µs <sup>(1,4)</sup> |

Legend: Shaded cells are outside of recommended range.

Note 1: The FRC source has a typical T<sub>AD</sub> time of 1.6 µs for V<sub>DD</sub>.

2: These values violate the minimum required T<sub>AD</sub> time.

3: For faster conversion times, the selection of another clock source is recommended.

4: The ADC clock period (T<sub>AD</sub>) and total ADC conversion time can be minimized when the ADC clock is derived from the system clock Fosc. However, the FRC clock source must be used when conversions are to be performed with the device in Sleep mode.

La selección de FRC del oscilador interno será una conversión más lenta pero garantizará que se cumplan los requisitos de T<sub>AD</sub>. El FRC también se puede usar en modo de suspensión para ejecutar mediciones de ADC.

## Control de interrupciones

El módulo ADC tiene la capacidad de generar una interrupción al finalizar una conversión de analógico a digital. Esta interrupción también se puede generar mientras el dispositivo está funcionando o mientras está en SUSPENSIÓN. Si el dispositivo está en SUSPENSIÓN, la interrupción activará el dispositivo y luego procesará la Rutina de servicio de interrupción (ISR) siempre que los bits de interrupción estén habilitados.

Esos bits de interrupción incluyen:

- El indicador de interrupción ADC es el bit ADIF en el registro 1 de interrupción periférica (PIR1).
- La habilitación de interrupción ADC es el bit ADIE en el registro de habilitación de interrupción periférica (PIE1).
- El bit de habilitación de interrupción global (GIE) y los bits de habilitación de interrupción periférica (PEIE) en el registro INTCON también deben estar habilitados.

Después de ejecutar una interrupción del modo SLEEP y completar ISR y ADC, el bit ADIF debe borrarse en el software.

## Formato de resultado ADC

El resultado de la conversión ADC se almacena en dos registros de 8 bits de ancho; ADRESH y ADRESL. Este par de registros tiene 16 bits de ancho, por lo que el módulo ADC tiene la flexibilidad de justificar a la izquierda o a la derecha el resultado de 10 bits en el registro de resultados de 16 bits. El bit de selección de formato ADC (ADFM) en el registro ADCON1 controla esta justificación. Los bits adicionales en los registros ADRESH y ADRESL se cargan con '0'.



## **bit 7      ADFM: ADC Result Format Select bit**

**1 : Right justified.** Six Most Significant bits of ADRESH are set to '1' when the conversion result is loaded.

**0 : Left justified.** Six Least Significant bits of ADRESL are set to '1' when the conversion result is loaded.

Luego, el resultado puede copiarse en una variable o usarse en una ecuación para implementar una función basada en el resultado del ADC.

---

### **Configurador de código MPLAB® - Configuración ADC**

[MPLAB® Code Configurator \(MCC\)](#) facilita la configuración del código ADC. Todos los ajustes de configuración descritos anteriormente se pueden configurar en una pantalla GUI simple dentro de MPLAB X IDE. La pantalla ADC se muestra aquí:



Cada opción de configuración se selecciona como una casilla de verificación o desde un menú desplegable. Una vez realizadas las selecciones, el código se genera y se coloca en el proyecto. Se crean dos archivos llamados adc.h y adc.c . Contienen código de configuración de ADC y también funciones personalizadas para usar el ADC dentro de los archivos de su proyecto principal.



### Ejemplo de proyecto ADC

Aquí hay un proyecto de ejemplo paso a paso para configurar el [ADC usando MCC](#).





# Celda lógica configurable

---

La celda lógica configurable (CLC) proporciona una lógica programable que opera fuera de las limitaciones de velocidad de ejecución del software. La celda lógica acepta hasta 16 señales de entrada y, mediante el uso de puertas configurables, reduce las 16 entradas en cuatro líneas lógicas que controlan una de las ocho funciones lógicas seleccionables de salida única.

Las fuentes de entrada son una combinación de lo siguiente:

- pines de E/S
- relojes internos
- Periféricos
- Bits de registro

La salida se puede dirigir internamente a los periféricos ya un pin de salida.

Las posibles configuraciones incluyen:

- Lógica Combinatoria
  - Y
  - NAND
  - Y-O
  - Y-O-INVERTIR
  - OR-XOR
  - O-XNOR
- Pestillos
  - RS
  - Reloj D con Set y Reset
  - D transparente con Set y Reset
  - JK cronometrado con reinicio

---

## Videotutorial de CLC

Este video presenta la celda lógica configurable (CLC) para dispositivos MCU de 8 bits de Microchip y muestra cómo usarla.

### Microchip Self Paced Training - Configurable Logic Cell



## Configuración de CLC

El periférico CLC tiene cuatro secciones que deben configurarse antes de poder usarse. Esto implica configurar ocho registros en su programa de software. Una vez que se configuran estos registros, el CLC funcionará independientemente del control del software hasta que los registros se cambien a través del software.

Incluyen:

- CLCxCON
- CLCxSEL0
- CLCxSEL1
- CLCxGLS0
- CLCxGLS1
- CLCxGLS2
- CLCxGLS3
- CLCxPOL

A **PIC®** device can have multiple CLCs so each CLC module has its own set of eight registers. The x in the register names above represent the CLC number (e.g., CLC1 uses the CLC1CON register).

To simplify the setup, the CLC can be broken down into four sections that need to be configured. They include:

- Inputs
- Data Gating
- Logic Function
- Output Setting



(/local--files/8bit:clc/clcsetup.png)

---

## Inputs

Inputs can come from 8-16 different sources, depending on the PIC device, and from this list, up to four can be chosen to feed the data gating section.

They can include:

- I/O pins
- Internal clock outputs
- Peripherals outputs
- Register bits

The inputs are selected by bits in the CLCxSEL0 and CLCxSEL1 registers.



(/local--files/8bit:clc/CLCselregisters.png)

Each input has an associated 3-bit code that is placed in the CLCxSEL registers to enable the input.

| CLC 1<br>Input | Source      |
|----------------|-------------|
| CLC1IN[0]      | CLC1IN0 PIN |
| CLC1IN[1]      | CLC1IN1 PIN |
| CLC1IN[2]      | SYNCC1OUT   |
| CLC1IN[3]      | SYNCC2OUT   |
| CLC1IN[4]      | Fosc        |
| CLC1IN[5]      | TMR0IF      |
| CLC1IN[6]      | TMR1IF      |
| CLC1IN[7]      | TMR2 = PR2  |
| CLC1IN[8]      | Ic1_out     |
| CLC1IN[9]      | Ic2_out     |
| CLC1IN[10]     | Ic3_out     |
| CLC1IN[11]     | Ic4_out     |
| CLC1IN[12]     | NCO1OUT     |
| CLC1IN[13]     | HFINTOSC    |
| CLC1IN[14]     | PWM3OUT     |
| CLC1IN[15]     | PWM4OUT     |

(/local--files/8bit:clc/CLCinputs.png)

## Data Gating

The Data Gating section has four logic gates that need to be set up. This requires five separate registers to be set up. They configure the inverted or non-inverted connection from the inputs that control the CLC peripheral. The five registers include:

- CLCxGLS0
- CLCxGLS1
- CLCxGLS2
- CLCxGLS3
- CLCxPOL

Each gate starts off as a base OR gate, but each input and output can be individually inverted or not inverted.

This allows AND, NAND, OR, and NOR gates to be created. The gates can also be set up to drive a constant 1 or 0 logic level.



(/local--files/8bit:clc/datagating.png)

Each input to a data gate has a pair of bits in one of the CLCxGLSx registers. The two bits include a non-inverted (T) bit and an inverted (N) bit that needs to be set up. If the T bit is set, then the input is non-inverted. If the N bit is set, then the input is inverted. If both are set to zero, then the input is not connected to the gate.

### CLC1POL

|        |   |   |   |          |          |          |               |
|--------|---|---|---|----------|----------|----------|---------------|
| LC1POL | - | - | - | LC1G4POL | LC1G3POL | LC1G2POL | LC1G1POL<br>0 |
|--------|---|---|---|----------|----------|----------|---------------|

### CLC1GLS0

|               |               |               |               |               |               |               |               |
|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| LC1G1D4T<br>0 | LC1G1D4N<br>1 | LC1G1D3T<br>0 | LC1G1D3N<br>1 | LC1G1D2T<br>0 | LC1G1D2N<br>1 | LC1G1D1T<br>0 | LC1G1D1N<br>1 |
|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|

Input 4

Input 3

Input 2

Input 1

(/local--files/8bit:clc/clcglsrcRegisters.png)

The CLCxPOL register bit, LCxGxPOL bit, will invert or not invert the output of the gate.

0 - non-inverted

1 - inverted

## Logic Function

The Logic Function has eight options to choose from. It is selected in the CLCxCON register. Each Logic Function has a 3-bit code associated with it.

000 = AND – OR



001 = OR – XOR



010 = 4-Input AND



011 = S-R Latch



(/local--files/8bit:clc/logic1.png)

100 = 1-Input D Flip-Flop with S and R



101 = 2-Input D Flip-Flop with R



110 = J-K Flip-Flop with R



111 = 1-Input Transparent Latch with S and R



(/local--files/8bit:clc/logic2.png)

The 3-bit code is set in the CLCxCON register LCxMODE bits to enable the selected Logic Function.

CLCxCON

LCxMODE < 2 : 0 >

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| - | - | - | - | - | 1 | 1 | 0 |
|---|---|---|---|---|---|---|---|

(/local--files/8bit:clc/clccon.png)

# Output

All of the CLC sections reduce down to a single output that can drive an I/O pin, feed another CLC module or internal peripheral, or can also trigger a rising or falling edge interrupt. These various options are set up in the CLCxCON and CLCxPOL registers.

There are multiple bits that control the output from the CLC module



(/local--files/8bit:clc/output.png)

The bits in the CLCxCON register control the output settings.

LCxEN – CLC module enable bit (1 - CLC On, 0 - Off )

LCxOE – Output enable bit (1 – Enable, 0 – Disable)

LCxOUT - Internally monitor output via software (Read Only Bit)

LCxINTP – Rising edge interrupt enable (1-CLCxIF set on Rising Edge)

LCxINTN – Falling edge interrupt enable (1-CLCxIF set on Falling Edge)



(/local--files/8bit:clc/clcconoutput.png)

## CLC Example

Here is a simple example that shows the eight registers set up in software to create the CLC setup shown in the picture.

The example below shows a setup for the CLC1 module.  
The eight register settings are shown for this example in a format for the XC8 compiler.

```
// CLC 1 Setup
CLC1SEL0 = 0x01; // CLC1IN1 Pin, Fosc Inputs
CLC1SEL1 = 0x02; // CLC1OUT, PWM3OUT Inputs
CLC1GLS0 = 0x01; // Input 1 not inverted
CLC1GLS1 = 0x04; // Input 2 inverted
CLC1GLS2 = 0x20; // Input 3 not inverted
CLC1GLS3 = 0x80; // Input 4 not inverted
CLC1POL = 0x00; // Output of CLC1 is not inverted
CLC1CON = 0xD2; // Enable OR-XOR, Rising Edge Interrupt, Output Pin Enabled, CLC enabled
```



(/local--files/8bit:clc/clcexample.png)

---

## CLC Designer Tool

The CLC Designer Tool is a GUI based tool that makes creating the CLC structure much easier. Through a series of setup options, the tool will automatically output the eight register settings so you can include it in your **MPLAB® X** project.



The CLC Designer Tool is part of MPLAB Code Configurator (MCC) MPLAB® X Plugin.



(/local--files/8bit:clc/clcgui.png)

# Herramienta de configuración de CLC

Configurable Logic Cell (CLC)



La celda lógica configurable (CLC) proporciona lógica programable que opera fuera de las limitaciones de velocidad de ejecución del software. La celda lógica acepta hasta 16 señales de entrada. Mediante el uso de puertas configurables, reduce las 16 entradas a cuatro líneas lógicas que controlan una de las ocho funciones lógicas de salida única seleccionables. El CLC puede tener su funcionalidad preprogramada o programada dinámicamente. Esto proporciona una mayor flexibilidad y potencial en los diseños integrados.

El propósito de la herramienta de configuración CLC es optimizar el proceso de configuración del módulo CLC simulando la funcionalidad de los registros en una interfaz gráfica de usuario (GUI). El resultado final del uso de la herramienta será un código fuente

generado, que se puede colocar en un archivo de proyecto **MPLAB® X existente**. El ejemplo de código creado se genera de forma personalizada, según sus entradas y preferencias, como el lenguaje de programación.

La herramienta CLC es parte de la herramienta **MPLAB Code Configurator (MCC)**.

El video en la parte superior de la página muestra un ejemplo paso a paso del uso de la herramienta de configuración CLC. A continuación se incluye una guía escrita paso a paso.

## Pasos de configuración de la GUI de CLC



(/local--files/8bit:clcgui/CLCGUI\_Highlight.png)

### 1 Seleccione el dispositivo

Aquí es donde se seleccionará el dispositivo, como el PIC16F1508 (<https://www.microchip.com/wwwproducts/en/PIC16F1508>) . Cuando se selecciona un dispositivo, el programa se configurará automáticamente para ese dispositivo específico, como las entradas de datos y la cantidad de salidas CLC disponibles.

### 2 Seleccione el Número CLC

Un dispositivo puede tener varios CLC, por lo que deberá seleccionar el número de CLC que desea configurar. Algunos dispositivos, como el PIC10F320 (<https://www.microchip.com/wwwproducts/en/PIC10F320>), solo tendrán un módulo CLC disponible en el dispositivo seleccionado. La “X” en cada registro CLC será reemplazada por el módulo CLC que se utilice.

### 3 Seleccione las entradas de datos

Hay cuatro grupos de selección de entrada. Cada grupo consta de ocho selecciones. Para un dispositivo con solo ocho entradas, las ocho entradas están disponibles en todos los grupos. Para un dispositivo con 16 entradas, solo ocho de las 16 están disponibles en cada grupo. Sin embargo, estas entradas se distribuyen de una manera que minimiza la exclusión de algunas combinaciones de selección de entrada. Ninguna entrada aparecerá dos veces en el mismo grupo, pero aparecerá como una entrada en otros grupos.

### 4 Entradas de puerta

Una vez que se seleccionan las entradas de datos, se pueden mapear en cada una de las cuatro puertas. La salida de cada puerta diferirá según la función lógica seleccionada. Para seleccionar la entrada en una puerta, simplemente desplace el cursor sobre la " X " deseada y haga clic una vez. La flecha del cursor habrá cambiado al puntero y aparecerá una línea que extiende la entrada hacia la puerta. Para invertir la señal, haga clic nuevamente donde estaba la " X " y ahora debería aparecer una burbuja, indicando una inversión. Si se hace clic una vez más, la burbuja y la línea deberían desaparecer y regresar por defecto al estado original desconectado.

### 5 Salidas de puerta

Cada una de las salidas de la puerta se puede invertir. Para hacer esto, simplemente haga clic una vez en la salida de una puerta individual para que aparezca una burbuja. La salida ahora está invertida. Para deshacer esto, vuelva a hacer clic en la burbuja para que desaparezca. Es importante tener en cuenta que cualquier puerta sin entradas seleccionadas tendrá su salida predeterminada en el estado "apagado", 0 lógico. Si se desea un 1 lógico constante, invierta el 0 lógico predeterminado haciendo clic en la salida de la burbuja inversora.

### 6 Seleccione el bloque lógico

Hay ocho funciones lógicas disponibles seleccionadas por las pestañas de la herramienta CLC. Los bloques lógicos no se pueden configurar para nada que no sea lo que se muestra. Solo se puede usar una función lógica a la vez para cada módulo CLC.

### 7 Control de salida

La salida del bloque lógico se alimenta a la última etapa del CLC, la puerta de inversión. Para invertir la salida, haga clic una vez en el pin de salida del búfer para que aparezca una burbuja. Desde aquí, la salida se puede enrutar a otros periféricos, un pin de salida o volver a la entrada CLC. Se puede habilitar una interrupción en el flanco ascendente y/o descendente de la salida CLC. Estas funciones se seleccionan marcando las casillas en la esquina inferior derecha de la pantalla de la herramienta CLC.

## 8 Guardar/Cargar

La herramienta de configuración CLC proporciona un método conveniente para guardar el diseño (o cargar un diseño anterior). Cuando el diseño haya concluido y esté listo para implementarse en el software, haga clic en el menú desplegable **Archivo** en la esquina superior izquierda del cuadro de diálogo.



(/local--files/8bit:clcgui/CLCGUI\_Output.png)

Luego, haga clic en **Guardar código ASSY** o **Guardar código C**, según el idioma de salida deseado. El código para todos los CLC configurados del dispositivo seleccionado se incluirá en el archivo de salida. El archivo resultante tendrá una extensión .inc.

Ambas piezas de código producen el mismo efecto. La Asamblea es más larga debido a la naturaleza del lenguaje. El código ahora se puede incluir fácilmente como un archivo de biblioteca o copiar y pegar en un programa existente.

- **Comentarios del proyecto** : los comentarios también se pueden guardar y cargar dentro del archivo de salida. Para hacerlo, simplemente complete el área de texto de entrada de comentarios como se ve en la parte inferior de la pantalla de la herramienta de configuración de CLC antes de guardar.
- **Cargar un archivo existente:** para cargar código previamente guardado desde la herramienta CLC, haga clic en **Archivo > Cargar > Código** . Si se importó correctamente, la herramienta habrá llenado la GUI con los valores apropiados correspondientes a los registros en el código cargado.

## Ejemplo

Aquí hay un ejemplo simple creado con la herramienta de configuración CLC. Muestra que los ocho registros se han configurado en el software para crear la configuración de CLC que se muestra en la imagen.

The example below shows a setup for the CLC1 module.  
The eight register settings are shown for this example in a format for the XC8 compiler.

```
// CLC 1 Setup
CLC1SEL0 = 0x01; // CLC1IN1 Pin, Fosc Inputs
CLC1SEL1 = 0x02; // CLC1OUT, PWM3OUT Inputs
CLC1GLS0 = 0x01; // Input 1 not inverted
CLC1GLS1 = 0x04; // Input 2 inverted
CLC1GLS2 = 0x20; // Input 3 not inverted
CLC1GLS3 = 0x80; // Input 4 not inverted
CLC1POL = 0x00; // Output of CLC1 is not inverted
CLC1CON = 0xD2; // Enable OR-XOR, Rising Edge Interrupt, Output Pin Enabled, CLC enabled
```



(/local--files/8bit:clc/clcexample.png)

## Descarga/Documentación

La herramienta de configuración CLC es parte del configurador de código MPLAB. Puede obtener la Herramienta de configuración de CLC, el Manual del usuario y la Guía de trucos y sugerencias de CLC directamente desde los siguientes enlaces:



La herramienta CLC ahora está incorporada en la herramienta MPLAB Code Configurator (MCC). Puede encontrar información sobre cómo instalar la herramienta MCC visitando la página MPLAB Code Configurator (MCC) (/mcc:overview) .

- "Guía del usuario de la herramienta de configuración de celdas lógicas configurables (CLC)" (<http://www.microchip.com/mymicrochip/filehandler.aspx?ddocname=en555291>)
- "Sugerencias y trucos de celdas lógicas configurables" (<http://www.microchip.com/mymicrochip/filehandler.aspx?ddocname=en557835>)

# Registro CLCxCON

La sección de salida y la sección lógica de la celda lógica configurable (CLC) (<https://microchip-dev.wikidot.com/8bit:clc>) están controladas por el registro CLCCON.

**CLCxCON: Registro de control de celda lógica configurable**

| L/E-0/0 | L/E-0/0 | L/E-0/0   | L/E-0/0 | L/E-0/0 | L/E-0/0  | L/E-0/0  | L/E-0/0  |
|---------|---------|-----------|---------|---------|----------|----------|----------|
| LCxES   | LCxOE   | LCxSALIDA | LCxINTP | LCxINTN | LCxMODE2 | LCxMODE1 | LCxMODE0 |
| bit 7   |         |           |         | bit 0   |          |          |          |

|                               |                           |                                                              |
|-------------------------------|---------------------------|--------------------------------------------------------------|
| <b>Leyenda</b>                |                           |                                                              |
| R = Bit legible               | W = bit grabable          | U = bit no implementado, leído como '0'                      |
| u = El bit no cambia          | x = el bit es desconocido | -n/n = Valor en POR y BOR/Valor en todos los demás reinicios |
| '1' = el bit está establecido | '0' = el bit se borra     | -n = Valor en el reinicio de POR                             |

bit 7      **LCxEN**: bit de habilitación de CLC

**1** = CLC está habilitado y mezcla señales de entrada  
**0** = CLC está deshabilitado y tiene salida lógica cero

**bit 6      LCxEOE:** bit de habilitación de salida CLC

**1** = Salida de pin de puerto CLC habilitada  
**0** = Salida de pin de puerto CLC deshabilitada

bit 5      **LCxOUT**: bit de salida de datos CLC

Solo lectura: datos de salida de celda lógica, después de LCxPOL; muestreado del cable |cx\_out

**bit 4 LCxINTP:** bit de habilitación de interrupción de avance de flanco positivo CLC

1 = LCxIF se establecerá cuando se produzca un flanco ascendente en lcx\_out  
0 = LCxIF no se establecerá

bit 3      **LCxINTN**: bit de habilitación de interrupción de flanco negativo CLC

1 = LCxIF se establecerá cuando se produzca un flanco descendente en lcx\_out

0 = LCxIF no se establecerá

bit 2-0 **LCxMODE<2:0>**: Bits de modo funcional CLC

111 = La celda es un pestillo transparente de 1 entrada con S y R

110 = La celda es un Flip-Flop JK con R

101 = La celda es un Flip-Flop D de 2 entradas con R

100 = La celda es un Flip-Flop D de 1 entrada con S y R

011 = La celda es SR latch

010 = La celda es AND de 4 entradas

001 = La celda es OR-XOR

000 = La celda es AND-OR

*De la hoja de datos PIC16F1507*

(<http://ww1.microchip.com/downloads/en/DeviceDoc/40001586D.pdf>) .

---

El bit de habilitación de CLC habilitará o deshabilitará el módulo CLC. Un 1 lo habilita y un 0 lo deshabilita.

bit 7 **LCxEN**: Configurable Logic Cell Enable bit

1 = Configurable logic cell is enabled and mixing input signals

0 = Configurable logic cell is disabled and has logic zero output

(/local--files/8bit:clccon/LCEN.png)

---

El bit de habilitación de salida CLC habilitará o deshabilitará la salida del módulo CLC. Un 1 lo habilita y un 0 lo deshabilita.

bit 6 **LCxOE**: Configurable Logic Cell Output Enable bit

1 = Configurable logic cell port pin output enabled

0 = Configurable logic cell port pin output disabled

(/local--files/8bit:clccon/LCOE.png)

---

El bit CLC LCOUT es un indicador que se puede monitorear en el software para determinar el estado de la salida CLC.

bit 5 **LCxOUT**: Configurable Logic Cell Data Output bit

Read-only: logic cell output data, after LCxPOL; sampled from lcx\_out wire.

(/local--files/8bit:clccon/LCOUT.png)

---

El bit CLC LCINTP habilita la interrupción de flanco ascendente en el CLC. Cuando está habilitado (establecido en 1), el CLC activará una interrupción cuando la salida del CLC aumente del estado bajo al alto.

bit 4

**LCxINTP:** Configurable Logic Cell Positive Edge Going Interrupt Enable bit

1 = LCxF will be set when a rising edge occurs on lcx\_out

0 = LCxF will not be set



---

El bit CLC LCINTN habilita la interrupción de flanco descendente en el CLC. Cuando está habilitado (establecido en 1), el CLC activará una interrupción cuando la salida del CLC caiga del estado alto al bajo.

bit 3

**LCxINTN:** Configurable Logic Cell Negative Edge Going Interrupt Enable bit

1 = LCxF will be set when a falling edge occurs on lcx\_out

0 = LCxF will not be set



---

Los bits CLC LCMODE seleccionan la función lógica CLC usando tres bits (0-2).

bit 2-0

**LCxMODE<2:0>:** Configurable Logic Cell Functional Mode bits

111 = Cell is 1-input transparent latch with S and R

110 = Cell is J-K Flip-Flop with R

101 = Cell is 2-input D Flip-Flop with R

100 = Cell is 1-input D Flip-Flop with S and R

011 = Cell is S-R latch

010 = Cell is 4-input AND

001 = Cell is OR-XOR

000 = Cell is AND-OR



# Registros CLCxSELn

Los registros CLCxSEL, contenidos en la celda lógica configurable (CLC) (<https://microchip-dev.wikidot.com/8bit:clc>) , controlan qué entradas se usan con el CLC.

## Fuentes de entrada CLC

El CLC tendrá múltiples entradas para seleccionar y cada una tendrá un código de 3 bits asociado, como se muestra en la siguiente tabla. Cada entrada se puede conectar a una de las dos puertas de datos de entrada a través de un multiplexor controlado por los registros CLCxSEL0 y CLCxSEL1.

| Data Input | Icx1<br>D1S | Icx2<br>D2S | Icx3<br>D3S | Icx4<br>D4S | CLC 1      | CLC 2      |
|------------|-------------|-------------|-------------|-------------|------------|------------|
| CLCxIN[0]  | 000         | —           | —           | 100         | CLC1IN0    | CLC2IN0    |
| CLCxIN[1]  | 001         | —           | —           | 101         | CLC1IN1    | CLC2IN1    |
| CLCxIN[2]  | 010         | —           | —           | 110         | Reserved   | Reserved   |
| CLCxIN[3]  | 011         | —           | —           | 111         | Reserved   | Reserved   |
| CLCxIN[4]  | 100         | 000         | —           | —           | Fosc       | Fosc       |
| CLCxIN[5]  | 101         | 001         | —           | —           | TMR0IF     | TMR0IF     |
| CLCxIN[6]  | 110         | 010         | —           | —           | TMR1IF     | TMR1IF     |
| CLCxIN[7]  | 111         | 011         | —           | —           | TMR2 = PR2 | TMR2 = PR2 |
| CLCxIN[8]  | —           | 100         | 000         | —           | Icx1_out   | Icx1_out   |
| CLCxIN[9]  | —           | 101         | 001         | —           | Icx2_out   | Icx2_out   |
| CLCxIN[10] | —           | 110         | 010         | —           | Icx3_out   | Icx3_out   |
| CLCxIN[11] | —           | 111         | 011         | —           | Icx4_out   | Icx4_out   |
| CLCxIN[12] | —           | —           | 100         | 000         | NCO1OUT    | LFINTOSC   |
| CLCxIN[13] | —           | —           | 101         | 001         | HFINTOSC   | ADCFRC     |
| CLCxIN[14] | —           | —           | 110         | 010         | PWM3OUT    | PWM1OUT    |
| CLCxIN[15] | —           | —           | 111         | 011         | PWM4OUT    | PWM2OUT    |

(/local--files/8bit:clcsel/CLCInputs.png)

De la hoja de datos PIC16F1507

(<http://ww1.microchip.com/downloads/en/DeviceDoc/40001586D.pdf>) .

Las selecciones de entrada están controladas por los registros CLCxSEL0 y CLCxSEL1 configurando el código de entrada de 3 bits.

- El registro CLCxSEL0 controla las puertas de entrada de datos 1 y 2. Los bits 0-2 controlan la entrada 1 y los bits 4-6 controlan la entrada 2.

## CLCxSEL0: MULTIPLEXOR DATOS 1 Y 2 SELECCIONAR REGISTRO

| U-0   | R/W-x/u | R/W-x/u     | R/W-x/u | U-0 | R/W-x/u | R/W-x/u     | R/W-x/u |
|-------|---------|-------------|---------|-----|---------|-------------|---------|
| —     |         | LCxD2S<2:0> |         | —   |         | LCxD1S<2:0> |         |
| bit 7 |         |             |         |     |         |             | bit 0   |

**Legend:**

|                      |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

|         |                                                                              |
|---------|------------------------------------------------------------------------------|
| bit 7   | <b>Unimplemented:</b> Read as '0'                                            |
| bit 6-4 | <b>LCxD2S&lt;2:0&gt;:</b> Input Data 2 Selection Control bits <sup>(1)</sup> |
|         | 111 = CLCxIN[11] is selected for lcxd2                                       |
|         | 110 = CLCxIN[10] is selected for lcxd2                                       |
|         | 101 = CLCxIN[9] is selected for lcxd2                                        |
|         | 100 = CLCxIN[8] is selected for lcxd2                                        |
|         | 011 = CLCxIN[7] is selected for lcxd2                                        |
|         | 010 = CLCxIN[6] is selected for lcxd2                                        |
|         | 001 = CLCxIN[5] is selected for lcxd2                                        |
|         | 000 = CLCxIN[4] is selected for lcxd2                                        |
| bit 3   | <b>Unimplemented:</b> Read as '0'                                            |
| bit 2-0 | <b>LCxD1S&lt;2:0&gt;:</b> Input Data 1 Selection Control bits <sup>(1)</sup> |
|         | 111 = CLCxIN[7] is selected for lcxd1                                        |
|         | 110 = CLCxIN[6] is selected for lcxd1                                        |
|         | 101 = CLCxIN[5] is selected for lcxd1                                        |
|         | 100 = CLCxIN[4] is selected for lcxd1                                        |
|         | 011 = CLCxIN[3] is selected for lcxd1                                        |
|         | 010 = CLCxIN[2] is selected for lcxd1                                        |
|         | 001 = CLCxIN[1] is selected for lcxd1                                        |
|         | 000 = CLCxIN[0] is selected for lcxd1                                        |

(/local--files/8bit:clcsel/CLCSEL0.png)

De la hoja de datos PIC16F1507

(<http://ww1.microchip.com/downloads/en/DeviceDoc/40001586D.pdf>) .

- El registro CLCxSEL1 controla las puertas de entrada de datos 3 y 4. Los bits 0-2 controlan la entrada 3 y los bits 4-6 controlan la entrada 4.

## CLCxSEL1: MULTIPLEXOR DATOS 3 Y 4 SELECCIONAR REGISTRO

| U-0   | R/W-x/u | R/W-x/u     | R/W-x/u | U-0 | R/W-x/u | R/W-x/u     | R/W-x/u |
|-------|---------|-------------|---------|-----|---------|-------------|---------|
| —     |         | LCxD4S<2:0> |         | —   |         | LCxD3S<2:0> |         |
| bit 7 |         |             |         |     |         |             | bit 0   |

**Legend:**

R = Readable bit

W = Writable bit

U = Unimplemented bit, read as '0'

u = Bit is unchanged

x = Bit is unknown

-n/n = Value at POR and BOR/Value at all other Resets

'1' = Bit is set

'0' = Bit is cleared

bit 7      **Unimplemented:** Read as '0'bit 6-4      **LCxD4S<2:0>:** Input Data 4 Selection Control bits<sup>(1)</sup>

111 = CLCxIN[3] is selected for lcx4

110 = CLCxIN[2] is selected for lcx4

101 = CLCxIN[1] is selected for lcx4

100 = CLCxIN[0] is selected for lcx4

011 = CLCxIN[15] is selected for lcx4

010 = CLCxIN[14] is selected for lcx4

001 = CLCxIN[13] is selected for lcx4

000 = CLCxIN[12] is selected for lcx4

bit 3      **Unimplemented:** Read as '0'bit 2-0      **LCxD3S<2:0>:** Input Data 3 Selection Control bits<sup>(1)</sup>

111 = CLCxIN[15] is selected for lcx3

110 = CLCxIN[14] is selected for lcx3

101 = CLCxIN[13] is selected for lcx3

100 = CLCxIN[12] is selected for lcx3

011 = CLCxIN[11] is selected for lcx3

010 = CLCxIN[10] is selected for lcx3

001 = CLCxIN[9] is selected for lcx3

000 = CLCxIN[8] is selected for lcx3

(./local--files/8bit:clcsel/CLCSEL1.png)

De la hoja de datos PIC16F1507

(http://ww1.microchip.com/downloads/en/DeviceDoc/40001586D.pdf) .

# Registros CLCxGLSn

---

Los registros CLCxGLSn, contenidos en la celda lógica configurable (CLC) (<https://microchip-dev.wikidot.com/8bit:clc>) , controlan la polaridad de las entradas CLC seleccionadas.

---

## Puerta de datos CLC

Las salidas de los multiplexores de entrada se dirigen a la entrada de función lógica deseada a través de la etapa de puerta de datos. Cada puerta de datos puede dirigir cualquier combinación de cuatro entradas seleccionadas. La puerta se puede configurar para dirigir cada señal de entrada como datos invertidos o no invertidos. Las señales dirigidas se combinan en OR en cada puerta. La salida de cada puerta también se puede invertir antes de pasar a la etapa de función lógica, pero eso está controlado por el registro CLCxPOL (<https://microchip-dev.wikidot.com/8bit:clcpol>) .

La sección de puerta de datos está controlada por uno de los cuatro registros. Cada puerta tiene un registro separado. Cada entrada tiene un bit "N" y un bit "P". Establecer el bit "N" invierte la entrada y establecer el bit "P" hace que no se invierta. Si no se establece ninguno, la puerta tendrá un nivel lógico constante alto o bajo dependiendo de la configuración de polaridad de salida en:

- CLCxGLS0
- CLCxGLS1
- CLCxGLS2
- CLCxGLS3

CLCxGLS0 se muestra en la Figura 1

| R/W-x/u  |  |
|----------|----------|----------|----------|----------|----------|----------|----------|--|
| LCxG1D4T | LCxG1D4N | LCxG1D3T | LCxG1D3N | LCxG1D2T | LCxG1D2N | LCxG1D1T | LCxG1D1N |  |
| bit 7    |          |          |          |          | bit 0    |          |          |  |

**Legend:**

|                      |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

|       |                                                                                                                                |
|-------|--------------------------------------------------------------------------------------------------------------------------------|
| bit 7 | <b>LCxG1D4T:</b> Gate 1 Data 4 True (non-inverted) bit<br>1 = lcxd4T is gated into lcxg1<br>0 = lcxd4T is not gated into lcxg1 |
| bit 6 | <b>LCxG1D4N:</b> Gate 1 Data 4 Negated (inverted) bit<br>1 = lcxd4N is gated into lcxg1<br>0 = lcxd4N is not gated into lcxg1  |
| bit 5 | <b>LCxG1D3T:</b> Gate 1 Data 3 True (non-inverted) bit<br>1 = lcxd3T is gated into lcxg1<br>0 = lcxd3T is not gated into lcxg1 |
| bit 4 | <b>LCxG1D3N:</b> Gate 1 Data 3 Negated (inverted) bit<br>1 = lcxd3N is gated into lcxg1<br>0 = lcxd3N is not gated into lcxg1  |
| bit 3 | <b>LCxG1D2T:</b> Gate 1 Data 2 True (non-inverted) bit<br>1 = lcxd2T is gated into lcxg1<br>0 = lcxd2T is not gated into lcxg1 |
| bit 2 | <b>LCxG1D2N:</b> Gate 1 Data 2 Negated (inverted) bit<br>1 = lcxd2N is gated into lcxg1<br>0 = lcxd2N is not gated into lcxg1  |
| bit 1 | <b>LCxG1D1T:</b> Gate 1 Data 1 True (non-inverted) bit<br>1 = lcxd1T is gated into lcxg1<br>0 = lcxd1T is not gated into lcxg1 |
| bit 0 | <b>LCxG1D1N:</b> Gate 1 Data 1 Negated (inverted) bit<br>1 = lcxd1N is gated into lcxg1<br>0 = lcxd1N is not gated into lcxg1  |

(/local--files/8bit:clcglis/CLCGLES.png)

Figura 1

De la hoja de datos **PIC16F1507**  
[\(<http://ww1.microchip.com/downloads/en/DeviceDoc/40001586D.pdf>\)](http://ww1.microchip.com/downloads/en/DeviceDoc/40001586D.pdf).

## Crear varias puertas

Cada compuerta de datos es, en esencia, una compuerta AND/NAND/OR/NOR de 1 a 4 entradas según la configuración de inversión/no inversión. Cuando cada entrada se invierte y la salida se invierte, la puerta es un NOR de todas las entradas de datos habilitadas. Cuando las entradas y salidas no están invertidas, la puerta es un OR de todas las entradas habilitadas.

La tabla que se muestra en la Figura 2 resume la lógica básica que se puede obtener en una puerta usando los bits de selección de lógica de puerta.



(/local--files/8bit:clc/datagating.png)

Figura 2

La tabla muestra la lógica de cuatro variables de entrada. Sin embargo, cada puerta se puede configurar para usar menos de cuatro. Si no se seleccionan entradas, la salida será 0 o 1, según el bit de polaridad de salida de la puerta. La polaridad de salida es controlada por el registro.

### CLC1POL

|        |   |   |   |          |          |          |          |
|--------|---|---|---|----------|----------|----------|----------|
| LC1POL | - | - | - | LC1G4POL | LC1G3POL | LC1G2POL | LC1G1POL |
|        |   |   |   |          |          |          | 0        |

### CLC1GLS0

|                                                |               |               |               |               |               |               |               |
|------------------------------------------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| LC1G1D4T<br>0                                  | LC1G1D4N<br>1 | LC1G1D3T<br>0 | LC1G1D3N<br>1 | LC1G1D2T<br>0 | LC1G1D2N<br>1 | LC1G1D1T<br>0 | LC1G1D1N<br>1 |
| Input 4      Input 3      Input 2      Input 1 |               |               |               |               |               |               |               |

(/local--files/8bit:clc/clcglrsregisters.png)

figura 3

# Registro CLCxPOL

El registro CLCxPOL, contenido en la celda lógica configurable (CLC) (<https://microchip-dev.wikidot.com/8bit:clc>) , controla la polaridad de las salidas de puerta de datos y también la polaridad de la salida CLC.

## Salidas de puerta de datos CLC

La siguiente imagen resume la lógica básica que se puede obtener en una puerta usando los bits de selección de lógica de puerta.



(/link)

La tabla muestra la lógica de cuatro variables de entrada, pero cada puerta se puede configurar para usar menos de cuatro. Si no se seleccionan entradas, la salida será 0 o 1, dependiendo del bit de polaridad de salida de la puerta. La polaridad de salida está controlada por el registro CLCxPOL.

## CLC1POL

|        |   |   |   |          |          |          |               |
|--------|---|---|---|----------|----------|----------|---------------|
| LC1POL | - | - | - | LC1G4POL | LC1G3POL | LC1G2POL | LC1G1POL<br>0 |
|--------|---|---|---|----------|----------|----------|---------------|

## CLC1GLS0

| LC1G1D4T<br>0 | LC1G1D4N<br>1 | LC1G1D3T<br>0 | LC1G1D3N<br>1 | LC1G1D2T<br>0 | LC1G1D2N<br>1 | LC1G1D1T<br>0 | LC1G1D1N<br>1 |
|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
|               |               |               |               |               |               |               |               |

Input 4

Input 3

Input 2

Input 1

(/link)

---

## Control de salida CLC

La salida de todo el CLC también se puede invertir en el registro CLCxPOL configurando el séptimo bit en el registro. Borrar el bit hará que la salida CLC no se invierta.

## CLC1POL

|        |   |   |   |          |          |          |          |
|--------|---|---|---|----------|----------|----------|----------|
| LC1POL | - | - | - | LC1G4POL | LC1G3POL | LC1G2POL | LC1G1POL |
|--------|---|---|---|----------|----------|----------|----------|

(/link)

1 - Invertir la salida CLC

0 - No invertir la salida CLC

# Generador de forma de onda complementaria (CWG)

El generador de forma de onda complementaria (CWG) produce una forma de onda complementaria con el retardo de banda muerta a partir de una selección de fuentes de entrada.

El módulo CWG tiene las siguientes características:

- Control de fuente de reloj de banda muerta seleccionable
- Fuentes de entrada seleccionables
- Control de habilitación de salida
- Control de polaridad de salida
- Control de banda muerta con contadores independientes de banda muerta de flanco ascendente y descendente de 6 bits
- Control de apagado automático con:
  - Fuentes de apagado seleccionables
  - Habilitar reinicio automático
  - Control de anulación de pin de apagado automático

El CWG genera una forma de onda complementaria de dos salidas a partir de una de varias fuentes de entrada seleccionables. La transición de apagado a encendido de cada salida se puede retrasar con respecto a la transición de encendido a apagado de la otra salida, creando así un retraso de tiempo inmediato en el que no se activa ninguna salida. Esto se conoce como tiempo muerto o banda muerta y se trata en la sección a continuación titulada "Control de banda muerta".

Puede ser necesario protegerse contra la posibilidad de fallas en el circuito. En este caso, el variador activo puede terminarse antes de que la condición de falla cause daño. Esto se conoce como apagado automático y se cubre en la sección a continuación titulada "Control de apagado automático".

Complimentary Waveform Generator creates a set of complementary waveforms from one input source.



(/local--files/8bit:cwg/cwg.png)

El CWG requiere que se establezcan cinco secciones:

- Aporte
- Reloj
- banda muerta
- Cerrar
- Control de salida

## Videotutorial de CWG

This video introduces the Complementary Waveform Generator (CWG) for Microchip 8-bit MCU devices and shows how to use it.

## Microchip Self Paced Training - Complimentary Waveform Gene...



## Input Source

The CWG offers several input sources to generate the complementary waveform. This may vary from device to device. The list below is from the PIC16F1507 device. The list includes:

- PWM1 (Pulse Width Modulated Output 1)
- PWM2 (Pulse Width Modulated Output 2)
- PWM3 (Pulse Width Modulated Output 3)
- PWM4 (Pulse Width Modulated Output 4)
- N1OUT (Numerically Controlled Oscillator Output)
- LC1OUT (Configurable Logic Cell Output)

The input source is selected using the GxIS<2:0> bits in the CWGxCON1 register.

Some devices also include the output from a comparator module as input to the CWG. It's best to refer to the data sheet for the device you are using for the updated list of selected input choices.



(/local--files/8bit:cwg/inputs.png)

## Clock Source

The CWG module allows for one of two clock sources to be selected:

- $F_{OSC}$  (system clock)
- HFINTOSC (16 MHz only)

The clock sources are selected using the GxCS0 bit of the CWGxCON0 register.



(/local--files/8bit:cwg/clocksource.png)

## Dead-band Control

Dead-band control provides for non-overlapping output signals, to prevent shoot-through current in power switches. The CWG contains two 6-bit dead-band counters (CWGxDBR and CWGxDBF registers). One dead-band counter is used for the rising edge of the input source control while the other is used for the falling edge of the input source control.

Dead-band is timed by counting CWG clock periods from zero up to the value in the rising or falling dead-band counter registers.



(/local--files/8bit:cwg/deadband.png)

## Rising Edge Control

The rising edge dead-band delays the turn-on of the CWGxA output from when the CWGxB output is turned off. The rising edge dead-band time starts when the rising edge of the input source signal goes true. When this happens, the CWGxB output is immediately turned off and the rising edge dead-band delay time starts. When the rising edge dead-band delay time is reached, the CWGxA output is turned on.

The CWGxDBR register sets the duration of the dead-band interval on the rising edge of the input source signal. This duration is from 0 to 64 counts of dead-band. Dead-band is always counted off the edge on the input source signal. A count of zero (0), indicates that no dead-band is present. If the input source signal is not present for enough time for the count to be completed, no output will be seen on the respective output.

A change in state of the input signal may not occur in sync with the clock signal. This can cause longer dead band delays.



(/local--files/8bit:cwg/risefall.png)

## Falling Edge Control

The falling edge dead-band delays the turn-on of the CWGxB output from when the CWGxA output is turned off. The falling edge dead-band time starts when the falling edge of the input source goes true. When this happens, the CWGxA output is immediately turned off and the falling edge dead-band delay time starts. When the falling edge dead-band delay time is reached, the CWGxB output is turned on.

The CWGxDBF register sets the duration of the dead-band interval on the falling edge of the input source signal. This duration is from 0 to 64 counts of dead-band. Dead-band is always counted off the edge on the input source signal. A count of zero (0), indicates that no dead-band is present. If the input source signal is not present for enough time for the count to be completed, no output will be seen on the respective output.

Using a one clock pulse delay for rising and falling edge Dead-Band control, the PWM signal would produce two waveforms similar to what is shown here.



(/local--files/8bit:cwg/dbexample.png)

## Dead-band Uncertainty

When the rising and falling edges of the input source trigger the dead-band counters, the input may be asynchronous to the clock input. This will create some uncertainty in the dead-band time delay. The maximum uncertainty is equal to one CWG clock period.



(/local--files/8bit:cwg/uncertainty.png)

## Auto-shutdown Control

Auto-shutdown is a method to immediately override the CWG output levels with specific settings that allow for safe shutdown of the circuit. The shutdown state can be either cleared automatically or held until cleared by software.

The shutdown state can be entered by either of the following two methods:

- Software generated
- External input

### Software Generated

Setting the GxASE bit of the CWGxCON2 register will force the CWG into the shutdown state. When auto-restart is disabled, the shutdown state will persist as long as the GxASE bit is set. When auto-restart is enabled, the GxASE bit will clear automatically and resume operation on the next rising edge event.

## External Input

External shutdown signals provide the fastest way to safely suspend CWG operation in the event of a fault condition. When any of the selected shutdown signals go active, the CWG outputs will immediately go to the selected override levels without software delay. Any combination of two shutdown signals can be selected to cause a shutdown condition. The shutdown signals offered may vary with the device being used but those shutdown sources are selected by the GxASDS0 and GxASDS1 bits of the CWGxCON2 register.



(/local--files/8bit:cwg/shutdown.png)

# Output Control

## Output Pin Enable

Each CWG output pin has an individual output pin enable control. The output enables are selected with the GxOEA and GxOEB bits of the CWGxCON0 register. When an output pin enable is cleared, the CWG has no connection to the output pin. When the output enable is set, the override value or active PWM waveform is applied to the pin per the internal port priority selection.

The CWG function can be completely disabled by clearing the GxEN pin in the CWGxCON0 register.

The CWGA and CWGB outputs can be connected to the I/O pin through the CWGCON0 Register setting.



## Polarity Control

The polarity of each CWG output can be selected independently. When the output polarity bit is set, the corresponding output is active high. Clearing the output polarity bit configures the corresponding output as active low. However, polarity does not affect override levels. Output polarity is selected with the GxPOLA and GxPOLB bits of the CWGxCON0 register.



(/local--files/8bit:cwg/outputpolarity.png)

## Operation During Sleep Mode

The CWG module operates independently from the system clock and will continue to run during Sleep, provided that the clock and input sources selected remain active. The High-Frequency Internal Oscillator (HFINTOSC) remains active during Sleep, provided that the CWG module is enabled, the input source is active, and the HFINTOSC is selected as the clock source, regardless of the system clock source selected.

In other words: if the HFINTOSC is simultaneously selected as the system clock and the CWG clock source, then when the CWG is enabled and the input source is active, the CPU will go idle during Sleep, but the CWG will continue to operate and the HFINTOSC will remain active. This will have a direct effect on the Sleep mode current.

## CWG Example

Sometimes it is helpful to step through an example. Visit this CWG example (/8bit:cwgexample) to see step-by-step instructions for the CWG Module.

# Ejemplo de generador de forma de onda complementaria

Esta página es un ejemplo paso a paso que utiliza el generador de formas de onda complementarias (CWG).

Este ejemplo utiliza la señal de salida del oscilador controlado numéricamente (NCO) (funcionando al 50 % del ciclo de trabajo) como entrada y el oscilador interno de alta frecuencia (HFINTOSC) como reloj.

Este ejemplo también produce dos salidas complementarias y utiliza un interruptor externo como control de apagado, como se muestra en el siguiente diagrama de bloques.



(/local--files/8bit:cwgexample/exp1.png)

## Configuración de ejemplo de CWG

- 1 El **NCO** se selecciona como entrada para el módulo CWG.

The NCO output is selected as the input signal for the CWG module in the CWGCON1 register.



## 2 El oscilador interno de alta frecuencia se selecciona como fuente de reloj.



## 3 Los retrasos de banda muerta se establecen en **63-64 conteos de reloj**.



(/local--files/8bit:cwgexample/exp4.png)

## 4 El pin **CWGFLT1** está habilitado como una señal de apagado que está conectado a un interruptor momentáneo normalmente abierto. Cuando se presiona el interruptor,

- aparece una señal baja en el pin CWGFLT1 y activa el apagado.



(/local--files/8bit:cwgexample/exp5.png)

- 5 El reinicio automático está habilitado y el **bit de apagado** se borra para comenzar en modo de ejecución.



(/local--files/8bit:cwgexample/exp6.png)

- 6 Ambas salidas están configuradas para conducir a su respectivo modo inactivo cuando se produce la señal de apagado.

The Shutdown state of the outputs are set to inactive.



(/local--files/8bit:cwgexample/exp7.png)

- 7 Las **salidas CWG** están conectadas a los pines de E/S y la polaridad de salida está configurada en modo normal.

The CWG output signals are connected to the CWG I/O pins through the CWGCON0 register.

```

G1OEA = 1; //Output signal on CWG1A pin
G1OEB = 1; //Output signal on CWG1B pin
G1POLA = 0; //Output is normal polarity
G1POLB = 0; //Output is normal polarity

```



(/local--files/8bit:cwgexample/exp8.png)

- 8 The **CWG** is then enabled. For reference, the NCO setup code is also shown that produces the input signal.

The CWG module is then enabled as the last step.

```
G1EN = 1; //Enable CWG module
```

The NCO module is setup to produce a 50% duty cycle square wave input to the CWG.

```

NCO1INCH = 8; // load NCO increment high register
NCO1INCL = 65;
NCO1CLK = 0b00000000; // Select HF internal OSC = 16 Mhz
NCO1CON = 0b11010000; // Enable NCO, Enable output,active hi, 50% dc mode

```

(/local--files/8bit:cwgexample/exp9.png)

# CWG Example Operation

The CWG example is running and the screen capture below shows the results.

The NCO signal can be seen at the top of the screen capture along with the CWGA and CWGB signals. You can also see the dead-band delays that are triggered by the edges of the NCO input signal.



(/local--files/8bit:cwgexample/exp10.png)

The CWG is forced into shutdown mode.

When the momentary switch is pressed, the CWG outputs are driven to their inactive state showing the shutdown has occurred.



(/local--files/8bit:cwgexample/exp11.png)

# Oscilador controlado numéricamente

---

El módulo **Oscilador controlado numéricamente (NCOx)** es un temporizador que utiliza el desbordamiento de un acumulador para crear una señal de salida. El desbordamiento del acumulador se controla mediante un valor de incremento ajustable en lugar de un solo pulso de reloj o un incremento posterior al escalador. Esto ofrece una ventaja sobre un simple contador accionado por temporizador en el sentido de que la resolución de la división no varía con el valor del divisor del preescalador/postescalador algo limitado. El NCOx es más útil para aplicaciones que requieren precisión de frecuencia y resolución fina en un ciclo de trabajo fijo.

Las características del NCOx incluyen:

- función de incremento de 16 bits
- Modo de ciclo de trabajo fijo (FDC)
- Modo de frecuencia de pulso (PF)
- Control de ancho de pulso de salida
- Múltiples fuentes de entrada de reloj
- Control de polaridad de salida
- capacidad de interrupción

El NCOx opera agregando repetidamente un valor fijo a un acumulador. Las adiciones ocurren a la velocidad del reloj de entrada. El acumulador se desbordará con un acarreo periódicamente, que es la salida de NCOx sin procesar. Esto reduce efectivamente el reloj de entrada en la proporción del valor agregado al valor máximo del acumulador.



(/local--files/8bit:nco/NCO.png)

La salida NCOx se puede modificar aún más estirando el pulso o alternando un flip-flop. La salida NCOx modificada se distribuye internamente a otros periféricos y, opcionalmente, se envía a un pin de E/S. El desbordamiento del acumulador también puede generar una interrupción. El período NCOx cambia en pasos discretos para crear una frecuencia promedio. Esta salida depende de la capacidad del circuito receptor (es decir, CWG o circuito convertidor resonante externo) para promediar la salida NCOx para reducir la incertidumbre.

El desbordamiento del módulo NCO se basa en la siguiente fórmula:

The NCO output is based on the formula below

$$\text{Accumulator Overflow Rate} = \frac{\text{Accumulator Overflow Value}}{\text{Input Clock Frequency} \times \text{Increment Value}}$$

(/local--files/8bit:nco/NCO\_formula.png)

## Videotutorial para suboficiales

Este video presenta el oscilador controlado numéricamente (NCO) para dispositivos MCU de 8 bits de Microchip y muestra cómo usarlo.

## Microchip Self-Paced Training – Numerically Controlled Oscillat...



## Modos NCO

El módulo NCO puede emitir una señal en uno de los dos modos.

NCO has Two modes of operation:  
■ Fixed 50% duty cycle (FDC)   
■ Pulse Frequency Modulation (PFM)

(/local--  
files/8bit:nco/NCO\_modes.png)

El registro NCOCON controla la configuración de modo para el NCO.

NCOxCON Register  

|      |      |       |       |   |   |   |       |
|------|------|-------|-------|---|---|---|-------|
| NxEN | NxEI | NxOUT | NxPOL | - | - | - | NxPFM |
|------|------|-------|-------|---|---|---|-------|

  
NxPFM NCOx Pulse Frequency Mode Bit  
1 – NCOx operates in Pulse Frequency Mode  
0 – NCOx operates in Fixed Duty Cycle Mode

(/local--  
files/8bit:nco/ncocon.png)

### Ciclo de trabajo fijo

El modo de ciclo de trabajo fijo alterna la salida en cada desbordamiento del acumulador. Siempre que el valor del sumador y el reloj no cambien, esto dará como resultado una salida del ciclo de trabajo del 50 %.



(/local--  
files/8bit:nco/NCO\_duty.png)

## Modulación de frecuencia de pulso

El modo de modulación de frecuencia de pulso activará un pulso en cada desbordamiento del acumulador durante un período establecido por tres bits en el registro NCOCON.



(/local--  
files/8bit:nco/NCO\_pulse.png)

## Acumulador

El acumulador es un registro de 20 bits con un valor máximo de 1.048.575. El acceso de lectura y escritura al acumulador está disponible a través de tres registros:

- NCOxACCL
- NCOxACCH
- NCOxACCU



(/local--  
files/8bit:nco/NCO\_accumulator.png)

Cuando el acumulador se desborda, la salida del módulo NCO cambiará de estado.

## Sumador

El sumador NCOx es un sumador completo que opera independientemente del reloj del sistema. Agrega el valor del valor de incremento al acumulador en cada pulso de reloj NCO. El sumador toma el valor en el acumulador y luego suma el valor del incremento. El resultado se vuelve a colocar en el acumulador. El valor del acumulador se acumulará y cualquier valor más allá de 1.048.575 se colocará como valor inicial en el acumulador.

Esto se puede restablecer si se desea escribiendo un cero en el acumulador. Esto normalmente se hace dentro de la rutina de servicio de interrupción si está habilitado en el módulo NCO.



(/local--  
files/8bit:nco/NCO\_400\_animated.gif)

## Registros de incremento

El valor de incremento se almacena en dos registros de 8 bits que componen un valor de incremento de 16 bits. Los 8 bits inferiores están en el registro NCOxINCL y los 8 bits superiores están en el registro NCOxINCH.

- NCOxINCL
- NCOxPULGADAS



(/local--  
files/8bit:nco/NCO\_adder.png)

Ambos registros son de lectura y escritura. Los registros de incremento tienen doble búfer para permitir que se realicen cambios de valor sin deshabilitar primero el módulo NCOx. Las cargas del búfer son inmediatas cuando el módulo está deshabilitado. Primero es necesario escribir en el registro NCOxINCH porque luego el búfer se carga sincrónicamente con la operación NCOx después de que se ejecuta la escritura en el registro NCOxINCL.

# Fuentes de reloj

Las fuentes de reloj disponibles para el NCOx incluyen:

- HFINTOSC
- F<sub>OSC</sub>
- LCxSALIDA
- pasador CLKIN

La fuente de reloj NCOx se selecciona configurando los bits NxCKS<2:0> en el registro NCOxCLK.



La selección de HFINTOSC continuará ejecutándose incluso si el dispositivo se pone en modo de suspensión.

# Producción

La salida del NCO tiene varias opciones que se pueden configurar en el registro NCOCON.

La salida se puede habilitar o deshabilitar (bit NxOE) y también invertir (bit NxPOL) configurando o borrando bits en el registro NCOCON.



(/local--  
files/8bit:nco/NCO\_outstate.png)

La salida también se puede monitorear en el software leyendo el estado del bit NxOUT en el registro NCOCON.



(/local--  
files/8bit:nco/NCO\_output.png)

El bit NxEN puede desactivar todo el módulo NCO. Una configuración '1' habilita el módulo y una configuración '0' lo deshabilita.

## Interrumpir

La salida NCO puede disparar una interrupción interna cuando el acumulador se desborda. Esto es manejado por tres bits (GIE, PEIE, NCOxIE) en el conjunto de registros que se muestra a continuación. Esto permitirá que el NCO controle las acciones del software a través de la rutina de servicio de interrupción en el código de la aplicación y al mismo tiempo emita una señal a un pin de E/S.

GIE es el bit de habilitación de interrupción global.

PEIE es el bit de habilitación de interrupción periférica.

NCOxIE es el bit de habilitación de interrupción NCO. Puede haber múltiples módulos NCO. La "x" representa el número de NCO.

El bit NCOxIF es la bandera indicadora de interrupción. Esto se puede monitorear en el software para ver si se ha producido una interrupción. Esto debe borrarse en la rutina de servicio de interrupción o en la rutina de software que lee el bit.



(/local--  
files/8bit:nco/NCO\_interrupt.png)

# Interrupciones de rango medio mejoradas

## Resumen

Las interrupciones son eventos detectados por la MCU que hacen que se anule el flujo normal del programa. Las interrupciones pausan el programa actual y transfieren el control a una rutina de firmware específica escrita por el usuario llamada Rutina de servicio de interrupción (ISR). El ISR procesa el evento de interrupción y luego reanuda el flujo normal del programa. Este artículo muestra cómo habilitar y procesar interrupciones en la familia PIC16F1xxx de PIC® de rango medio <sup>mejorado</sup>.

## Descripción general del proceso de interrupción

### 1 Programa MCU para reaccionar a las interrupciones

La MCU debe programarse para permitir que ocurran interrupciones. La configuración de Global Interrupt Enable (GIE) y, en muchos casos, Peripheral Interrupt Enable (PEIE), permite que la MCU reciba interrupciones. GIE y PEIE se encuentran en el registro de funciones especiales de control de interrupciones (INTCON).

### 2 Habilitar interrupciones de periféricos seleccionados

Cada periférico en la MCU tiene un bit de habilitación individual. Se debe establecer el bit de activación de interrupción individual de un periférico, además de GIE/PEIE, antes de que el periférico pueda generar una interrupción. Los bits de habilitación de interrupción individuales se encuentran en INTCON, PIE1, PIE2 y PIE3.

### 3 Periférico afirma una solicitud de interrupción

Cuando un periférico alcanza un estado en el que se necesita la intervención del programa, el periférico establece un indicador de solicitud de interrupción (xxIF). Estos indicadores de interrupción se establecen independientemente del estado de GIE, PEIE y los bits de activación de interrupción individuales. Los indicadores de interrupción se encuentran en INTCON, PIR1, PIR2 y PIR3.

Los indicadores de solicitud de interrupción se bloquean en alto cuando se establecen y deben ser borrados por el ISR escrito por el usuario.

### 4 Ocurre una interrupción

Cuando se establece un indicador de solicitud de interrupción y la interrupción está habilitada correctamente, comienza el proceso de interrupción:

- Las interrupciones globales se desactivan borrando GIE a 0.
- El contexto del programa actual se guarda en los registros de sombra.
- El valor del contador de programa se almacena en la pila de retorno.
- El control del programa se transfiere al vector de interrupción en la dirección 04h.

### 5 Ejecuciones de ISR

El ISR es una función escrita por el usuario y ubicada en la dirección 04h. El ISR hace lo siguiente:

1. Comprueba los periféricos habilitados para interrupción en busca del origen de la solicitud de interrupción.
2. Realiza las tareas periféricas necesarias.
3. Borra el indicador de solicitud de interrupción apropiado.
4. Ejecuta la instrucción Return From Interrupt (RETFIE) como instrucción ISR final.

### 6 El control vuelve al programa principal

Cuando se ejecuta RETFIE:

1. Las interrupciones globales están habilitadas (GIE=1).
2. El contexto del programa se restaura desde los registros de sombra.
3. La dirección de retorno de la pila se carga en el contador de programa.
4. La ejecución se reanuda desde el punto en que se interrumpió.

# Registros utilizados para procesar interrupciones

## Registro de control de interrupciones

registro INTCON

|       |      |        |      |       |        |      |       |
|-------|------|--------|------|-------|--------|------|-------|
| GIE   | PEIE | TMR0IE | INTE | IOCIE | TMR0IF | INTF | IOCIF |
| bit 7 |      |        |      | bit 0 |        |      |       |

(/local--files/8bit:emr-interrupts/intcon-reg.png)

**GIE** - Habilitación de interrupción global   **PEIE** - Habilitación de interrupción periférica   **TMR0IE** - Habilitación de interrupción del temporizador 0   **INTE** - Habilitación de interrupción externa   **IOCIE** - Habilitación de interrupción por cambio   **TMR0IF** - Indicador de interrupción del temporizador 0   **INTF** - Indicador de interrupción externa   **IOCIF** - Indicador de interrupción por cambio



**INTCON** contiene banderas de habilitación de interrupción global y periférica, así como banderas de solicitud de interrupción individuales y banderas de habilitación de interrupción para tres de las interrupciones PIC16F1xxxx.

## Registros de habilitación de interrupción

registro PIE1

|         |      |      |      |       |        |        |         |
|---------|------|------|------|-------|--------|--------|---------|
| TMR1GIE | ADIE | RCIE | TXIE | SSPIE | CCP1IE | TMR2IE | TMRI1IE |
| bit 7   |      |      |      | bit 0 |        |        |         |

(/local--files/8bit:emr-interrupts/pie1-reg.png)

**TMR1GIE** - Habilitación de interrupción de puerta del temporizador 1   **ADIE** - Habilitación de interrupción de convertidor analógico a digital (ADC)   **RCIE** - Habilitación de interrupción de recepción de transmisor receptor asíncrono síncrono universal (USART)   **TXIE** - Habilitación de interrupción de transmisión USART   **SSPIE** - Habilitación de interrupción de puerto serie síncrono (MSSP)   **CCP1IE** - Habilitación de interrupción CCP1   **TMR2IE** - Habilitación de interrupción del temporizador 2   **TMRI1IE** - Habilitación de interrupción de la interfaz de red de alta velocidad (RJ45)

**temporizador 2 TMR1IE** - Habilitación de interrupción

## registro PIE2

|       |      |      |      |       |       |      |        |
|-------|------|------|------|-------|-------|------|--------|
| OSFIE | C2IE | C1IE | EEIE | BCLIE | LCDIE | ---- | CCP2IE |
|-------|------|------|------|-------|-------|------|--------|

bit 7

bit 0

(/local--files/8bit:emr-interrupts/pie2-reg.png)

- OSFIE** - Habilitación de interrupción por falla del oscilador
- C2IE** - Habilitación de interrupción del comparador C2
- C1IE** - Habilitación de interrupción del comparador C1
- EEIE** - Habilitación de interrupción de finalización de escritura de EEPROM
- BCLIE** - Habilitación de interrupción de colisión de bus MSSP
- LCDIE** - Habilitación de interrupción del módulo LCD
- - Sin implementar, se lee como 0
- CCP2IE** - CCP2 Habilitar interrupción



## registro PIE3

|      |        |        |        |        |      |        |      |
|------|--------|--------|--------|--------|------|--------|------|
| ---- | CCP5IE | CCP4IE | CCP3IE | TMR6IE | ---- | TMR4IE | ---- |
|------|--------|--------|--------|--------|------|--------|------|

bit 7

bit 0

(/local--files/8bit:emr-interrupts/pie3-reg.png)

- - No implementado leído como 0
- CCP5IE** - CCP5 Interrupt Enable
- CCP4IE** - CCP4 Interrupt Enable
- CCP3IE** - CCP3 Interrupt Enable
- TMR6IE** - Timer6 Interrupt Enable
- - No implementado, leído como 0
- TMR4IE** - Timer4 Interrupt Enable
- - No implementado, leído como 0





**PIE1**, **PIE2** y **PIE3** contienen los indicadores de activación de interrupción individuales para los periféricos de la MCU.

## Registros de solicitud de interrupción

### registro PIR1

|         |      |      |      |       |        |        |        |
|---------|------|------|------|-------|--------|--------|--------|
| TMR1GIF | ADIF | RCIF | TXIF | SSPIF | CCP1IF | TMR2IF | TMRI1F |
| bit 7   |      |      |      | bit 0 |        |        |        |

(/local--files/8bit:emr-interrupts/pir1-reg.png)

**TMR1GIF** - Indicador de interrupción de puerta del temporizador 1  
**ADIF** - Indicador de interrupción de ADC  
**RCIF** - Indicador de interrupción de recepción de USART  
**TXIF** - Indicador de interrupción de transmisión de USART  
**SSPIF** - Indicador de interrupción de MSSP  
**CCP1IF** - Indicador de interrupción de CCP1  
**TMR2IF** - Indicador de interrupción de temporizador 2  
**TMRI1F** - Indicador de interrupción



### registro PIR2

|       |      |      |      |       |       |     |        |
|-------|------|------|------|-------|-------|-----|--------|
| OSFIF | C2IF | C1IF | EEIF | BCLIF | LCDIF | --- | CCP2IF |
| bit 7 |      |      |      |       | bit 0 |     |        |

(/local--files/8bit:emr-interrupts/pir2-reg.png)

**OSFIF** - Indicador de interrupción por falla del oscilador  
**C2IF** - Indicador de interrupción C2 del comparador  
**C1IF** - Indicador de interrupción C1 del comparador  
**EEIF** - Indicador de interrupción de finalización de escritura de EEPROM  
**BCLIF** - Indicador de interrupción de colisión del bus MSSP  
**LCDIF** - Indicador de interrupción del módulo LCD  
**---** - Sin implementar, se lee como 0  
**CCP2IF** - CCP2  
**Indicador de interrupción**





## registro PIR3

|       |        |        |        |        |     |        |     |
|-------|--------|--------|--------|--------|-----|--------|-----|
| ---   | CCP5IF | CCP4IF | CCP3IF | TMR6IF | --- | TMR4IF | --- |
| bit 7 |        |        |        | bit 0  |     |        |     |

(/local--files/8bit:emr-interrupts/pir3-reg.png)

--- - Sin implementar, leer como 0 CCP5IF - Bandera de interrupción de CCP5 CCP4IF - Bandera de interrupción de CCP4 CCP3IF - Bandera de interrupción de CCP3 TMR6IF - Bandera de interrupción de Timer6 --- - No implementada, leer como 0 TMR4IF - Bandera de interrupción de Timer4 --- - No implementada, leer como 0



PIR1, PIR2 y PIR3 contienen los indicadores de solicitud de interrupción individuales para los periféricos de la MCU.

## OPCIÓN\_REG

### OPCIÓN\_REG

|       |        |        |        |     |         |       |
|-------|--------|--------|--------|-----|---------|-------|
| WPUEN | INTEDG | TMR0CS | TMR0SE | PSA | PS<2:0> | bit 0 |
|-------|--------|--------|--------|-----|---------|-------|

(/local--files/8bit:emr-interrupts/option-reg.png)

El indicador INTEDG en OPTION\_REG se usa para establecer un flanco ascendente o descendente en el pin INT como desencadenante de una interrupción INTE.

# Habilitación de interrupciones

## Interrupciones del núcleo

Tres fuentes de interrupción (Timer0, External Interrupt e Interrupt on Change) tienen bits de habilitación de interrupción ubicados en INTCON. Estas interrupciones se denominan interrupciones centrales.



(/local--files/8bit:emr-interrupts/core-enable-reg.png)

Para habilitar una de las interrupciones principales, solo es necesario establecer el bit de habilitación de interrupción individual y el GIE.



(/local--files/8bit:emr-interrupts/core-enable-code.png)



Borrar un indicador de solicitud de interrupción antes de establecer el indicador de activación de interrupción evita que cualquier solicitud de interrupción pendiente active una interrupción inmediata.

## Interrupciones Periféricas

Los periféricos PIC16F1xxx, capaces de generar solicitudes de interrupción cada uno, tienen sus indicadores de activación de interrupción en uno de los tres registros PIE. Para habilitar una interrupción periférica, el indicador de interrupción individual, GIE y PEIE deben estar todos configurados.

|                 | Assembly                                                                                                                                                                                                                       | C                                                                                                 |                  |                    |        |                    |        |        |        |                                                                                                                                                                         |   |   |   |   |   |   |   |   |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|------------------|--------------------|--------|--------------------|--------|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|
|                 | <pre> banksel PIR1 bsf PIR1, SSPIF banksel PIE1 bsf PIE1, SSPIE  bsf INTCON, PEIE bsf INTCON, GIE </pre>                                                                                                                       | <pre> PIR1bits.SSP1IF = 0 ; PIE1bits.SSP1IE = 1;  INTCONbits.PEIE =1; INTCONbits.GIE = 1 ; </pre> |                  |                    |        |                    |        |        |        |                                                                                                                                                                         |   |   |   |   |   |   |   |   |
| INTCON          | <table border="1" style="width: 100%; text-align: center;"> <tr> <td>GIE<br/><b>1</b></td> <td>PEIE<br/><b>1</b></td> <td>TMROIE</td> <td>INTE</td> <td>IOCIE</td> <td>TMROIF</td> <td>INTF</td> <td>IOCIF</td> </tr> </table> | GIE<br><b>1</b>                                                                                   | PEIE<br><b>1</b> | TMROIE             | INTE   | IOCIE              | TMROIF | INTF   | IOCIF  | <table border="1" style="width: 100%; text-align: center;"> <tr> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> </tr> </table> | X | X | X | X | X | X | X | X |
| GIE<br><b>1</b> | PEIE<br><b>1</b>                                                                                                                                                                                                               | TMROIE                                                                                            | INTE             | IOCIE              | TMROIF | INTF               | IOCIF  |        |        |                                                                                                                                                                         |   |   |   |   |   |   |   |   |
| X               | X                                                                                                                                                                                                                              | X                                                                                                 | X                | X                  | X      | X                  | X      |        |        |                                                                                                                                                                         |   |   |   |   |   |   |   |   |
| PIE1            | <table border="1" style="width: 100%; text-align: center;"> <tr> <td>TMR1GIE</td> <td>ADIE</td> <td>RCIE</td> <td>TXIE</td> <td>SSP1IE<br/><b>1</b></td> <td>CCPIE</td> <td>TMR2IE</td> <td>TMR1IE</td> </tr> </table>         | TMR1GIE                                                                                           | ADIE             | RCIE               | TXIE   | SSP1IE<br><b>1</b> | CCPIE  | TMR2IE | TMR1IE | <table border="1" style="width: 100%; text-align: center;"> <tr> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> </tr> </table> | X | X | X | X | X | X | X | X |
| TMR1GIE         | ADIE                                                                                                                                                                                                                           | RCIE                                                                                              | TXIE             | SSP1IE<br><b>1</b> | CCPIE  | TMR2IE             | TMR1IE |        |        |                                                                                                                                                                         |   |   |   |   |   |   |   |   |
| X               | X                                                                                                                                                                                                                              | X                                                                                                 | X                | X                  | X      | X                  | X      |        |        |                                                                                                                                                                         |   |   |   |   |   |   |   |   |
| PIR1            | <table border="1" style="width: 100%; text-align: center;"> <tr> <td>TMR1GIF</td> <td>ADIF</td> <td>RCIF</td> <td>TXIF</td> <td>SSP1IF<br/><b>0</b></td> <td>CCPIF</td> <td>TMR2IF</td> <td>TMR1IF</td> </tr> </table>         | TMR1GIF                                                                                           | ADIF             | RCIF               | TXIF   | SSP1IF<br><b>0</b> | CCPIF  | TMR2IF | TMR1IF | <table border="1" style="width: 100%; text-align: center;"> <tr> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> <td>X</td> </tr> </table> | X | X | X | X | X | X | X | X |
| TMR1GIF         | ADIF                                                                                                                                                                                                                           | RCIF                                                                                              | TXIF             | SSP1IF<br><b>0</b> | CCPIF  | TMR2IF             | TMR1IF |        |        |                                                                                                                                                                         |   |   |   |   |   |   |   |   |
| X               | X                                                                                                                                                                                                                              | X                                                                                                 | X                | X                  | X      | X                  | X      |        |        |                                                                                                                                                                         |   |   |   |   |   |   |   |   |

(/local--files/8bit:emr-interrupts/peie-code.png)

## Dar servicio a una interrupción

### ISR

El ISR es un programa escrito por el usuario que realiza las tareas necesarias cuando ocurre una interrupción. El usuario es responsable de escribir el ISR y colocarlo en la dirección 04h. La última instrucción ejecutada por el ISR debe ser la instrucción RETFIE. Los ISR se pueden escribir en lenguaje C o ensamblador.

### ISR en ensamblaje (izquierda) e ISR en C (derecha)



(/local--files/8bit:emr-interrupts/isr-location.png)

## Guardar contexto

El hardware de la MCU invocará el mecanismo de ahorro de contexto cuando ocurra una interrupción.



(/local--files/8bit:emr-interrupts/context-saving.png)

## Verificar fuente de la interrupción

Hay un ISR que da servicio a todas las interrupciones de la aplicación. El ISR necesita verificar secuencialmente los indicadores de solicitud de interrupción individuales para determinar la fuente de la interrupción.

## Borrado del indicador de solicitud de interrupción

Los indicadores de solicitud de interrupción se bloquean cuando los establece el periférico. Deben ser autorizados por ISR. Si el ISR no restablece un indicador de solicitud, se producirá otra interrupción inmediatamente después de que el ISR devuelva el control al programa principal.

```
void interrupt sample_isr (void)
{
    if (TMR2IF == 1)
    {
        // perform TMR2 Interrupt task
        TMR2IF = 0 ;
    }

    if (INTE == 1)
    {
        // External Interrupt tasks
        INTF = 0 ;
    }

    if (CCP1IF == 1)
        // CCP tasks
        CCP1IF = 0;
}
```

(/local--files/8bit:emr-interrupts/sample-isr.png)

---

## Ejemplo de código de interrupción

### Procesando una interrupción del Timer2

La siguiente animación muestra el código para configurar y procesar una interrupción del Timer2 en el MCU de rango medio mejorado PIC16F1xxx. Los íconos de control en la parte inferior de la animación permiten pausar la visualización y realizar un solo paso.

 [Imagen de presentación de diapositivas](#)

◀ ▶ ⟲ 1 /0

Se puede encontrar una explicación más detallada de las interrupciones PIC16F1xxx en la página Interrupciones (/mcu1102:interrupts) .

La página Timer2/4/6 (/8bit:timer2) proporciona los detalles sobre la configuración y el funcionamiento de Timer2.