

Welcome to E-XFL.COM

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

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

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

#### Details

E-XF

| 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        | 3.5KB (2K x 14)                                                            |
| Program Memory Type        | ОТР                                                                        |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 128 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 5.5V                                                                |
| 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/pic16c622a-04-so |

Email: info@E-XFL.COM

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



### **EPROM-Based 8-Bit CMOS Microcontrollers**

#### Devices included in this data sheet:

Referred to collectively as PIC16C62X.

- PIC16C620 PIC16C620A
- PIC16C621 PIC16C621A
- PIC16C622 PIC16C622A
- PIC16CR620A

#### **High Performance RISC CPU:**

- Only 35 instructions to learn
- All single cycle instructions (200 ns), except for program branches which are two-cycle
- Operating speed:
  - DC 40 MHz clock input
  - DC 100 ns instruction cycle

| Device      | Program<br>Memory | Data<br>Memory |
|-------------|-------------------|----------------|
| PIC16C620   | 512               | 80             |
| PIC16C620A  | 512               | 96             |
| PIC16CR620A | 512               | 96             |
| PIC16C621   | 1K                | 80             |
| PIC16C621A  | 1K                | 96             |
| PIC16C622   | 2K                | 128            |
| PIC16C622A  | 2K                | 128            |

· Interrupt capability

- 16 special function hardware registers
- 8-level deep hardware stack
- Direct, Indirect and Relative addressing modes

#### **Peripheral Features:**

- 13 I/O pins with individual direction control
- High current sink/source for direct LED drive
- Analog comparator module with:
- Two analog comparators
- Programmable on-chip voltage reference (VREF) module
- Programmable input multiplexing from device inputs and internal voltage reference
- Comparator outputs can be output signals
- Timer0: 8-bit timer/counter with 8-bit programmable prescaler

#### Pin Diagrams

#### PDIP, SOIC, Windowed CERDIP



#### **Special Microcontroller Features:**

- · Power-on Reset (POR)
- Power-up Timer (PWRT) and Oscillator Start-up Timer (OST)
- Brown-out Reset
- Watchdog Timer (WDT) with its own on-chip RC oscillator for reliable operation
- · Programmable code protection
- · Power saving SLEEP mode
- Selectable oscillator options
- Serial in-circuit programming (via two pins)
- Four user programmable ID locations

#### **CMOS Technology:**

- Low power, high speed CMOS EPROM technology
- Fully static design
- · Wide operating range
  - 2.5V to 5.5V
- Commercial, industrial and extended temperature range
- Low power consumption
  - < 2.0 mA @ 5.0V, 4.0 MHz
  - 15 μA typical @ 3.0V, 32 kHz
  - < 1.0 μA typical standby current @ 3.0V

#### 2.0 PIC16C62X DEVICE VARIETIES

A variety of frequency ranges and packaging options are available. Depending on application and production requirements, the proper device option can be selected using the information in the PIC16C62X Product Identification System section at the end of this data sheet. When placing orders, please use this page of the data sheet to specify the correct part number.

#### 2.1 UV Erasable Devices

The UV erasable version, offered in CERDIP package, is optimal for prototype development and pilot programs. This version can be erased and reprogrammed to any of the Oscillator modes.

Microchip's PICSTART<sup>®</sup> and PRO MATE<sup>®</sup> programmers both support programming of the PIC16C62X.

Note: Microchip does not recommend code protecting windowed devices.

#### 2.2 One-Time-Programmable (OTP) Devices

The availability of OTP devices is especially useful for customers who need the flexibility for frequent code updates and small volume applications. In addition to the program memory, the configuration bits must also be programmed.

#### 2.3 Quick-Turnaround-Production (QTP) Devices

Microchip offers a QTP programming service for factory production orders. This service is made available for users who chose not to program a medium to high quantity of units and whose code patterns have stabilized. The devices are identical to the OTP devices, but with all EPROM locations and configuration options already programmed by the factory. Certain code and prototype verification procedures apply before production shipments are available. Please contact your Microchip Technology sales office for more details.

#### 2.4 Serialized Quick-Turnaround-Production<sup>sm</sup> (SQTP<sup>sm</sup>) Devices

Microchip offers a unique programming service where a few user-defined locations in each device are programmed with different serial numbers. The serial numbers may be random, pseudo-random or sequential.

Serial programming allows each device to have a unique number, which can serve as an entry-code, password or ID number.

#### 5.3 I/O Programming Considerations

#### 5.3.1 BI-DIRECTIONAL I/O PORTS

Any instruction which writes, operates internally as a read followed by a write operation. The BCF and BSF instructions, for example, read the register into the CPU, execute the bit operation and write the result back to the register. Caution must be used when these instructions are applied to a port with both inputs and outputs defined. For example, a BSF operation on bit5 of PORTB will cause all eight bits of PORTB to be read into the CPU. Then the BSF operation takes place on bit5 and PORTB is written to the output latches. If another bit of PORTB is used as a bi-directional I/O pin (e.g., bit0) and it is defined as an input at this time, the input signal present on the pin itself would be read into the CPU and re-written to the data latch of this particular pin, overwriting the previous content. As long as the pin stays in the Input mode, no problem occurs. However, if bit0 is switched into Output mode later on, the content of the data latch may now be unknown.

Reading the port register reads the values of the port pins. Writing to the port register writes the value to the port latch. When using read-modify-write instructions (ex. BCF, BSF, etc.) on a port, the value of the port pins is read, the desired operation is done to this value, and this value is then written to the port latch.

Example 5-2 shows the effect of two sequential read-modify-write instructions (ex.,  ${\tt BCF}\,,\ {\tt BSF},$  etc.) on an I/O port

A pin actively outputting a Low or High should not be driven from external devices at the same time in order to change the level on this pin ("wired-or", "wired-and"). The resulting high output currents may damage the chip.

#### EXAMPLE 5-2: READ-MODIFY-WRITE INSTRUCTIONS ON AN I/O PORT

| ; Initial PORT settings:                              | PORTB<7:4> Inpu            | ıts      |
|-------------------------------------------------------|----------------------------|----------|
| ;                                                     | PORTB<3:0> Outp            | puts     |
| ; PORTB<7:6> have external ; connected to other circu | . pull-up and are<br>uitry | not      |
| ;                                                     |                            |          |
| ;                                                     | PORT latch PO              | ORT pins |
| ;                                                     |                            |          |
|                                                       | -                          |          |
|                                                       |                            |          |
| BCF PORTB, 7                                          | ;01pp pppp 11              | ipp pppp |
| BCF PORTB, 6                                          | ;10pp pppp 11              | lpp pppp |
| BSF STATUS, RPO                                       | ;                          |          |
| BCF TRISB, 7                                          | ;10pp pppp 11              | lpp pppp |
| BCF TRISB, 6                                          | ;10pp pppp 10              | )pp pppp |
| ;                                                     |                            |          |
| ; Note that the user may h                            | ave expected the           | pin      |
| ; values to be 00pp pppp.                             | The 2nd BCF cause          | ed       |
| ; RB7 to be latched as the                            | e pin value (High)         | ).       |
|                                                       |                            |          |

### 5.3.2 SUCCESSIVE OPERATIONS ON I/O PORTS

The actual write to an I/O port happens at the end of an instruction cycle, whereas for reading, the data must be valid at the beginning of the instruction cycle (Figure 5-7). Therefore, care must be exercised if a write followed by a read operation is carried out on the same I/O port. The sequence of instructions should be such to allow the pin voltage to stabilize (load dependent) before the next instruction which causes that file to be read into the CPU is executed. Otherwise, the previous state of that pin may be read into the CPU rather than the new state. When in doubt, it is better to separate these instructions with a NOP or another instruction not accessing this I/O port.



#### FIGURE 5-7: SUCCESSIVE I/O OPERATION

#### 6.3.1 SWITCHING PRESCALER ASSIGNMENT

The prescaler assignment is fully under software control (i.e., it can be changed "on-the-fly" during program execution). To avoid an unintended device RESET, the following instruction sequence (Example 6-1) must be executed when changing the prescaler assignment from Timer0 to WDT.)

#### EXAMPLE 6-1: CHANGING PRESCALER (TIMER0→WDT)

|          | -            |                                               |
|----------|--------------|-----------------------------------------------|
| 1.BCF    | STATUS, RPO  | ;Skip if already in<br>;Bank 0                |
| 2.CLRWDT |              | ;Clear WDT                                    |
| 3.CLRF   | TMR0         | ;Clear TMR0 & Prescaler                       |
| 4.BSF    | STATUS, RPO  | ;Bank 1                                       |
| 5.MOVLW  | '00101111'b; | ;These 3 lines (5, 6, 7)                      |
| 6.MOVWF  | OPTION       | ;are required only if<br>;desired PS<2:0> are |
| 7.CLRWDT |              | ;000 or 001                                   |
| 8.MOVLW  | '00101xxx'b  | ;Set Postscaler to                            |
| 9.MOVWF  | OPTION       | ;desired WDT rate                             |
| 10.BCF   | STATUS, RPO  | ;Return to Bank 0                             |
|          |              |                                               |

To change prescaler from the WDT to the TMR0 module, use the sequence shown in Example 6-2. This precaution must be taken even if the WDT is disabled.

#### EXAMPLE 6-2:

#### CHANGING PRESCALER (WDT→TIMER0)

|        | •           |                    |
|--------|-------------|--------------------|
| CLRWDT |             | ;Clear WDT and     |
|        |             | ;prescaler         |
| BSF    | STATUS, RPO |                    |
| MOVLW  | b'xxxx0xxx' | ;Select TMR0, new  |
|        |             | prescale value and |
|        |             | , plock gourgo     |
|        |             | ,CIOCK SOULCE      |
| MOVWF  | OPTION REG  |                    |
| BCF    | STATUS, RPO |                    |
|        |             |                    |

#### TABLE 6-1: REGISTERS ASSOCIATED WITH TIMER0

| 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 |
|---------|--------|--------|-------------|-------|--------|--------|--------|--------|--------|-----------------|---------------------------------|
| 01h     | TMR0   | Timer0 | module regi | ister |        |        |        |        |        | XXXX XXXX       | uuuu uuuu                       |
| 0Bh/8Bh | INTCON | GIE    | PEIE        | T0IE  | INTE   | RBIE   | TOIF   | INTF   | RBIF   | 0000 000x       | 0000 000u                       |
| 81h     | OPTION | RBPU   | INTEDG      | TOCS  | TOSE   | PSA    | PS2    | PS1    | PS0    | 1111 1111       | 1111 1111                       |
| 85h     | TRISA  | _      | _           |       | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 1 1111          | 1 1111                          |

Legend: — = Unimplemented locations, read as '0', u = unchanged, x = unknown

**Note:** Shaded bits are not used by TMR0 module.

#### 7.6 Comparator Interrupts

The comparator interrupt flag is set whenever there is a change in the output value of either comparator. Software will need to maintain information about the status of the output bits, as read from CMCON<7:6>, to determine the actual change that has occurred. The CMIF bit, PIR1<6>, is the comparator interrupt flag. The CMIF bit must be RESET by clearing '0'. Since it is also possible to write a '1' to this register, a simulated interrupt may be initiated.

The CMIE bit (PIE1<6>) and the PEIE bit (INTCON<6>) must be set to enable the interrupt. In addition, the GIE bit must also be set. If any of these bits are clear, the interrupt is not enabled, though the CMIF bit will still be set if an interrupt condition occurs.

| Note: | If a change in the CMCON register          |
|-------|--------------------------------------------|
|       | (C1OUT or C2OUT) should occur when a       |
|       | read operation is being executed (start of |
|       | the Q2 cycle), then the CMIF (PIR1<6>)     |
|       | interrupt flag may not get set.            |

The user, in the interrupt service routine, can clear the interrupt in the following manner:

- a) Any read or write of CMCON. This will end the mismatch condition.
- b) Clear flag bit CMIF.

A mismatch condition will continue to set flag bit CMIF. Reading CMCON will end the mismatch condition and allow flag bit CMIF to be cleared.

### 7.7 Comparator Operation During SLEEP

When a comparator is active and the device is placed in SLEEP mode, the comparator remains active and the interrupt is functional if enabled. This interrupt will

Vdd ∆Vt = 0.6V RIC Rs < 10K Δικ **I**LEAKAGE CPIN VT = 0.6V ±500 nA 5 pF Vss Input Capacitance Legend CPIN = Threshold Voltage Vт = Leakage Current at the pin due to various junctions ILEAKAGE = = Interconnect Resistance RIC Rs = Source Impedance Analog Voltage VA =

FIGURE 7-4: ANALOG INPUT MODEL

wake up the device from SLEEP mode when enabled. While the comparator is powered-up, higher SLEEP currents than shown in the power-down current specification will occur. Each comparator that is operational will consume additional current as shown in the comparator specifications. To minimize power consumption while in SLEEP mode, turn off the comparators, CM<2:0> = 111, before entering SLEEP. If the device wakes up from SLEEP, the contents of the CMCON register are not affected.

#### 7.8 Effects of a RESET

A device RESET forces the CMCON register to its RESET state. This forces the comparator module to be in the comparator RESET mode, CM<2:0> = 000. This ensures that all potential inputs are analog inputs. Device current is minimized when analog inputs are present at RESET time. The comparators will be powered-down during the RESET interval.

#### 7.9 Analog Input Connection Considerations

A simplified circuit for an analog input is shown in Figure 7-4. Since the analog pins are connected to a digital output, they have reverse biased diodes to VDD and Vss. The analog input therefore, must be between Vss and VDD. If the input voltage deviates from this range by more than 0.6V in either direction, one of the diodes is forward biased and a latchup may occur. A maximum source impedance of  $10 \ k\Omega$ is recommended for the analog sources. Any external component connected to an analog input pin, such as a capacitor or a Zener diode, should have very little leakage current.

### 9.0 SPECIAL FEATURES OF THE CPU

Special circuits to deal with the needs of real-time applications are what sets a microcontroller apart from other processors. The PIC16C62X family has a host of such features intended to maximize system reliability, minimize cost through elimination of external components, provide power saving operating modes and offer code protection.

These are:

- 1. OSC selection
- 2. RESET Power-on Reset (POR) Power-up Timer (PWRT) Oscillator Start-up Timer (OST) Brown-out Reset (BOR)
- 3. Interrupts
- 4. Watchdog Timer (WDT)
- 5. SLEEP
- 6. Code protection
- 7. ID Locations
- 8. In-Circuit Serial Programming™

The PIC16C62X devices have a Watchdog Timer which is controlled by configuration bits. It runs off its own RC oscillator for added reliability. There are two timers that offer necessary delays on power-up. One is the Oscillator Start-up Timer (OST), intended to keep the chip in RESET until the crystal oscillator is stable. The other is the Power-up Timer (PWRT), which provides a fixed delay of 72 ms (nominal) on power-up only, designed to keep the part in RESET while the power supply stabilizes. There is also circuitry to RESET the device if a brown-out occurs, which provides at least a 72 ms RESET. With these three functions on-chip, most applications need no external RESET circuitry.

The SLEEP mode is designed to offer a very low current Power-down mode. The user can wake-up from SLEEP through external RESET, Watchdog Timer wake-up or through an interrupt. Several oscillator options are also made available to allow the part to fit the application. The RC oscillator option saves system cost, while the LP crystal option saves power. A set of configuration bits are used to select various options.

#### 9.1 Configuration Bits

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

The user will note that address 2007h is beyond the user program memory space. In fact, it belongs to the special test/configuration memory space (2000h - 3FFFh), which can be accessed only during programming.

#### REGISTER 9-1: CONFIGURATION WORD (ADDRESS 2007h)

| CP1              | CP0 (2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | CP1                                                                                                                                                                                                                                                                                                                                      | CP0 (2)            | CP1        | CP0 (2)   |      | BODEN | CP1     | CP0 <sup>(2)</sup> | PWRTE       | WDTE     | F0SC1 | F0SC0 |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------|-----------|------|-------|---------|--------------------|-------------|----------|-------|-------|
| bit 13           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                          |                    |            |           |      | Į     |         | ļ                  |             | <u> </u> | ļ     | bit 0 |
| bit 13-8<br>5-4: | S, CP<1:0>: Code protection bit pairs <sup>(2)</sup><br>Code protection for 2K program memory<br>11 = Program memory code protection off<br>10 = 0400h-07FFh code protected<br>01 = 0200h-07FFh code protected<br>00 = 0000h-07FFh code protected Code protection for 1K program memory<br>11 = Program memory code protection off<br>10 = Program memory code protection off<br>10 = Program memory code protected 000h-03FFh code protected 000h-03FFh code protected |                                                                                                                                                                                                                                                                                                                                          |                    |            |           |      |       |         |                    |             |          |       |       |
|                  | Cod<br>11 =<br>10 =<br>01 =<br>00 =                                                                                                                                                                                                                                                                                                                                                                                                                                     | Code protection for 0.5K program memory<br>11 = Program memory code protection off<br>10 = Program memory code protection off<br>01 = Program memory code protection off<br>00 = 0000h-01FFh code protected                                                                                                                              |                    |            |           |      |       |         |                    |             |          |       |       |
| bit 7            | Uniı                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | npleme                                                                                                                                                                                                                                                                                                                                   | e <b>nted</b> : Re | ead as 'C  | )'        |      |       |         |                    |             |          |       |       |
| bit 6            | BOI                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DEN: Br                                                                                                                                                                                                                                                                                                                                  | own-out            | Reset E    | nable bit | (1)  |       |         |                    |             |          |       |       |
|                  | 1 =<br>0 =                                                                                                                                                                                                                                                                                                                                                                                                                                                              | BOR en<br>BOR dis                                                                                                                                                                                                                                                                                                                        | abled<br>sabled    |            |           |      |       |         |                    |             |          |       |       |
| bit 3            | <b>PWI</b><br>1 =<br>0 =                                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>PWRTE</b> : Power-up Timer Enable bit <sup>(1, 3)</sup><br>1 = PWRT disabled<br>0 = PWRT enabled                                                                                                                                                                                                                                      |                    |            |           |      |       |         |                    |             |          |       |       |
| bit 2            | <b>WD</b><br>1 = '<br>0 = '                                                                                                                                                                                                                                                                                                                                                                                                                                             | WDTE: Watchdog Timer Enable bit<br>1 = WDT enabled<br>0 = WDT disabled                                                                                                                                                                                                                                                                   |                    |            |           |      |       |         |                    |             |          |       |       |
| bit 1-0          | FOS                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | C1:FO                                                                                                                                                                                                                                                                                                                                    | SCO: Oso           | cillator S | election  | bits |       |         |                    |             |          |       |       |
|                  | 11 -<br>10 =<br>01 =<br>00 =                                                                                                                                                                                                                                                                                                                                                                                                                                            | 11 = RC oscillator<br>10 = HS oscillator<br>01 = XT oscillator<br>00 = LP oscillator                                                                                                                                                                                                                                                     |                    |            |           |      |       |         |                    |             |          |       |       |
|                  | Note                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <ul> <li>Note 1: Enabling Brown-out Reset automatically enables Power-up Timer (PWRT) regardless of the value of bit PWRTE. Ensure the Power-up Timer is enabled anytime Brown-out Detect Reset is enabled.</li> <li>21 All of the CR&lt;1:0&gt; peirs have to be given the same value to enable the code protection actions.</li> </ul> |                    |            |           |      |       |         | the<br>eset is     |             |          |       |       |
|                  | <ol> <li>All of the CF &gt; 1.02 pairs have to be given the same value to enable the code protection schem<br/>listed.</li> <li>Unprogrammed parts default the Power-up Timer disabled.</li> </ol>                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                          |                    |            |           |      |       |         |                    |             |          |       |       |
| Logond           | 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                          |                    |            |           |      |       |         |                    |             |          |       |       |
| R = Re           | ı.<br>adable b                                                                                                                                                                                                                                                                                                                                                                                                                                                          | it                                                                                                                                                                                                                                                                                                                                       |                    | W = 1      | Writable  | bit  | U =   | Unimple | emented            | bit, read a | s '0'    |       |       |

#### 9.4 Power-on Reset (POR), Power-up Timer (PWRT), Oscillator Start-up Timer (OST) and Brown-out Reset (BOR)

#### 9.4.1 POWER-ON RESET (POR)

The on-chip POR circuit holds the chip in RESET until VDD has reached a high enough level for proper operation. To take advantage of the POR, just tie the MCLR pin through a resistor to VDD. This will eliminate external RC components usually needed to create Power-on Reset. A maximum rise time for VDD is required. See Electrical Specifications for details.

The POR circuit does not produce an internal RESET when VDD declines.

When the device starts normal operation (exits the RESET condition), device operating parameters (voltage, frequency, temperature, etc.) must be met to ensure operation. If these conditions are not met, the device must be held in RESET until the operating conditions are met.

For additional information, refer to Application Note AN607, "Power-up Trouble Shooting".

#### 9.4.2 POWER-UP TIMER (PWRT)

The Power-up Timer provides a fixed 72 ms (nominal) time-out on power-up only, from POR or Brown-out Reset. The Power-up Timer operates on an internal RC oscillator. The chip is kept in RESET as long as PWRT is active. The PWRT delay allows the VDD to rise to an acceptable level. A configuration bit, PWRTE can disable (if set) or enable (if cleared or programmed) the Power-up Timer. The Power-up Timer should always be enabled when Brown-out Reset is enabled.

The Power-up Time delay will vary from chip-to-chip and due to VDD, temperature and process variation. See DC parameters for details.

#### 9.4.3 OSCILLATOR START-UP TIMER (OST)

The Oscillator Start-Up Timer (OST) provides a 1024 oscillator cycle (from OSC1 input) delay after the PWRT delay is over. This ensures that the crystal oscillator or resonator has started and stabilized.

The OST time-out is invoked only for XT, LP and HS modes and only on Power-on Reset or wake-up from SLEEP.

#### 9.4.4 BROWN-OUT RESET (BOR)

The PIC16C62X members have on-chip Brown-out Reset circuitry. A configuration bit, BODEN, can disable (if clear/programmed) or enable (if set) the Brown-out Reset circuitry. If VDD falls below 4.0V refer to VBOR parameter D005 (VBOR) for greater than parameter (TBOR) in Table 12-5. The brown-out situation will RESET the chip. A RESET won't occur if VDD falls below 4.0V for less than parameter (TBOR).

On any RESET (Power-on, Brown-out, Watchdog, etc.) the chip will remain in RESET until VDD rises above BVDD. The Power-up Timer will now be invoked and will keep the chip in RESET an additional 72 ms.

If VDD drops below BVDD while the Power-up Timer is running, the chip will go back into a Brown-out Reset and the Power-up Timer will be re-initialized. Once VDD rises above BVDD, the Power-Up Timer will execute a 72 ms RESET. The Power-up Timer should always be enabled when Brown-out Reset is enabled. Figure 9-7 shows typical Brown-out situations.



#### FIGURE 9-7: BROWN-OUT SITUATIONS

#### 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  $\overline{\text{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

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

### **10.1** Instruction Descriptions

| ADDLW            | Add Literal and W                                                                    |  |  |  |  |  |  |
|------------------|--------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ADDLW k                                                             |  |  |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                    |  |  |  |  |  |  |
| Operation:       | $(W) + k \to (W)$                                                                    |  |  |  |  |  |  |
| Status Affected: | C, DC, Z                                                                             |  |  |  |  |  |  |
| Encoding:        | 11 111x kkkk kkkk                                                                    |  |  |  |  |  |  |
| Description:     | added to the eight bit literal 'k' and<br>the result is placed in the W<br>register. |  |  |  |  |  |  |
| Cycles:          | 1                                                                                    |  |  |  |  |  |  |
| Example          | ADDLW 0x15                                                                           |  |  |  |  |  |  |
|                  | Before Instruction<br>W = 0x10<br>After Instruction<br>W = 0x25                      |  |  |  |  |  |  |

| ANDLW            | AND Literal with W                                                                                                     |  |  |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ANDLW k                                                                                               |  |  |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                                                      |  |  |  |  |  |  |
| Operation:       | (W) .AND. (k) $\rightarrow$ (W)                                                                                        |  |  |  |  |  |  |
| Status Affected: | Z                                                                                                                      |  |  |  |  |  |  |
| Encoding:        | 11 1001 kkkk kkkk                                                                                                      |  |  |  |  |  |  |
| Description:     | The contents of W register are<br>AND'ed with the eight bit literal 'k'.<br>The result is placed in the W<br>register. |  |  |  |  |  |  |
| Words:           | 1                                                                                                                      |  |  |  |  |  |  |
| Cycles:          | 1                                                                                                                      |  |  |  |  |  |  |
| Example          | ANDLW 0x5F                                                                                                             |  |  |  |  |  |  |
|                  | Before Instruction<br>W = 0xA3<br>After Instruction<br>W = 0x03                                                        |  |  |  |  |  |  |
| ANDWF            | AND W with f                                                                                                           |  |  |  |  |  |  |

| ADDWF            | Add W and f                                                                                                                                                                    |  |  |  |  |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ADDWF f,d                                                                                                                                                     |  |  |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in  [0,1] \end{array}$                                                                                                              |  |  |  |  |  |  |  |
| Operation:       | $(W) + (f) \rightarrow (dest)$                                                                                                                                                 |  |  |  |  |  |  |  |
| Status Affected: | C, DC, Z                                                                                                                                                                       |  |  |  |  |  |  |  |
| Encoding:        | 00 0111 dfff ffff                                                                                                                                                              |  |  |  |  |  |  |  |
| Description:     | Add the contents of the W register<br>with register 'f'. If 'd' is 0, the result<br>is stored in the W register. If 'd' is<br>1, the result is stored back in<br>register 'f'. |  |  |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                              |  |  |  |  |  |  |  |
| Cycles:          | 1                                                                                                                                                                              |  |  |  |  |  |  |  |
| Example          | ADDWF FSR, <b>O</b>                                                                                                                                                            |  |  |  |  |  |  |  |
|                  | Before Instruction<br>W = 0x17<br>FSR = 0xC2<br>After Instruction<br>W = 0xD9<br>FSR = 0xC2                                                                                    |  |  |  |  |  |  |  |

| ANDWF            | AND W with f                                                                                                                                                |  |  |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ANDWF f,d                                                                                                                                  |  |  |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in  [0,1] \end{array}$                                                                                           |  |  |  |  |  |  |  |
| Operation:       | (W) .AND. (f) $\rightarrow$ (dest)                                                                                                                          |  |  |  |  |  |  |  |
| Status Affected: | Z                                                                                                                                                           |  |  |  |  |  |  |  |
| Encoding:        | 00 0101 dfff ffff                                                                                                                                           |  |  |  |  |  |  |  |
| Description:     | AND the W register with register<br>'f'. If 'd' is 0, the result is stored in<br>the W register. If 'd' is 1, the result<br>is stored back in register 'f'. |  |  |  |  |  |  |  |
| Words:           | 1                                                                                                                                                           |  |  |  |  |  |  |  |
| Cycles:          | 1                                                                                                                                                           |  |  |  |  |  |  |  |
| Example          | ANDWF FSR, 1                                                                                                                                                |  |  |  |  |  |  |  |
|                  | Before Instruction<br>W = 0x17<br>FSR = 0xC2<br>After Instruction<br>W = 0x17<br>FSR = 0x02                                                                 |  |  |  |  |  |  |  |

| CLRW                                                                                                     | Clear W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | COMF                                                                                                                        | Complement f                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                                                                                  | [label] CLRW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Syntax:                                                                                                                     | [ <i>label</i> ] COMF f,d                                                                                                                                                                                                                                                                                                                                                                |
| Operands:                                                                                                | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Operands:                                                                                                                   | $0 \le f \le 127$                                                                                                                                                                                                                                                                                                                                                                        |
| Operation:                                                                                               | $00h \rightarrow (W)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                             | d ∈ [0,1]                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                          | $1 \rightarrow Z$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Operation:                                                                                                                  | $(f) \rightarrow (dest)$                                                                                                                                                                                                                                                                                                                                                                 |
| Status Affected:                                                                                         | Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Status Affected:                                                                                                            | Z                                                                                                                                                                                                                                                                                                                                                                                        |
| Encoding:                                                                                                | 00 0001 0000 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Encoding:                                                                                                                   | 00 1001 dfff ffff                                                                                                                                                                                                                                                                                                                                                                        |
| Description:                                                                                             | W register is cleared. Zero bit (Z) is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Description:                                                                                                                | The contents of register 'f' are complemented. If 'd' is 0, the                                                                                                                                                                                                                                                                                                                          |
| Words:                                                                                                   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                             | result is stored in W. If 'd' is 1, the                                                                                                                                                                                                                                                                                                                                                  |
| Cycles:                                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Words:                                                                                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                        |
| Example                                                                                                  | CLRW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Cycles:                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                          | Before Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Evernle                                                                                                                     | COME DECI 0                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                          | W = 0x5A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Example                                                                                                                     | Comp REGI, 0                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                          | W = 0x00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                             | REG1 = $0x13$                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                          | Z = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                             | After Instruction                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                             | $\begin{array}{rcl} REG1 &= & 0x13 \\ W &= & 0xEC \end{array}$                                                                                                                                                                                                                                                                                                                           |
| CLRWDT                                                                                                   | Clear Watchdog Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                          |
| Syntax:                                                                                                  | [label] CLRWDT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                          |
| e jineaa                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | DECE                                                                                                                        | Decrement f                                                                                                                                                                                                                                                                                                                                                                              |
| Operands:                                                                                                | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DECF                                                                                                                        | Decrement f                                                                                                                                                                                                                                                                                                                                                                              |
| Operands:<br>Operation:                                                                                  | None $00h \rightarrow WDT$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DECF<br>Syntax:                                                                                                             | Decrement f [/abe/] DECF f,d                                                                                                                                                                                                                                                                                                                                                             |
| Operands:<br>Operation:                                                                                  | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow \overline{TO}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | DECF<br>Syntax:<br>Operands:                                                                                                | Decrement f<br>[ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                                                           |
| Operands:<br>Operation:                                                                                  | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow PD$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | DECF<br>Syntax:<br>Operands:<br>Operation:                                                                                  | Decrement f<br>[ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 $\rightarrow$ (dest)                                                                                                                                                                                                                                                                           |
| Operands:<br>Operation:<br>Status Affected:                                                              | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow PD$<br>$\overline{TO}, PD$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:                                                              | Decrement f<br>[ label ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 $\rightarrow$ (dest)<br>7                                                                                                                                                                                                                                                                             |
| Operands:<br>Operation:<br>Status Affected:                                                              | None<br>$00h \rightarrow WDT$ $0 \rightarrow WDT \text{ prescaler,}$ $1 \rightarrow TO$ $1 \rightarrow PD$ $TO, PD$ $00 \qquad 0000 \qquad 0110 \qquad 0100$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:                                                 | Decrement f $[label]$ DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dfffffff                                                                                                                                                                                                                                                                               |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | None<br>$00h \rightarrow WDT$ $0 \rightarrow WDT \text{ prescaler,}$ $1 \rightarrow \overline{TO}$ $1 \rightarrow PD$ $\overline{TO}, \overline{PD}$ $00  0000  0110  0100$ CLEWDT instruction resets the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | Decrement f $[label]$ DECF f,d $0 \le f \le 127$ $d \in [0,1]$ $(f) - 1 \rightarrow (dest)$ Z $00$ $0011$ dffdffDecrement register 'f'If 'd' is 0                                                                                                                                                                                                                                        |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | None<br>$00h \rightarrow WDT$ $0 \rightarrow WDT \text{ prescaler,}$ $1 \rightarrow \overline{10}$ $1 \rightarrow PD$ $\overline{10}, PD$ $00  0000  0110  0100$ CLRWDT instruction resets the<br>Watchdog Timer. It also resets the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | Decrement f[ label ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dfffDecrement register 'f'. If 'd' is 0,the result is stored in the W                                                                                                                                                                                                                   |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow PD$<br>$\overline{TO}, \overline{PD}$<br>OUDIAL OF CONSTRUCTION OF CONSTRUCTURE OF CONSTRUCTION OF CONSTRUCTURE OF CONSTRUCTION OF CONSTRUCTURE OF CONSTRUCTION OF CONSTRUCTURE OF CONSTRUCTION OF CONSTRUCTURE OF CON | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | Decrement f[ label ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z $00$ $0011$ dffffffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result is                                                                                                                                                                     |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | None<br>$00h \rightarrow WDT$ $0 \rightarrow WDT \text{ prescaler,}$ $1 \rightarrow \overline{10}$ $1 \rightarrow PD$ $\overline{10}, PD$ $00  0000  0110  0100$ CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. STATUS<br>bits TO and PD are set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | Decrement f[ label ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dfffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.                                                                                                                                                   |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:                       | None<br>$\begin{array}{c} 00h \rightarrow WDT \\ 0 \rightarrow WDT \text{ prescaler,} \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow PD \\ \hline \overline{TO}, \overline{PD} \\ \hline \hline 00 & 0000 & 0110 & 0100 \\ \hline \\ CLRWDT \text{ instruction resets the} \\ Watchdog Timer. It also resets the \\ prescaler of the WDT. STATUS \\ bits TO and PD are set. \\ 1 \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:                       | Decrement f $[label]$ DECF f,d $0 \le f \le 127$ $d \in [0,1]$ $(f) - 1 \rightarrow (dest)$ Z $00$ $0011$ dffffffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.1                                                                                                                                      |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:            | None<br>$00h \rightarrow WDT$ $0 \rightarrow WDT prescaler,$ $1 \rightarrow TO$ $1 \rightarrow PD$ $TO, PD$ $00 0000 0110 0100$ CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>pres <u>caler of the</u> WDT. STATUS<br>bits TO and PD are set.<br>1<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:            | Decrement f[ label ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dffffffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.11                                                                                                                                              |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$\begin{array}{l} 00h \rightarrow WDT \\ 0 \rightarrow WDT \text{ prescaler,} \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow PD \\ \hline \overline{TO}, \overline{PD} \\ \hline \hline 00 & 0000 & 0110 & 0100 \\ \hline \end{array}$ CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. STATUS<br>bits TO and PD are set.<br>1<br>1<br>CLRWDT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f[ label ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z $00$ $0011$ dffffffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.11DECFCNT, 1                                                                                                                             |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT prescaler,$<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow PD$<br>$\overline{TO}, PD$<br>00  0000  0110  0100<br>CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. STATUS<br>bits TO and PD are set.<br>1<br>1<br>CLRWDT<br>Before Instruction<br>WDT counter = 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f<br>[ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 → (dest)<br>Z<br>00 0011 dfff ffff<br>Decrement register 'f'. If 'd' is 0,<br>the result is stored in the W<br>register. If 'd' is 1, the result is<br>stored back in register 'f'.<br>1<br>1<br>DECF CNT, 1<br>Before Instruction<br>CNT = 0x01                                               |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$\begin{array}{l} 00h \rightarrow WDT \\ 0 \rightarrow WDT \text{ prescaler,} \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow PD \\ \hline \overline{TO}, \overline{PD} \\ \hline \hline 00 & 0000 & 0110 & 0100 \\ \hline \end{array}$ CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. STATUS<br>bits TO and PD are set.<br>1<br>1<br>CLRWDT<br>Before Instruction<br>WDT counter = ?<br>After Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f[ label ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dffffffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.11DECFCNT, 1Before Instruction $CNT = 0x01$ $Z = 0$                                                                                             |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$\begin{array}{c} 00h \rightarrow WDT \\ 0 \rightarrow WDT \ prescaler, \\ 1 \rightarrow TO \\ 1 \rightarrow PD \\ \hline TO, PD \\ \hline 00 & 0000 & 0110 & 0100 \\ \hline \\ CLRWDT \ instruction \ resets the \\ Watchdog \ Timer. It also resets the \\ prescaler \ of \ the \ WDT. \ STATUS \\ bits \ TO \ and \ PD \ are \ set. \\ 1 \\ 1 \\ \hline \\ CLRWDT \\ \hline \\ Before \ Instruction \\ \ WDT \ counter \ = \ ? \\ After \ Instruction \\ \ WDT \ counter \ = \ 0x00 \\ \hline \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f[ label ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z $00$ $0011$ dffffffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.11DECFCNT, 1Before InstructionCNTZ0After Instruction                                                                                     |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$\begin{array}{c} 00h \rightarrow WDT\\ 0 \rightarrow WDT \ prescaler,\\ 1 \rightarrow \overline{TO}\\ 1 \rightarrow PD\\ \hline \overline{TO}, \overline{PD}\\ \hline \hline 00 & 0000 & 0110 & 0100\\ \hline \end{array}$ CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. STATUS<br>bits $\overline{TO}$ and $\overline{PD}$ are set.<br>1<br>1<br>CLRWDT<br>Before Instruction<br>WDT counter = ?<br>After Instruction<br>WDT counter = 0<br>$\overline{TO}$ = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | DECF<br>Syntax:<br>Operands:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example               | Decrement f[ label ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dffffffDecrement register 'f'. If 'd' is 0,<br>the result is stored in the W<br>register. If 'd' is 1, the result is<br>stored back in register 'f'.11DECFCNT, 1Before Instruction<br>$Z = 0$ After Instruction<br>$CNT = 0x01$<br>$Z = 0$ After Instruction<br>$CNT = 0x00$<br>$Z = 1$ |

| RETFIE           | Return from Interrupt                                                                                                                                                                                                |                        |          |      |  |  |  |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------|------|--|--|--|--|
| Syntax:          | [ label ]                                                                                                                                                                                                            | RETFIE                 | -        |      |  |  |  |  |
| Operands:        | None                                                                                                                                                                                                                 |                        |          |      |  |  |  |  |
| Operation:       | $TOS \rightarrow PC, \\ 1 \rightarrow GIE$                                                                                                                                                                           |                        |          |      |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                                                 |                        |          |      |  |  |  |  |
| Encoding:        | 00                                                                                                                                                                                                                   | 0000                   | 0000     | 1001 |  |  |  |  |
| Description:     | Return from Interrupt. Stack is<br>POPed and Top of Stack (TOS) is<br>loaded in the PC. Interrupts are<br>enabled by setting Global<br>Interrupt Enable bit, GIE<br>(INTCON<7>). This is a two-cycle<br>instruction. |                        |          |      |  |  |  |  |
| Words:           | 1                                                                                                                                                                                                                    |                        |          |      |  |  |  |  |
| Cycles:          | 2                                                                                                                                                                                                                    |                        |          |      |  |  |  |  |
| Example          | RETFIE                                                                                                                                                                                                               |                        |          |      |  |  |  |  |
|                  | After Inte                                                                                                                                                                                                           | rrupt<br>PC =<br>GIE = | TOS<br>1 |      |  |  |  |  |

| RETLW            | Return with Literal in W                                                                                                                                                            |  |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] RETLW k                                                                                                                                                            |  |  |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                                                                                                                   |  |  |  |  |  |  |
| Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow$ PC                                                                                                                                        |  |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                |  |  |  |  |  |  |
| Encoding:        | 11 01xx kkkk kkkk                                                                                                                                                                   |  |  |  |  |  |  |
| Description:     | The W register is loaded with the<br>eight bit literal 'k'. The program<br>counter is loaded from the top of<br>the stack (the return address).<br>This is a two-cycle instruction. |  |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                                   |  |  |  |  |  |  |
| Cycles:          | 2                                                                                                                                                                                   |  |  |  |  |  |  |
| Example          | CALL TABLE;W contains<br>table                                                                                                                                                      |  |  |  |  |  |  |
| TABLE            | ;offset value<br>;W now has table value<br>ADDWF PC ;W = offset<br>RETLW k1 ;Begin table<br>RETLW k2 ;                                                                              |  |  |  |  |  |  |
|                  | •<br>•<br>RETLW kn ; End of table                                                                                                                                                   |  |  |  |  |  |  |
|                  | W = 0x07 After Instruction $W = value of k8$                                                                                                                                        |  |  |  |  |  |  |
| RETURN           | Return from Subroutine                                                                                                                                                              |  |  |  |  |  |  |
| Syntax:          | [label] RETURN                                                                                                                                                                      |  |  |  |  |  |  |
| Operands:        | None                                                                                                                                                                                |  |  |  |  |  |  |
| Operation:       | $TOS \rightarrow PC$                                                                                                                                                                |  |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                |  |  |  |  |  |  |
| Encoding:        | 00 0000 0000 1000                                                                                                                                                                   |  |  |  |  |  |  |
| Description:     | Return from subroutine. The stack<br>is POPed and the top of the stack<br>(TOS) is loaded into the program<br>counter. This is a two-cycle<br>instruction.                          |  |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                                   |  |  |  |  |  |  |
| Cycles:          | 2                                                                                                                                                                                   |  |  |  |  |  |  |
| Example          | RETURN                                                                                                                                                                              |  |  |  |  |  |  |
|                  | After Interrupt<br>PC = TOS                                                                                                                                                         |  |  |  |  |  |  |

#### 11.9 MPLAB ICE 2000 High Performance Universal In-Circuit Emulator

The MPLAB ICE 2000 universal in-circuit emulator is intended to provide the product development engineer with a complete microcontroller design tool set for PICmicro microcontrollers. Software control of the MPLAB ICE 2000 in-circuit emulator is advanced by the MPLAB Integrated Development Environment, which allows editing, building, downloading and source debugging from a single environment.

The MPLAB ICE 2000 is a full-featured emulator system with enhanced trace, trigger and data monitoring features. Interchangeable processor modules allow the system to be easily reconfigured for emulation of different processors. The universal architecture of the MPLAB ICE in-circuit emulator allows expansion to support new PICmicro microcontrollers.

The MPLAB ICE 2000 in-circuit emulator system has been designed as a real-time emulation system with advanced features that are typically found on more expensive development tools. The PC platform and Microsoft<sup>®</sup> Windows 32-bit operating system were chosen to best make these features available in a simple, unified application.

#### 11.10 MPLAB ICE 4000 High Performance Universal In-Circuit Emulator

The MPLAB ICE 4000 universal in-circuit emulator is intended to provide the product development engineer with a complete microcontroller design tool set for highend PICmicro microcontrollers. Software control of the MPLAB ICE in-circuit emulator is provided by the MPLAB Integrated Development Environment, which allows editing, building, downloading and source debugging from a single environment.

The MPLAB ICD 4000 is a premium emulator system, providing the features of MPLAB ICE 2000, but with increased emulation memory and high speed performance for dsPIC30F and PIC18XXXX devices. Its advanced emulator features include complex triggering and timing, up to 2 Mb of emulation memory, and the ability to view variables in real-time.

The MPLAB ICE 4000 in-circuit emulator system has been designed as a real-time emulation system with advanced features that are typically found on more expensive development tools. The PC platform and Microsoft Windows 32-bit operating system were chosen to best make these features available in a simple, unified application.

#### 11.11 MPLAB ICD 2 In-Circuit Debugger

Microchip's In-Circuit Debugger, MPLAB ICD 2, is a powerful, low cost, run-time development tool, connecting to the host PC via an RS-232 or high speed USB interface. This tool is based on the FLASH PICmicro MCUs and can be used to develop for these and other PICmicro microcontrollers. The MPLAB ICD 2 utilizes the in-circuit debugging capability built into the FLASH devices. This feature, along with Microchip's In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) protocol, offers cost effective in-circuit FLASH debugging from the graphical user interface of the MPLAB Integrated Development Environment. This enables a designer to develop and debug source code by setting breakpoints, single-stepping and watching variables, CPU status and peripheral registers. Running at full speed enables testing hardware and applications in real-time. MPLAB ICD 2 also serves as a development programmer for selected PICmicro devices.

#### 11.12 PRO MATE II Universal Device Programmer

The PRO MATE II is a universal, CE compliant device programmer with programmable voltage verification at VDDMIN and VDDMAX for maximum reliability. It features an LCD display for instructions and error messages and a modular detachable socket assembly to support various package types. In Stand-Alone mode, the PRO MATE II device programmer can read, verify, and program PICmicro devices without a PC connection. It can also set code protection in this mode.

#### 11.13 PICSTART Plus Development Programmer

The PICSTART Plus development programmer is an easy-to-use, low cost, prototype programmer. It connects to the PC via a COM (RS-232) port. MPLAB Integrated Development Environment software makes using the programmer simple and efficient. The PICSTART Plus development programmer supports most PICmicro devices up to 40 pins. Larger pin count devices, such as the PIC16C92X and PIC17C76X, may be supported with an adapter socket. The PICSTART Plus development programmer is CE compliant.

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

#### 11.20 PICDEM 18R PIC18C601/801 Demonstration Board

The PICDEM 18R demonstration board serves to assist development of the PIC18C601/801 family of Microchip microcontrollers. It provides hardware implementation of both 8-bit Multiplexed/De-multiplexed and 16-bit Memory modes. The board includes 2 Mb external FLASH memory and 128 Kb SRAM memory, as well as serial EEPROM, allowing access to the wide range of memory types supported by the PIC18C601/801.

#### 11.21 PICDEM LIN PIC16C43X Demonstration Board

The powerful LIN hardware and software kit includes a series of boards and three PICmicro microcontrollers. The small footprint PIC16C432 and PIC16C433 are used as slaves in the LIN communication and feature on-board LIN transceivers. A PIC16F874 FLASH microcontroller serves as the master. All three micro-controllers are programmed with firmware to provide LIN bus communication.

#### 11.22 PICkit<sup>™</sup> 1 FLASH Starter Kit

A complete "development system in a box", the PICkit FLASH Starter Kit includes a convenient multi-section board for programming, evaluation, and development of 8/14-pin FLASH PIC<sup>®</sup> microcontrollers. Powered via USB, the board operates under a simple Windows GUI. The PICkit 1 Starter Kit includes the user's guide (on CD ROM), PICkit 1 tutorial software and code for various applications. Also included are MPLAB<sup>®</sup> IDE (Integrated Development Environment) software, software and hardware "Tips 'n Tricks for 8-pin FLASH PIC<sup>®</sup> Microcontrollers" Handbook and a USB Interface Cable. Supports all current 8/14-pin FLASH PIC microcontrollers, as well as many future planned devices.

#### 11.23 PICDEM USB PIC16C7X5 Demonstration Board

The PICDEM USB Demonstration Board shows off the capabilities of the PIC16C745 and PIC16C765 USB microcontrollers. This board provides the basis for future USB products.

#### 11.24 Evaluation and Programming Tools

In addition to the PICDEM series of circuits, Microchip has a line of evaluation kits and demonstration software for these products.

- KEELOQ evaluation and programming tools for Microchip's HCS Secure Data Products
- CAN developers kit for automotive network applications
- Analog design boards and filter design software
- PowerSmart battery charging evaluation/ calibration kits
- IrDA<sup>®</sup> development kit
- microID development and rfLab<sup>™</sup> development software
- SEEVAL<sup>®</sup> designer kit for memory evaluation and endurance calculations
- PICDEM MSC demo boards for Switching mode power supply, high power IR driver, delta sigma ADC, and flow rate sensor

Check the Microchip web page and the latest Product Line Card for the complete list of demonstration and evaluation kits.

#### 12.1 DC Characteristics: PIC16C62X-04 (Commercial, Industrial, Extended) PIC16C62X-20 (Commercial, Industrial, Extended) PIC16LC62X-04 (Commercial, Industrial, Extended)

| PIC16C        | 62X  |                                               | <b>Stan</b><br>Oper                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | dard O<br>ating te | <b>perati</b><br>empera | <b>ng Con</b><br>ature -4<br>-4 | ditions (unless otherwise stated)<br>$10^{\circ}C \leq TA \leq +85^{\circ}C$ for industrial and<br>$0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial and<br>$10^{\circ}C \leq TA \leq +125^{\circ}C$ for extended |
|---------------|------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-------------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PIC16L        | C62X |                                               | $\begin{array}{ c c c c c c } \hline \textbf{Standard Operating Conditions (unless otherwise stated)} \\ \hline \textbf{Operating temperature } -40^{\circ}\text{C} &\leq \text{Ta} \leq +85^{\circ}\text{C} \text{ for industrial and} \\ 0^{\circ}\text{C} &\leq \text{Ta} \leq +70^{\circ}\text{C} \text{ for commercial and} \\ -40^{\circ}\text{C} &\leq \text{Ta} \leq +125^{\circ}\text{C} \text{ for extended} \\ \hline \textbf{Operating voltage VDD range is the PIC16C62X range.} \end{array}$ |                    |                         |                                 |                                                                                                                                                                                                                       |
| Param.<br>No. | Sym  | Characteristic                                | Min                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Тур†               | Max                     | Units                           | Conditions                                                                                                                                                                                                            |
| D001          | Vdd  | Supply Voltage                                | 3.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                    | 6.0                     | V                               | See Figures 12-1, 12-2, 12-3, 12-4, and 12-5                                                                                                                                                                          |
| D001          | Vdd  | Supply Voltage                                | 2.5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | —                  | 6.0                     | V                               | See Figures 12-1, 12-2, 12-3, 12-4, and 12-5                                                                                                                                                                          |
| D002          | Vdr  | RAM Data Retention Voltage <sup>(1)</sup>     | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1.5*               | —                       | V                               | Device in SLEEP mode                                                                                                                                                                                                  |
| D002          | Vdr  | RAM Data Retention Voltage <sup>(1)</sup>     | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1.5*               | —                       | V                               | Device in SLEEP mode                                                                                                                                                                                                  |
| D003          | VPOR | VDD start voltage to ensure<br>Power-on Reset | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Vss                | —                       | V                               | See section on Power-on Reset for details                                                                                                                                                                             |
| D003          | VPOR | VDD start voltage to<br>ensure Power-on Reset | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Vss                | —                       | V                               | See section on Power-on Reset for details                                                                                                                                                                             |
| D004          | SVDD | VDD rise rate to ensure<br>Power-on Reset     | 0.05*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | —                  | —                       | V/ms                            | See section on Power-on Reset for details                                                                                                                                                                             |
| D004          | SVDD | VDD rise rate to ensure<br>Power-on Reset     | 0.05*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | —                  | —                       | V/ms                            | See section on Power-on Reset for details                                                                                                                                                                             |
| D005          | VBOR | Brown-out Detect Voltage                      | 3.7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 4.0                | 4.3                     | V                               | BOREN configuration bit is cleared                                                                                                                                                                                    |
| D005          | VBOR | Brown-out Detect Voltage                      | 3.7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 4.0                | 4.3                     | V                               | BOREN configuration bit is cleared                                                                                                                                                                                    |
| D010          | IDD  | Supply Current <sup>(2)</sup>                 | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1.8                | 3.3                     | mA                              | Fosc = 4 MHz, Vdd = 5.5V, WDT disabled, XT<br>mode, ( <b>Note 4</b> )*                                                                                                                                                |
|               |      |                                               | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 35                 | 70                      | μA                              | Fosc = 32 kHz, VDD = 4.0V, WDT disabled, LP                                                                                                                                                                           |
|               |      |                                               | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 9.0                | 20                      | mA                              | Fosc = 20 MHz, VDD = 5.5V, WDT disabled, HS mode                                                                                                                                                                      |
| D010          | IDD  | Supply Current <sup>(2)</sup>                 | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1.4                | 2.5                     | mA                              | Fosc = 2.0 MHz, VDD = 3.0V, WDT disabled, XT mode, ( <b>Note 4</b> )                                                                                                                                                  |
|               |      |                                               | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 26                 | 53                      | μA                              | Fosc = 32 kHz, VDD = 3.0V, WDT disabled, LP mode                                                                                                                                                                      |
| D020          | IPD  | Power-down Current <sup>(3)</sup>             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1.0                | 2.5<br>15               | μΑ<br>μΑ                        | VDD=4.0V, WDT disabled<br>(125°C)                                                                                                                                                                                     |
| D020          | IPD  | Power-down Current <sup>(3)</sup>             | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0.7                | 2                       | μA                              | VDD=3.0V, WDT disabled                                                                                                                                                                                                |

\* These parameters are characterized but not tested.

† Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

Note 1: This is the limit to which VDD can be lowered without losing RAM data.

2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an impact on the current consumption.

The test conditions for all IDD measurements in Active Operation mode are:

OSC1 = external square wave, from rail to rail; all I/O pins tri-stated, pulled to VDD,

 $\overline{MCLR}$  = VDD; WDT enabled/disabled as specified.

3: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD or Vss.

4: For RC osc configuration, current through REXT is not included. The current through the resistor can be estimated by the formula: Ir = VDD/2REXT (mA) with REXT in kΩ.

5: The  $\Delta$  current is the additional current consumed when this peripheral is enabled. This current should be added to the base IDD or IPD measurement.

|                  |       |                |       | Standard Operating Conditions (unless otherwise stated) |        |          |                                           |                                           |
|------------------|-------|----------------|-------|---------------------------------------------------------|--------|----------|-------------------------------------------|-------------------------------------------|
| PIC16CR          | 62XA- | 04             | Opera | ating te                                                | empera | ature -  | 40°C                                      | $\leq$ TA $\leq$ +85°C for industrial and |
| PIC16CR          | 62XA- | 20             |       |                                                         |        |          | 0°C                                       | $\leq$ TA $\leq$ +70°C for commercial and |
|                  |       |                |       |                                                         |        | -4       | 40°C                                      | $\leq$ TA $\leq$ +125°C for extended      |
|                  |       |                | Stand | dard O                                                  | perati | ng Cor   | nditio                                    | ns (unless otherwise stated)              |
|                  | DESYA | 04             | Opera | ating te                                                | empera | ature -4 | 40°C                                      | $\leq$ TA $\leq$ +85°C for industrial and |
| PIC IOLCROZAA-04 |       |                |       |                                                         |        | 0°C      | $\leq$ TA $\leq$ +70°C for commercial and |                                           |
|                  |       |                |       |                                                         |        |          | 40°C                                      | $\leq$ TA $\leq$ +125°C for extended      |
| Param.           | Sym   | Characteristic | Min   | Typ†                                                    | Max    | Units    |                                           | Conditions                                |
| No.              |       |                |       |                                                         |        |          |                                           |                                           |

\* These parameters are characterized but not tested.

† Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

Note 1: This is the limit to which VDD can be lowered without losing RAM data.

2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an impact on the current consumption.

The test conditions for all IDD measurements in Active Operation mode are:

OSC1 = external square wave, from rail to rail; all I/O pins tri-stated, pulled to VDD,

MCLR = VDD; WDT enabled/disabled as specified.

**3:** The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD or Vss.

4: For RC osc configuration, current through REXT is not included. The current through the resistor can be estimated by the formula: Ir = VDD/2REXT (mA) with REXT in k $\Omega$ .

5: The ∆ current is the additional current consumed when this peripheral is enabled. This current should be added to the base IDD or IPD measurement.

**6:** Commercial temperature range only.









#### INDEX

| Α                      |    |
|------------------------|----|
| ADDLW Instruction      | 63 |
| ADDWF Instruction      | 63 |
| ANDLW Instruction      | 63 |
| ANDWF Instruction      | 63 |
| Architectural Overview | 9  |
| Assembler              |    |
| MPASM Assembler        | 75 |
| В                      |    |

| 8                                 |    |
|-----------------------------------|----|
| BCF Instruction                   | 64 |
| Block Diagram                     |    |
| TIMER0                            |    |
| TMR0/WDT PRESCALER                |    |
| Brown-Out Detect (BOD)            | 50 |
| BSF Instruction                   | 64 |
| BTFSC Instruction                 | 64 |
| BTFSS Instruction                 | 65 |
| С                                 |    |
| C Compilers                       |    |
| MPLAB C17                         | 76 |
| MPLAB C18                         | 76 |
| MPLAB C30                         | 76 |
| CALL Instruction                  |    |
| Clocking Scheme/Instruction Cycle |    |
| CLRF Instruction                  |    |
| CLRW Instruction                  |    |
| CLRWDT Instruction                |    |
| Code Protection                   | 60 |

| C Compilers                       |    |
|-----------------------------------|----|
| MPLAB C17                         | 76 |
| MPLAB C18                         | 76 |
| MPLAB C30                         | 76 |
| CALL Instruction                  | 65 |
| Clocking Scheme/Instruction Cycle | 12 |
| CLRF Instruction                  | 65 |
| CLRW Instruction                  |    |
| CLRWDT Instruction                | 66 |
| Code Protection                   | 60 |
| COMF Instruction                  |    |
| Comparator Configuration          |    |
| Comparator Interrupts             | 41 |
| Comparator Module                 |    |
| Comparator Operation              |    |
| Comparator Reference              |    |
| Configuration Bits                |    |
| Configuring the Voltage Reference |    |
| Crystal Operation                 |    |
|                                   |    |

#### D

| Data Memory Organization            |
|-------------------------------------|
| DC Characteristics                  |
| PIC16C717/770/771                   |
| DECF Instruction                    |
| DECFSZ Instruction                  |
| Demonstration Boards                |
| PICDEM 1                            |
| PICDEM 17                           |
| PICDEM 18R PIC18C601/80179          |
| PICDEM 2 Plus78                     |
| PICDEM 3 PIC16C92X                  |
| PICDEM 4                            |
| PICDEM LIN PIC16C43X79              |
| PICDEM USB PIC16C7X579              |
| PICDEM.net Internet/Ethernet        |
| Development Support75               |
| E                                   |
| Errata3                             |
| Evaluation and Programming Tools    |
| External Crystal Oscillator Circuit |
| G                                   |
| General purpose Register File       |
| GOTO Instruction                    |

I

| I/O Ports                                         | 25       |
|---------------------------------------------------|----------|
| I/O Programming Considerations                    | 30       |
| ID Locations                                      | 60       |
| INCEST Instruction                                | 67<br>69 |
| In-Circuit Serial Programming                     | 60<br>60 |
| Indirect Addressing, INDF and FSR Registers       | 24       |
| Instruction Flow/Pipelining                       | 12       |
| Instruction Set                                   |          |
| ADDLW                                             | 63       |
|                                                   | 63       |
|                                                   | 63<br>63 |
| BCF                                               | 64       |
| BSF                                               | 64       |
| BTFSC                                             | 64       |
| BTFSS                                             | 65       |
| CALL                                              | 65       |
| CLRF                                              | 65       |
|                                                   | 66<br>66 |
| COME                                              | 66<br>66 |
| DECF                                              | 66       |
| DECFSZ                                            | 67       |
| GOTO                                              | 67       |
| INCF                                              | 67       |
| INCFSZ                                            | 68       |
| IORLW                                             | 68       |
|                                                   | 60<br>60 |
|                                                   | 69<br>68 |
| MOVWE                                             | 60<br>69 |
| NOP                                               | 69       |
| OPTION                                            | 69       |
| RETFIE                                            | 70       |
| RETLW                                             | 70       |
| RETURN                                            | 70       |
| RLF                                               | 71<br>74 |
|                                                   | 71<br>71 |
| SLEEF                                             | 71<br>72 |
| SUBWF                                             | 72       |
| SWAPF                                             | 73       |
| TRIS                                              | 73       |
| XORLW                                             | 73       |
| XORWF                                             | 73       |
| Instruction Set Summary                           | 61       |
| INTCON Degister                                   | 56       |
| Interrupts                                        | 20<br>55 |
| IORI W Instruction                                | 55<br>68 |
| IORWF Instruction                                 | 68       |
| Μ                                                 |          |
| MOVE Instruction                                  | 60       |
| MOVI W Instruction                                | 68       |
| MOVWF Instruction                                 | 69       |
| MPLAB ASM30 Assembler, Linker, Librarian          | 76       |
| MPLAB ICD 2 In-Circuit Debugger                   | 77       |
| MPLAB ICE 2000 High Performance Universal         |          |
| In-Circuit Emulator                               | 77       |
| MPLAB ICE 4000 High Performance Universal         | 77       |
| MPLAB Integrated Development Environment Software | //<br>75 |
| MPLINK Object Linker/MPLIB Object Librarian       | 76       |
|                                                   |          |