



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, PWM, WDT                                    |
| Number of I/O              | 11                                                                       |
| Program Memory Size        | 3.5КВ (2К х 14)                                                          |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 128 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                |
| Data Converters            | A/D 8x10b                                                                |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 150°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/pic16f616-h-sl |

Email: info@E-XFL.COM

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

# 2.0 MEMORY ORGANIZATION

# 2.1 Program Memory Organization

The PIC16F610/616/16HV610/616 has a 13-bit program counter capable of addressing an 8K x 14 program memory space. Only the first 1K x 14 (0000h-3FF) for the PIC16F610/16HV610 and the first 2K x 14 (0000h-07FFh) for the PIC16F616/16HV616 is physically implemented. Accessing a location above these boundaries will cause a wraparound within the first 1K x 14 space (PIC16F610/16HV610) and 2K x 14 space (PIC16F616/16HV616). The Reset vector is at 0000h and the interrupt vector is at 0004h (see Figure 2-1).

#### FIGURE 2-1: PROGRAM MEMORY MAP AND STACK FOR THE PIC16F610/16HV610



### FIGURE 2-2:

#### PROGRAM MEMORY MAP AND STACK FOR THE PIC16F616/16HV616



#### 2.2.2.5 PIR1 Register

The PIR1 register contains the peripheral interrupt flag bits, as shown in Register 2-5.

Note: Interrupt flag bits are set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the global enable bit, GIE of the INTCON register. User software should ensure the appropriate interrupt flag bits are clear prior to enabling an interrupt.

### REGISTER 2-5: PIR1: PERIPHERAL INTERRUPT REQUEST REGISTER 1

| U-0   | R/W-0               | R/W-0                 | R/W-0 | R/W-0 | U-0 | R/W-0                 | R/W-0  |
|-------|---------------------|-----------------------|-------|-------|-----|-----------------------|--------|
| —     | ADIF <sup>(1)</sup> | CCP1IF <sup>(1)</sup> | C2IF  | C1IF  | —   | TMR2IF <sup>(1)</sup> | TMR1IF |
| bit 7 |                     |                       |       |       |     |                       | bit 0  |
|       |                     |                       |       |       |     |                       |        |

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

| bit 7   | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                           |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6   | ADIF: A/D Interrupt Flag bit <sup>(1)</sup>                                                                                                                                                                                                                                                                                          |
|         | 1 = A/D conversion complete                                                                                                                                                                                                                                                                                                          |
|         | 0 = A/D conversion has not completed or has not been started                                                                                                                                                                                                                                                                         |
| bit 5   | CCP1IF: CCP1 Interrupt Flag bit <sup>(1)</sup>                                                                                                                                                                                                                                                                                       |
|         | <u>Capture mod</u> e:<br>1 = A TMR1 register capture occurred (must be cleared in software)<br>0 = No TMR1 register capture occurred<br><u>Compare mode</u> :<br>1 = A TMR1 register compare match occurred (must be cleared in software)<br>0 = No TMR1 register compare match occurred<br><u>PWM mode</u> :<br>Unused in this mode |
| bit 4   | <b>C2IF:</b> Comparator C2 Interrupt Flag bit                                                                                                                                                                                                                                                                                        |
|         | <ul> <li>1 = Comparator C2 output has changed (must be cleared in software)</li> <li>0 = Comparator C2 output has not changed</li> </ul>                                                                                                                                                                                             |
| bit 3   | C1IF: Comparator C1 Interrupt Flag bit                                                                                                                                                                                                                                                                                               |
|         | <ul><li>1 = Comparator C1 output has changed (must be cleared in software)</li><li>0 = Comparator C1 output has not changed</li></ul>                                                                                                                                                                                                |
| bit 2   | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                           |
| bit 1   | TMR2IF: Timer2 to PR2 Match Interrupt Flag bit <sup>(1)</sup>                                                                                                                                                                                                                                                                        |
|         | <ul><li>1 = Timer2 to PR2 match occurred (must be cleared in software)</li><li>0 = Timer2 to PR2 match has not occurred</li></ul>                                                                                                                                                                                                    |
| bit 0   | <b>TMR1IF:</b> Timer1 Overflow Interrupt Flag bit<br>1 = Timer1 register overflowed (must be cleared in software)<br>0 = Timer1 has not overflowed                                                                                                                                                                                   |
| Note 1: | PIC16F616/16HV616 only. PIC16F610/16HV610 unimplemented, read as '0'.                                                                                                                                                                                                                                                                |

### 3.3.3 LP, XT, HS MODES

The LP, XT and HS modes support the use of quartz crystal resonators or ceramic resonators connected to OSC1 and OSC2 (Figure 3-3). The mode selects a low, medium or high gain setting of the internal inverter-amplifier to support various resonator types and speed.

**LP** Oscillator mode selects the lowest gain setting of the internal inverter-amplifier. LP mode current consumption is the least of the three modes. This mode is designed to drive only 32.768 kHz tuning-fork type crystals (watch crystals).

**XT** Oscillator mode selects the intermediate gain setting of the internal inverter-amplifier. XT mode current consumption is the medium of the three modes. This mode is best suited to drive resonators with a medium drive level specification.

**HS** Oscillator mode selects the highest gain setting of the internal inverter-amplifier. HS mode current consumption is the highest of the three modes. This mode is best suited for resonators that require a high drive setting.

Figure 3-3 and Figure 3-4 show typical circuits for quartz crystal and ceramic resonators, respectively.

#### FIGURE 3-3: QUARTZ CRYSTAL OPERATION (LP, XT OR HS MODE)



- Note 1: Quartz crystal characteristics vary according to type, package and manufacturer. The user should consult the manufacturer data sheets for specifications and recommended application.
  - **2:** Always verify oscillator performance over the VDD and temperature range that is expected for the application.
  - **3:** For oscillator design assistance, reference the following Microchip Applications Notes:
    - AN826, "Crystal Oscillator Basics and Crystal Selection for rfPIC<sup>®</sup> and PIC<sup>®</sup> Devices" (DS00826)
    - AN849, "Basic PIC<sup>®</sup> Oscillator Design" (DS00849)
    - AN943, "Practical PIC<sup>®</sup> Oscillator Analysis and Design" (DS00943)
    - AN949, "Making Your Oscillator Work" (DS00949)



#### CERAMIC RESONATOR OPERATION (XT OR HS MODE)



- **2:** The value of RF varies with the Oscillator mode selected (typically between 2 MΩ to 10 MΩ).
- **3:** An additional parallel feedback resistor (RP) may be required for proper ceramic resonator operation.

### 4.2.4.6 RA5/T1CKI/OSC1/CLKIN

Figure 4-5 shows the diagram for this pin. The RA5 pin is configurable to function as one of the following:

- a general purpose I/O
- a Timer1 clock input
- a crystal/resonator connection
- a clock input



| R/W-1           | R/W-1                                                | R/W-1                                    | R/W-1           | R/W-1            | R/W-1           | R/W-1          | R/W-1 |  |  |  |  |
|-----------------|------------------------------------------------------|------------------------------------------|-----------------|------------------|-----------------|----------------|-------|--|--|--|--|
| RAPU            | INTEDG                                               | TOCS                                     | TOSE            | PSA              | PS2             | PS1            | PS0   |  |  |  |  |
| bit 7           |                                                      |                                          |                 |                  |                 |                | bit 0 |  |  |  |  |
|                 |                                                      |                                          |                 |                  |                 |                |       |  |  |  |  |
| Legend:         |                                                      |                                          |                 |                  |                 |                |       |  |  |  |  |
| R = Readable    | bit                                                  | W = Writable                             | e bit           | U = Unimpler     | mented bit, rea | d as '0'       |       |  |  |  |  |
| -n = Value at F | POR                                                  | '1' = Bit is se                          | t               | '0' = Bit is cle | ared            | x = Bit is unk | nown  |  |  |  |  |
|                 |                                                      |                                          |                 |                  |                 |                |       |  |  |  |  |
| bit 7           | RAPU: PORT                                           | TA Pull-up Ena                           | able bit        |                  |                 |                |       |  |  |  |  |
|                 | 1 = PORTA p                                          | ull-ups are dis                          | abled           |                  |                 |                |       |  |  |  |  |
|                 | 0 = PORTA p                                          | ull-ups are en                           | abled by indivi | idual PORT late  | ch values       |                |       |  |  |  |  |
| bit 6           | INTEDG: Inte                                         | errupt Edge Se                           | elect bit       |                  |                 |                |       |  |  |  |  |
|                 | 1 = Interrupt                                        | = Interrupt on rising edge of INT pin    |                 |                  |                 |                |       |  |  |  |  |
|                 | 0 = Interrupt                                        | 0 = Interrupt on falling edge of INT pin |                 |                  |                 |                |       |  |  |  |  |
| bit 5           | TOCS: TMR0                                           | Clock Source                             | Select bit      |                  |                 |                |       |  |  |  |  |
|                 | 1 = Transitior                                       | L = Transition on T0CKI pin              |                 |                  |                 |                |       |  |  |  |  |
|                 | 0 = Internal instruction cycle clock (Fosc/4)        |                                          |                 |                  |                 |                |       |  |  |  |  |
| bit 4           | TOSE: TMR0                                           | 0 Source Edge Select bit                 |                 |                  |                 |                |       |  |  |  |  |
|                 | 1 = Increment on high-to-low transition on T0CKI pin |                                          |                 |                  |                 |                |       |  |  |  |  |
|                 | 0 = Increment on low-to-high transition on TOCKI pin |                                          |                 |                  |                 |                |       |  |  |  |  |
| bit 3           | PSA: Presca                                          | ler Assignmen                            | t bit           |                  |                 |                |       |  |  |  |  |
|                 | 1 = Prescaler is assigned to the WDT                 |                                          |                 |                  |                 |                |       |  |  |  |  |
|                 | 0 = Prescaler is assigned to the Timer0 module       |                                          |                 |                  |                 |                |       |  |  |  |  |
| bit 2-0         | <b>PS&lt;2:0&gt;:</b> Pr€                            | escaler Rate S                           | elect bits      |                  |                 |                |       |  |  |  |  |
|                 | BIT                                                  | VALUE TMR0 F                             | RATE WDT RA     | TE               |                 |                |       |  |  |  |  |
|                 | C                                                    | 000 1:2                                  | : 1:1           |                  |                 |                |       |  |  |  |  |
|                 | C                                                    | 001 1:4                                  | 1:2             |                  |                 |                |       |  |  |  |  |
|                 | C                                                    | 010 1:8                                  | 1:4             |                  |                 |                |       |  |  |  |  |
|                 | 0                                                    |                                          |                 |                  |                 |                |       |  |  |  |  |
|                 | 1                                                    | 01 1:3                                   | 4 1.32          |                  |                 |                |       |  |  |  |  |
|                 | 1                                                    | 10 1:1                                   | 28 1:64         |                  |                 |                |       |  |  |  |  |
|                 | 1                                                    | 11 1 : 2                                 | 1 : 128         | 3                |                 |                |       |  |  |  |  |

#### **REGISTER 5-1: OPTION\_REG: OPTION REGISTER**

| TABLE 5-1: SUMMART OF REGISTERS ASSOCIATED WITH TIMER | TABLE 5-1: | SUMMARY OF REGISTERS | <b>5 ASSOCIATED WITH TIMER</b> |
|-------------------------------------------------------|------------|----------------------|--------------------------------|
|-------------------------------------------------------|------------|----------------------|--------------------------------|

| Name       | Bit 7    | Bit 6      | Bit 5   | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Valu<br>POR, | e on<br>BOR | Valu<br>all o<br>Res | e on<br>ther<br>sets |
|------------|----------|------------|---------|--------|--------|--------|--------|--------|--------------|-------------|----------------------|----------------------|
| TMR0       | Timer0 N | /lodules R | egister |        |        |        |        |        | xxxx         | xxxx        | uuuu                 | uuuu                 |
| INTCON     | GIE      | PEIE       | TOIE    | INTE   | RAIE   | T0IF   | INTF   | RAIF   | 0000         | 0000        | 0000                 | 0000                 |
| OPTION_REG | RAPU     | INTEDG     | TOCS    | T0SE   | PSA    | PS2    | PS1    | PS0    | 1111         | 1111        | 1111                 | 1111                 |
| TRISA      | _        | —          | TRISA5  | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 11           | 1111        | 11                   | 1111                 |

**Legend:** -= Unimplemented locations, read as '0', u = unchanged, x = unknown. Shaded cells are not used by the Timer0 module.

### 6.2.1 INTERNAL CLOCK SOURCE

When the internal clock source is selected the TMR1H:TMR1L register pair will increment on multiples of TCY as determined by the Timer1 prescaler.

#### 6.2.2 EXTERNAL CLOCK SOURCE

When the external clock source is selected, the Timer1 module may work as a timer or a counter.

When counting, Timer1 is incremented on the rising edge of the external clock input T1CKI. In addition, the Counter mode clock can be synchronized to the microcontroller system clock or run asynchronously.

If an external clock oscillator is needed (and the microcontroller is using the INTOSC without CLKOUT), Timer1 can use the LP oscillator as a clock source.

| Note: | In Counter mode, a falling edge must be      |
|-------|----------------------------------------------|
|       | registered by the counter prior to the first |
|       | incrementing rising edge.                    |

### 6.3 Timer1 Prescaler

Timer1 has four prescaler options allowing 1, 2, 4 or 8 divisions of the clock input. The T1CKPS bits of the T1CON register control the prescale counter. The prescale counter is not directly readable or writable; however, the prescaler counter is cleared upon a write to TMR1H or TMR1L.

#### 6.4 Timer1 Oscillator

A low-power 32.768 kHz crystal oscillator is built-in between pins OSC1 (input) and OSC2 (output). The oscillator is enabled by setting the T1OSCEN control bit of the T1CON register. The oscillator will continue to run during Sleep.

The Timer1 oscillator is shared with the system LP oscillator. Thus, Timer1 can use this mode only when the primary system clock is derived from the internal oscillator or when the oscillator is in the LP Oscillator mode. The user must provide a software time delay to ensure proper oscillator start-up.

TRISA5 and TRISA4 bits are set when the Timer1 oscillator is enabled. RA5 and RA4 bits read as '0' and TRISA5 and TRISA4 bits read as '1'.

Note: The oscillator requires a start-up and stabilization time before use. Thus, T1OSCEN should be set and a suitable delay observed prior to enabling Timer1.

#### 6.5 Timer1 Operation in Asynchronous Counter Mode

If control bit T1SYNC of the T1CON register is set, the external clock input is not synchronized. The timer continues to increment asynchronous to the internal phase clocks. The timer will continue to run during Sleep and can generate an interrupt on overflow, which will wake-up the processor. However, special precautions in software are needed to read/write the timer (see Section 6.5.1 "Reading and Writing Timer1 in Asynchronous Counter Mode").

- Note: When switching from synchronous to asynchronous operation, it is possible to skip an increment. When switching from asynchronous to synchronous operation, it is possible to produce an additional increment.
- Note: In asynchronous counter mode or when using the internal oscillator and T1ACS=1, Timer1 can not be used as a time base for the capture or compare modes of the ECCP module (for PIC16F616/HV616 only).

#### 6.5.1 READING AND WRITING TIMER1 IN ASYNCHRONOUS COUNTER MODE

Reading TMR1H or TMR1L while the timer is running from an external asynchronous clock will ensure a valid read (taken care of in hardware). However, the user should keep in mind that reading the 16-bit timer in two 8-bit values itself, poses certain problems, since the timer may overflow between the reads.

For writes, it is recommended that the user simply stop the timer and write the desired values. A write contention may occur by writing to the timer registers, while the register is incrementing. This may produce an unpredictable value in the TMR1H:TMR1L register pair.

### 6.6 Timer1 Gate

Timer1 gate source is software configurable to be the T1G pin or the output of Comparator C2. This allows the device to directly time external events using T1G or analog events using Comparator C2. See the CM2CON1 register (Register 8-3) for selecting the Timer1 gate source. This feature can simplify the software for a Delta-Sigma A/D converter and many

| R/W-0              | R/W-0                                                                                                                                              | R/W-0                                                               | R/W-0                                           | R/S-0                   | R/S-0              | U-0                | R/W-0           |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------|-------------------------|--------------------|--------------------|-----------------|
| SR1 <sup>(2)</sup> | SR0 <sup>(2)</sup>                                                                                                                                 | C1SEN                                                               | C2REN                                           | PULSS                   | PULSR              |                    | SRCLKEN         |
| bit 7              |                                                                                                                                                    |                                                                     |                                                 |                         |                    |                    | bit 0           |
|                    |                                                                                                                                                    |                                                                     |                                                 |                         |                    |                    |                 |
| Legend:            |                                                                                                                                                    |                                                                     |                                                 | S = Bit is set o        | nly -              |                    |                 |
| R = Readable       | bit                                                                                                                                                | W = Writable b                                                      | it                                              | U = Unimpleme           | ented bit, read as | s 'O'              |                 |
| -n = Value at P    | OR                                                                                                                                                 | '1' = Bit is set                                                    |                                                 | '0' = Bit is clea       | red                | x = Bit is unkno   | wn              |
| bit 7              | <b>SR1:</b> SR Latch<br>1 = C2OUT<br>0 = C2OUT                                                                                                     | Configuration bip pin is the latch $\overline{C}$ pin is the C2 cor | t <mark>(2)</mark><br>output<br>nparator output |                         |                    |                    |                 |
| bit 6              | bit 6 <b>SR0:</b> SR Latch Configuration bits <sup>(2)</sup><br>1 = C10UT  pin is the latch Q output<br>0 = C10UT  pin is the C1 Comparator output |                                                                     |                                                 |                         |                    |                    |                 |
| bit 5              | bit 5 <b>C1SEN:</b> C1 Set Enable bit<br>1 = C1 comparator output sets SR latch<br>0 = C1 comparator output has no effect on SR latch              |                                                                     |                                                 |                         |                    |                    |                 |
| bit 4              | <pre>it 4 C2REN: C2 Reset Enable bit 1 = C2 comparator output resets SR latch 0 = C2 comparator output has no effect on SR latch</pre>             |                                                                     |                                                 |                         |                    |                    |                 |
| bit 3              | PULSS: Pulse<br>1 = Triggers p<br>0 = Does not t                                                                                                   | the SET Input of<br>ulse generator to<br>trigger pulse gen          | the SR Latch bi<br>set SR latch. B<br>erator    | t<br>it is immediately  | reset by hardwa    | re.                |                 |
| bit 2              | PULSR: Pulse<br>1 = Triggers p<br>0 = Does not t                                                                                                   | the Reset Input<br>ulse generator to<br>trigger pulse gen           | of the SR Latch<br>o reset SR latch.<br>erator  | bit<br>Bit is immediate | ly reset by hardw  | vare.              |                 |
| bit 1              | Unimplemente                                                                                                                                       | ed: Read as '0'                                                     |                                                 |                         |                    |                    |                 |
| bit 0              | SRCLKEN: SR                                                                                                                                        | Latch Set Clock                                                     | c Enable bit                                    |                         |                    |                    |                 |
|                    | 1 = Set input of                                                                                                                                   | of SR latch is pu                                                   | sed with SRCLK                                  | (                       |                    |                    |                 |
|                    | 0 = Set input of                                                                                                                                   | of SR latch is not                                                  | t pulsed with the                               | SRCLK                   |                    |                    |                 |
| Note 1: Th         | e C1OUT and C20                                                                                                                                    | OUT bits in the C                                                   | MxCON0 registe                                  | er will always refle    | ect the actual com | nparator output (n | ot the level on |

#### REGISTER 8-4: SRCON0: SR LATCH CONTROL 0 REGISTER

the pin), regardless of the SR latch operation.2: To enable an SR Latch output to the pin, the appropriate CxOE, and TRIS bits must be properly configured.

## REGISTER 8-5: SRCON1: SR LATCH CONTROL 1 REGISTER

| R/W-0       | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 |  |
|-------------|-------|-----|-----|-----|-----|-----|-----|--|
| SRCS1       | SRCS0 | —   | —   | —   | —   | —   | _   |  |
| bit 7 bit 0 |       |     |     |     |     |     |     |  |

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

| bit 7-6 | SRCS<1:0>: SR Latch Clock Prescale bits |
|---------|-----------------------------------------|
|         | 00 = Fosc/16                            |
|         | 01 = Fosc/32                            |
|         | 10 = Fosc/64                            |

11 = Fosc/128

bit 5-0 Unimplemented: Read as '0'

#### 8.11.5 FIXED VOLTAGE REFERENCE

The fixed voltage reference is independent of VDD, with a nominal output voltage of 0.6V. This reference can be enabled by setting the FVREN bit of the VRCON register to '1'. This reference is always enabled when the HFINTOSC oscillator is active.

#### 8.11.6 FIXED VOLTAGE REFERENCE STABILIZATION PERIOD

When the fixed voltage reference module is enabled, it will require some time for the reference and its amplifier circuits to stabilize. The user program must include a small delay routine to allow the module to settle. See the electrical specifications section for the minimum delay requirement.

#### 8.11.7 VOLTAGE REFERENCE SELECTION

Multiplexers on the output of the voltage reference module enable selection of either the CVREF or fixed voltage reference for use by the comparators.

Setting the C1VREN bit of the VRCON register enables current to flow in the CVREF voltage divider and selects the CVREF voltage for use by C1. Clearing the C1VREN bit selects the fixed voltage for use by C1.

Setting the C2VREN bit of the VRCON register enables current to flow in the CVREF voltage divider and selects the CVREF voltage for use by C2. Clearing the C2VREN bit selects the fixed voltage for use by C2.

When both the C1VREN and C2VREN bits are cleared, current flow in the CVREF voltage divider is disabled minimizing the power drain of the voltage reference peripheral.



### FIGURE 8-9: COMPARATOR VOLTAGE REFERENCE BLOCK DIAGRAM

#### **REGISTER 9-3:** ADRESH: ADC RESULT REGISTER HIGH (ADRESH) ADFM = 0 (READ-ONLY)

| R-x                               | R-x    | R-x    | R-x           | R-x                | R-x    | R-x    | R-x    |
|-----------------------------------|--------|--------|---------------|--------------------|--------|--------|--------|
| ADRES9                            | ADRES8 | ADRES7 | ADRES6        | ADRES5             | ADRES4 | ADRES3 | ADRES2 |
| bit 7                             |        |        |               |                    |        |        | bit 0  |
|                                   |        |        |               |                    |        |        |        |
| Legend:                           |        |        |               |                    |        |        |        |
| R = Readable bit W = Writable bit |        | t      | U = Unimpleme | ented bit, read as | ·'O'   |        |        |

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 7-0 ADRES<9:2>: ADC Result Register bits Upper 8 bits of 10-bit conversion result

#### REGISTER 9-4: ADRESL: ADC RESULT REGISTER LOW (ADRESL) ADFM = 0 (READ-ONLY)

| R-x              | R-x    | U-0              | U-0 | U-0                | U-0                | U-0              | U-0   |
|------------------|--------|------------------|-----|--------------------|--------------------|------------------|-------|
| ADRES1           | ADRES0 | —                | —   | —                  | —                  | —                | —     |
| bit 7            |        |                  |     |                    |                    |                  | bit 0 |
|                  |        |                  |     |                    |                    |                  |       |
| Legend:          |        |                  |     |                    |                    |                  |       |
| R = Readable bi  | it     | W = Writable bi  | it  | U = Unimpleme      | ented bit, read as | s 'O'            |       |
| -n = Value at PC | R      | '1' = Bit is set |     | '0' = Bit is clear | red                | x = Bit is unkno | wn    |

| bit 7-6 | ADRES<1:0>: ADC Result Register bits |
|---------|--------------------------------------|
| bit 5-0 | Reserved: Do not use.                |

#### REGISTER 9-5: ADRESH: ADC RESULT REGISTER HIGH (ADRESH) ADFM = 1 (READ-ONLY)

| U-0   | U-0 | U-0 | U-0 | U-0 | U-0 | R-x    | R-x    |
|-------|-----|-----|-----|-----|-----|--------|--------|
| —     | —   | —   | —   | —   | —   | ADRES9 | ADRES8 |
| bit 7 |     |     |     |     |     |        | bit 0  |

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

bit 7-2 Reserved: Do not use.

bit 1-0 ADRES<9:8>: ADC Result Register bits Upper 2 bits of 10-bit conversion result

### REGISTER 9-6: ADRESL: ADC RESULT REGISTER LOW (ADRESL) ADFM = 1 (READ-ONLY)

| R-x    |
|--------|--------|--------|--------|--------|--------|--------|--------|
| ADRES7 | ADRES6 | ADRES5 | ADRES4 | ADRES3 | ADRES2 | ADRES1 | ADRES0 |
| bit 7  |        |        |        |        |        |        | bit 0  |

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

bit 7-0 ADRES<7:0>: ADC Result Register bits Lower 8 bits of 10-bit conversion result





| BTFSS            | Bit Test f, Skip if Set                                                                                                                                                                                           |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] BTFSS f,b                                                                                                                                                                                        |
| Operands:        | $0 \le f \le 127$<br>$0 \le b < 7$                                                                                                                                                                                |
| Operation:       | skip if (f <b>) = 1</b>                                                                                                                                                                                           |
| Status Affected: | None                                                                                                                                                                                                              |
| Description:     | If bit 'b' in register 'f' is '0', the next<br>instruction is executed.<br>If bit 'b' is '1', then the next<br>instruction is discarded and a NOP<br>is executed instead, making this a<br>two-cycle instruction. |

| CLRWDT           | Clear Watchdog Timer                                                                                                                                     |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] CLRWDT                                                                                                                                           |
| Operands:        | None                                                                                                                                                     |
| Operation:       | $\begin{array}{l} 00h \rightarrow WDT \\ 0 \rightarrow WDT \text{ prescaler,} \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow \overline{PD} \end{array}$ |
| Status Affected: | TO, PD                                                                                                                                                   |
| Description:     | CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT.<br>Status bits TO and PD are set.                           |

| CALL             | Call Subroutine                                                                                                                                                                                                                               |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] CALL k                                                                                                                                                                                                                       |
| Operands:        | $0 \leq k \leq 2047$                                                                                                                                                                                                                          |
| Operation:       | (PC)+ 1→ TOS,<br>k → PC<10:0>,<br>(PCLATH<4:3>) → PC<12:11>                                                                                                                                                                                   |
| Status Affected: | None                                                                                                                                                                                                                                          |
| Description:     | Call Subroutine. First, return<br>address (PC + 1) is pushed onto<br>the stack. The eleven-bit<br>immediate address is loaded into<br>PC bits <10:0>. The upper bits of<br>the PC are loaded from PCLATH.<br>CALL is a two-cycle instruction. |

| COMF             | Complement f                                                                                                                                                   |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] COMF f,d                                                                                                                                      |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                |
| Operation:       | $(\overline{f}) \rightarrow (destination)$                                                                                                                     |
| Status Affected: | Z                                                                                                                                                              |
| Description:     | The contents of register 'f' are<br>complemented. If 'd' is '0', the<br>result is stored in W. If 'd' is '1',<br>the result is stored back in<br>register 'f'. |

Decrement f

[label] DECF f,d

| CLRF             | Clear f                                                               |
|------------------|-----------------------------------------------------------------------|
| Syntax:          | [label]CLRF f                                                         |
| Operands:        | $0 \leq f \leq 127$                                                   |
| Operation:       | $\begin{array}{l} 00h \rightarrow (f) \\ 1 \rightarrow Z \end{array}$ |
| Status Affected: | Z                                                                     |
| Description:     | The contents of register 'f' are<br>cleared and the Z bit is set.     |

|   | Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in  [0,1] \end{array}$                                                                                 |
|---|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
|   | Operation:       | (f) - 1 $\rightarrow$ (destination)                                                                                                               |
|   | Status Affected: | Z                                                                                                                                                 |
| _ | Description:     | Decrement register 'f'. If 'd' is '0',<br>the result is stored in the W<br>register. If 'd' is '1', the result is<br>stored back in register 'f'. |

DECF

Syntax:

| CLRW             | Clear W                                                                                    |  |  |
|------------------|--------------------------------------------------------------------------------------------|--|--|
| Syntax:          | [ label ] CLRW                                                                             |  |  |
| Operands:        | None                                                                                       |  |  |
| Operation:       | $\begin{array}{l} \text{00h} \rightarrow (\text{W}) \\ 1 \rightarrow \text{Z} \end{array}$ |  |  |
| Status Affected: | Z                                                                                          |  |  |
| Description:     | W register is cleared. Zero bit (Z) is set.                                                |  |  |

| RLF              | Rotate Left f through Carry                                                                                                                                                                                          |  |  |  |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:          | [ <i>label</i> ] RLF f,d                                                                                                                                                                                             |  |  |  |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                   |  |  |  |  |
| Operation:       | See description below                                                                                                                                                                                                |  |  |  |  |
| Status Affected: | С                                                                                                                                                                                                                    |  |  |  |  |
| Description:     | The contents of register 'f' are<br>rotated one bit to the left through<br>the Carry flag. If 'd' is '0', the<br>result is placed in the W register.<br>If 'd' is '1', the result is stored<br>back in register 'f'. |  |  |  |  |
| Words:           | 1                                                                                                                                                                                                                    |  |  |  |  |
| Cycles:          | 1                                                                                                                                                                                                                    |  |  |  |  |
| Example:         | RLF REG1,0                                                                                                                                                                                                           |  |  |  |  |
|                  | Before Instruction                                                                                                                                                                                                   |  |  |  |  |
|                  | REG1 = 1110 0110                                                                                                                                                                                                     |  |  |  |  |
|                  | C = 0                                                                                                                                                                                                                |  |  |  |  |
|                  | After Instruction                                                                                                                                                                                                    |  |  |  |  |
|                  | REG1 = 1110 0110                                                                                                                                                                                                     |  |  |  |  |
|                  | $W = 1100 \ 1100$                                                                                                                                                                                                    |  |  |  |  |
|                  | C = 1                                                                                                                                                                                                                |  |  |  |  |

| SI FFP           | Enter Sleen mode                                                                                                                                                                                                                   |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                  |                                                                                                                                                                                                                                    |  |
| Syntax:          | [label] SLEEP                                                                                                                                                                                                                      |  |
| Operands:        | None                                                                                                                                                                                                                               |  |
| Operation:       | $00h \rightarrow WDT$ ,                                                                                                                                                                                                            |  |
|                  | $0 \rightarrow WDT$ prescaler,                                                                                                                                                                                                     |  |
|                  | $1 \rightarrow \overline{\overline{\text{TO}}},$                                                                                                                                                                                   |  |
|                  | $0 \rightarrow PD$                                                                                                                                                                                                                 |  |
| Status Affected: | TO, PD                                                                                                                                                                                                                             |  |
| Description:     | The power-down Status bit, $\overline{PD}$ is<br>cleared. Time-out Status bit, $\overline{TO}$<br>is set. Watchdog Timer and its<br>prescaler are cleared.<br>The processor is put into Sleep<br>mode with the oscillator stopped. |  |

| RRF              | Rotate Right f through Carry                                                                                                                                                                                          |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:          | [label] RRF f,d                                                                                                                                                                                                       |  |  |  |
| Operands:        | $\begin{array}{l} 0\leq f\leq 127\\ d\in [0,1] \end{array}$                                                                                                                                                           |  |  |  |
| Operation:       | See description below                                                                                                                                                                                                 |  |  |  |
| Status Affected: | С                                                                                                                                                                                                                     |  |  |  |
| Description:     | The contents of register 'f' are<br>rotated one bit to the right through<br>the Carry flag. If 'd' is '0', the<br>result is placed in the W register.<br>If 'd' is '1', the result is placed<br>back in register 'f'. |  |  |  |
|                  | C Register f                                                                                                                                                                                                          |  |  |  |

| SUBLW            | Subtract W from literal                                                                                                      |           |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------|-----------|--|
| Syntax:          | [ <i>label</i> ] SUBLW k                                                                                                     |           |  |
| Operands:        | $0 \le k \le 255$                                                                                                            |           |  |
| Operation:       | $k - (W) \rightarrow (W)$                                                                                                    |           |  |
| Status Affected: | C, DC, Z                                                                                                                     |           |  |
| Description:     | The W register is subtracted (2's complement method) from the eight-bit literal 'k'. The result is placed in the W register. |           |  |
|                  | Result                                                                                                                       | Condition |  |
|                  | •                                                                                                                            | \A/       |  |

| <b>C</b> = 0  | W > k           |
|---------------|-----------------|
| <b>C</b> = 1  | $W \leq k$      |
| DC = 0        | W<3:0> > k<3:0> |
| <b>DC</b> = 1 | W<3:0> ≤ k<3:0> |

# 14.7 MPLAB SIM Software Simulator

The MPLAB SIM Software Simulator allows code development in a PC-hosted environment by simulating the PIC MCUs and dsPIC<sup>®</sup> DSCs on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a comprehensive stimulus controller. Registers can be logged to files for further run-time analysis. The trace buffer and logic analyzer display extend the power of the simulator to record and track program execution, actions on I/O, most peripherals and internal registers.

The MPLAB SIM Software Simulator fully supports symbolic debugging using the MPLAB C Compilers, and the MPASM and MPLAB Assemblers. The software simulator offers the flexibility to develop and debug code outside of the hardware laboratory environment, making it an excellent, economical software development tool.

#### 14.8 MPLAB REAL ICE In-Circuit Emulator System

MPLAB REAL ICE In-Circuit Emulator System is Microchip's next generation high-speed emulator for Microchip Flash DSC and MCU devices. It debugs and programs PIC<sup>®</sup> Flash MCUs and dsPIC<sup>®</sup> Flash DSCs with the easy-to-use, powerful graphical user interface of the MPLAB Integrated Development Environment (IDE), included with each kit.

The emulator is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with either a connector compatible with incircuit debugger systems (RJ11) or with the new high-speed, noise tolerant, Low-Voltage Differential Signal (LVDS) interconnection (CAT5).

The emulator is field upgradable through future firmware downloads in MPLAB IDE. In upcoming releases of MPLAB IDE, new devices will be supported, and new features will be added. MPLAB REAL ICE offers significant advantages over competitive emulators including low-cost, full-speed emulation, run-time variable watches, trace analysis, complex breakpoints, a ruggedized probe interface and long (up to three meters) interconnection cables.

#### 14.9 MPLAB ICD 3 In-Circuit Debugger System

MPLAB ICD 3 In-Circuit Debugger System is Microchip's most cost effective high-speed hardware debugger/programmer for Microchip Flash Digital Signal Controller (DSC) and microcontroller (MCU) devices. It debugs and programs PIC<sup>®</sup> Flash microcontrollers and dsPIC<sup>®</sup> DSCs with the powerful, yet easyto-use graphical user interface of MPLAB Integrated Development Environment (IDE).

The MPLAB ICD 3 In-Circuit Debugger probe is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with a connector compatible with the MPLAB ICD 2 or MPLAB REAL ICE systems (RJ-11). MPLAB ICD 3 supports all MPLAB ICD 2 headers.

### 14.10 PICkit 3 In-Circuit Debugger/ Programmer and PICkit 3 Debug Express

The MPLAB PICkit 3 allows debugging and programming of PIC<sup>®</sup> and dsPIC<sup>®</sup> Flash microcontrollers at a most affordable price point using the powerful graphical user interface of the MPLAB Integrated Development Environment (IDE). The MPLAB PICkit 3 is connected to the design engineer's PC using a full speed USB interface and can be connected to the target via an Microchip debug (RJ-11) connector (compatible with MPLAB ICD 3 and MPLAB REAL ICE). The connector uses two device I/O pins and the reset line to implement in-circuit debugging and In-Circuit Serial Programming<sup>™</sup>.

The PICkit 3 Debug Express include the PICkit 3, demo board and microcontroller, hookup cables and CDROM with user's guide, lessons, tutorial, compiler and MPLAB IDE software.

FIGURE 15-1: PIC16F610/616 VOLTAGE-FREQUENCY GRAPH, -40°C  $\leq$  Ta  $\leq$  +125°C



Note 1: The shaded region indicates the permissible combinations of voltage and frequency.





# 16.0 DC AND AC CHARACTERISTICS GRAPHS AND TABLES

**Note:** The graphs and tables provided following this note are a statistical summary based on a limited number of samples and are provided for informational purposes only. The performance characteristics listed herein are not tested or guaranteed. In some graphs or tables, the data presented may be outside the specified operating range (e.g., outside specified power supply range) and therefore, outside the warranted range.

"Typical" represents the mean of the distribution at 25°C. "Maximum" or "minimum" represents (mean +  $3\sigma$ ) or (mean -  $3\sigma$ ) respectively, where s is a standard deviation, over each temperature range.







#### FIGURE 16-2: PIC16F610/616 IDD EC (1 MHz) vs. VDD









#### FIGURE 16-20: PIC16HV610/616 IDD EC (1 MHz) vs. VDD











#### FIGURE 16-41: SCHMITT TRIGGER INPUT THRESHOLD VIN vs. VDD OVER TEMPERATURE





### 16-Lead Plastic Quad Flat, No Lead Package (ML) - 4x4x0.9mm Body [QFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



| Units                      |    | MILLIMETERS |          |      |
|----------------------------|----|-------------|----------|------|
| Dimension Limits           |    | MIN         | NOM      | MAX  |
| Contact Pitch              | Е  |             | 0.65 BSC |      |
| Optional Center Pad Width  | W2 |             |          | 2.50 |
| Optional Center Pad Length | T2 |             |          | 2.50 |
| Contact Pad Spacing        | C1 |             | 4.00     |      |
| Contact Pad Spacing        | C2 |             | 4.00     |      |
| Contact Pad Width (X28)    | X1 |             |          | 0.35 |
| Contact Pad Length (X28)   | Y1 |             |          | 0.80 |
| Distance Between Pads      | G  | 0.30        |          |      |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing No. C04-2127A

# READER RESPONSE

It is our intention to provide you with the best documentation possible to ensure successful use of your Microchip product. If you wish to provide your comments on organization, clarity, subject matter, and ways in which our documentation can better serve you, please FAX your comments to the Technical Publications Manager at (480) 792-4150.

Please list the following information, and use this outline to provide us with your comments about this document.

| To:   | Technical Publications Manager         | Total Pages Sent                                       |
|-------|----------------------------------------|--------------------------------------------------------|
| RE:   | Reader Response                        |                                                        |
| From  | : Name                                 |                                                        |
|       | Company                                |                                                        |
|       | Address                                |                                                        |
|       | City / State / ZIP / Country           |                                                        |
|       | Telephone: ()                          | FAX: ()                                                |
| Appli | cation (optional):                     |                                                        |
| Woul  | ld you like a reply?YN                 |                                                        |
| Devi  | ce: PIC16F610/616/16HV610/616          | Literature Number: DS41288F                            |
| Ques  | stions:                                |                                                        |
| 1 V   | What are the best features of this do  | cument?                                                |
|       |                                        |                                                        |
| _     |                                        |                                                        |
|       | low does this document meet your h     | nardware and software development needs?               |
|       |                                        |                                                        |
| _     |                                        |                                                        |
| 3. E  | Do you find the organization of this d | ocument easy to follow? If not, why?                   |
| _     |                                        |                                                        |
| _     |                                        |                                                        |
| 4. V  | What additions to the document do y    | ou think would enhance the structure and subject?      |
| _     |                                        |                                                        |
| _     |                                        |                                                        |
| 5. V  | What deletions from the document co    | ould be made without affecting the overall usefulness? |
| _     |                                        |                                                        |
| _     |                                        |                                                        |
| 6. l: | s there any incorrect or misleading in | nformation (what and where)?                           |
| -     |                                        |                                                        |
|       |                                        |                                                        |
| 7. H  | low would you improve this docume      | ent?                                                   |
| _     |                                        |                                                        |
|       |                                        |                                                        |