



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

#### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | PIC                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 20MHz                                                                     |
| Connectivity               | -                                                                         |
| Peripherals                | Brown-out Detect/Reset, POR, WDT                                          |
| Number of I/O              | 11                                                                        |
| Program Memory Size        | 1.75KB (1K x 14)                                                          |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 64 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5V                                                                   |
| Data Converters            | -                                                                         |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 14-SOIC (0.154", 3.90mm Width)                                            |
| Supplier Device Package    | 14-SOIC                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16hv610-e-sl |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

# PIC16F610/16HV610 16-Pin Diagram (QFN)



| TABLE 3: | PIC16F610/16HV610 | <b>16-PIN SUMMARY</b> |
|----------|-------------------|-----------------------|
|          |                   |                       |

| I/O                | Pin | Comparators | Timers | Interrupts | Pull-ups | Basic       |
|--------------------|-----|-------------|--------|------------|----------|-------------|
| RA0                | 12  | C1IN+       | -      | IOC        | Y        | ICSPDAT     |
| RA1                | 11  | C12IN0-     |        | IOC        | Y        | ICSPCLK     |
| RA2                | 10  | C1OUT       | TOCKI  | INT/IOC    | Y        | —           |
| RA3 <sup>(1)</sup> | 3   | —           | _      | IOC        | Y(2)     | MCLR/VPP    |
| RA4                | 2   | —           | T1G    | IOC        | Y        | OSC2/CLKOUT |
| RA5                | 1   | —           | T1CKI  | IOC        | Y        | OSC1/CLKIN  |
| RC0                | 9   | C2IN+       | —      | —          | —        | —           |
| RC1                | 8   | C12IN1-     |        | —          |          | —           |
| RC2                | 7   | C12IN2-     | —      | —          | _        | —           |
| RC3                | 6   | C12IN3-     |        | —          | —        | _           |
| RC4                | 5   | C2OUT       | _      | —          | —        | —           |
| RC5                | 4   | —           |        | —          | _        | _           |
| —                  | 16  | —           | _      | —          | _        | Vdd         |
| —                  | 13  |             |        |            |          | Vss         |

Note 1: Input only.

**2:** Only when pin is configured for external  $\overline{MCLR}$ .





## 2.2 Data Memory Organization

The data memory (see Figure 2-4) is partitioned into two banks, which contain the General Purpose Registers (GPR) and the Special Function Registers (SFR). The Special Function Registers are located in the first 32 locations of each bank. PIC16F610/16HV610 Register locations 40h-7Fh in Bank 0 are General Purpose Registers, implemented as static RAM. PIC16F616/16HV616 Register locations 20h-7Fh in Bank 0 and A0h-BFh in Bank 1 are General Purpose Registers, implemented as static RAM. Register locations F0h-FFh in Bank 1 point to addresses 70h-7Fh in Bank 0. All other RAM is unimplemented and returns '0' when read. The RP0 bit of the STATUS register is the bank select bit.

<u>RP0</u>

- $0 \rightarrow \text{Bank 0 is selected}$
- $1 \rightarrow \text{Bank 1 is selected}$

| Note: | The IRP and RP1 bits of the STATUS         |
|-------|--------------------------------------------|
|       | register are reserved and should always be |
|       | maintained as '0's.                        |

#### 2.2.1 GENERAL PURPOSE REGISTER FILE

The register file is organized as  $64 \times 8$  in the PIC16F610/16HV610 and  $128 \times 8$  in the PIC16F616/16HV616. Each register is accessed, either directly or indirectly, through the File Select Register (FSR) (see Section 2.4 "Indirect Addressing, INDF and FSR Registers").

#### 2.2.2 SPECIAL FUNCTION REGISTERS

The Special Function Registers are registers used by the CPU and peripheral functions for controlling the desired operation of the device (see Table 2-1). These registers are static RAM.

The special registers can be classified into two sets: core and peripheral. The Special Function Registers associated with the "core" are described in this section. Those related to the operation of the peripheral features are described in the section of that peripheral feature.

#### 2.2.2.6 PCON Register

The Power Control (PCON) register (see Table 12-2) contains flag bits to differentiate between a:

- Power-on Reset (POR)
- Brown-out Reset (BOR)
- Watchdog Timer Reset (WDT)
- External MCLR Reset

The PCON register also controls the software enable of the  $\overline{\text{BOR}}.$ 

The PCON register bits are shown in Register 2-6.

### REGISTER 2-6: PCON: POWER CONTROL REGISTER

| U-0   | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 <sup>(1)</sup> |
|-------|-----|-----|-----|-----|-----|-------|----------------------|
| —     | —   | —   | —   | —   | —   | POR   | BOR                  |
| bit 7 |     |     |     |     |     |       | bit 0                |

| Legend:                               |           |                            |                                 |                      |  |  |
|---------------------------------------|-----------|----------------------------|---------------------------------|----------------------|--|--|
| R = Readab                            | le bit    | W = Writable bit           | U = Unimplemented bit,          | read as '0'          |  |  |
| -n = Value at POR                     |           | '1' = Bit is set           | '0' = Bit is cleared            | x = Bit is unknown   |  |  |
|                                       |           |                            |                                 |                      |  |  |
| bit 7-2                               | Unimpler  | mented: Read as '0'        |                                 |                      |  |  |
| bit 1                                 | POR: Pov  | wer-on Reset Status bit    |                                 |                      |  |  |
|                                       | 1 = No Po | ower-on Reset occurred     |                                 |                      |  |  |
|                                       | 0 = A Pov | ver-on Reset occurred (mus | t be set in software after a Po | wer-on Reset occurs) |  |  |
| bit 0 BOR: Brown-out Reset Status bit |           |                            |                                 |                      |  |  |
| 1 = No Brown-out Reset occurred       |           |                            |                                 |                      |  |  |

0 = A Brown-out Reset occurred (must be set in software after a Brown-out Reset occurs)

**Note 1:** Reads as '0' if Brown-out Reset is disabled.

### 4.2 Additional Pin Functions

Every PORTA pin on the PIC16F610/616/16HV610/ 616 has an interrupt-on-change option and a weak pullup option. The next three sections describe these functions.

#### 4.2.1 ANSEL REGISTER

The ANSEL register is used to configure the Input mode of an I/O pin to analog. Setting the appropriate ANSEL bit high will cause all digital reads on the pin to be read as '0' and allow analog functions on the pin to operate correctly.

The state of the ANSEL bits has no affect on digital output functions. A pin with TRIS clear and ANSEL set will still operate as a digital output, but the Input mode will be analog. This can cause unexpected behavior when executing read-modify-write instructions on the affected port.

#### 4.2.2 WEAK PULL-UPS

Each of the PORTA pins, except RA3, has an individually configurable internal weak pull-up. Control bits WPUAx enable or disable each pull-up. Refer to Register 4-4. Each weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are disabled on a Power-on Reset by the RAPU bit of the OPTION register). A weak pull-up is automatically enabled for RA3 when configured as MCLR and disabled when RA3 is an input. There is no software control of the MCLR pull-up.

#### 4.2.3 INTERRUPT-ON-CHANGE

Each PORTA pin is individually configurable as an interrupt-on-change pin. Control bits IOCAx enable or disable the interrupt function for each pin. Refer to Register 4-5. The interrupt-on-change is disabled on a Power-on Reset.

For enabled interrupt-on-change pins, the values are compared with the old value latched on the last read of PORTA. The 'mismatch' outputs of the last read are OR'd together to set the PORTA Change Interrupt Flag bit (RAIF) in the INTCON register (Register 2-3).

This interrupt can wake the device from Sleep. The user, in the Interrupt Service Routine, clears the interrupt by:

- a) Any read or write of PORTA. This will end the mismatch condition, then,
- b) Clear the flag bit RAIF.

A mismatch condition will continue to set flag bit RAIF. Reading PORTA will end the mismatch condition and allow flag bit RAIF to be cleared. The <u>latch</u> holding the last read value is not affected by a MCLR nor BOR Reset. After these resets, the RAIF flag will continue to be set if a mismatch is present.

Note: If a change on the I/O pin should occur when any PORTA operation is being executed, then the RAIF interrupt flag may not get set.

#### REGISTER 4-3: ANSEL: ANALOG SELECT REGISTER

| R/W-1                              | R/W-1 | R/W-1 | R/W-1 | R/W-1                                    | R/W-1               | R/W-1 | R/W-1 |  |
|------------------------------------|-------|-------|-------|------------------------------------------|---------------------|-------|-------|--|
| ANS7                               | ANS6  | ANS5  | ANS4  | ANS3 <sup>(2)</sup>                      | ANS2 <sup>(2)</sup> | ANS1  | ANS0  |  |
| bit 7                              |       |       |       |                                          |                     |       | bit 0 |  |
|                                    |       |       |       |                                          |                     |       |       |  |
| Legend:                            |       |       |       |                                          |                     |       |       |  |
| R = Readable bit W = Writable bit  |       |       | bit   | U = Unimplemented bit, read as '0'       |                     |       |       |  |
| -n = Value at POR (1' = Bit is set |       |       |       | 0' = Bit is cleared $x = Bit is unknown$ |                     |       |       |  |

bit 7-0 ANS<7:0>: Analog Select bits

Analog select between analog or digital function on pins AN<7:0>, respectively.

1 =Analog input. Pin is assigned as analog input<sup>(1)</sup>.

0 = Digital I/O. Pin is assigned to port or special function.

- **Note 1:** Setting a pin to an analog input automatically disables the digital input circuitry, weak pull-ups, and interrupt-on-change if available. The corresponding TRIS bit must be set to Input mode in order to allow external control of the voltage on the pin.
  - 2: PIC16F616/HV616.

| U-0             | U-0                                         | R/W-1            | R/W-1 | U-0                                | R/W-1 | R/W-1              | R/W-1 |  |  |
|-----------------|---------------------------------------------|------------------|-------|------------------------------------|-------|--------------------|-------|--|--|
|                 | —                                           | WPUA5            | WPUA4 | —                                  | WPUA2 | WPUA1              | WPUA0 |  |  |
| bit 7           |                                             |                  |       |                                    |       |                    | bit 0 |  |  |
|                 |                                             |                  |       |                                    |       |                    |       |  |  |
| Legend:         |                                             |                  |       |                                    |       |                    |       |  |  |
| R = Readable    | bit                                         | W = Writable bit |       | U = Unimplemented bit, read as '0' |       |                    |       |  |  |
| -n = Value at P | POR                                         | '1' = Bit is set |       | '0' = Bit is cleared               |       | x = Bit is unknown |       |  |  |
|                 |                                             |                  |       |                                    |       |                    |       |  |  |
| bit 7-6         | Unimplemen                                  | ted: Read as 'o  | )'    |                                    |       |                    |       |  |  |
| bit 5-4         | it 5-4 WPUA<5:4>: Weak Pull-up Control bits |                  |       |                                    |       |                    |       |  |  |
|                 | 1 = Pull-up enabled<br>0 = Pull-up disabled |                  |       |                                    |       |                    |       |  |  |

#### REGISTER 4-4: WPUA: WEAK PULL-UP PORTA REGISTER

bit 3Unimplemented: Read as '0'bit 2-0WPUA<2:0>: Weak Pull-up Control bits

- - 1 =Pull-up enabled 0 =Pull-up disabled

**Note 1:** Global RAPU must be enabled for individual pull-ups to be enabled.

- 2: The weak pull-up device is automatically disabled if the pin is in Output mode (TRISA = 0).
- **3:** The RA3 pull-up is enabled when configured as MCLR and disabled as an input in the Configuration Word.
- 4: WPUA<5:4> always reads '1' in XT, HS and LP Oscillator modes.

#### REGISTER 4-5: IOCA: INTERRUPT-ON-CHANGE PORTA REGISTER

| U-0   | U-0         | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|-------|-------------|-------|-------|-------|-------|-------|-------|
| —     | IOCA5 IOCA4 |       | IOCA4 | IOCA3 | IOCA2 | IOCA1 | IOCA0 |
| bit 7 |             |       |       |       |       |       | bit 0 |

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

bit 7-6 Unimplemented: Read as '0'

bit 5-0 IOCA<5:0>: Interrupt-on-change PORTA Control bit

1 = Interrupt-on-change enabled

0 = Interrupt-on-change disabled

Note 1: Global Interrupt Enable (GIE) must be enabled for individual interrupts to be recognized.

2: IOCA<5:4> always reads '1' in XT, HS and LP Oscillator modes.

| Name       | Bit 7 | Bit 6  | Bit 5  | Bit 4  | Bit 3               | Bit 2               | Bit 1  | Bit 0  | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|------------|-------|--------|--------|--------|---------------------|---------------------|--------|--------|----------------------|---------------------------------|
| ANSEL      | ANS7  | ANS6   | ANS5   | ANS4   | ANS3 <sup>(1)</sup> | ANS2 <sup>(1)</sup> | ANS1   | ANS0   | 1111 1111            | 1111 1111                       |
| CM1CON0    | C10N  | C10UT  | C10E   | C1POL  | —                   | C1R                 | C1CH1  | C1CH0  | 0000 -000            | 0000 -000                       |
| CM2CON0    | C2ON  | C2OUT  | C2OE   | C2POL  | —                   | C2R                 | C2CH1  | C2CH0  | 0000 -000            | 0000 -000                       |
| INTCON     | GIE   | PEIE   | TOIE   | INTE   | RAIE                | T0IF                | INTF   | RAIF   | 0000 0000            | 0000 0000                       |
| IOCA       | —     | _      | IOCA5  | IOCA4  | IOCA3               | IOCA2               | IOCA1  | IOCA0  | 00 0000              | 00 0000                         |
| OPTION_REG | RAPU  | INTEDG | T0CS   | T0SE   | PSA                 | PS2                 | PS1    | PS0    | 1111 1111            | 1111 1111                       |
| PORTA      | _     |        | RA5    | RA4    | RA3                 | RA2                 | RA1    | RA0    | x0 x000              | u0 u000                         |
| TRISA      | —     | —      | TRISA5 | TRISA4 | TRISA3              | TRISA2              | TRISA1 | TRISA0 | 11 1111              | 11 1111                         |
| WPUA       | _     | _      | WPUA5  | WPUA4  | _                   | WPUA2               | WPUA1  | WPUA0  | 11 -111              | 11 -111                         |

#### TABLE 4-1: SUMMARY OF REGISTERS ASSOCIATED WITH PORTA

 $\label{eq:Legend: Legend: Legend: u = unchanged, - = unimplemented locations read as `0'. Shaded cells are not used by PORTA.$ 

Note 1: For PIC16F616/HV616 only.

# 4.3.1 RC0/AN4<sup>(1)</sup>/C2IN+

The RC0 is configurable to function as one of the following:  $\label{eq:configurable}$ 

- a general purpose I/O
- an analog input for the ADC<sup>(1)</sup>
- an analog non-inverting input to Comparator C2

# 4.3.2 RC1/AN5<sup>(1)</sup>/C12IN1-

The RC1 is configurable to function as one of the following:

- a general purpose I/O
- an analog input for the ADC<sup>(1)</sup>

an analog inverting input to the comparator

Note 1: PIC16F616/16HV616 only.



# 4.3.3 RC2/AN6<sup>(1)</sup>/C12IN2-/P1D<sup>(1)</sup>

The RC2 is configurable to function as one of the following:

- a general purpose I/O
- an analog input for the ADC<sup>(1)</sup>
- an analog input to Comparators C1 and C2
- a digital output from the Enhanced CCP<sup>(1)</sup>

# 4.3.4 RC3/AN7<sup>(1)</sup>/C12IN3-/P1C<sup>(1)</sup>

The RC3 is configurable to function as one of the following:

- a general purpose I/O
- an analog input for the ADC<sup>(1)</sup>
- an analog inverting input to Comparators C1 and C2
- a digital output from the Enhanced CCP<sup>(1)</sup>

Note 1: PIC16F616/16HV616 only.



#### 7: BLOCK DIAGRAM OF RC2 AND RC3



NOTES:

# 8.2 Comparator Control

Each comparator has a separate control and Configuration register: CM1CON0 for Comparator C1 and CM2CON0 for Comparator C2. In addition, Comparator C2 has a second control register, CM2CON1, for controlling the interaction with Timer1 and simultaneous reading of both comparator outputs.

The CM1CON0 and CM2CON0 registers (see Registers 8-1 and 8-2, respectively) contain the control and Status bits for the following:

- Enable
- Input selection
- Reference selection
- Output selection
- Output polarity

### 8.2.1 COMPARATOR ENABLE

Setting the CxON bit of the CMxCON0 register enables the comparator for operation. Clearing the CxON bit disables the comparator for minimum current consumption.

#### 8.2.2 COMPARATOR INPUT SELECTION

The CxCH<1:0> bits of the CMxCON0 register direct one of four analog input pins to the comparator inverting input.

| Note: | To use CxIN+ and CxIN- pins as analog       |
|-------|---------------------------------------------|
|       | inputs, the appropriate bits must be set in |
|       | the ANSEL register and the corresponding    |
|       | TRIS bits must also be set to disable the   |
|       | output drivers.                             |

# 8.2.3 COMPARATOR REFERENCE SELECTION

Setting the CxR bit of the CMxCON0 register directs an internal voltage reference or an analog input pin to the non-inverting input of the comparator. See **Section 8.11 "Comparator Voltage Reference"** for more information on the internal voltage reference module.

### 8.2.4 COMPARATOR OUTPUT SELECTION

The output of the comparator can be monitored by reading either the CxOUT bit of the CMxCON0 register or the MCxOUT bit of the CM2CON1 register. In order to make the output available for an external connection, the following conditions must be true:

- CxOE bit of the CMxCON0 register must be set
- · Corresponding TRIS bit must be cleared
- CxON bit of the CMxCON0 register must be set.
  - **Note 1:** The CxOE bit overrides the PORT data latch. Setting the CxON has no impact on the port override.
    - 2: The internal output of the comparator is latched with each instruction cycle. Unless otherwise specified, external outputs are not latched.

#### 8.2.5 COMPARATOR OUTPUT POLARITY

Inverting the output of the comparator is functionally equivalent to swapping the comparator inputs. The polarity of the comparator output can be inverted by setting the CxPOL bit of the CMxCON0 register. Clearing the CxPOL bit results in a non-inverted output.

Table 8-1 shows the output state versus input conditions, including polarity control.

#### TABLE 8-1: COMPARATOR OUTPUT STATE VS. INPUT CONDITIONS

| Input Condition   | CxPOL | CxOUT |
|-------------------|-------|-------|
| CxVIN - > CxVIN + | 0     | 0     |
| CxVIN- < CxVIN+   | 0     | 1     |
| CxVIN - > CxVIN + | 1     | 1     |
| CxVIN- < CxVIN+   | 1     | 0     |

### 8.3 Comparator Response Time

The comparator output is indeterminate for a period of time after the change of an input source or the selection of a new reference voltage. This period is referred to as the response time. The response time of the comparator differs from the settling time of the voltage reference. Therefore, both of these times must be considered when determining the total response time to a comparator input change. See the Comparator and Voltage Reference Specifications in **Section 15.0 "Electrical Specifications"** for more details.

#### **TABLE 8-2:** SUMMARY OF REGISTERS ASSOCIATED WITH THE COMPARATOR AND **VOLTAGE REFERENCE MODULES**

| Name    | Bit 7  | Bit 6               | Bit 5                 | Bit 4  | Bit 3               | Bit 2               | Bit 1                 | Bit 0   | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|---------|--------|---------------------|-----------------------|--------|---------------------|---------------------|-----------------------|---------|----------------------|---------------------------------|
| ANSEL   | ANS7   | ANS6                | ANS5                  | ANS4   | ANS3 <sup>(1)</sup> | ANS2 <sup>(1)</sup> | ANS1                  | ANS0    | 1111 1111            | 1111 1111                       |
| CM1CON0 | C1ON   | C1OUT               | C1OE                  | C1POL  | C1SP                | C1R                 | C1CH1                 | C1CH0   | 0000 0000            | 0000 0000                       |
| CM2CON0 | C2ON   | C2OUT               | C2OE                  | C2POL  | C2SP                | C2R                 | C2CH1                 | C2CH0   | 0000 0000            | 0000 0000                       |
| CM2CON1 | MC1OUT | MC2OUT              | —                     | T1ACS  | C1HYS               | C2HYS               | T1GSS                 | C2SYNC  | 00-0 0010            | 00-0 0010                       |
| INTCON  | GIE    | PEIE                | T0IE                  | INTE   | RAIE                | T0IF                | INTF                  | RAIF    | 0000 000x            | 0000 000x                       |
| PIE1    | _      | ADIE <sup>(1)</sup> | CCP1IE <sup>(1)</sup> | C2IE   | C1IE                | _                   | TMR2IE <sup>(1)</sup> | TMR1IE  | -000 0-00            | -000 0-00                       |
| PIR1    | —      | ADIF <sup>(1)</sup> | CCP1IF <sup>(1)</sup> | C2IF   | C1IF                |                     | TMR2IF <sup>(1)</sup> | TMR1IF  | -000 0-00            | -000 0-00                       |
| PORTA   | _      | _                   | RA5                   | RA4    | RA3                 | RA2                 | RA1                   | RA0     | x0 x000              | x0 x000                         |
| PORTC   | _      | _                   | RC5                   | RC4    | RC3                 | RC2                 | RC1                   | RC0     | xx 00xx              | uu 00uu                         |
| SRCON0  | SR1    | SR0                 | C1SEN                 | C2REN  | PULSS               | PULSR               | _                     | SRCLKEN | 0000 00-0            | 0000 00-0                       |
| SRCON1  | SRCS1  | SRCS0               | _                     | _      | _                   | _                   | _                     | —       | 00                   | 00                              |
| TRISA   | _      | _                   | TRISA5                | TRISA4 | TRISA3              | TRISA2              | TRISA1                | TRISA0  | 11 1111              | 11 1111                         |
| TRISC   |        |                     | TRISC5                | TRISC4 | TRISC3              | TRISC2              | TRISC1                | TRISC0  | 1111 1111            | 1111 1111                       |
| VRCON   | C1VREN | C2VREN              | VRR                   | FVREN  | VR3                 | VR2                 | VR1                   | VR0     | 0000 0000            | 0000 0000                       |

 Legend:
 x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used for comparator.

 Note
 1:
 PIC16F616/16HV616 only.

#### 10.3.1 PWM PERIOD

The PWM period is specified by writing to the PR2 register of Timer2. The PWM period can be calculated using the formula of Equation 10-1.

#### EQUATION 10-1: PWM PERIOD

$$PWM Period = [(PR2) + 1] \bullet 4 \bullet Tosc \bullet$$
$$(TMR2 Prescale Value)$$

When TMR2 is equal to PR2, the following three events occur on the next increment cycle:

- TMR2 is cleared
- The CCP1 pin is set. (Exception: If the PWM duty cycle = 0%, the pin will not be set.)
- The PWM duty cycle is latched from CCPR1L into CCPR1H.

| Note: | The Timer2 postscaler (see Section 7.1 |
|-------|----------------------------------------|
|       | "Timer2 Operation") is not used in the |
|       | determination of the PWM frequency.    |

#### 10.3.2 PWM DUTY CYCLE

The PWM duty cycle is specified by writing a 10-bit value to multiple registers: CCPR1L register and CCP1<1:0> bits of the CCP1CON register. The CCPR1L contains the eight MSbs and the CCP1<1:0> bits of the CCP1CON register contain the two LSbs. CCPR1L and CCP1<1:0> bits of the CCP1CON register can be written to at any time. The duty cycle value is not latched into CCPR1H until after the period completes (i.e., a match between PR2 and TMR2 registers occurs). While using the PWM, the CCPR1H register is read-only.

Equation 10-2 is used to calculate the PWM pulse width.

Equation 10-3 is used to calculate the PWM duty cycle ratio.

#### EQUATION 10-2: PULSE WIDTH

 $Pulse Width = (CCPR1L:CCP1CON < 5:4>) \bullet$ 

TOSC • (TMR2 Prescale Value)

## EQUATION 10-3: DUTY CYCLE RATIO

Duty Cycle Ratio = 
$$\frac{(CCPR1L:CCP1CON < 5:4>)}{4(PR2 + 1)}$$

The CCPR1H register and a 2-bit internal latch are used to double buffer the PWM duty cycle. This double buffering is essential for glitchless PWM operation.

The 8-bit timer TMR2 register is concatenated with either the 2-bit internal system clock (Fosc), or 2 bits of the prescaler, to create the 10-bit time base. The system clock is used if the Timer2 prescaler is set to 1:1.

When the 10-bit time base matches the CCPR1H and 2-bit latch, then the CCP1 pin is cleared (see Figure 10-3).

#### 10.3.3 PWM RESOLUTION

The resolution determines the number of available duty cycles for a given period. For example, a 10-bit resolution will result in 1024 discrete duty cycles, whereas an 8-bit resolution will result in 256 discrete duty cycles.

The maximum PWM resolution is 10 bits when PR2 is 255. The resolution is a function of the PR2 register value as shown by Equation 10-4.

#### EQUATION 10-4: PWM RESOLUTION

Resolution = 
$$\frac{\log[4(PR2 + 1)]}{\log(2)}$$
 bits

Note: If the pulse width value is greater than the period the assigned PWM pin(s) will remain unchanged.

#### TABLE 10-4: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (Fosc = 20 MHz)

| PWM Frequency             | 1.22 kHz | 4.88 kHz | 19.53 kHz | 78.12 kHz | 156.3 kHz | 208.3 kHz |
|---------------------------|----------|----------|-----------|-----------|-----------|-----------|
| Timer Prescale (1, 4, 16) | 16       | 4        | 1         | 1         | 1         | 1         |
| PR2 Value                 | 0xFF     | 0xFF     | 0xFF      | 0x3F      | 0x1F      | 0x17      |
| Maximum Resolution (bits) | 10       | 10       | 10        | 8         | 7         | 6.6       |

#### TABLE 10-5: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (Fosc = 8 MHz)

| PWM Frequency             | 1.22 kHz | 4.90 kHz | 19.61 kHz | 76.92 kHz | 153.85 kHz | 200.0 kHz |
|---------------------------|----------|----------|-----------|-----------|------------|-----------|
| Timer Prescale (1, 4, 16) | 16       | 4        | 1         | 1         | 1          | 1         |
| PR2 Value                 | 0x65     | 0x65     | 0x65      | 0x19      | 0x0C       | 0x09      |
| Maximum Resolution (bits) | 8        | 8        | 8         | 6         | 5          | 5         |

#### 10.4.4 ENHANCED PWM AUTO-SHUTDOWN MODE

The PWM mode supports an Auto-Shutdown mode that will disable the PWM outputs when an external shutdown event occurs. Auto-Shutdown mode places the PWM output pins into a predetermined state. This mode is used to help prevent the PWM from damaging the application.

The auto-shutdown sources are selected using the ECCPASx bits of the ECCPAS register. A shutdown event may be generated by:

- A logic '0' on the INT pin
- Comparator C1
- Comparator C2
- · Setting the ECCPASE bit in firmware

A shutdown condition is indicated by the ECCPASE (Auto-Shutdown Event Status) bit of the ECCPAS register. If the bit is a '0', the PWM pins are operating normally. If the bit is a '1', the PWM outputs are in the shutdown state.

When a shutdown event occurs, two things happen:

The ECCPASE bit is set to '1'. The ECCPASE will remain set until cleared in firmware or an auto-restart occurs (see Section 10.4.5 "Auto-Restart Mode").

The enabled PWM pins are asynchronously placed in their shutdown states. The PWM output pins are grouped into pairs [P1A/P1C] and [P1B/P1D]. The state of each pin pair is determined by the PSSAC and PSSBD bits of the ECCPAS register. Each pin pair may be placed into one of three states:

- Drive logic '1'
- Drive logic '0'
- Tri-state (high-impedance)

#### REGISTER 10-2: ECCPAS: ENHANCED CAPTURE/COMPARE/PWM AUTO-SHUTDOWN CONTROL REGISTER

| R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0  | R/W-0  | R/W-0  | R/W-0  |
|---------|---------|---------|---------|--------|--------|--------|--------|
| ECCPASE | ECCPAS2 | ECCPAS1 | ECCPAS0 | PSSAC1 | PSSAC0 | PSSBD1 | PSSBD0 |
| bit 7   |         |         |         |        |        |        | bit 0  |
|         |         |         |         |        |        |        |        |

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

| bit 7   | ECCPASE: ECCP Auto-Shutdown Event Status bit                                                                                                                                                                                       |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | <ul><li>1 = A shutdown event has occurred; ECCP outputs are in shutdown state</li><li>0 = ECCP outputs are operating</li></ul>                                                                                                     |
| bit 6-4 | ECCPAS<2:0>: ECCP Auto-shutdown Source Select bits                                                                                                                                                                                 |
|         | <ul> <li>000 = Auto-Shutdown is disabled</li> <li>001 = Comparator C1 output high</li> <li>010 = Comparator C2 output high<sup>(1)</sup></li> <li>011 = Either Comparators output is high</li> <li>100 = VIL on INT pin</li> </ul> |
|         | <ul> <li>101 = VIL on INT pin or Comparator C1 output high</li> <li>110 = VIL on INT pin or Comparator C2 output high</li> <li>111 = VIL on INT pin or either Comparators output is high</li> </ul>                                |
| bit 3-2 | <b>PSSACn:</b> Pins P1A and P1C Shutdown State Control bits<br>00 = Drive pins P1A and P1C to '0'<br>01 = Drive pins P1A and P1C to '1'<br>1x = Pins P1A and P1C tri-state                                                         |
| bit 1-0 | <b>PSSBDn:</b> Pins P1B and P1D Shutdown State Control bits<br>00 = Drive pins P1B and P1D to '0'<br>01 = Drive pins P1B and P1D to '1'<br>1x = Pins P1B and P1D tri-state                                                         |
|         |                                                                                                                                                                                                                                    |

# 12.0 SPECIAL FEATURES OF THE CPU

The PIC16F610/616/16HV610/616 has a host of features intended to maximize system reliability, minimize cost through elimination of external components, provide power-saving features and offer code protection.

These features are:

- Reset
  - Power-on Reset (POR)
  - Power-up Timer (PWRT)
  - Oscillator Start-up Timer (OST)
  - Brown-out Reset (BOR)
- Interrupts
- Watchdog Timer (WDT)
- Oscillator selection
- Sleep
- Code protection
- ID Locations
- In-Circuit Serial Programming<sup>™</sup>

The PIC16F610/616/16HV610/616 has two timers that offer necessary delays on power-up. One is the Oscillator Start-up Timer (OST), intended to keep the chip in Reset until the crystal oscillator is stable. The other is the Power-up Timer (PWRT), which provides a fixed delay of 64 ms (nominal) on power-up only, designed to keep the part in Reset while the power supply stabilizes. There is also circuitry to reset the device if a brown-out occurs, which can use the Powerup Timer to provide at least a 64 ms Reset. With these three functions-on-chip, most applications need no external Reset circuitry.

The Sleep mode is designed to offer a very low-current Power-Down mode. The user can wake-up from Sleep through:

- External Reset
- Watchdog Timer Wake-up
- An interrupt

Several oscillator options are also made available to allow the part to fit the application. The INTOSC option saves system cost while the LP crystal option saves power. A set of Configuration bits are used to select various options (see Register 12-1).

## 12.1 Configuration Bits

The Configuration bits can be programmed (read as '0'), or left unprogrammed (read as '1') to select various device configurations as shown in Register 12-1. These bits are mapped in program memory location 2007h.

**Note:** Address 2007h is beyond the user program memory space. It belongs to the special configuration memory space (2000h-3FFFh), which can be accessed only during programming. See the *Memory Programming Specification* (DS41284) for more information.

### 15.10 Thermal Considerations

| Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ |           |                                        |       |       |                                                          |  |  |
|----------------------------------------------------------------------------------------------------------------------|-----------|----------------------------------------|-------|-------|----------------------------------------------------------|--|--|
| Param<br>No.                                                                                                         | Sym       | Characteristic                         | Тур   | Units | Conditions                                               |  |  |
| TH01                                                                                                                 | θJA       | Thermal Resistance                     | 70*   | C/W   | 14-pin PDIP package                                      |  |  |
|                                                                                                                      |           | Junction to Ambient                    | 85.0* | C/W   | 14-pin SOIC package                                      |  |  |
|                                                                                                                      |           |                                        | 100*  | C/W   | 14-pin TSSOP package                                     |  |  |
|                                                                                                                      |           |                                        | 37*   | C/W   | 16-pin QFN 4x4mm package                                 |  |  |
| TH02                                                                                                                 | θJC       | Thermal Resistance<br>Junction to Case | 32.5* | C/W   | 14-pin PDIP package                                      |  |  |
|                                                                                                                      |           |                                        | 31.0* | C/W   | 14-pin SOIC package                                      |  |  |
|                                                                                                                      |           |                                        | 31.7* | C/W   | 14-pin TSSOP package                                     |  |  |
|                                                                                                                      |           |                                        | 2.6*  | C/W   | 16-pin QFN 4x4mm package                                 |  |  |
| TH03                                                                                                                 | TDIE      | Die Temperature                        | 150*  | С     |                                                          |  |  |
| TH04                                                                                                                 | PD        | Power Dissipation                      | —     | W     | PD = PINTERNAL + PI/O                                    |  |  |
| TH05                                                                                                                 | PINTERNAL | Internal Power Dissipation             | —     | W     | PINTERNAL = IDD x VDD<br>(NOTE 1)                        |  |  |
| TH06                                                                                                                 | Pi/o      | I/O Power Dissipation                  | —     | W     | $PI/O = \Sigma (IOL * VOL) + \Sigma (IOH * (VDD - VOH))$ |  |  |
| TH07                                                                                                                 | Pder      | Derated Power                          | _     | W     | Pder = PDmax (Tdie - Ta)/θja<br>(NOTE 2)                 |  |  |
| * These parameters are characterized but not tested                                                                  |           |                                        |       |       |                                                          |  |  |

These parameters are characterized but not tested.

Note 1: IDD is current to run the chip alone without driving any load on the output pins.

**2:** TA = Ambient Temperature.









### FIGURE 16-26: PIC16HV610/616 IDD EXTRC (4 MHz) vs. VDD











FIGURE 16-45: TYPICAL HFINTOSC FREQUENCY CHANGE vs. VDD (25°C)







FIGURE 16-48: TYPICAL HFINTOSC FREQUENCY CHANGE vs. Vdd (-40°C)







