



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 - Microcontrollers</u>"

| Details                    |                                                                            |
|----------------------------|----------------------------------------------------------------------------|
| Product Status             | Active                                                                     |
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 4MHz                                                                       |
| Connectivity               | -                                                                          |
| Peripherals                | Brown-out Detect/Reset, POR, WDT                                           |
| Number of I/O              | 13                                                                         |
| Program Memory Size        | 896B (512 x 14)                                                            |
| Program Memory Type        | OTP                                                                        |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 80 x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 6V                                                                    |
| Data Converters            | -                                                                          |
| Oscillator Type            | External                                                                   |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 18-SOIC (0.295", 7.50mm Width)                                             |
| Supplier Device Package    | 18-SOIC                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c620t-04-so |

## **PIC16C62X**

## **Device Differences**

| Device                     | Voltage Range | Oscillator | Process Technology<br>(Microns) |
|----------------------------|---------------|------------|---------------------------------|
| PIC16C620 <sup>(3)</sup>   | 2.5 - 6.0     | See Note 1 | 0.9                             |
| PIC16C621 <sup>(3)</sup>   | 2.5 - 6.0     | See Note 1 | 0.9                             |
| PIC16C622 <sup>(3)</sup>   | 2.5 - 6.0     | See Note 1 | 0.9                             |
| PIC16C620A <sup>(4)</sup>  | 2.7 - 5.5     | See Note 1 | 0.7                             |
| PIC16CR620A <sup>(2)</sup> | 2.5 - 5.5     | See Note 1 | 0.7                             |
| PIC16C621A <sup>(4)</sup>  | 2.7 - 5.5     | See Note 1 | 0.7                             |
| PIC16C622A <sup>(4)</sup>  | 2.7 - 5.5     | See Note 1 | 0.7                             |

Note 1: If you change from this device to another device, please verify oscillator characteristics in your application.

- 2: For ROM parts, operation from 2.5V 3.0V will require the PIC16LCR62X parts.
- **3:** For OTP parts, operation from 2.5V 3.0V will require the PIC16LC62X parts.
- **4:** For OTP parts, operations from 2.7V 3.0V will require the PIC16LC62XA parts.

TABLE 3-1: PIC16C62X PINOUT DESCRIPTION

| Name         | DIP/SOIC<br>Pin # | SSOP<br>Pin# | I/O/P Type | Buffer<br>Type        | Description                                                                                                                                                                                              |
|--------------|-------------------|--------------|------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSC1/CLKIN   | 16                | 18           | I          | ST/CMOS               | Oscillator crystal input/external clock source input.                                                                                                                                                    |
| OSC2/CLKOUT  | 15                | 17           | 0          | _                     | Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. In RC mode, OSC2 pin outputs CLKOUT, which has 1/4 the frequency of OSC1 and denotes the instruction cycle rate. |
| MCLR/VPP     | 4                 | 4            | I/P        | ST                    | Master Clear (Reset) input/programming voltage input. This pin is an Active Low Reset to the device.                                                                                                     |
|              |                   |              |            |                       | PORTA is a bi-directional I/O port.                                                                                                                                                                      |
| RA0/AN0      | 17                | 19           | I/O        | ST                    | Analog comparator input                                                                                                                                                                                  |
| RA1/AN1      | 18                | 20           | I/O        | ST                    | Analog comparator input                                                                                                                                                                                  |
| RA2/AN2/VREF | 1                 | 1            | I/O        | ST                    | Analog comparator input or VREF output                                                                                                                                                                   |
| RA3/AN3      | 2                 | 2            | I/O        | ST                    | Analog comparator input /output                                                                                                                                                                          |
| RA4/T0CKI    | 3                 | 3            | I/O        | ST                    | Can be selected to be the clock input to the Timer0 timer/counter or a comparator output. Output is open drain type.                                                                                     |
|              |                   |              |            |                       | PORTB is a bi-directional I/O port. PORTB can be software programmed for internal weak pull-up on all inputs.                                                                                            |
| RB0/INT      | 6                 | 7            | I/O        | TTL/ST <sup>(1)</sup> | RB0/INT can also be selected as an external interrupt pin.                                                                                                                                               |
| RB1          | 7                 | 8            | I/O        | TTL                   |                                                                                                                                                                                                          |
| RB2          | 8                 | 9            | I/O        | TTL                   |                                                                                                                                                                                                          |
| RB3          | 9                 | 10           | I/O        | TTL                   |                                                                                                                                                                                                          |
| RB4          | 10                | 11           | I/O        | TTL                   | Interrupt-on-change pin.                                                                                                                                                                                 |
| RB5          | 11                | 12           | I/O        | TTL                   | Interrupt-on-change pin.                                                                                                                                                                                 |
| RB6          | 12                | 13           | I/O        | TTL/ST <sup>(2)</sup> | Interrupt-on-change pin. Serial programming clock.                                                                                                                                                       |
| RB7          | 13                | 14           | I/O        | TTL/ST <sup>(2)</sup> | Interrupt-on-change pin. Serial programming data.                                                                                                                                                        |
| Vss          | 5                 | 5,6          | Р          | _                     | Ground reference for logic and I/O pins.                                                                                                                                                                 |
| VDD          | 14                | 15,16        | Р          | _                     | Positive supply for logic and I/O pins.                                                                                                                                                                  |

Legend:

O = output — = Not used TTL = TTL input I/O = input/output I = Input P = power

ST = Schmitt Trigger input

Note 1: This buffer is a Schmitt Trigger input when configured as the external interrupt.

2: This buffer is a Schmitt Trigger input when used in Serial Programming mode.

FIGURE 4-6: DATA MEMORY MAP FOR THE PIC16C620A/CR620A/621A

|                  | 1 10 10 002                                       | UA/CR0ZUA/C         |                 |  |  |  |  |  |
|------------------|---------------------------------------------------|---------------------|-----------------|--|--|--|--|--|
| File<br>Address  | ;                                                 |                     | File<br>Address |  |  |  |  |  |
| 00h              | INDF <sup>(1)</sup>                               | INDF <sup>(1)</sup> | 80h             |  |  |  |  |  |
| 01h              | TMR0                                              | OPTION              | 81h             |  |  |  |  |  |
| 02h              | PCL                                               | PCL                 | 82h             |  |  |  |  |  |
| 03h              | STATUS                                            | STATUS              | 83h             |  |  |  |  |  |
| 04h              | FSR                                               | FSR                 | 84h             |  |  |  |  |  |
| 05h              | PORTA                                             | TRISA               | 85h             |  |  |  |  |  |
| 06h              | PORTB                                             | TRISB               | 86h             |  |  |  |  |  |
| 07h              |                                                   |                     | 87h             |  |  |  |  |  |
| 08h              |                                                   |                     | 88h             |  |  |  |  |  |
| 09h              |                                                   |                     | 89h             |  |  |  |  |  |
| 0Ah              | PCLATH                                            | PCLATH              | 8Ah             |  |  |  |  |  |
| 0Bh              | INTCON                                            | INTCON              | 8Bh             |  |  |  |  |  |
| 0Ch              | PIR1                                              | PIE1                | 8Ch             |  |  |  |  |  |
| 0Dh              |                                                   |                     | 8Dh             |  |  |  |  |  |
| 0Eh              |                                                   | PCON                | 8Eh             |  |  |  |  |  |
| 0Fh              |                                                   |                     | 8Fh             |  |  |  |  |  |
| 10h              |                                                   |                     | 90h             |  |  |  |  |  |
| 11h              |                                                   |                     | 91h             |  |  |  |  |  |
| 12h              |                                                   |                     | 92h             |  |  |  |  |  |
| 13h              |                                                   |                     | 93h             |  |  |  |  |  |
| 14h              |                                                   |                     | 94h             |  |  |  |  |  |
| 15h              |                                                   |                     | 95h             |  |  |  |  |  |
| 16h              |                                                   |                     | 96h             |  |  |  |  |  |
| 17h              |                                                   |                     | 97h             |  |  |  |  |  |
| 18h              |                                                   |                     | 98h             |  |  |  |  |  |
| 19h              |                                                   |                     | 99h             |  |  |  |  |  |
| 1Ah              |                                                   |                     | 9Ah             |  |  |  |  |  |
| 1Bh              |                                                   |                     | 9Bh             |  |  |  |  |  |
| 1Ch              |                                                   |                     | 9Ch             |  |  |  |  |  |
| 1Dh              |                                                   |                     | 9Dh             |  |  |  |  |  |
| 1Eh              |                                                   |                     | 9Eh             |  |  |  |  |  |
| 1Fh              | CMCON                                             | VRCON               | 9Fh             |  |  |  |  |  |
| 20h              |                                                   |                     | A0h             |  |  |  |  |  |
|                  | General<br>Purpose<br>Register                    |                     | 7.011           |  |  |  |  |  |
| 6Fh              |                                                   |                     |                 |  |  |  |  |  |
| 70h              | Conorol                                           |                     | F0h             |  |  |  |  |  |
| / Un             | General<br>Purpose                                | Accesses            |                 |  |  |  |  |  |
| フロト              | Register                                          | 70h-7Fh             | FFh             |  |  |  |  |  |
| 7Fh <sup>[</sup> | Bank 0                                            | Bank 1              | <b>⊐</b> 1 1 11 |  |  |  |  |  |
| Unimp            | Unimplemented data memory locations, read as '0'. |                     |                 |  |  |  |  |  |
|                  | Not a physical re                                 |                     |                 |  |  |  |  |  |
|                  |                                                   |                     |                 |  |  |  |  |  |

FIGURE 4-7: DATA MEMORY MAP FOR THE PIC16C622A

| THE PICTOCOZZA                   |                     |                     |                 |  |  |  |  |  |
|----------------------------------|---------------------|---------------------|-----------------|--|--|--|--|--|
| File<br>Address                  | 3                   |                     | File<br>Address |  |  |  |  |  |
| 00h                              | INDF <sup>(1)</sup> | INDF <sup>(1)</sup> | 80h             |  |  |  |  |  |
| 01h                              | TMR0                | OPTION              | 81h             |  |  |  |  |  |
| 02h                              | PCL                 | PCL                 | 82h             |  |  |  |  |  |
| 03h                              | STATUS              | STATUS              | 83h             |  |  |  |  |  |
| 04h                              | FSR                 | FSR                 | 84h             |  |  |  |  |  |
| 05h                              | PORTA               | TRISA               | 85h             |  |  |  |  |  |
| 06h                              | PORTB               | TRISB               | 86h             |  |  |  |  |  |
| 07h                              |                     |                     | 87h             |  |  |  |  |  |
| 08h                              |                     |                     | 88h             |  |  |  |  |  |
| 09h                              |                     |                     | 89h             |  |  |  |  |  |
| 0Ah                              | PCLATH              | PCLATH              | 8Ah             |  |  |  |  |  |
| 0Bh                              | INTCON              | INTCON              | 8Bh             |  |  |  |  |  |
| 0Ch                              | PIR1                | PIE1                | 8Ch             |  |  |  |  |  |
| 0Dh                              |                     |                     | 8Dh             |  |  |  |  |  |
| 0Eh                              |                     | PCON                | 8Eh             |  |  |  |  |  |
| 0Fh                              |                     |                     | 8Fh             |  |  |  |  |  |
| 10h                              |                     |                     | 90h             |  |  |  |  |  |
| 11h                              |                     |                     | 91h             |  |  |  |  |  |
| 12h                              |                     |                     | 92h             |  |  |  |  |  |
| 13h                              |                     |                     | 93h             |  |  |  |  |  |
| 14h                              |                     |                     | 94h             |  |  |  |  |  |
| 15h                              |                     |                     | 95h             |  |  |  |  |  |
| 16h                              |                     |                     | 96h             |  |  |  |  |  |
| 17h                              |                     |                     | 97h             |  |  |  |  |  |
| 18h                              |                     |                     | 98h             |  |  |  |  |  |
| 19h                              |                     |                     | 99h             |  |  |  |  |  |
| 1Ah                              |                     |                     | 9Ah             |  |  |  |  |  |
| 1Bh                              |                     |                     | 9Bh             |  |  |  |  |  |
| 1Ch                              |                     |                     | 9Ch             |  |  |  |  |  |
| 1Dh                              |                     |                     | 9Dh             |  |  |  |  |  |
| 1Eh                              |                     |                     | 9Eh             |  |  |  |  |  |
| 1Fh                              | CMCON               | VRCON               | 9Fh             |  |  |  |  |  |
| 20h                              | 01110011            | VICOIT              |                 |  |  |  |  |  |
| 2011                             | General             | General             | A0h             |  |  |  |  |  |
|                                  | Purpose             | Purpose             |                 |  |  |  |  |  |
|                                  | Register            | Register            | BFh             |  |  |  |  |  |
|                                  |                     |                     | C0h             |  |  |  |  |  |
|                                  |                     |                     |                 |  |  |  |  |  |
| 6Fh                              |                     |                     | FOh             |  |  |  |  |  |
| 70h                              | General<br>Purpose  | Accesses            | ' ''            |  |  |  |  |  |
|                                  | Register            | 70h-7Fh             |                 |  |  |  |  |  |
| 7Fh                              | Bank 0              | Bank 1              | ا FFh           |  |  |  |  |  |
|                                  | Danko               | Dank i              |                 |  |  |  |  |  |
| Unimp                            | olemented data me   | mory locations, re  | ead as '0'.     |  |  |  |  |  |
| Note 1:                          | Not a physical re   | agietor             |                 |  |  |  |  |  |
| Note 1: Not a physical register. |                     |                     |                 |  |  |  |  |  |

### 4.2.2.1 STATUS Register

The STATUS register, shown in Register 4-1, contains the arithmetic status of the ALU, the RESET status and the bank select bits for data memory.

The STATUS register can be the destination for any instruction, like any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the TO and PD bits are not writable. Therefore, the result of an instruction with the STATUS register as destination may be different than intended.

For example, CLRF STATUS will clear the upper-three bits and set the Z bit. This leaves the STATUS register as 000uu1uu (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions are used to alter the STATUS register, because these instructions do not affect any STATUS bit. For other instructions not affecting any STATUS bits, see the "Instruction Set Summary".

- Note 1: The IRP and RP1 bits (STATUS<7:6>) are not used by the PIC16C62X and should be programmed as '0'. Use of these bits as general purpose R/W bits is NOT recommended, since this may affect upward compatibility with future products.
  - 2: The <u>C and DC bits</u> operate as a Borrow and Digit Borrow out bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples.

## REGISTER 4-1: STATUS REGISTER (ADDRESS 03H OR 83H)

| Reserved | Reserved | R/W-0 | R-1 | R-1 | R/W-x | R/W-x | R/W-x |
|----------|----------|-------|-----|-----|-------|-------|-------|
| IRP      | RP1      | RP0   | TO  | PD  | Z     | DC    | С     |
| bit 7    |          | •     |     |     | •     |       | bit 0 |

- bit 7 IRP: Register Bank Select bit (used for indirect addressing)
  - 1 = Bank 2, 3 (100h 1FFh)
  - 0 = Bank 0, 1 (00h FFh)

The IRP bit is reserved on the PIC16C62X; always maintain this bit clear.

- bit 6-5 RP<1:0>: Register Bank Select bits (used for direct addressing)
  - 01 = Bank 1 (80h FFh)
  - 00 = Bank 0 (00h 7Fh)

Each bank is 128 bytes. The RP1 bit is reserved on the PIC16C62X; always maintain this bit clear.

- bit 4  $\overline{\mathbf{TO}}$ : Time-out bit
  - 1 = After power-up, CLRWDT instruction, or SLEEP instruction
  - 0 = A WDT time-out occurred
- bit 3 **PD**: Power-down bit
  - 1 = After power-up or by the CLRWDT instruction
  - 0 = By execution of the SLEEP instruction
- bit 2 **Z**: Zero bit
  - 1 = The result of an arithmetic or logic operation is zero
  - 0 = The result of an arithmetic or logic operation is not zero
- bit 1 **DC**: Digit carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions)(for borrow the polarity is reversed)
  - 1 = A carry-out from the 4th low order bit of the result occurred
  - 0 = No carry-out from the 4th low order bit of the result
- - 1 = A carry-out from the Most Significant bit of the result occurred
  - 0 = No carry-out from the Most Significant bit of the result occurred

**Note:** For borrow the polarity is reversed. A subtraction is executed by adding the two's complement of the second operand. For rotate (RRF, RLF) instructions, this bit is loaded with either the high or low order bit of the source register.

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

### 6.2 Using Timer0 with External Clock

When an external clock input is used for Timer0, it must meet certain requirements. The external clock requirement is due to internal phase clock (Tosc) synchronization. Also, there is a delay in the actual incrementing of Timer0 after synchronization.

## 6.2.1 EXTERNAL CLOCK SYNCHRONIZATION

When no prescaler is used, the external clock input is the same as the prescaler output. The synchronization of T0CKI with the internal phase clocks is accomplished by sampling the prescaler output on the Q2 and Q4 cycles of the internal phase clocks (Figure 6-5). Therefore, it is necessary for T0CKI to be high for at least 2Tosc (and a small RC delay of 20 ns) and low for at least 2Tosc (and a small RC delay of 20 ns). Refer to the electrical specification of the desired device.

When a prescaler is used, the external clock input is divided by the asynchronous ripple-counter type prescaler, so that the prescaler output is symmetrical. For the external clock to meet the sampling requirement, the ripple-counter must be taken into account. Therefore, it is necessary for T0CKI to have a period of at least 4Tosc (and a small RC delay of 40 ns) divided by the prescaler value. The only requirement on T0CKI high and low time is that they do not violate the minimum pulse width requirement of 10 ns. Refer to parameters 40, 41 and 42 in the electrical specification of the desired device.

### 6.2.2 TIMERO INCREMENT DELAY

Since the prescaler output is synchronized with the internal clocks, there is a small delay from the time the external clock edge occurs to the time the TMR0 is actually incremented. Figure 6-5 shows the delay from the external clock edge to the timer incrementing.

FIGURE 6-5: TIMERO TIMING WITH EXTERNAL CLOCK



- Note 1: Delay from clock input change to Timer0 increment is 3Tosc to 7Tosc. (Duration of Q = Tosc).

  Therefore, the error in measuring the interval between two edges on Timer0 input = ±4Tosc max.
  - 2: External clock if no prescaler selected, Prescaler output otherwise.
  - 3: The arrows indicate the points in time where sampling occurs.

# **PIC16C62X**

NOTES:

The code example in Example 7-1 depicts the steps required to configure the comparator module. RA3 and RA4 are configured as digital output. RA0 and RA1 are configured as the V- inputs and RA2 as the V+ input to both comparators.

## EXAMPLE 7-1: INITIALIZING COMPARATOR MODULE

| MOVLW | 0x03         | ;Init comparator mode              |
|-------|--------------|------------------------------------|
| MOVWF | CMCON        | ;CM<2:0> = 011                     |
| CLRF  | PORTA        | ;Init PORTA                        |
| BSF   | STATUS, RPO  | ;Select Bank1                      |
| MOVLW | 0x07         | ;Initialize data direction         |
| MOVWF | TRISA        | ;Set RA<2:0> as inputs             |
|       |              | ;RA<4:3> as outputs                |
|       |              | ;TRISA<7:5> always read '0'        |
| BCF   | STATUS, RPO  | ;Select Bank 0                     |
| CALL  | DELAY 10     | ;10µs delay                        |
| MOVF  | CMCON, F     | ; Read CMCONtoend change condition |
| BCF   | PIR1,CMIF    | ;Clear pending interrupts          |
| BSF   | STATUS, RPO  | ;Select Bank 1                     |
| BSF   | PIE1,CMIE    | ;Enable comparator interrupts      |
| BCF   | STATUS, RPO  | ;Select Bank 0                     |
| BSF   | INTCON, PEIE | ;Enable peripheral interrupts      |
| BSF   | INTCON, GIE  | ;Global interrupt enable           |

## 7.2 Comparator Operation

A single comparator is shown in Figure 7-2 along with the relationship between the analog input levels and the digital output. When the analog input at VIN+ is less than the analog input VIN-, the output of the comparator is a digital low level. When the analog input at VIN+ is greater than the analog input VIN-, the output of the comparator is a digital high level. The shaded areas of the output of the comparator in Figure 7-2 represent the uncertainty due to input offsets and response time.

### 7.3 Comparator Reference

An external or internal reference signal may be used depending on the comparator Operating mode. The analog signal that is present at VIN- is compared to the signal at VIN+, and the digital output of the comparator is adjusted accordingly (Figure 7-2).

FIGURE 7-2: SINGLE COMPARATOR



#### 7.3.1 EXTERNAL REFERENCE SIGNAL

When external voltage references are used, the comparator module can be configured to have the comparators operate from the same or different reference sources. However, threshold detector applications may require the same reference. The reference signal must be between Vss and VDD, and can be applied to either pin of the comparator(s).

### 7.3.2 INTERNAL REFERENCE SIGNAL

The comparator module also allows the selection of an internally generated voltage reference for the comparators. Section 10, Instruction Sets, contains a detailed description of the Voltage Reference Module that provides this signal. The internal reference signal is used when the comparators are in mode CM<2:0>=010 (Figure 7-1). In this mode, the internal voltage reference is applied to the VIN+ pin of both comparators.

# 8.0 VOLTAGE REFERENCE MODULE

The Voltage Reference is a 16-tap resistor ladder network that provides a selectable voltage reference. The resistor ladder is segmented to provide two ranges of VREF values and has a power-down function to conserve power when the reference is not being used. The VRCON register controls the operation of the reference as shown in Register 8-1. The block diagram is given in Figure 8-1.

## 8.1 Configuring the Voltage Reference

The Voltage Reference can output 16 distinct voltage levels for each range. The equations used to calculate the output of the Voltage Reference are as follows:

if 
$$VRR = 0$$
:  $VREF = (VDD x 1/4) + (VR < 3:0 > /32) x VDD$ 

The setting time of the Voltage Reference must be considered when changing the VREF output (Table 12-1). Example 8-1 shows an example of how to configure the Voltage Reference for an output voltage of 1.25V with VDD = 5.0V.

### REGISTER 8-1: VRCON REGISTER(ADDRESS 9Fh)

| R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|-------|-------|-------|-----|-------|-------|-------|-------|
| VREN  | VROE  | VRR   | -   | VR3   | VR2   | Vr1   | VR0   |
| bit 7 |       |       |     |       |       |       | bit 0 |

bit 7 VREF Enable

1 = VREF circuit powered on

0 = VREF circuit powered down, no IDD drain

bit 6 **VROE:** VREF Output Enable

1 = VREF is output on RA2 pin

0 = VREF is disconnected from RA2 pin

bit 5 VRR: VREF Range selection

1 = Low Range

0 = High Range

bit 4 Unimplemented: Read as '0'

bit 3-0 **VR<3:0>**: VREF value selection  $0 \le VR [3:0] \le 15$ 

when VRR = 1: VREF = (VR<3:0>/ 24) \* VDD

when VRR = 0: VREF = 1/4 \* VDD + (VR<3:0>/ 32) \* VDD

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

### FIGURE 8-1: VOLTAGE REFERENCE BLOCK DIAGRAM



## EXAMPLE 8-1: VOLTAGE REFERENCE CONFIGURATION

| MOVLW | 0x02        | ; | 4 Inputs Muxed |
|-------|-------------|---|----------------|
| MOVWF | CMCON       | ; | to 2 comps.    |
| BSF   | STATUS, RPO | ; | go to Bank 1   |
| MOVLW | 0x0F        | ; | RA3-RA0 are    |
| MOVWF | TRISA       | ; | inputs         |
| MOVLW | 0xA6        | ; | enable VREF    |
| MOVWF | VRCON       | ; | low range      |
|       |             | ; | set VR<3:0>=6  |
| BCF   | STATUS, RPO | ; | go to Bank 0   |
| CALL  | DELAY10     | ; | 10μs delay     |

## 8.2 Voltage Reference Accuracy/Error

The full range of VSS to VDD cannot be realized due to the construction of the module. The transistors on the top and bottom of the resistor ladder network (Figure 8-1) keep VREF from approaching VSS or VDD. The voltage reference is VDD derived and therefore, the VREF output changes with fluctuations in VDD. The tested absolute accuracy of the voltage reference can be found in Table 12-2.

## 8.3 Operation During SLEEP

When the device wakes up from SLEEP through an interrupt or a Watchdog Timer time-out, the contents of the VRCON register are not affected. To minimize current consumption in SLEEP mode, the voltage reference should be disabled.

#### 8.4 Effects of a RESET

A device RESET disables the voltage reference by clearing bit VREN (VRCON<7>). This reset also disconnects the reference from the RA2 pin by clearing bit VROE (VRCON<6>) and selects the high voltage range by clearing bit VRR (VRCON<5>). The VREF value select bits, VRCON<3:0>, are also cleared.

#### 8.5 Connection Considerations

The voltage reference module operates independently of the comparator module. The output of the reference generator may be connected to the RA2 pin if the TRISA<2> bit is set and the VROE bit, VRCON<6>, is set. Enabling the voltage reference output onto the RA2 pin with an input signal present will increase current consumption. Connecting RA2 as a digital output with VREF enabled will also increase current consumption.

The RA2 pin can be used as a simple D/A output with limited drive capability. Due to the limited drive capability, a buffer must be used in conjunction with the voltage reference output for external connections to VREF. Figure 8-2 shows an example buffering technique.

### FIGURE 8-2: VOLTAGE REFERENCE OUTPUT BUFFER EXAMPLE



TABLE 8-1: REGISTERS ASSOCIATED WITH VOLTAGE REFERENCE

| Address | Name  | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Value On<br>POR | Value On<br>All Other<br>RESETS |
|---------|-------|-------|-------|-------|--------|--------|--------|--------|--------|-----------------|---------------------------------|
| 9Fh     | VRCON | VREN  | VROE  | VRR   | _      | VR3    | VR2    | VR1    | VR0    | 000- 0000       | 000- 0000                       |
| 1Fh     | CMCON | C2OUT | C1OUT | _     | _      | CIS    | CM2    | CM1    | CM0    | 00 0000         | 00 0000                         |
| 85h     | TRISA | _     | _     | _     | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 1 1111          | 1 1111                          |

Note: - = Unimplemented, read as "0"

### 9.2 Oscillator Configurations

### 9.2.1 OSCILLATOR TYPES

The PIC16C62X devices can be operated in four different oscillator options. The user can program two configuration bits (FOSC1 and FOSC0) to select one of these four modes:

LP Low Power CrystalXT Crystal/Resonator

HS High Speed Crystal/Resonator

RC Resistor/Capacitor

## 9.2.2 CRYSTAL OSCILLATOR / CERAMIC RESONATORS

In XT, LP or HS modes, a crystal or ceramic resonator is connected to the OSC1 and OSC2 pins to establish oscillation (Figure 9-1). The PIC16C62X oscillator design requires the use of a parallel cut crystal. Use of a series cut crystal may give a frequency out of the crystal manufacturers specifications. When in XT, LP or HS modes, the device can have an external clock source to drive the OSC1 pin (Figure 9-2).

FIGURE 9-1: CRYSTAL OPERATION
(OR CERAMIC
RESONATOR) (HS, XT OR
LP OSC
CONFIGURATION)



See Table 9-1 and Table 9-2 for recommended values of C1 and C2.

**Note:** A series resistor may be required for AT strip cut crystals.

FIGURE 9-2: EXTERNAL CLOCK INPUT OPERATION (HS, XT OR LP OSC CONFIGURATION)



TABLE 9-1: CAPACITOR SELECTION FOR CERAMIC RESONATORS

| R    | anges Chara                   |                           |                                         |
|------|-------------------------------|---------------------------|-----------------------------------------|
| Mode | Freq                          | OSC1(C1)                  | OS62(C2)                                |
| XT   | 455 kHz<br>2.0 MHz<br>4.0 MHz | 22 - 100 pF<br>15 - 68 pF | 22 - 100 pF<br>15 - 68 pF<br>15 - 68 pF |
| HS   | 8.0 MHz<br>16.0 MHz           | 10-22 pF                  | 10 - 68 pF<br>10 - 22 pF                |

Higher capacitance increases the stability of the oscillator but also increases the start-up time. These waltes are for design guidance only. Since each resonator has its own characteristics, the user should consult the resonator manufacturer for appropriate values of external components.

TABLE 9-2: CAPACITOR SELECTION FOR CRYSTAL OSCILLATOR

| Mode | Freq    | OSC1(C1)    | OSC2(C2)     |
|------|---------|-------------|--------------|
| LP   | 32 kHz  | 68 - 100 pF | 68 - 100 pF  |
|      | 200 kHz | 15 - 30 pF  | 15 - 30 pF   |
| XT   | 100 kHz | 68 - 150 pF | 150 - 200 pF |
|      | 2 MHz   | 15 - 30 pF  | 15 - 30 pF   |
|      | 4 MHz   | 15 - 30 pF  | 15 - 30 pF   |
| HS   | 8 MHz   | 15-30 pF    | 15 - 30 pF   |
|      | 10 MHz  | 15-30 pF    | 15 - 30 pF   |
|      | 20 MHz  | 15-30 pF    | 15 - 30 pF   |

Higher capacitance increases the stability of the oscillator but also increases the start-up time.
These values are for design guidance only. Rs may be required in HS mode as well as XT mode to avoid overdriving crystals with low drive level specification. Since each crystal has its own characteristics, the user should consult the crystal manufacturer for appropriate values of external components.

TABLE 9-4: INITIALIZATION CONDITION FOR SPECIAL REGISTERS

| Condition                          | Program<br>Counter    | STATUS<br>Register | PCON<br>Register |
|------------------------------------|-----------------------|--------------------|------------------|
| Power-on Reset                     | 000h                  | 0001 1xxx          | 0x               |
| MCLR Reset during normal operation | 000h                  | 000u uuuu          | uu               |
| MCLR Reset during SLEEP            | 000h                  | 0001 0uuu          | uu               |
| WDT Reset                          | 000h                  | 0000 uuuu          | uu               |
| WDT Wake-up                        | PC + 1                | uuu0 0uuu          | uu               |
| Brown-out Reset                    | 000h                  | 000x xuuu          | u0               |
| Interrupt Wake-up from SLEEP       | PC + 1 <sup>(1)</sup> | uuu1 0uuu          | uu               |

Legend: u = unchanged, x = unknown, - = unimplemented bit, reads as '0'.

**Note 1:** When the wake-up is due to an interrupt and global enable bit, GIE is set, the PC is loaded with the interrupt vector (0004h) after execution of PC+1.

TABLE 9-5: INITIALIZATION CONDITION FOR REGISTERS

| Register | Address | Power-on Reset | MCLR Reset during normal operation     MCLR Reset during SLEEP     WDT Reset     Brown-out Reset (1) | Wake-up from SLEEP<br>through interrupt     Wake-up from SLEEP<br>through WDT time-out |
|----------|---------|----------------|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| W        | _       | xxxx xxxx      | uuuu uuuu                                                                                            | uuuu uuuu                                                                              |
| INDF     | 00h     | _              | _                                                                                                    | _                                                                                      |
| TMR0     | 01h     | xxxx xxxx      | uuuu uuuu                                                                                            | uuuu uuuu                                                                              |
| PCL      | 02h     | 0000 0000      | 0000 0000                                                                                            | PC + 1 <sup>(3)</sup>                                                                  |
| STATUS   | 03h     | 0001 1xxx      | 000q quuu <sup>(4)</sup>                                                                             | uuuq quuu <sup>(4)</sup>                                                               |
| FSR      | 04h     | xxxx xxxx      | uuuu uuuu                                                                                            | uuuu uuuu                                                                              |
| PORTA    | 05h     | x xxxx         | u uuuu                                                                                               | u uuuu                                                                                 |
| PORTB    | 06h     | xxxx xxxx      | uuuu uuuu                                                                                            | uuuu uuuu                                                                              |
| CMCON    | 1Fh     | 00 0000        | 00 0000                                                                                              | uu uuuu                                                                                |
| PCLATH   | 0Ah     | 0 0000         | 0 0000                                                                                               | u uuuu                                                                                 |
| INTCON   | 0Bh     | 0000 000x      | 0000 000u                                                                                            | uuuu uqqq <sup>(2)</sup>                                                               |
| PIR1     | 0Ch     | -0             | -0                                                                                                   | -q <sup>(2,5)</sup>                                                                    |
| OPTION   | 81h     | 1111 1111      | 1111 1111                                                                                            | uuuu uuuu                                                                              |
| TRISA    | 85h     | 1 1111         | 1 1111                                                                                               | u uuuu                                                                                 |
| TRISB    | 86h     | 1111 1111      | 1111 1111                                                                                            | uuuu uuuu                                                                              |
| PIE1     | 8Ch     | -0             | -0                                                                                                   | -u                                                                                     |
| PCON     | 8Eh     | 0x             | uq <sup>(1,6)</sup>                                                                                  | uu                                                                                     |
| VRCON    | 9Fh     | 000- 0000      | 000- 0000                                                                                            | uuu- uuuu                                                                              |

 $\label{eq:local_local_local_local_local} \text{Legend:} \quad \text{$u$ = unchanged, $x$ = unknown, $-$ = unimplemented bit, reads as `0', $q$ = value depends on condition.}$ 

Note 1: If VDD goes too low, Power-on Reset will be activated and registers will be affected differently.

- 2: One or more bits in INTCON, PIR1 and/or PIR2 will be affected (to cause wake-up).
- 3: When the wake-up is due to an interrupt and the GIE bit is set, the PC is loaded with the interrupt vector (0004h).
- **4:** See Table 9-4 for RESET value for specific condition.
- 5: If wake-up was due to comparator input changing, then bit 6 = 1. All other interrupts generating a wake-up will cause bit 6 = u.
- **6:** If RESET was due to brown-out, then bit 0 = 0. All other RESETS will cause bit 0 = u.

#### 9.5.1 RB0/INT INTERRUPT

External interrupt on RB0/INT pin is edge triggered, either rising if INTEDG bit (OPTION<6>) is set, or falling, if INTEDG bit is clear. When a valid edge appears on the RB0/INT pin, the INTF bit (INTCON<1>) is set. This interrupt can be disabled by clearing the INTE control bit (INTCON<4>). The INTF bit must be cleared in software in the interrupt service routine before reenabling this interrupt. The RB0/INT interrupt can wake-up the processor from SLEEP, if the INTE bit was set prior to going into SLEEP. The status of the GIE bit decides whether or not the processor branches to the interrupt vector following wake-up. See Section 9.8 for details on SLEEP and Figure 9-18 for timing of wake-up from SLEEP through RB0/INT interrupt.

#### 9.5.2 TMR0 INTERRUPT

An overflow (FFh  $\rightarrow$  00h) in the TMR0 register will set the T0IF (INTCON<2>) bit. The interrupt can be enabled/disabled by setting/clearing T0IE (INTCON<5>) bit. For operation of the Timer0 module, see Section 6.0.

#### 9.5.3 PORTB INTERRUPT

An input change on PORTB <7:4> sets the RBIF (INTCON<0>) bit. The interrupt can be enabled/disabled by setting/clearing the RBIE (INTCON<4>) bit. For operation of PORTB (Section 5.2).

Note: If a change on the I/O pin should occur when the read operation is being executed (start of the Q2 cycle), then the RBIF interrupt flag may not get set.

#### 9.5.4 COMPARATOR INTERRUPT

See Section 7.6 for complete description of comparator interrupts.





Note 1: INTF flag is sampled here (every Q1).

- 2: Asynchronous interrupt latency = 3-4 Tcy. Synchronous latency = 3 Tcy, where Tcy = instruction cycle time. Latency is the same whether Inst (PC) is a single cycle or a two-cycle instruction.
- 3: CLKOUT is available only in RC Oscillator mode.
- 4: For minimum width of INT pulse, refer to AC specs.
- 5: INTF is enabled to be set anytime during the Q4-Q1 cycles.

### 9.7 Watchdog Timer (WDT)

The Watchdog Timer is a free running on-chip RC oscillator which does not require any external components. This RC oscillator is separate from the RC oscillator of the CLKIN pin. That means that the WDT will run, even if the clock on the OSC1 and OSC2 pins of the device has been stopped, for example, by execution of a SLEEP instruction. During normal operation, a WDT time-out generates a device RESET. If the device is in SLEEP mode, a WDT time-out causes the device to wake-up and continue with normal operation. The WDT can be permanently disabled by programming the configuration bit WDTE as clear (Section 9.1).

#### 9.7.1 WDT PERIOD

The WDT has a nominal time-out period of 18 ms, (with no prescaler). The time-out periods vary with temperature, VDD and process variations from part to part (see DC specs). If longer time-out periods are desired, a prescaler with a division ratio of up to 1:128 can be assigned to the WDT under software control by writing to the OPTION register. Thus, time-out periods up to 2.3 seconds can be realized.

The CLRWDT and SLEEP instructions clear the WDT and the postscaler, if assigned to the WDT, and prevent it from timing out and generating a device RESET.

The TO bit in the STATUS register will be cleared upon a Watchdog Timer time-out.

## 9.7.2 WDT PROGRAMMING CONSIDERATIONS

It should also be taken in account that under worst case conditions (VDD = Min., Temperature = Max., max. WDT prescaler) it may take several seconds before a WDT time-out occurs.

FIGURE 9-17: WATCHDOG TIMER BLOCK DIAGRAM



TABLE 9-7: SUMMARY OF WATCHDOG TIMER REGISTERS

| Address | Name         | Bit 7 | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR Reset | Value on all<br>other<br>RESETS |
|---------|--------------|-------|--------|-------|-------|-------|-------|-------|-------|-----------------------|---------------------------------|
| 2007h   | Config. bits | _     | BODEN  | CP1   | CP0   | PWRTE | WDTE  | FOSC1 | FOSC0 | _                     | _                               |
| 81h     | OPTION       | RBPU  | INTEDG | T0CS  | T0SE  | PSA   | PS2   | PS1   | PS0   | 1111 1111             | 1111 1111                       |

Legend: Shaded cells are not used by the Watchdog Timer.

**Note:** – = Unimplemented location, read as "0"

+ = Reserved for future use

### 9.8 Power-Down Mode (SLEEP)

The Power-down mode is entered by executing a SLEEP instruction.

If enabled, the Watchdog Timer will be cleared but keeps running, the PD bit in the STATUS register is cleared, the TO bit is set, and the oscillator driver is turned off. The I/O ports maintain the status they had, before SLEEP was executed (driving high, low, or himpedance).

For lowest current consumption in this mode, all I/O pins should be either at VDD or Vss with no external circuitry drawing current from the I/O pin and the comparators and VREF should be disabled. I/O pins that are hi-impedance inputs should be pulled high or low externally to avoid switching currents caused by floating inputs. The TOCKI input should also be at VDD or Vss for lowest current consumption. The contribution from on chip pull-ups on PORTB should be considered.

The MCLR pin must be at a logic high level (VIHMC).

| Note: | It should be noted that a RESET generated |
|-------|-------------------------------------------|
|       | by a WDT time-out does not drive MCLR     |
|       | pin low.                                  |

#### 9.8.1 WAKE-UP FROM SLEEP

The device can wake-up from SLEEP through one of the following events:

- 1. External RESET input on MCLR pin
- 2. Watchdog Timer Wake-up (if WDT was enabled)
- 3. Interrupt from RB0/INT pin, RB Port change, or the Peripheral Interrupt (Comparator).

The first event will cause a device RESET. The two latter events are considered a continuation of program execution. The  $\overline{\text{TO}}$  and  $\overline{\text{PD}}$  bits in the STATUS register  $\overline{\text{can}}$  be used to determine the cause of device RESET.  $\overline{\text{PD}}$  bit, which is set on power-up, is cleared when SLEEP is invoked.  $\overline{\text{TO}}$  bit is cleared if WDT wake-up occurred.

When the SLEEP instruction is being executed, the next instruction (PC + 1) is pre-fetched. For the device to wake-up through an interrupt event, the corresponding interrupt enable bit must be set (enabled). Wake-up is regardless of the state of the GIE bit. If the GIE bit is clear (disabled), the device continues execution at the instruction after the SLEEP instruction. If the GIE bit is set (enabled), the device executes the instruction after the SLEEP instruction and then branches to the interrupt address (0004h). In cases where the execution of the instruction following SLEEP is not desirable, the user should have an NOP after the SLEEP instruction.

Note: If the global interrupts are disabled (GIE is cleared), but any interrupt source has both its interrupt enable bit and the corresponding interrupt flag bits set, the device will immediately wake-up from SLEEP. The SLEEP instruction is completely executed.

The WDT is cleared when the device wakes up from SLEEP, regardless of the source of wake-up.

## FIGURE 9-18: WAKE-UP FROM SLEEP THROUGH INTERRUPT



- Note 1: XT, HS or LP Oscillator mode assumed.
  - 2: Tost = 1024Tosc (drawing not to scale) This delay will not be there for RC Osc mode.
  - 3: GIE = '1' assumed. In this case, after wake-up, the processor jumps to the interrupt routine. If GIE = '0', execution will continue in-line.
  - 4: CLKOUT is not available in these Osc modes, but shown here for timing reference.

| INCFSZ                                                                                                                                                                  | Increment f, Skip if 0                                                                                          | IORWF            | Inclusive OR W with f                                                                                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                                                                                                                                                 | [ label ] INCFSZ f,d                                                                                            | Syntax:          | [ label ] IORWF f,d                                                                                                                                       |
| Operands:                                                                                                                                                               | $0 \le f \le 127$<br>$d \in [0,1]$                                                                              | Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                        |
| Operation:                                                                                                                                                              | (f) + 1 $\rightarrow$ (dest), skip if result = 0                                                                | Operation:       | (W) .OR. (f) $\rightarrow$ (dest)                                                                                                                         |
| Status Affected:                                                                                                                                                        | None                                                                                                            | Status Affected: | Z                                                                                                                                                         |
| Encoding:                                                                                                                                                               | 00 1111 dfff ffff                                                                                               | Encoding:        | 00 0100 dfff ffff                                                                                                                                         |
| Description:  The contents of register 'f' are incremented. If 'd' is 0 the result is placed in the W register. If 'd' is 1, the result is placed back in register 'f'. |                                                                                                                 | Description:     | Inclusive OR the W register with register 'f'. If 'd' is 0 the result is placed in the W register. If 'd' is 1 the result is placed back in register 'f'. |
|                                                                                                                                                                         | If the result is 0, the next instruction, which is already fetched, is                                          | Words:           | 1                                                                                                                                                         |
|                                                                                                                                                                         | discarded. A NOP is executed                                                                                    | Cycles:          | 1                                                                                                                                                         |
|                                                                                                                                                                         | instead making it a two-cycle                                                                                   | Example          | IORWF RESULT, 0                                                                                                                                           |
| Words:                                                                                                                                                                  | instruction. 1                                                                                                  |                  | Before Instruction  RESULT = 0x13  W = 0x91                                                                                                               |
| Cycles:                                                                                                                                                                 | 1(2)                                                                                                            |                  | After Instruction                                                                                                                                         |
| Example                                                                                                                                                                 | HERE INCFSZ CNT, 1 GOTO LOOP                                                                                    |                  | RESULT = 0x13  W = 0x93                                                                                                                                   |
|                                                                                                                                                                         | CONTINUE •                                                                                                      |                  | W = 0x93<br>Z = 1                                                                                                                                         |
|                                                                                                                                                                         | :                                                                                                               |                  |                                                                                                                                                           |
|                                                                                                                                                                         | Before Instruction                                                                                              | MOVLW            | Move Literal to W                                                                                                                                         |
|                                                                                                                                                                         | PC = address HERE After Instruction                                                                             | Syntax:          | [ label ] MOVLW k                                                                                                                                         |
|                                                                                                                                                                         | CNT = CNT + 1                                                                                                   | Operands:        | $0 \leq k \leq 255$                                                                                                                                       |
|                                                                                                                                                                         | <pre>if CNT= 0, PC = address CONTINUE</pre>                                                                     | Operation:       | $k \rightarrow (W)$                                                                                                                                       |
|                                                                                                                                                                         | if CNT≠ 0,                                                                                                      | Status Affected: | None                                                                                                                                                      |
|                                                                                                                                                                         | PC = address HERE +1                                                                                            | Encoding:        | 11 00xx kkkk kkkk                                                                                                                                         |
|                                                                                                                                                                         |                                                                                                                 | Description:     | The eight bit literal 'k' is loaded                                                                                                                       |
| IORLW                                                                                                                                                                   | Inclusive OR Literal with W                                                                                     |                  | into W register. The don't cares                                                                                                                          |
| Syntax:                                                                                                                                                                 | [ <i>label</i> ] IORLW k                                                                                        |                  | will assemble as 0's.                                                                                                                                     |
| Operands:                                                                                                                                                               | $0 \leq k \leq 255$                                                                                             | Words:           | 1                                                                                                                                                         |
| Operation:                                                                                                                                                              | (W) .OR. $k \rightarrow (W)$                                                                                    | Cycles:          | 1                                                                                                                                                         |
| Status Affected:                                                                                                                                                        | Z                                                                                                               | Example          | MOVLW 0x5A                                                                                                                                                |
| Encoding:                                                                                                                                                               | 11 1000 kkkk kkkk                                                                                               |                  | After Instruction<br>W = 0x5A                                                                                                                             |
| Description:                                                                                                                                                            | The contents of the W register is OR'ed with the eight bit literal 'k'. The result is placed in the W register. |                  | W G.G.                                                                                                                                                    |
| Words:                                                                                                                                                                  | 1                                                                                                               |                  |                                                                                                                                                           |
| Cycles:                                                                                                                                                                 | 1                                                                                                               |                  |                                                                                                                                                           |
| Example                                                                                                                                                                 | IORLW 0x35                                                                                                      |                  |                                                                                                                                                           |
| - P -                                                                                                                                                                   | Before Instruction                                                                                              |                  |                                                                                                                                                           |
|                                                                                                                                                                         | W = 0x9A                                                                                                        |                  |                                                                                                                                                           |
|                                                                                                                                                                         | After Instruction  W = 0xBF                                                                                     |                  |                                                                                                                                                           |
|                                                                                                                                                                         | Z = 1                                                                                                           |                  |                                                                                                                                                           |

| MOVF             | Move f                                                                                                                                                                                                                                                  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:          | [ label ] MOVF f,d                                                                                                                                                                                                                                      |  |  |  |  |
| Operands:        | $0 \le f \le 127$<br>d $\in [0,1]$                                                                                                                                                                                                                      |  |  |  |  |
| Operation:       | $(f) \rightarrow (dest)$                                                                                                                                                                                                                                |  |  |  |  |
| Status Affected: | Z                                                                                                                                                                                                                                                       |  |  |  |  |
| Encoding:        | 00 1000 dfff ffff                                                                                                                                                                                                                                       |  |  |  |  |
| Description:     | The contents of register f is moved to a destination dependent upon the status of d. If d = 0, destination is W register. If d = 1, the destination is file register f itself. d = 1 is useful to test a file register since status flag Z is affected. |  |  |  |  |
| Words:           | 1                                                                                                                                                                                                                                                       |  |  |  |  |
| Cycles:          | 1                                                                                                                                                                                                                                                       |  |  |  |  |
| Example          | MOVF FSR, 0                                                                                                                                                                                                                                             |  |  |  |  |
|                  | After Instruction  W = value in FSR register Z = 1                                                                                                                                                                                                      |  |  |  |  |

| MOVWF            | Move W to f                                                                             |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:          | [label] MOVWF f                                                                         |  |  |  |  |
| Operands:        | $0 \leq f \leq 127$                                                                     |  |  |  |  |
| Operation:       | $(W) \rightarrow (f)$                                                                   |  |  |  |  |
| Status Affected: | None                                                                                    |  |  |  |  |
| Encoding:        | 00 0000 1fff ffff                                                                       |  |  |  |  |
| Description:     | Move data from W register to register 'f'.                                              |  |  |  |  |
| Words:           | 1                                                                                       |  |  |  |  |
| Cycles:          | 1                                                                                       |  |  |  |  |
| Example          | MOVWF OPTION                                                                            |  |  |  |  |
|                  | Before Instruction  OPTION = 0xFF  W = 0x4F  After Instruction  OPTION = 0x4F  W = 0x4F |  |  |  |  |

| NOP              | No Operation |        |      |      |  |  |
|------------------|--------------|--------|------|------|--|--|
| Syntax:          | [ label ]    | NOP    |      |      |  |  |
| Operands:        | None         |        |      |      |  |  |
| Operation:       | No operation |        |      |      |  |  |
| Status Affected: | None         |        |      |      |  |  |
| Encoding:        | 00           | 0000   | 0xx0 | 0000 |  |  |
| Description:     | No opera     | ation. |      |      |  |  |
| Words:           | 1            |        |      |      |  |  |
| Cycles:          | 1            |        |      |      |  |  |
| Example          | NOP          |        |      |      |  |  |

| OPTION               | Load Op                                                                                                                                                                                                                        | tion Reg | gister |      |  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|------|--|
| Syntax:              | [ label ]                                                                                                                                                                                                                      | OPTION   | ٧      |      |  |
| Operands:            | None                                                                                                                                                                                                                           |          |        |      |  |
| Operation:           | $(W) \rightarrow OPTION$                                                                                                                                                                                                       |          |        |      |  |
| Status Affected:     | None                                                                                                                                                                                                                           |          |        |      |  |
| Encoding:            | 00                                                                                                                                                                                                                             | 0000     | 0110   | 0010 |  |
| Description:  Words: | The contents of the W register are loaded in the OPTION register. This instruction is supported for code compatibility with PIC16C5X products. Since OPTION is a readable/writable register, the user can directly address it. |          |        |      |  |
|                      | 1                                                                                                                                                                                                                              |          |        |      |  |
| Cycles:<br>Example   | Į.                                                                                                                                                                                                                             |          |        |      |  |
|                      | To maintain upward compatibility with future PICmicro® products, do not use this instruction.                                                                                                                                  |          |        |      |  |
|                      |                                                                                                                                                                                                                                |          |        |      |  |

| RLF              | Rotate Left f through Carry                                                                                                                                                                       |           |     |           |      |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|-----------|------|--|
| Syntax:          | [ label ]                                                                                                                                                                                         | RLF       | f,d |           |      |  |
| Operands:        | $0 \le f \le 12$ $d \in [0,1]$                                                                                                                                                                    | 7         |     |           |      |  |
| Operation:       | See description below                                                                                                                                                                             |           |     |           |      |  |
| Status Affected: | С                                                                                                                                                                                                 |           |     |           |      |  |
| Encoding:        | 00                                                                                                                                                                                                | 1101      | df  | ff        | ffff |  |
| Description:     | The contents of register 'f' are rotated one bit to the left through the Carry Flag. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is stored back in register 'f'. |           |     |           |      |  |
| Words:           | 1                                                                                                                                                                                                 |           |     |           |      |  |
| Cycles:          | 1                                                                                                                                                                                                 |           |     |           |      |  |
| Example          | RLF                                                                                                                                                                                               | REG1,     | )   |           |      |  |
|                  | Before In                                                                                                                                                                                         | structior | 1   |           |      |  |
|                  |                                                                                                                                                                                                   | REG1<br>C | =   | 1110      | 0110 |  |
|                  | After Inst                                                                                                                                                                                        | _         | =   | 0         |      |  |
|                  |                                                                                                                                                                                                   | REG1      | =   | 1110      | 0110 |  |
|                  |                                                                                                                                                                                                   | W<br>C    | =   | 1100<br>1 | 1100 |  |

| RRF              | Rotate Right f through Carry                                    |                                                  |                                        |                                              |  |
|------------------|-----------------------------------------------------------------|--------------------------------------------------|----------------------------------------|----------------------------------------------|--|
| Syntax:          | [ label ]                                                       | RRF f                                            | ,d                                     |                                              |  |
| Operands:        | $0 \le f \le 12$ $d \in [0,1]$                                  | 27                                               |                                        |                                              |  |
| Operation:       | See description below                                           |                                                  |                                        |                                              |  |
| Status Affected: | С                                                               |                                                  |                                        |                                              |  |
| Encoding:        | 00                                                              | 1100                                             | dfff                                   | ffff                                         |  |
| Description:     | The control rotated or the Carry is placed 1, the reserviser 'I | ne bit to<br>Flag. If<br>in the W<br>sult is pla | the right<br>'d' is 0, th<br>/ registe | through<br>ne result<br>r. If 'd' is<br>k in |  |
| Words:           | 1                                                               |                                                  |                                        |                                              |  |
| Cycles:          | 1                                                               |                                                  |                                        |                                              |  |
| Example          | RRF                                                             |                                                  | REG1,<br>0                             |                                              |  |
|                  | Before In                                                       | struction                                        | า                                      |                                              |  |
|                  |                                                                 | REG1<br>C                                        | = 11:                                  | 10 0110                                      |  |
|                  | After Inst                                                      |                                                  | = 0                                    |                                              |  |
|                  |                                                                 | REG1                                             | = 11                                   | 10 0110                                      |  |
|                  |                                                                 | W<br>C                                           | = 013                                  | 11 0011                                      |  |

## SLEEP Syntax:

|                  | ]                                                                                                                                                                                                                             |      |      |      |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|
| Operands:        | None                                                                                                                                                                                                                          |      |      |      |
| Operation:       | 00h → WDT,<br>0 → WDT prescaler,<br>1 → $\overline{TO}$ ,<br>0 → $\overline{PD}$                                                                                                                                              |      |      |      |
| Status Affected: | TO, PD                                                                                                                                                                                                                        |      |      |      |
| Encoding:        | 00                                                                                                                                                                                                                            | 0000 | 0110 | 0011 |
| Description:     | The power-down STATUS bit, PD is cleared. Time-out STATUS bit, TO is set. Watch-dog Timer and its prescaler are cleared.  The processor is put into SLEEP mode with the oscillator stopped. See Section 9.8 for more details. |      |      |      |
| Words:           | 1                                                                                                                                                                                                                             |      |      |      |
| Cycles:          | 1                                                                                                                                                                                                                             |      |      |      |
| Example:         | SLEEP                                                                                                                                                                                                                         |      |      |      |

[ label

SLEEP

### 11.0 DEVELOPMENT SUPPORT

The PICmicro<sup>®</sup> microcontrollers are supported with a full range of hardware and software development tools:

- · Integrated Development Environment
  - MPLAB® IDE Software
- · Assemblers/Compilers/Linkers
  - MPASM™ Assembler
  - MPLAB C17 and MPLAB C18 C Compilers
  - MPLINK<sup>™</sup> Object Linker/ MPLIB<sup>™</sup> Object Librarian
  - MPLAB C30 C Compiler
- MPLAB ASM30 Assembler/Linker/Library
- Simulators
  - MPLAB SIM Software Simulator
  - MPLAB dsPIC30 Software Simulator
- Emulators
  - MPLAB ICE 2000 In-Circuit Emulator
  - MPLAB ICE 4000 In-Circuit Emulator
- · In-Circuit Debugger
  - MPLAB ICD 2
- · Device Programmers
  - PRO MATE® II Universal Device Programmer
  - PICSTART® Plus Development Programmer
- · Low Cost Demonstration Boards
  - PICDEM™ 1 Demonstration Board
  - PICDEM.net™ Demonstration Board
  - PICDEM 2 Plus Demonstration Board
  - PICDEM 3 Demonstration Board
  - PICDEM 4 Demonstration Board
  - PICDEM 17 Demonstration Board
  - PICDEM 18R Demonstration Board
  - PICDEM LIN Demonstration Board
  - PICDEM USB Demonstration Board
- Evaluation Kits
  - KEELOQ®
  - PICDEM MSC
  - microID®
  - CAN
  - PowerSmart®
  - Analog

## 11.1 MPLAB Integrated Development Environment Software

The MPLAB IDE software brings an ease of software development previously unseen in the 8/16-bit microcontroller market. The MPLAB IDE is a Windows® based application that contains:

- · An interface to debugging tools
  - simulator
  - programmer (sold separately)
  - emulator (sold separately)
  - in-circuit debugger (sold separately)
- · A full-featured editor with color coded context
- · A multiple project manager
- Customizable data windows with direct edit of contents
- · High level source code debugging
- · Mouse over variable inspection
- · Extensive on-line help

The MPLAB IDE allows you to:

- Edit your source files (either assembly or C)
- One touch assemble (or compile) and download to PICmicro emulator and simulator tools (automatically updates all project information)
- · Debug using:
  - source files (assembly or C)
  - absolute listing file (mixed assembly and C)
  - machine code

MPLAB IDE supports multiple debugging tools in a single development paradigm, from the cost effective simulators, through low cost in-circuit debuggers, to full-featured emulators. This eliminates the learning curve when upgrading to tools with increasing flexibility and power.

### 11.2 MPASM Assembler

The MPASM assembler is a full-featured, universal macro assembler for all PICmicro MCUs.

The MPASM assembler generates relocatable object files for the MPLINK object linker, Intel® standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code and COFF files for debugging.

The MPASM assembler features include:

- Integration into MPLAB IDE projects
- · User defined macros to streamline assembly code
- Conditional assembly for multi-purpose source files
- Directives that allow complete control over the assembly process

## 11.14 PICDEM 1 PICmicro Demonstration Board

The PICDEM 1 demonstration board demonstrates the capabilities of the PIC16C5X (PIC16C54 to PIC16C58A), PIC16C61, PIC16C62X, PIC16C71, PIC16C8X, PIC17C42, PIC17C43 and PIC17C44. All necessary hardware and software is included to run basic demo programs. The sample microcontrollers provided with the PICDEM 1 demonstration board can be programmed with a PRO MATE II device programmer, or a PICSTART Plus development programmer. The PICDEM 1 demonstration board can be connected to the MPLAB ICE in-circuit emulator for testing. A prototype area extends the circuitry for additional application components. Features include an RS-232 interface, a potentiometer for simulated analog input, push button switches and eight LEDs.

## 11.15 PICDEM.net Internet/Ethernet Demonstration Board

The PICDEM.net demonstration board is an Internet/ Ethernet demonstration board using the PIC18F452 microcontroller and TCP/IP firmware. The board supports any 40-pin DIP device that conforms to the standard pinout used by the PIC16F877 or PIC18C452. This kit features a user friendly TCP/IP stack, web server with HTML, a 24L256 Serial EEPROM for Xmodem download to web pages into Serial EEPROM, ICSP/MPLAB ICD 2 interface connector, an Ethernet interface, RS-232 interface, and a 16 x 2 LCD display. Also included is the book and CD-ROM "TCP/IP Lean, Web Servers for Embedded Systems," by Jeremy Bentham

## 11.16 PICDEM 2 Plus Demonstration Board

The PICDEM 2 Plus demonstration board supports many 18-, 28-, and 40-pin microcontrollers, including PIC16F87X and PIC18FXX2 devices. All the necessary hardware and software is included to run the demonstration programs. The sample microcontrollers provided with the PICDEM 2 demonstration board can be programmed with a PRO MATE II device programmer, PICSTART Plus development programmer, or MPLAB ICD 2 with a Universal Programmer Adapter. The MPLAB ICD 2 and MPLAB ICE in-circuit emulators may also be used with the PICDEM 2 demonstration board to test firmware. A prototype area extends the circuitry for additional application components. Some of the features include an RS-232 interface, a 2 x 16 LCD display, a piezo speaker, an on-board temperature sensor, four LEDs, and sample PIC18F452 and PIC16F877 FLASH microcontrollers.

# 11.17 PICDEM 3 PIC16C92X Demonstration Board

The PICDEM 3 demonstration board supports the PIC16C923 and PIC16C924 in the PLCC package. All the necessary hardware and software is included to run the demonstration programs.

# 11.18 PICDEM 4 8/14/18-Pin Demonstration Board

The PICDEM 4 can be used to demonstrate the capabilities of the 8-, 14-, and 18-pin PIC16XXXX and PIC18XXXX MCUs, including the PIC16F818/819, PIC16F87/88, PIC16F62XA and the PIC18F1320 family of microcontrollers. PICDEM 4 is intended to showcase the many features of these low pin count parts, including LIN and Motor Control using ECCP. Special provisions are made for low power operation with the supercapacitor circuit, and jumpers allow onboard hardware to be disabled to eliminate current draw in this mode. Included on the demo board are provisions for Crystal, RC or Canned Oscillator modes, a five volt regulator for use with a nine volt wall adapter or battery, DB-9 RS-232 interface, ICD connector for programming via ICSP and development with MPLAB ICD 2, 2x16 liquid crystal display, PCB footprints for H-Bridge motor driver, LIN transceiver and EEPROM. Also included are: header for expansion, eight LEDs, four potentiometers, three push buttons and a prototyping area. Included with the kit is a PIC16F627A and a PIC18F1320. Tutorial firmware is included along with the User's Guide.

#### 11.19 PICDEM 17 Demonstration Board

The PICDEM 17 demonstration board is an evaluation board that demonstrates the capabilities of several Microchip microcontrollers, including PIC17C752, PIC17C756A, PIC17C762 and PIC17C766. A programmed sample is included. The PRO MATE II device programmer, or the PICSTART Plus development programmer, can be used to reprogram the device for user tailored application development. The PICDEM 17 demonstration board supports program download and execution from external on-board FLASH memory. A generous prototype area is available for user hardware expansion.

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

| 10.  | Technical Publications Manager Total Pages Sent                                          |  |  |  |  |
|------|------------------------------------------------------------------------------------------|--|--|--|--|
| RE:  | Reader Response                                                                          |  |  |  |  |
| Fron | : Name                                                                                   |  |  |  |  |
|      | Company                                                                                  |  |  |  |  |
|      | Address                                                                                  |  |  |  |  |
|      | City / State / ZIP / Country                                                             |  |  |  |  |
|      | Telephone: (                                                                             |  |  |  |  |
|      | cation (optional):                                                                       |  |  |  |  |
| Wou  | d you like a reply?YN                                                                    |  |  |  |  |
| Dev  | ce: PIC16C62X Literature Number: DS30235J                                                |  |  |  |  |
| Que  | stions:                                                                                  |  |  |  |  |
| 1.   | Vhat are the best features of this document?                                             |  |  |  |  |
|      |                                                                                          |  |  |  |  |
| 2.   | low does this document meet your hardware and software development needs?                |  |  |  |  |
|      |                                                                                          |  |  |  |  |
| 3    | Do you find the organization of this document easy to follow? If not, why?               |  |  |  |  |
| 0.   | to you mile the organization of the december one of the follow. If not, why.             |  |  |  |  |
|      |                                                                                          |  |  |  |  |
| 4.   | Vhat additions to the document do you think would enhance the structure and subject?     |  |  |  |  |
|      |                                                                                          |  |  |  |  |
| 5.   | What deletions from the document could be made without affecting the overall usefulness? |  |  |  |  |
|      |                                                                                          |  |  |  |  |
|      |                                                                                          |  |  |  |  |
| 6.   | s there any incorrect or misleading information (what and where)?                        |  |  |  |  |
|      |                                                                                          |  |  |  |  |
| 7.   | How would you improve this document?                                                     |  |  |  |  |
|      |                                                                                          |  |  |  |  |
|      |                                                                                          |  |  |  |  |