# E·XFL



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

| Details                    |                                                                              |
|----------------------------|------------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                     |
| Core Processor             | PIC                                                                          |
| Core Size                  | 8-Bit                                                                        |
| Speed                      | 20MHz                                                                        |
| Connectivity               | -                                                                            |
| Peripherals                | Brown-out Detect/Reset, POR, WDT                                             |
| Number of I/O              | 12                                                                           |
| Program Memory Size        | 768B (512 x 12)                                                              |
| Program Memory Type        | OTP                                                                          |
| EEPROM Size                | -                                                                            |
| RAM Size                   | 25 x 8                                                                       |
| Voltage - Supply (Vcc/Vdd) | 3.5V ~ 15V                                                                   |
| Data Converters            | -                                                                            |
| Oscillator Type            | External                                                                     |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                                |
| Package / Case             | 20-SSOP (0.209", 5.30mm Width)                                               |
| Supplier Device Package    | 20-SSOP                                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16hv540t-20i-ss |

Email: info@E-XFL.COM

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

#### 2.0 PIC16HV540 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 this section. When placing orders, please use the PIC16HV540 Product Identification System at the back of this data sheet to specify the correct part number.

For the PIC16HV540 family of devices, there is one device type, as indicated in the device number:

1. **HV**, as in PIC16HV540. These devices have EPROM program memory and operate over the standard voltage range of 3.5 to 15 volts.

#### 2.1 <u>UV Erasable Devices</u>

The UV erasable versions, offered in CERDIP packages, are optimal for prototype development and pilot programs.

UV erasable devices can be programmed for any of the four oscillator configurations. Microchip's PICSTART<sup>®</sup> and PRO MATE<sup>®</sup> programmers both support programming of the PIC16HV540. Third party programmers also are available; refer to Literature Number DS00104 for a list of sources.

#### 2.2 <u>One-Time-Programmable (OTP)</u> <u>Devices</u>

The availability of OTP devices is especially useful for customers expecting frequent code changes and updates.

The OTP devices, packaged in plastic packages, permit the user to program them once. In addition to the program memory, the configuration bits must be programmed.

#### 2.3 <u>Quick-Turnaround-Production (QTP)</u> <u>Devices</u>

Microchip offers a QTP Programming Service for factory production orders. This service is made available for users who choose 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 bit 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 <u>Serialized Quick-Turnaround-</u> <u>Production (SQTP) Devices</u>

Microchip offers the 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. (Please contact your Microchip Technology sales office for more details.)

#### 4.0 MEMORY ORGANIZATION

PIC16HV540 memory is organized into program memory and data memory. For devices with more than 512 bytes of program memory, a paging scheme is used. Program memory pages are accessed using one or two STATUS register bits. For devices with a data memory register file of more than 32 registers, a banking scheme is used. Data memory banks are accessed using the File Selection Register (FSR).

#### 4.1 Program Memory Organization

The PIC16HV540 has a 9-bit Program Counter (PC) capable of addressing a 512 x 12 program memory space (Figure 4-1). Accessing a location above the physically implemented address will cause a wrap-around.

The reset vector for the PIC16HV540 is at 1FFh. A NOP at the reset vector location will cause a restart at location 000h.

#### FIGURE 4-1: PIC16HV540 PROGRAM MEMORY MAP AND STACK



#### 4.2 Data Memory Organization

Data memory is composed of registers, or bytes of RAM. Therefore, data memory for a device is specified by its register file. The register file is divided into two functional groups: special function registers and general purpose registers.

The special function registers include the TMR0 register, the Program Counter (PC), the Status Register, the I/O registers (ports), and the File Select Register (FSR). In addition, special purpose registers are used to control the I/O port configuration and prescaler options.

The general purpose registers are used for data and control information under command of the instructions.

For the PIC16HV540, the register file is composed of 10 special function registers and 25 general purpose registers (Figure 4-2).

#### 4.2.1 GENERAL PURPOSE REGISTER FILE

The register file is accessed either directly or indirectly through the file select register FSR (Section 4.8).

### FIGURE 4-2: PIC16HV540 REGISTER FILE MAP



#### 4.2.2 SPECIAL FUNCTION REGISTERS

The Special Function Registers are registers used by the CPU and peripheral functions to control the operation of the device (Table 4-1).

The special registers can be classified into two sets. The special function registers associated with the "core" functions are described in this section. Those related to the operation of the peripheral features are described in the section for each peripheral feature.

#### 4.6 Program Counter

As a program instruction is executed, the Program Counter (PC) will contain the address of the next program instruction to be executed. The PC value is increased by one every instruction cycle, unless an instruction changes the PC.

For a GOTO instruction, bits 8:0 of the PC are provided by the GOTO instruction word. (Figure 4-3).

For a CALL instruction, or any instruction where the PCL is the destination, bits 7:0 of the PC again are provided by the instruction word. However, PC<8> does not come from the instruction word, but is always cleared (Figure 4-3).

Instructions where the PCL is the destination, or Modify PCL instructions, include <code>MOVWF PC</code>, <code>ADDWF PC</code>, and <code>BSF PC</code>, <code>5.</code>.

| Note:                                    | Because PC<8> is cleared in the CALL           |
|------------------------------------------|------------------------------------------------|
|                                          | instruction, or any Modify PCL instruction,    |
|                                          | all subroutine calls or computed jumps are     |
| limited to the first 256 locations of an | limited to the first 256 locations of any pro- |
|                                          | gram memory page (512 words long).             |

#### FIGURE 4-3: LOADING OF PC BRANCH INSTRUCTIONS -PIC16HV540



#### 4.6.1 EFFECTS OF RESET

The Program Counter is set upon a RESET, which means that the PC addresses the last location in the last page i.e., the reset vector.

The STATUS register page preselect bits are cleared upon a RESET, which means that page 0 is pre-selected.

Therefore, upon a RESET, a GOTO instruction at the reset vector location will automatically cause the program to jump to page 0.

#### 4.7 <u>Stack</u>

PIC16HV540 device has a 12-bit wide L.I.F.O. (last in, first out) hardware 4 level stack.

A CALL instruction will *push* the current value of stack 1 into stack 2 and then push the current program counter value, incremented by one, into stack level 1. If more than four sequential CALL's are executed, only the most recent four return addresses are stored.

A RETLW instruction will *pop* the contents of stack level 1 into the program counter and then copy stack level 2 contents into level 1. If more than four sequential RETLW's are executed, the stack will be filled with the address previously stored in level 4. Note that the W register will be loaded with the literal value specified in the instruction. This is particularly useful for the implementation of data look-up tables within the program memory.

Upon any reset, the contents of the stack remain unchanged, however the program counter (PCL) will also be reset to 0.

- Note 1: There are no STATUS bits to indicate stack overflows or stack underflow conditions.
- Note 2: There are no instructions mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL and RETLW instructions.

| Address | Name    | Bit 7       | Bit 6     | Bit 5       | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>Power-On<br>Reset | Value on<br>MCLR and<br>WDT Reset | Value on<br>Wake-up on<br>Pin Change | Value on<br>Brown-Out<br>Reset |
|---------|---------|-------------|-----------|-------------|--------|-------|-------|-------|-------|-------------------------------|-----------------------------------|--------------------------------------|--------------------------------|
| N/A     | TRIS    | I/O control | registers | s (TRISA, T | RISB)  |       |       |       |       | 1111 1111                     | 1111 1111                         | 1111 1111                            | 1111 1111                      |
| 05h     | PORTA   | _           | _         | _           | _      | RA3   | RA2   | RA1   | RA0   | xxxx                          | uuuu                              | uuuu                                 | xxxx                           |
| 06h     | PORTB   | RB7         | RB6       | RB5         | RB4    | RB3   | RB2   | RB1   | RB0   | XXXX XXXX                     | uuuu uuuu                         | uuuu uuuu                            | xxxx xxxx                      |
| 03h     | STATUS  | PCWUF       | PA1       | PA0         | TO     | PD    | Z     | DC    | С     | 100x xxxx                     | 100q quuu                         | 000u uuuu                            | x00x xxxx                      |
| N/A     | OPTION2 | _           | _         | PCWU        | SWDTEN | RL    | SL    | BODL  | BODEN | 11 1111                       | uu uuuu                           | uu uuuu                              | xx xxxx                        |

#### TABLE 5-1: SUMMARY OF PORT REGISTERS

Legend: Shaded boxes = unimplemented, read as '0', --= unimplemented, read as '0', x = unknown, u = unchanged.

#### 5.5 I/O Programming Considerations

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

Some instructions operate internally as read followed by write operations. The BCF and BSF instructions, for example, read the entire port into the CPU, execute the bit operation and re-write the result. Caution must be used when these instructions are applied to a port where one or more pins are used as input/outputs. For example, a BSF operation on bit5 of PORTB will cause all eight bits of PORTB to be read into the CPU, bit5 to be set and the PORTB value to be written to the output latches. If another bit of PORTB is used as a bi-directional I/O pin (say 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 rewritten 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.

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

A pin actively outputting a high or a low 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-1: READ-MODIFY-WRITE INSTRUCTIONS ON AN I/O PORT

;Initial PORT Settings

; PORTB<7:4> Inputs

; PORTB<3:0> Outputs

;PORTB<7:6> have external pull-ups and are ;not connected to other circuitry

| ,<br>;<br>; |       |                                   | PORT                         | latch | PORT                 | pins |
|-------------|-------|-----------------------------------|------------------------------|-------|----------------------|------|
| ,           | MOVLW | PORTB,<br>PORTB,<br>03Fh<br>PORTB | ;01pp<br>;10pp<br>;<br>;10pp | pppp  | 11pp<br>11pp<br>10pp | pppp |
| •           |       |                                   |                              |       |                      |      |

;Note that the user may have expected the pin ;values to be 00pp pppp. The 2nd BCF caused ;RB7 to be latched as the pin value (High).

### 5.5.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-5). 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 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.

NOTES:



FIGURE 6-6: BLOCK DIAGRAM OF THE TIMER0/WDT PRESCALER

The Electrical Specifications sections show RC frequency variation from part to part due to normal process variation. The variation is larger for larger R (since leakage current variation will affect RC frequency more for large R) and for smaller C (since variation of input capacitance will affect RC frequency more).

Also, see the Electrical Specifications sections for variation of oscillator frequency due to VDD for given Rext/ Cext values as well as frequency variation due to operating temperature for given R, C, and VDD values.

When used in RC mode, the CLKOUT pin can be used as a programmable clock output. The output is connected to TMR0, bit 0, and by setting the prescaler rate select bits, clock out frequencies of CLKIN/8 to CLKIN/1024 can be generated.





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

#### 7.3 <u>Reset</u>

PIC16HV540 devices may be reset in one of the following ways:

- Power-On Reset (POR)
- MCLR reset (normal operation)
- MCLR wake-up reset (from SLEEP)
- WDT reset (normal operation)
- WDT wake-up reset (from SLEEP)
- Wake-up from SLEEP on Pin Change
- Brown-out Detect

Table 7-3 shows these reset conditions for the PCL and STATUS registers.

Some registers are not affected in any reset condition. Their status is unknown on POR and unchanged in any other reset. Most other registers are reset to a "reset state" on Power-On Reset (POR), MCLR or WDT Reset. A MCLR, WDT Wake-up from SLEEP or Wakeup from SLEEP on Pin Change also results in a device RESET, and not a continuation of operation before SLEEP.

The  $\overline{\text{TO}}$  and  $\overline{\text{PD}}$  bits (STATUS <4:3>) and  $\overline{\text{PCWUF}}$  (STATUS<7>) are set or cleared depending on the different reset conditions (Section 7.9). These bits may be used to determine the nature of the reset.

Table 7-4 lists a full description of reset states of all registers. Figure 7-6 shows a simplified block diagram of the on-chip reset circuit.

#### 7.9 <u>Time-out Sequence and Power-down</u> Status Bits (TO/PD/PCWUF)

The  $\overline{\text{TO}}$ ,  $\overline{\text{PD}}$  and  $\overline{\text{PCWUF}}$  bits in the STATUS register can be tested to determine if a RESET condition has been caused by a power-up condition, a  $\overline{\text{MCLR}}$ , Watchdog Timer (WDT) Reset, WDT Wake-up Reset, or Wake-up from SLEEP on Pin Change.

### TABLE 7-7:TO/PD/PCWUF STATUSAFTER RESET

| PCWUF | то | PD | RESET was caused by                          |
|-------|----|----|----------------------------------------------|
| 1     | 1  | 1  | Power-up (POR)                               |
| u     | u  | u  | MCLR Reset (normal operation) <sup>(1)</sup> |
| u     | 1  | 0  | MCLR Wake-up Reset (from SLEEP)              |
| u     | 0  | 1  | WDT Reset (normal operation)                 |
| u     | 0  | 0  | WDT Wake-up Reset (from SLEEP)               |
| 0     | u  | u  | Wake-up from SLEEP on Pin Change             |
| x     | x  | x  | Brown-out Reset                              |

Legend: u = unchanged, x = unknown

Note 1: The TO and PD and PCWUF bits maintain their status (u) until a reset occurs. A low-pulse on the MCLR input does not change the TO and PD and PCWUF status bits.

These STATUS bits are only affected by events listed in Table 7-8.

### TABLE 7-8:EVENTS AFFECTING TO/PDSTATUS BITS

| Event                            | PCWUF | то | PD | Remarks         |
|----------------------------------|-------|----|----|-----------------|
| Power-up                         | 1     | 1  | 1  |                 |
| WDT Time-out                     | u     | 0  | u  | No effect on PD |
| SLEEP instruction                | 1     | 1  | 0  |                 |
| CLRWDT instruction               | u     | 1  | 1  |                 |
| Wake-up from SLEEP on Pin Change | 0     | u  | u  |                 |

Legend: u = unchanged

Note: A WDT time-out will occur regardless of the status of the TO bit. A SLEEP instruction will be executed, regardless of the status of the PD bit. Table 7-7 reflects the status of TO and PD after the corresponding event.

Table 7-3 lists the reset conditions for the special function registers, while Table 7-4 lists the reset conditions for all the registers.

#### 7.10 Power-down Mode (SLEEP)

A device may be powered down (SLEEP) and later powered up (Wake-up from SLEEP).

#### 7.10.1 SLEEP

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

If enabled, the Watchdog Timer will be cleared but keeps running, the TO bit (STATUS<4>) is set, the PD bit (STATUS<3>) is cleared, the PCWUF bit (STATUS<7>) is set and the oscillator driver is turned off. The I/O ports maintain the status they had before the SLEEP instruction was executed (driving high, driving low, or hi-impedance).

It should be noted that a RESET generated by a WDT time-out does not drive the MCLR/VPP pin low.

For lowest current consumption while powered down, the TOCKI input should be at VDD or Vss and the  $\overline{\text{MCLR}}$ /VPP pin must be at a logic high level (VIH  $\overline{\text{MCLR}}$ ).

#### 7.10.2 WAKE-UP FROM SLEEP

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

- 1. An external reset input on MCLR/VPP pin.
- 2. A Watchdog Timer Time-out Reset (if WDT was enabled).
- 3. A change on input pins PORTB:<0-3,7> when Wake-up on Pin Change is enabled.
- 4. Brown-out Reset.

These events cause a device RESET. The TO and PD and PCWUF bits can be used to determine the cause of device RESET. The TO bit is cleared if a WDT timeout occurred (and caused wake-up). The PD bit, which is set on power-up, is cleared when SLEEP is invoked.

The PCWUF bit indicates a change in state while in SLEEP at pins PORTB:<0-3,7> (since the SLEEP state was entered).

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

| CALL                                                     | Subroutine Call                                                                                                                                                                                                                                                   |  |  |  |  |
|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:                                                  | [ <i>label</i> ] CALL k                                                                                                                                                                                                                                           |  |  |  |  |
| Operands:                                                | $0 \le k \le 255$                                                                                                                                                                                                                                                 |  |  |  |  |
| Operation:                                               | $\begin{array}{l} (PC) + 1 \rightarrow \text{Top of Stack;} \\ k \rightarrow PC < 7:0>; \\ (STATUS < 6:5>) \rightarrow PC < 10:9>; \\ 0 \rightarrow PC < 8> \end{array}$                                                                                          |  |  |  |  |
| Status Affected:                                         | None                                                                                                                                                                                                                                                              |  |  |  |  |
| Encoding:                                                | 1001 kkkk kkkk                                                                                                                                                                                                                                                    |  |  |  |  |
| Description:                                             | Subroutine call. First, return address<br>(PC+1) is pushed onto the stack. The<br>eight bit immediate address is loaded<br>into PC bits <7:0>. The upper bits<br>PC<10:9> are loaded from STA-<br>TUS<6:5>, PC<8> is cleared. CALL is<br>a two cycle instruction. |  |  |  |  |
| Words:                                                   | 1                                                                                                                                                                                                                                                                 |  |  |  |  |
| Cycles:                                                  | 2                                                                                                                                                                                                                                                                 |  |  |  |  |
| Example:                                                 | HERE CALL THERE                                                                                                                                                                                                                                                   |  |  |  |  |
| Before Instru<br>PC =<br>After Instruct<br>PC =<br>TOS = | address (HERE)                                                                                                                                                                                                                                                    |  |  |  |  |
| CLRF                                                     | Clear f                                                                                                                                                                                                                                                           |  |  |  |  |
| Syntax:                                                  | [ <i>label</i> ] CLRF f                                                                                                                                                                                                                                           |  |  |  |  |
| Operands:                                                | $0 \le f \le 31$                                                                                                                                                                                                                                                  |  |  |  |  |
| Operation:                                               | $\begin{array}{l} 00h \rightarrow (f); \\ 1 \rightarrow Z \end{array}$                                                                                                                                                                                            |  |  |  |  |
| Status Affected:                                         | Z                                                                                                                                                                                                                                                                 |  |  |  |  |
| Encoding:                                                | 0000 011f ffff                                                                                                                                                                                                                                                    |  |  |  |  |
| Description:                                             | The contents of register 'f' are cleared and the Z bit is set.                                                                                                                                                                                                    |  |  |  |  |
| Words:                                                   | 1                                                                                                                                                                                                                                                                 |  |  |  |  |
| Cycles:                                                  | 1                                                                                                                                                                                                                                                                 |  |  |  |  |
| Example:                                                 | CLRF FLAG_REG                                                                                                                                                                                                                                                     |  |  |  |  |
| Before Instru<br>FLAG_RI                                 |                                                                                                                                                                                                                                                                   |  |  |  |  |
| After Instruct<br>FLAG_RI                                |                                                                                                                                                                                                                                                                   |  |  |  |  |

| CLRW                                              | Clear W                                                                                                                                                                              |
|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                           | [label] CLRW                                                                                                                                                                         |
| Operands:                                         | None                                                                                                                                                                                 |
| Operation:                                        | $\begin{array}{l} 00h \rightarrow (W); \\ 1 \rightarrow Z \end{array}$                                                                                                               |
| Status Affected:                                  | Z                                                                                                                                                                                    |
| Encoding:                                         | 0000 0100 0000                                                                                                                                                                       |
| Description:                                      | The W register is cleared. Zero bit (Z) is set.                                                                                                                                      |
| Words:                                            | 1                                                                                                                                                                                    |
| Cycles:                                           | 1                                                                                                                                                                                    |
| Example:                                          | CLRW                                                                                                                                                                                 |
| Before Instru<br>W =                              | ction<br>0x5A                                                                                                                                                                        |
| After Instruct<br>W =<br>Z =                      | ion<br>0x00<br>1                                                                                                                                                                     |
| CLRWDT                                            | Clear Watchdog Timer                                                                                                                                                                 |
| Syntax:                                           | [label] CLRWDT                                                                                                                                                                       |
| Operands:                                         | None                                                                                                                                                                                 |
| Operation:                                        | $\begin{array}{l} 00h \rightarrow WDT; \\ 0 \rightarrow \underline{WD}T \text{ prescaler (if assigned)}; \\ 1 \rightarrow \overline{TO}; \\ 1 \rightarrow \overline{PD} \end{array}$ |
| Status Affected:                                  | TO, PD                                                                                                                                                                               |
| Encoding:                                         | 0000 0000 0100                                                                                                                                                                       |
| Description:                                      | The CLRWDT instruction resets the WDT. It also resets the prescaler, if the prescaler is assigned to the WDT and not Timer0. Status bits TO and PD are set.                          |
| Words:                                            | 1                                                                                                                                                                                    |
| Cycles:                                           | 1                                                                                                                                                                                    |
| Example:                                          | CLRWDT                                                                                                                                                                               |
| Before Instru<br>WDT cou                          |                                                                                                                                                                                      |
| After Instruct<br>WDT cou<br>WDT pres<br>TO<br>PD | nter = $0x00$                                                                                                                                                                        |

Z

= 1

| MOVF             | Move f                                                                                       | MOVWF            | Move W to f                             |
|------------------|----------------------------------------------------------------------------------------------|------------------|-----------------------------------------|
| Syntax:          | [label] MOVF f,d                                                                             | Syntax:          | [label] MOVWF f                         |
| Operands:        | $0 \le f \le 31$                                                                             | Operands:        | $0 \le f \le 31$                        |
|                  | $d \in [0,1]$                                                                                | Operation:       | $(W) \to (f)$                           |
| Operation:       | $(f) \rightarrow (dest)$                                                                     | Status Affected: | None                                    |
| Status Affected: | Z                                                                                            | Encoding:        | 0000 001f ffff                          |
| Encoding:        | 0010 00df ffff                                                                               | Description:     | Move data from the W register to regis- |
| Description:     | The contents of register 'f' is moved to                                                     |                  | ter 'f'.                                |
|                  | destination 'd'. If 'd' is 0, destination is<br>the W register. If 'd' is 1, the destination | Words:           | 1                                       |
|                  | is file register 'f'. 'd' is 1 is useful to test                                             | Cycles:          | 1                                       |
|                  | a file register since status flag Z is affected.                                             | Example:         | MOVWF TEMP_REG                          |
| Words:           | 1                                                                                            | Before Instr     |                                         |
| Cycles:          | 1                                                                                            | TEMP_F<br>W      | REG = 0xFF<br>= 0x4F                    |
| Example:         | MOVF FSR, 0                                                                                  | After Instruc    |                                         |
| After Instruc    |                                                                                              | TEMP_F           |                                         |
| W =              | value in FSR register                                                                        | W                | = 0x4F                                  |
|                  |                                                                                              | NOP              | No Operation                            |
| MOVLW            | Move Literal to W                                                                            | Syntax:          | [label] NOP                             |
| Syntax:          | [ <i>label</i> ] MOVLW k                                                                     | Operands:        | None                                    |
| Operands:        | $0 \le k \le 255$                                                                            | Operation:       | No operation                            |
| Operation:       | $k \rightarrow (W)$                                                                          | Status Affected: | None                                    |
| Status Affected: | None                                                                                         | Encoding:        | 0000 0000 0000                          |
| Encoding:        | 1100 kkkk kkkk                                                                               | Description:     | No operation.                           |
| Description:     | The eight bit literal 'k' is loaded into the                                                 | Words:           | 1                                       |
|                  | W register. The don't cares will assem-<br>ble as 0s.                                        | Cycles:          | 1                                       |
| Words:           | 1                                                                                            | Example:         | NOP                                     |
| Cycles:          | 1                                                                                            |                  |                                         |
| Example:         | MOVLW 0x5A                                                                                   |                  |                                         |
| Litample.        | MCATM OXDA                                                                                   |                  |                                         |

After Instruction W = 0x5

0x5A

| OPTION               | Load OPTION Regis                                                                                                                                                                   | ter              |  |  |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--|--|
| Syntax:              | [label] OPTION                                                                                                                                                                      |                  |  |  |
| Operands:            | None                                                                                                                                                                                |                  |  |  |
| Operation:           | $(W) \rightarrow OPTION$                                                                                                                                                            |                  |  |  |
| Status Affected:     | None                                                                                                                                                                                |                  |  |  |
| Encoding:            | 0000 0000 00                                                                                                                                                                        | 10               |  |  |
| Description:         | The content of the W reg                                                                                                                                                            | gister is loaded |  |  |
|                      | into the OPTION registe                                                                                                                                                             | r.               |  |  |
| Words:               | 1                                                                                                                                                                                   |                  |  |  |
| Cycles:              | 1                                                                                                                                                                                   |                  |  |  |
| Example              | OPTIO<br>N                                                                                                                                                                          |                  |  |  |
| Before Instru        |                                                                                                                                                                                     |                  |  |  |
| W                    | = 0x07                                                                                                                                                                              |                  |  |  |
| After Instruct       | ion                                                                                                                                                                                 |                  |  |  |
| OPTION               | = 0x07                                                                                                                                                                              |                  |  |  |
| RETLW                | Return with Literal i                                                                                                                                                               | n W              |  |  |
| Syntax:              | [label] RETLW k                                                                                                                                                                     |                  |  |  |
| Operands:            | $0 \leq k \leq 255$                                                                                                                                                                 |                  |  |  |
| Operation:           | $k \rightarrow (W);$                                                                                                                                                                |                  |  |  |
|                      | $TOS \rightarrow PC$                                                                                                                                                                |                  |  |  |
| Status Affected:     | None                                                                                                                                                                                |                  |  |  |
| Encoding:            | 1000 kkkk kkk                                                                                                                                                                       | :k               |  |  |
| Description:         | The W register is loaded with the eight<br>bit literal 'k'. The program counter is<br>loaded from the top of the stack (the<br>return address). This is a two cycle<br>instruction. |                  |  |  |
| Words:               | 1                                                                                                                                                                                   |                  |  |  |
| Cycles:              | 2                                                                                                                                                                                   |                  |  |  |
| Example:             | CALL TABLE ;W cont                                                                                                                                                                  | ains             |  |  |
|                      | ;table                                                                                                                                                                              |                  |  |  |
|                      | ; value.                                                                                                                                                                            | has table        |  |  |
|                      | <ul> <li>, w now</li> <li>; value.</li> </ul>                                                                                                                                       |                  |  |  |
| TABLE                |                                                                                                                                                                                     |                  |  |  |
| TABLE                | ADDWF PC ;W = of<br>RETLW k1 ;Begin                                                                                                                                                 |                  |  |  |
|                      | RETLW k2 ;                                                                                                                                                                          |                  |  |  |
|                      | •                                                                                                                                                                                   |                  |  |  |
|                      | •                                                                                                                                                                                   |                  |  |  |
|                      | RETLW kn ; End c                                                                                                                                                                    | of table         |  |  |
| Before Instru<br>W = |                                                                                                                                                                                     |                  |  |  |
|                      |                                                                                                                                                                                     |                  |  |  |
| After Instruct       | IOU                                                                                                                                                                                 |                  |  |  |
|                      | value of k8                                                                                                                                                                         |                  |  |  |

| RLF                                                                                                                                           | Rotate Left f through Carry                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                                                                                                                       | [label] RLF f,d                                                                                                                                                                                                                                                                                                                                                                        |
| Operands:                                                                                                                                     | $\begin{array}{l} 0\leq f\leq 31\\ d\in \ [0,1] \end{array}$                                                                                                                                                                                                                                                                                                                           |
| Operation:                                                                                                                                    | See description below                                                                                                                                                                                                                                                                                                                                                                  |
| Status Affected:                                                                                                                              | С                                                                                                                                                                                                                                                                                                                                                                                      |
| Encoding:                                                                                                                                     | 0011 01df ffff                                                                                                                                                                                                                                                                                                                                                                         |
| Description:                                                                                                                                  | The contents of register 'f' are rotated<br>one bit to the left through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is stored<br>back in register 'f'.                                                                                                                                                                            |
| Words:                                                                                                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                      |
| Cycles:                                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                      |
| Example:                                                                                                                                      | RLF REG1,0                                                                                                                                                                                                                                                                                                                                                                             |
| Before Instru<br>REG1<br>C                                                                                                                    | uction<br>= 1110 0110<br>= 0                                                                                                                                                                                                                                                                                                                                                           |
| After Instruc<br>REG1<br>W<br>C                                                                                                               | -                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                        |
| RRF                                                                                                                                           | Rotate Right f through Carry                                                                                                                                                                                                                                                                                                                                                           |
| RRF<br>Syntax:                                                                                                                                | Rotate Right f through Carry [ label ] RRF f,d                                                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                        |
| Syntax:                                                                                                                                       | [label] RRF f,d<br>0 $\leq$ f $\leq$ 31                                                                                                                                                                                                                                                                                                                                                |
| Syntax:<br>Operands:                                                                                                                          | $\begin{bmatrix} label \end{bmatrix} RRF f,d$<br>$0 \le f \le 31$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                                                     |
| Syntax:<br>Operands:<br>Operation:                                                                                                            | $\begin{bmatrix} label \end{bmatrix} RRF f,d$<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below                                                                                                                                                                                                                                                                            |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:                                                                                        | $\begin{bmatrix} label \end{bmatrix} RRF f,d$<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>$\boxed{0011  00df  ffff}$<br>The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'.                         |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:                                                                           | $\begin{bmatrix} label \end{bmatrix} RRF f,d$ $0 \le f \le 31$ $d \in [0,1]$ See description below C $0011  00df  ffff$ The contents of register 'f' are rotated one bit to the right through the Carry Flag. If 'd' is 0 the result is placed in the W register. If 'd' is 1 the result is placed                                                                                     |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:                                                                           | $\begin{bmatrix} label \end{bmatrix} RRF f,d$<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>$\boxed{0011  00df  ffff}$<br>The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'.                         |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                                           | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'<br>register 'f'                                           |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:                                                 | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'<br>register 'f'<br>1                                      |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:                                      | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'<br>1<br>1<br>RRF REG1, 0                                  |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example:<br>Before Instru<br>REG1 | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'.<br>1<br>1<br>RRF REG1, 0<br>iction<br>= 1110 0110<br>= 0 |

| SLEEP            | Enter SLEEP Mode                                                                                                                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] SLEEP                                                                                                                                                                                                                                   |
| Operands:        | None                                                                                                                                                                                                                                            |
| Operation:       | $\begin{array}{l} 00h \rightarrow WDT; \\ 0 \rightarrow \underline{W}DT \ prescaler; \\ 1 \rightarrow \underline{TO}; \\ 0 \rightarrow \underline{PD} \\ 1 \rightarrow \overline{PCWUF} \end{array}$                                            |
| Status Affected: | TO, PD, PCWUF                                                                                                                                                                                                                                   |
| Encoding:        | 0000 0000 0011                                                                                                                                                                                                                                  |
| Description:     | Time-out status bit (TO) is set. The<br>power down status bit (PD) is cleared.<br>The WDT and its prescaler are<br>cleared.<br>The processor is put into SLEEP mode<br>with the oscillator stopped. See sec-<br>tion on SLEEP for more details. |
| Words:           | 1                                                                                                                                                                                                                                               |
| Cycles:          | 1                                                                                                                                                                                                                                               |
| Example:         | SLEEP                                                                                                                                                                                                                                           |

| SUBWF                                | Sub                  | otract              | W from                 | f                                                                                                    |  |
|--------------------------------------|----------------------|---------------------|------------------------|------------------------------------------------------------------------------------------------------|--|
| Syntax:                              | [lab                 | el]                 | SUBWF                  | f,d                                                                                                  |  |
| Operands:                            | -                    | f ≤ 31<br>[0,1]     |                        |                                                                                                      |  |
| Operation:                           | (f) –                | • (W) •             | $\rightarrow$ (dest)   |                                                                                                      |  |
| Status Affected:                     | С, Г                 | DC, Z               |                        |                                                                                                      |  |
| Encoding:                            | 00                   | 00                  | 10df                   | ffff                                                                                                 |  |
| Description:                         | W re<br>resu         | egister<br>It is st | from registored in the | ement method) the<br>ster 'f'. If 'd' is 0 the<br>9 W register. If 'd' is<br>1 back in register 'f'. |  |
| Words:                               | 1                    |                     |                        |                                                                                                      |  |
| Cycles:                              | 1                    |                     |                        |                                                                                                      |  |
| Example 1:                           | SUB                  | WF                  | REG1, 1                |                                                                                                      |  |
| Before Instru<br>REG1<br>W<br>C      | etior<br>=<br>=<br>= | 1<br>3<br>2<br>?    |                        |                                                                                                      |  |
| After Instruct                       | ion                  |                     |                        |                                                                                                      |  |
| REG1<br>W<br>C<br><u>Example 2</u> : | =<br>=<br>=          | 1<br>2<br>1         | ; result is            | positive                                                                                             |  |
| Before Instru                        | ctior                | ı                   |                        |                                                                                                      |  |
| REG1<br>W                            | =                    | 2                   |                        |                                                                                                      |  |
| C                                    | =                    | 2<br>?              |                        |                                                                                                      |  |
| After Instruct                       | ion                  |                     |                        |                                                                                                      |  |
| REG1                                 | =                    | 0                   |                        |                                                                                                      |  |
| W<br>C                               | =                    | 2<br>1              | ; result is            | zero                                                                                                 |  |
| Example 3:                           |                      |                     | ,                      | 20.0                                                                                                 |  |
| Before Instruction                   |                      |                     |                        |                                                                                                      |  |
| REG1<br>W                            | =                    | 1<br>2              |                        |                                                                                                      |  |
| C                                    | =                    | ?                   |                        |                                                                                                      |  |
| After Instruct                       | ion                  |                     |                        |                                                                                                      |  |
| REG1<br>W                            | =                    | FF                  |                        |                                                                                                      |  |
| C                                    | =                    | 2<br>0              | ; result is            | negative                                                                                             |  |
|                                      |                      |                     |                        |                                                                                                      |  |

### 10.0 ELECTRICAL CHARACTERISTICS - PIC16HV540

#### Absolute Maximum Ratings<sup>†</sup>

| Ambient temperature under bias                                                                               | –20°C to +85°C                    |
|--------------------------------------------------------------------------------------------------------------|-----------------------------------|
| Storage temperature                                                                                          | –65°C to +150°C                   |
| Voltage on VDD with respect to VSS                                                                           |                                   |
| Voltage on MCLR with respect to Vss                                                                          | 0 to +14V                         |
| Voltage on all other pins with respect to Vss                                                                | –0.6V to (VDD + 0.6V)             |
| Total power dissipation <sup>(1)</sup>                                                                       | 800 mW                            |
| Max. current out of Vss pin                                                                                  |                                   |
| Max. current into Vod pin                                                                                    | 100 mA                            |
| Max. current into an input pin (T0CKI only)                                                                  | ±500 μA                           |
| Input clamp current, Iк (VI < 0 or VI > VDD)                                                                 | ±20 mA                            |
| Output clamp current, IOK (VO < 0 or VO > VDD)                                                               | ±20 mA                            |
| Max. output current sunk by any I/O pin                                                                      | 25 mA                             |
| Max. output current sourced by any I/O pin                                                                   | 10 mA                             |
| Max. output current sourced by a single I/O port A or B                                                      | 40 mA                             |
| Max. output current sourced by a single I/O port A or B                                                      | 50 mA                             |
| <b>Note 1:</b> Power dissipation is calculated as follows: Pdis = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD-VC | )H) x IOH} + $\Sigma$ (VOL x IOL) |

2: Voltage spikes below Vss at the  $\overline{\text{MCLR}}$  pin, inducing currents greater than 80mA, may cause latch-up. Thus, a series resistor of 50-100 $\Omega$  should be used when applying a "low" level to the  $\overline{\text{MCLR}}$  pin rather than pulling this pin directly to Vss.

<sup>†</sup> NOTICE: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

#### 10.1 <u>DC Characteristics:</u> <u>PIC16HV540-04, 20 (Commercial)</u> <u>PIC16HV540-04I, 20I (Industrial)</u>

| DC Characteristics<br>Power Supply Pins                                                     |      | Standard Operating Conditions (unless otherwise specified)Operating Temperature $0^{\circ}C \le TA \le +70^{\circ}C$ (commercial) $-40^{\circ}C \le TA \le +85^{\circ}C$ (industrial) |                     |                  |                |                                                                                                                                   |
|---------------------------------------------------------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Characteristic                                                                              | Sym. | Min.                                                                                                                                                                                  | Typ. <sup>(1)</sup> | Max.             | Units          | Conditions                                                                                                                        |
| Supply Voltage                                                                              | Vdd  | 3.5<br>4.5                                                                                                                                                                            | _                   | 15<br>15         | V<br>V         | LP, XT and RC modes<br>HS mode                                                                                                    |
| RAM Data Retention Voltage <sup>(2)</sup>                                                   | Vdr  | —                                                                                                                                                                                     | 1.5*                | —                | V              | Device in SLEEP mode                                                                                                              |
| VDD start voltage to ensure<br>Power-on Reset                                               | VPOR | _                                                                                                                                                                                     | Vss                 | _                | V              | See section on Power-on Reset for details.                                                                                        |
| VDD rise rate to ensure<br>Power-on Reset                                                   | SVDD | 0.05<br>Vdd                                                                                                                                                                           |                     |                  | V/ms           | See Section 7.4 for details on<br>Power-on Reset                                                                                  |
| Supply Current <sup>(3)</sup><br>HS option<br>XT and RC <sup>(4)</sup> options<br>LP option | IDD  |                                                                                                                                                                                       | 5<br>1.8<br>300     | 20<br>3.3<br>500 | mA<br>mA<br>μA | Fosc = 20 MHz, VDD = 15V, VREG = 5V<br>Fosc = 4 MHz, VDD = 15V, VREG = 5V<br>Fosc = 32 kHz, VDD = 15V, VREG = 5V,<br>WDT disabled |
| Power-down Current <sup>(5)(6)</sup>                                                        | IPD  | _                                                                                                                                                                                     | 4.5                 | 20               | μA             | VDD = 15V, VREG = 5V sleep timer enable,<br>BOD disabled                                                                          |
|                                                                                             |      | —                                                                                                                                                                                     | 0.25                | 14               | μA             | $V_{DD} = 15V$ , $V_{REG} = 3V$ sleep timer enable,<br>BOD disabled                                                               |
|                                                                                             |      | —                                                                                                                                                                                     | 1.8                 | 10               | μA             | VDD = 15V, $VREG = 5V$ sleep timer disabled,<br>BOD disabled                                                                      |
|                                                                                             |      | —                                                                                                                                                                                     | 1.4                 | 5                | μA             | VDD = 15V, VREG = 3V sleep timer disabled,<br>BOD disabled                                                                        |
| Brown-out Current                                                                           |      | —                                                                                                                                                                                     | 0.5                 |                  | μΑ             | VDD = 15V, VREG = 5V, BOD enabled                                                                                                 |
| Brown-out Detector Threshold                                                                | Bvdd | 2.7<br>1.8                                                                                                                                                                            | 3.1<br>2.2          | 4.2<br>2.8       | V<br>V         | VDD = 15V, VREG = 5V* (7)<br>VDD = 15V, VREG = 3V* (7)                                                                            |
| Regulation Voltage                                                                          | Vio  | 2                                                                                                                                                                                     | 3                   | 4.5              | V              | VDD = 15V, VREG = 3V, Unloaded outputs, SLEEP                                                                                     |
|                                                                                             |      | 4                                                                                                                                                                                     | 5                   | 6                | V              | VDD = 15V, VREG = 5V, Unloaded outputs,<br>SLEEP                                                                                  |

\* These parameters are characterized but not tested.

- Note 1: Data in the Typical ("Typ") column is based on characterization results at 25°C. This data is for design guidance only and is not tested.
  - 2: This is the limit to which VDD can be lowered in SLEEP mode without losing RAM data.
  - **3:** The supply current is mainly a function of the operating voltage and frequency. Other factors such as bus loading, oscillator type, bus rate, internal code execution pattern, and temperature also have an impact on the current consumption.
    - a) The test conditions for all IDD measurements in active operation mode are:
    - OSC1 = external square wave, from rail-to-rail; all I/O pins tristated, pulled to Vss, TOCKI = VDD, MCLR = VDD; WDT enabled/disabled as specified.
    - b) For standby current measurements, the conditions are the same, except that the device is in SLEEP mode.
  - 4: Does not include current through REXT. The current through the resistor can be estimated by the formula: IR = VDD/2REXT (mA) with REXT in k $\Omega$ .
  - 5: 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 and Vss.
  - 6: The oscillator start-up time can be as much as 8 seconds for XT and LP oscillator selection, if the SLEEP mode is exited or during initial power-up.
  - 7: See Section 7.6.1 for additional information.

#### 12.5 Package Marking Information



 Legend:
 MM...M
 Microchip part number information

 XX...X
 Customer specific information\*

 YY
 Year code (last 2 digits of calendar year)

 WW
 Week code (week of January 1 is week '01')

 NNN
 Alphanumeric traceability code

 Note:
 In the event the full Microchip part number cannot be marked on one line, it will be carried over to the next line thus limiting the number of available characters for customer specific information.

Standard OTP marking consists of Microchip part number, year code, week code, facility code, mask rev#, and assembly code. For OTP marking beyond this, certain price adders apply. Please check with your Microchip Sales Office. For QTP devices, any special marking adders are included in QTP price.

© 2000 Microchip Technology Inc.

NOTES:

### INDEX

| Α                                        |
|------------------------------------------|
| Absolute Maximum Ratings61               |
| ALU                                      |
| Applications                             |
| Architectural Overview                   |
|                                          |
| Assembler                                |
| MPASM Assembler 55                       |
| В                                        |
| Block Diagram                            |
| On-Chip Reset Circuit                    |
| PIC16C5X Series                          |
|                                          |
| Timer0                                   |
| TMR0/WDT Prescaler                       |
| Watchdog Timer 40                        |
| Brown-out Detect                         |
| С                                        |
| Carry bit7                               |
|                                          |
| Clocking Scheme                          |
| Code Protection                          |
| Configuration Bits                       |
| Configuration Word                       |
| PIC16CR54C                               |
|                                          |
| D                                        |
| DC and AC Characteristics - PIC16CR54C   |
| DC Characteristics                       |
| Development Support55                    |
| Device Varieties                         |
| Digit Carry bit                          |
| • ,                                      |
| E                                        |
| Electrical Characteristics               |
| PIC16CR54C61                             |
| Enhanced Watchdog Timer (WDT)            |
| Errata                                   |
| External Power-On Reset Circuit          |
| F                                        |
| 1                                        |
| Family of Devices                        |
| PIC16C5X                                 |
| Features1                                |
| FSR                                      |
| FSR Register                             |
|                                          |
|                                          |
| I/O Interfacing19                        |
| I/O Ports                                |
| I/O Programming Considerations           |
| INDF                                     |
| INDF Register                            |
|                                          |
| Indirect Data Addressing                 |
| Instruction Cycle 10                     |
| Instruction Flow/Pipelining10            |
| Instruction Set Summary43                |
| ĸ                                        |
| KeeLoq® Evaluation and Programming Tools |
|                                          |
|                                          |
| Load Conditions                          |
| Loading of PC 16                         |
| M                                        |
| MCLR                                     |
| Memory Map11                             |
| PIC16C54s/CR54s/C55s                     |
|                                          |
| Memory Organization                      |
| Data Mamani 11                           |
| Data Memory11                            |
|                                          |
| Program Memory                           |

| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| One-Time-Programmable (OTP) Devices5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| OPTION Register 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| OSC selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Oscillator Configurations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Oscillator Types                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| HS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| LP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| RC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| XT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Р                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Package Marking Information77                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Packaging Information73                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PICDEM-1 Low-Cost PICmicro Demo Board57                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PICDEM-2 Low-Cost PIC16CXX Demo Board57                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PICDEM-3 Low-Cost PIC16CXXX Demo Board57                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| PICSTART® Plus Entry Level Development System 57                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| pin diagrams1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| POR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Device Reset Timer (DRT)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| PD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Power-On Reset (POR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| TO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PORTA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| PORTB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Power-Down Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Prescaler                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| PRO MATE® II Universal Programmer57                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Program Counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Q                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Q cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Quick-Turnaround-Production (QTP) Devices                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| R<br>BC Oscillator 33                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RC Oscillator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| RC Oscillator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         Special Function       11         Reset       31, 34                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System       58                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System       58         Serialized Quick-Turnaround-Production (SQTP) Devices       5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System       58         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System       58         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System       58         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Function Registers       11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System       58         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Function Registers       11         Stack       16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0                                                                                                                                                                                                                                                                                                                                                                                                                            |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28                                                                                                                                                                                                                                                                                                                                                                            |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28         Timer0 (TMR0) Module       25                                                                                                                                                                                                                                                                                                                                      |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28         Timer0 (TMR0) Module       25         TMR0 with External Clock       27                                                                                                                                                                                                                                                                                            |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Features of the CPU       31         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28         Timer0 (TMR0) Module       25         TMR0 with External Clock       27         Timing Diagrams and Specifications       65                                                                                                                                              |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28         Timer0 (TMR0) Module       25         TMR0 with External Clock       27         Timing Diagrams and Specifications       65         Timing Parameter Symbology and Load Conditions       64                                                                                                                                                                        |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28         Timer0 (TMR0) Module       25         TMR0 with External Clock       27         Timing Diagrams and Specifications       65         Timing Parameter Symbology and Load Conditions       64         TRIS Registers       19                                                                                                                                        |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28         Timer0 (TMR0) Module       25         TMR0 with External Clock       27         Timing Diagrams and Specifications       65         Timing Parameter Symbology and Load Conditions       64         TRIS Registers       19         U       U                                                                         |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       Special Function         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28         Timer0 (TMR0) Module       25         TMR0 with External Clock       27         Timing Diagrams and Specifications       65         Timing Parameter Symbology and Load Conditions       64         TRIS Registers       19         U       UV Erasable Devices       5                                               |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28         Timer0 (TMR0) Module       25         TMR0 with External Clock       27         Timing Diagrams and Specifications       65         Timing Parameter Symbology and Load Conditions       64         TRIS Registers       19         U       UV Erasable Devices       5                                                             |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28         Timer0 (TMR0) Module       25         TMR0 with External Clock       27         Timing Diagrams and Specifications       65         Timing Parameter Symbology and Load Conditions       64         VU Erasable Devices       5         W       35                                                                                  |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28         Timer0 (TMR0) Module       25         TMR0 with External Clock       27         Timing Diagrams and Specifications       65         Timing Parameter Symbology and Load Conditions       64         TRIS Registers       19         U       V       Erasable Devices       5         W       35         Wake-up from SLEEP       41 |
| RC Oscillator       33         Read-Modify-Write       22         Register File Map       11         Registers       11         Special Function       11         Reset       31, 34         S       SEEVAL® Evaluation and Programming System         Serialized Quick-Turnaround-Production (SQTP) Devices       5         SLEEP       31, 41         Software Simulator (MPLAB-SIM)       56         Special Features of the CPU       31         Special Features of the CPU       31         Special Function Registers       11         Stack       16         STATUS       35         STATUS Register       7, 13         T       Timer0         Switching Prescaler Assignment       28         Timer0 (TMR0) Module       25         TMR0 with External Clock       27         Timing Diagrams and Specifications       65         Timing Parameter Symbology and Load Conditions       64         VU Erasable Devices       5         W       35                                                                                  |

| Period                     |   |
|----------------------------|---|
| Programming Considerations |   |
| WWW, On-Line Support       |   |
| Z                          |   |
| Zero bit                   | 7 |

#### **READER RESPONSE**

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

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

| To:   | Technical Publications Manager Total Pages Sent                                            |
|-------|--------------------------------------------------------------------------------------------|
| RE:   | Reader Response                                                                            |
| From  | · Name                                                                                     |
|       | Company                                                                                    |
|       | Address City / State / ZIP / Country                                                       |
|       | Telephone: () FAX: ()                                                                      |
| ilaaA | cation (optional):                                                                         |
|       | d you like a reply?YN                                                                      |
|       | ce: PIC16HV540 Literature Number: DS40197B                                                 |
| Ques  | stions:                                                                                    |
| 1.    | What are the best features of this document?                                               |
| _     |                                                                                            |
| 2.    | How does this document meet your hardware and software development needs?                  |
| _     |                                                                                            |
| 3.    | Do you find the organization of this data sheet easy to follow? If not, why?               |
| _     |                                                                                            |
| 4.    | What additions to the data sheet do you think would enhance the structure and subject?     |
| _     |                                                                                            |
| 5.    | What deletions from the data sheet could be made without affecting the overall usefulness? |
|       |                                                                                            |
| 6.    | Is there any incorrect or misleading information (what and where)?                         |
| _     |                                                                                            |
| 7.    | How would you improve this document?                                                       |
| _     |                                                                                            |
| 8.    | How would you improve our software, systems, and silicon products?                         |
| _     |                                                                                            |

#### Note the following details of the code protection feature on PICmicro<sup>®</sup> MCUs.

- The PICmicro family meets the specifications contained in the Microchip Data Sheet.
- Microchip believes that its family of PICmicro microcontrollers is one of the most secure products of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the PICmicro microcontroller in a manner outside the operating specifications contained in the data sheet. The person doing so may be engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable".
- Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our product.

If you have any further questions about this matter, please contact the local sales office nearest to you.

Information contained in this publication regarding device applications and the like is intended through suggestion only and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. No representation or warranty is given and no liability is assumed by Microchip Technology Incorporated with respect to the accuracy or use of such information, or infringement of patents or other intellectual property rights arising from such use or otherwise. Use of Microchip's products as critical components in life support systems is not authorized except with express written approval by Microchip. No licenses are conveyed, implicitly or otherwise, under any intellectual property rights.

#### Trademarks

The Microchip name and logo, the Microchip logo, FilterLab, KEELOQ, microID, MPLAB, PIC, PICmicro, PICMASTER, PICSTART, PRO MATE, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

dsPIC, ECONOMONITOR, FanSense, FlexROM, fuzzyLAB, In-Circuit Serial Programming, ICSP, ICEPIC, microPort, Migratable Memory, MPASM, MPLIB, MPLINK, MPSIM, MXDEV, PICC, PICDEM, PICDEM.net, rfPIC, Select Mode and Total Endurance are trademarks of Microchip Technology Incorporated in the U.S.A.

Serialized Quick Turn Programming (SQTP) is a service mark of Microchip Technology Incorporated in the U.S.A.

All other trademarks mentioned herein are property of their respective companies.

© 2002, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.





Microchip received QS-9000 quality system certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona in July 1999. The Company's quality system processes and procedures are QS-9000 compliant for its PICmicro® 8-bit MCUs, KEELoq® code hopping devices, Serial EEPROMs and microperipheral products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001 certified.