

Welcome to E-XFL.COM

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

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

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

#### Details

E·XF

| Product Status             | 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 × 12)                                                              |
| Program Memory Type        | OTP                                                                          |
| EEPROM Size                | <u> </u>                                                                     |
| 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             | 18-SOIC (0.295", 7.50mm Width)                                               |
| Supplier Device Package    | 18-SOIC                                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16hv540t-20i-so |

Email: info@E-XFL.COM

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

## 1.0 GENERAL DESCRIPTION

The PIC16HV540 from Microchip Technology is a lowcost, high-performance, 8-bit, fully-static, EPROMbased CMOS microcontroller. It is pin and software compatible with the PIC16C5X family of devices. It employs a RISC architecture with only 33 single word/ single cycle instructions. All instructions are single cycle except for program branches, which take two cycles. The PIC16HV540 delivers performance an order of magnitude higher than its competitors in the same price category. The 12-bit wide instructions are highly orthogonal resulting in 2:1 code compression over other 8-bit microcontrollers in its class. The easyto-use and easy-to-remember instruction set reduces development time significantly.

The PIC16HV540 is the first One-Time-Programmable (OTP) microcontroller with an on-chip 3 volt and 5 volt regulator. This eliminates the need for an external regulator in many applications powered from 9 Volt or 12 Volt batteries or unregulated 6 volt, 9 volt or 12 volt mains adapters. The PIC16HV540 is ideally suited for applications that require very low standby current at high voltages. These typically require expensive low current regulators.

The PIC16HV540 is equipped with special features that reduce system cost and power requirements. The Power-On Reset (POR) and Device Reset Timer (DRT) eliminate the need for external reset circuitry. There are four oscillator configurations to choose from, including the powersaving LP (Low Power) oscillator, cost saving RC oscillator, and XT and HS for crystal oscillators. Power saving SLEEP mode, Watchdog Timer and code protection features improve system cost, power and reliability.

The UV erasable CERDIP packaged versions are ideal for code development, while the cost-effective OTP versions are suitable for production in any volume. The customer can take full advantage of Microchip's price leadership in OTP microcontrollers, while benefiting from the OTP's flexibility.

The PIC16HV540 is supported by a full-featured macro assembler, a software simulator, an in-circuit emulator, a low-cost development programmer, and a full featured programmer. All the tools are supported on IBM<sup>®</sup> PC and compatible machines.

#### 1.1 <u>Applications</u>

The PIC16HV540 fits in low-power battery applications such as CO and smoke detection, toys, games, security systems and automobile modules. The EPROM technology makes customizing of application programs (transmitter codes, receiver frequencies, etc.) extremely fast and convenient. The small footprint package, for through hole or surface mounting, make this microcontroller suitable for applications with space limitations. Low-cost, low-power, high-performance, ease of use and I/O flexibility make the PIC16HV540 very versatile even in areas where no microcontroller use has been considered before (e.g., timer functions, replacement of "glue" logic in larger systems, coprocessor applications).

### 1.2 Enhanced Features

#### 1.2.1 REGULATED I/O PORTA INDEPENDENT OF CORE REGULATOR

PORTA I/O pads and OSC2 output are powered by the regulated internal voltage VIO. A maximum of 10mA per output is allowed, or a total of 40mA. The core itself is powered from the independently regulated supply VREG.

#### 1.2.2 HIGH VOLTAGE I/O PORTB

All eight PORTB I/Os are high voltage I/O. The inputs will tolerate input voltages as high as the VDD and outputs will swing from VSs to the VDD. The input threshold voltages vary with supply voltage. (See Electrical Characteristics.)

#### 1.2.3 WAKE-UP ON PIN CHANGE ON PORTB [0:3]

Four of the PORTB inputs latch the status of the pin at the onset of sleep mode. A level change on the inputs resets the device, implementing wake up on pin change (via warm reset). The PCWUF bit in the status register is reset to indicate that a pin change caused the reset condition. Any pin change (glitch insensitive) of the opposite level of the initial value wakes up the device. This option can be enabled/disabled in OPTION2 register. (See OPTION2 Register, Register 4-3.)

#### 1.2.4 WAKE-UP ON PIN CHANGE WITH A SLOWLY-RISING VOLTAGE ON PORTB [7]

PORTB [7] also implements wake up from sleep, however this input is specifically adapted so that a slowly **rising** voltage does not cause excessive power consumption. This input can be used with external RC circuits for long sleep periods without using the internal timer and prescaler. This option is also enabled/disabled in OPTION2 register. (The enable/disable bit is shared with the other 4 wake-up inputs.) The PCWUF bit in the status register is also shared with the other four wake-up inputs.

#### 1.2.5 LOW-VOLTAGE (BROWN-OUT) DETECTION

A low voltage (Brown-out) detect circuit optionally resets the device at a voltage level higher than that at which the PICmicro<sup>®</sup> device stops operating. The nominal trip voltages are 3.1 volts (for 5 volt operation) and 2.2 volt (for 3 volt operation), respectively. The core remains in the reset state as long as this condition holds (as if a MCLR external reset was given). The Brown-out trip level is user selectable, with built-in interlocks. The Brown-out detector is disabled at power-up and is activated by clearing the appropriate bit (BODEN) in OPTION2 register.

## 3.0 ARCHITECTURAL OVERVIEW

The high performance of the PIC16HV540 can be attributed to a number of architectural features commonly found in RISC microprocessors. To begin with, the PIC16HV540 uses a Harvard architecture in which program and data are accessed on separate buses. This improves bandwidth over traditional von Neumann architecture where program and data are fetched on the same bus. Separating program and data memory further allows instructions to be sized differently than the 8-bit wide data word. Instruction opcodes are 12bits wide making it possible to have all single word instructions. A 12-bit wide program memory access bus fetches a 12-bit instruction in a single cycle. A twostage pipeline overlaps fetch and execution of instructions. Consequently, all instructions (33) execute in a single cycle (200ns @ 20MHz) except for program branches.

The PIC16HV540 address 512 x 12 of program memory. All program memory is internal.

The PIC16HV540 can directly or indirectly address its register files and data memory. All special function registers including the program counter are mapped in the data memory. The PIC16HV540 has a highly orthogonal (symmetrical) instruction set that makes it possible to carry out any operation on any register using any addressing mode. This symmetrical nature and lack of 'special optimal situations' make programming with the PIC16HV540 simple yet efficient. In addition, the learning curve is reduced significantly. The PIC16HV540 device contains an 8-bit ALU and working register. The ALU is a general purpose arithmetic unit. It performs arithmetic and Boolean functions between data in the working register and any register file.

The ALU is 8-bits wide and capable of addition, subtraction, shift and logical operations. Unless otherwise mentioned, arithmetic operations are two's complement in nature. In two-operand instructions, typically one operand is the W (working) register. The other operand is either a file register or an immediate constant. In single operand instructions, the operand is either the W register or a file register.

The W register is an 8-bit working register used for ALU operations. It is not an addressable register.

Depending on the instruction executed, the ALU may affect the values of the Carry (C), Digit Carry (DC), and Zero (Z) bits in the STATUS register. The C and DC bits operate as a borrow and digit borrow out bit, respectively, in subtraction. See the SUBWF and ADDWF instructions for examples.

A simplified block diagram is shown in Figure 3-1, with the corresponding device pins described in Table 3-1.

| Name        | DIP, SOIC<br>No. | SSOP<br>No. | I/O/P<br>Type | Input<br>Levels | Description                                                                                                                                                                                                                     |                         |  |  |
|-------------|------------------|-------------|---------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--|--|
| RA0         | 17               | 19          | I/O           | TTL             | Independently regulated Bi-directional I/O port — VIO                                                                                                                                                                           |                         |  |  |
| RA1         | 18               | 20          | I/O           | TTL             |                                                                                                                                                                                                                                 | ·                       |  |  |
| RA2         | 1                | 1           | I/O           | TTL             |                                                                                                                                                                                                                                 |                         |  |  |
| RA3         | 2                | 2           | I/O           | TTL             |                                                                                                                                                                                                                                 |                         |  |  |
| RB0         | 6                | 7           | I/O           | TTL             | High-voltage Bi-directional I/O port.                                                                                                                                                                                           | Wake-up on pin          |  |  |
| RB1         | 7                | 8           | I/O           | TTL             | Sourced from VDD.                                                                                                                                                                                                               | change                  |  |  |
| RB2         | 8                | 9           | I/O           | TTL             |                                                                                                                                                                                                                                 | -                       |  |  |
| RB3         | 9                | 10          | I/O           | TTL             |                                                                                                                                                                                                                                 |                         |  |  |
| RB4         | 10               | 11          | I/O           | TTL             |                                                                                                                                                                                                                                 |                         |  |  |
| RB5         | 11               | 12          | I/O           | TTL             |                                                                                                                                                                                                                                 |                         |  |  |
| RB6         | 12               | 13          | I/O           | TTL             |                                                                                                                                                                                                                                 |                         |  |  |
| RB7         | 13               | 14          | I/O           | TTL             |                                                                                                                                                                                                                                 | Wake-up on SLOW         |  |  |
|             |                  |             |               |                 |                                                                                                                                                                                                                                 | rising pin change.      |  |  |
| TOCKI       | 3                | 3           | I             | ST              | Clock input to Timer 0. Must be tied to                                                                                                                                                                                         | o Vss or VDD, if not in |  |  |
|             |                  |             |               |                 | use, to reduce current consumption.                                                                                                                                                                                             |                         |  |  |
| MCLR/Vpp    | 4                | 4           | I             | ST              | Master clear (reset) input/programming voltage input. This<br>pin is an active low reset to the device. Voltage on the MCLR/<br>VPP pin must not exceed VDD <sup>(1)</sup> to avoid unintended entering<br>of programming mode. |                         |  |  |
| OSC1/CLKIN  | 16               | 18          | I             | ST              | Oscillator crystal input/external clock                                                                                                                                                                                         | source input.           |  |  |
| OSC2/CLKOUT | 15               | 17          | 0             | _               | Oscillator crystal output. Connects to crystal or resonator in crystal oscillator mode. In RC mode, OSC2/CLKOUT output is connected to TMR0, bit 0. Frequencies of CLKIN/8 to CLKIN/1024 can be generated on this pin.          |                         |  |  |
| Vdd         | 14               | 15,16       | Р             | —               | Positive supply.                                                                                                                                                                                                                |                         |  |  |
| Vss         | 5                | 5,6         | Р             |                 | Ground reference.                                                                                                                                                                                                               |                         |  |  |

| <b>TABLE 3-1:</b> | <b>PINOUT DESCRIPTION - PIC16HV540</b> |
|-------------------|----------------------------------------|
|                   |                                        |

 $\label{eq:legend: Legend: I = input, O = output, I/O = input/output, P = power, --- = Not Used, TTL = TTL input, ST = Schmitt Trigger input.$ 

**Note 1:** VDD during programming mode can not exceed parameter PD1 called out in the PIC16C5X Programming Specification (Literature number DS30190).

| 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 contro                                                             | l registe                                                        | rs (TRIS/  | A, TRISE   | 3)       |           |          |           | 1111 1111                     | 1111 1111                         | 1111 1111                            | 1111 1111                      |
| N/A                | OPTION  | Contains                                                               | control b                                                        | its to cor | ifigure Ti | mer0 an  | d Timer0  | /WDT pr  | escaler   | 11 1111                       | 11 1111                           | 11 1111                              | 11 1111                        |
| N/A                | OPTION2 | Contains<br>WDT, reg                                                   |                                                                  |            |            | n change | es, softw | are enab | led       | 11 1111                       | uu uuuu                           | uu uuuu                              | xx xxxx                        |
| 00h                | INDF    | Uses contents of FSR to address data memory (not a physical regis ter) |                                                                  |            |            |          |           | l regis- | XXXX XXXX | uuuu uuuu                     | uuuu uuuu                         | xxxx xxxx                            |                                |
| 01h                | TMR0    | 8-bit real-                                                            | 8-bit real-time clock/counter xxxx xxxx uuuu uuuu uuuu xxxx xxxx |            |            |          |           |          |           |                               |                                   |                                      |                                |
| 02h <sup>(1)</sup> | PCL     | Low order                                                              | Low order 8 bits of PC                                           |            |            |          |           |          |           | 1111 1111                     | 1111 1111                         | 1111 1111                            | 1111 1111                      |
| 03h                | STATUS  | PCWUF                                                                  | PA1                                                              | PA0        | TO         | PD       | Z         | DC       | С         | 1001 1xxx                     | 100q quuu                         | 000u uuuu                            | x00x xxxx                      |
| 04h                | FSR     | •                                                                      | Indirect data memory address pointer                             |            |            |          |           |          | 111x xxxx | 111u uuuu                     | 111u uuuu                         | 111x xxxx                            |                                |
| 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                      |

#### **TABLE 4-1:** SPECIAL FUNCTION REGISTER SUMMARY

Legend: Shaded boxes = unimplemented or unused, - = unimplemented, read as '0' (if applicable) x = unknown, u = unchanged, q = value depends on condition.
 Note 1: The upper byte of the Program Counter is not directly accessible. See Section 4.6 of the PIC16HV540 data sheet (DS40197B) for an explanation of how to access these bits.

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

NOTES:

## 5.0 I/O PORTS

As with any other register, the I/O registers can be written and read under program control. However, read instructions (e.g., MOVF PORTB, W) always read the I/O pins independent of the pin's input/output modes. On RESET, all I/O ports are defined as input (inputs are at hi-impedance) since the I/O control registers (TRISA, TRISB) are all set.

#### 5.1 <u>PORTA</u>

PORTA is a 4-bit I/O register. Only the low order 4 bits are used (RA3:RA0). Bits 7-4 are unimplemented and read as '0's. The inputs will tolerate input voltages as high as VIO and outputs will swing from Vss to VIO. The internal voltage regulator VIO powers PORTA I/O pads. The internal regulator output, VIO, is switchable between 3Vdc and 5Vdc, via the (RL) bit in the OPTION2 register.

### 5.2 <u>PORTB</u>

PORTB is an 8-bit I/O register (PORTB<7:0>). All 8 PORTB I/Os are high voltage I/O. The inputs will tolerate input voltages as high as VDD and outputs will swing from Vss to VDD. In addition, 5 of the PORTB pins can be configured for the wake-up on change feature. Pins RB0, RB1, RB2 and RB3 latch the state of the pin at the onset of sleep mode. (No "dummy" read of the PORTB pins is required prior to executing the SLEEP instruction.) A level change on the input resets the device, implementing wake-up on pin change. The PCWUF bit in the status register is cleared to indicate that a pin change caused the reset. This feature can be enabled/ disabled in the OPTION2 register.

PORTB pin RB7 also exhibits this wake-up on pin high feature but is specially adapted for a slow-rising input signal. This special feature prevents excessive power consumption when desiring long sleep periods without using the watchdog timer and prescaler. PCWUF bit in the status register is cleared to indicate that a pin change caused the reset. This feature can be enabled/ disabled in the OPTION2 register.

Only pins configured as inputs can cause this wake-up on pin change to occur.

To prevent false wake-up on pin change events on pins RB<0:3>, the pin state must be driven to a logic 1 or logic 0 and not left floating during the "SLEEP" state. For pin RB7, the pin state must be driven to logic 0 and allowed to ramp to a logic 1 for correct operation.

### 5.3 TRIS Registers

The output driver control registers are loaded with the contents of the W register by executing the TRIS f instruction. A '1' from a TRIS register bit puts the corresponding output driver in a hi-impedance mode. A '0' puts the contents of the output data latch on the selected pins, enabling the output buffer.

| Note: | A read of the ports reads the pins, not the    |
|-------|------------------------------------------------|
|       | output data latches. That is, if an output     |
|       | driver on a pin is enabled and driven high,    |
|       | but the external system is holding it low, a   |
|       | read of the port will indicate that the pin is |
|       | low.                                           |

The TRIS registers are "write-only" and are set (output drivers disabled) upon RESET.

### 5.4 I/O Interfacing

The equivalent circuit for the PORTA and PORTB I/O pins are shown in Figure 5-1 through Figure 5-4. All ports may be used for both input and output operation. For input operations, these ports are non-latching. Any input must be present until read by an input instruction (e.g., MOVF PORTB, W). The outputs are latched and remain unchanged until the output latch is rewritten. To use a port pin as output, the corresponding direction control bit (in TRISA, TRISB) must be cleared (= 0). For use as an input, the corresponding TRIS bit must be set. Any I/O pin can be programmed individually as input or output.

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

|                         | PC                   | PC + 1                             | PC + 2                          | V PC + 3                              |                                         |
|-------------------------|----------------------|------------------------------------|---------------------------------|---------------------------------------|-----------------------------------------|
| Instruction<br>fetched  | 1<br>1               | MOVF PORTB,W                       |                                 | NOP                                   | This example shows a write              |
| RB7:RB0                 | <u>۱</u>             | I                                  | X                               | ·                                     | to PORTB followed by a read from PORTB. |
|                         | 1<br> <br> <br> <br> | Port pin<br>written here           | Port pin<br>sampled here        | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |                                         |
| Instruction<br>executed | <br> <br> <br> <br>  | MOVWF PORTB<br>(Write to<br>PORTB) | MOVF PORTB,W<br>(Read<br>PORTB) | NOP                                   |                                         |
|                         |                      | Write to                           | (Read                           |                                       | •                                       |

#### 6.2 <u>Prescaler</u>

An 8-bit counter is available as a prescaler for the Timer0 module, or as a postscaler for the Watchdog Timer (WDT) (WDT postscaler not implemented on PIC16C52), respectively (Section 6.1.2). For simplicity, this counter is being referred to as "prescaler" throughout this data sheet. Note that the prescaler may be used by either the Timer0 module or the WDT, but not both. Thus, a prescaler assignment for the Timer0 module means that there is no prescaler for the WDT, and vice-versa.

The PSA and PS2:PS0 bits (OPTION<3:0>) determine prescaler assignment and prescale ratio.

When assigned to the Timer0 module, all instructions writing to the TMR0 register (e.g., CLRF 1, MOVWF 1, BSF 1, x, etc.) will clear the prescaler. When assigned to WDT, a CLRWDT instruction will clear the prescaler along with the WDT. The prescaler is neither readable nor writable. On a RESET, the prescaler contains all '0's.

#### 6.2.1 SWITCHING PRESCALER ASSIGNMENT

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

# EXAMPLE 6-1: CHANGING PRESCALER (TIMER0 $\rightarrow$ WDT)

| 1. | CLRWDT |                      | ;Clear WDT                          |
|----|--------|----------------------|-------------------------------------|
| 2. | CLRF   | TMR0                 | ;Clear TMR0 & Prescaler             |
| 3. | MOVLW  | '00xx1111 <i>'</i> b | ;These 3 lines (5, 6, 7)            |
| 4. | OPTION |                      | ; are required only if<br>; desired |
|    |        |                      | ; desired                           |
| 5. | CLRWDT |                      | ;PS<2:0> are 000 or 001             |
| 6. | MOVLW  | '00xx1xxx'b          | ;Set Postscaler to                  |
| 7. | OPTION |                      | ; desired WDT rate                  |

To change prescaler from the WDT to the Timer0 module, use the sequence shown in Example 6-2. This sequence must be used even if the WDT is disabled. A CLRWDT instruction should be executed before switching the prescaler.

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

| CLRWDT |            | ;Clear WDT and      |
|--------|------------|---------------------|
|        |            | ;prescaler          |
| MOVLW  | 'xxxx0xxx' | ;Select TMR0, new   |
|        |            | ;prescale value and |
|        |            | ;clock source       |
| OPTION |            |                     |

#### 6.3 Programmable Clock Generator

When the PIC16HV540 is programmed to operate in the RC oscillator mode, the CLKOUT pin is connected to the compliment state of TMR0<0>. Use of the prescaler rate select bits PSA:PS0 in the OPTION register will provide for frequencies of CLKIN/8 to CLKIN/1024 on the CLKOUT pin.

#### EXAMPLE 6-3:

| Fosc | PRESCALER SETTING/CLKOUT FREQUENCY |         |  |  |  |  |
|------|------------------------------------|---------|--|--|--|--|
|      | CLKIN/1024                         | CLKIN/8 |  |  |  |  |
| 1Mhz | 976 Hz                             | 125 kHz |  |  |  |  |
| 2Mhz | 1953 Hz                            | 250 kHz |  |  |  |  |
| 3Mhz | 2930 Hz                            | 375 kHz |  |  |  |  |
| 4Mhz | 3906 Hz                            | 500 kHz |  |  |  |  |

In addition to this mode of operation, TMR0<0> can be toggled via the bcf and bsf bit type instructions. For this mode, the T0CS bit in the OPTION register must be set to 1. This setting configures TMR0 to increment on the T0CKI pin. To set the CLKOUT pin high, a bcf TMR0,0 instruction is used and to set the CLKOUT pin low, the bsf TMR0,0 instruction is used. The T0CKI pin should be pulled high or low to prevent false state changes on the CLKOUT pin.

#### 7.11 Program Verification/Code Protection

If the code protection bit(s) have not been programmed, the on-chip program memory can be read out for verification purposes.

| Note: | Microchip does not recommend code pro- |
|-------|----------------------------------------|
|       | tecting windowed devices.              |

### 7.12 ID Locations

Four memory locations are designated as ID locations where the user can store checksum or other code-identification numbers. These locations are not accessible during normal execution but are readable and writable during program/verify.

Use only the lower 4 bits of the ID locations and always program the upper 8 bits as '1's.

| Note: | Microchip will assign a unique pattern    |
|-------|-------------------------------------------|
|       | number for QTP and SQTP requests and      |
|       | for ROM devices. This pattern number will |
|       | be unique and traceable to the submitted  |
|       | code.                                     |

| BSF                            | Bit Set f                                                                                                                                                                               | BTFSS              | Bit Test f, Skip if Set                                                          |  |  |  |  |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----------------------------------------------------------------------------------|--|--|--|--|
| Syntax:                        | [ <i>label</i> ] BSF f,b                                                                                                                                                                | Syntax:            | [label] BTFSS f,b                                                                |  |  |  |  |
| Operands:                      | $\begin{array}{l} 0 \leq f \leq 31 \\ 0 \leq b \leq 7 \end{array}$                                                                                                                      | Operands:          | $0 \le f \le 31$<br>$0 \le b < 7$                                                |  |  |  |  |
| Operation:                     | $1 \rightarrow (f < b >)$                                                                                                                                                               | Operation:         | skip if (f <b>) = 1</b>                                                          |  |  |  |  |
| Status Affected:               | None                                                                                                                                                                                    | Status Affected:   | None                                                                             |  |  |  |  |
| Encoding:                      | 0101 bbbf ffff                                                                                                                                                                          | Encoding:          | 0111 bbbf ffff                                                                   |  |  |  |  |
| Description:                   | Bit 'b' in register 'f' is set.                                                                                                                                                         | Description:       | If bit 'b' in register 'f' is '1' then the next                                  |  |  |  |  |
| Words:                         | 1                                                                                                                                                                                       |                    | instruction is skipped.<br>If bit 'b' is '1', then the next instruction          |  |  |  |  |
| Cycles:                        | 1                                                                                                                                                                                       |                    | fetched during the current instruction                                           |  |  |  |  |
| Example:                       | BSF FLAG_REG, 7                                                                                                                                                                         |                    | execution, is discarded and an NOP is<br>executed instead, making this a 2 cycle |  |  |  |  |
| Before Instru                  |                                                                                                                                                                                         |                    | instruction.                                                                     |  |  |  |  |
|                                | EG = 0x0A                                                                                                                                                                               | Words:             | 1                                                                                |  |  |  |  |
| After Instruc<br>FLAG R        | tion<br>EG = 0x8A                                                                                                                                                                       | Cycles:            | 1(2)                                                                             |  |  |  |  |
|                                |                                                                                                                                                                                         | Example:           | HERE BTFSS FLAG,1                                                                |  |  |  |  |
| BTFSC                          | Bit Test f, Skip if Clear                                                                                                                                                               |                    | FALSE GOTO PROCESS_CODE<br>TRUE •                                                |  |  |  |  |
| Syntax:                        | [ <i>label</i> ] BTFSC f,b                                                                                                                                                              |                    | •                                                                                |  |  |  |  |
| Operands:                      | $0 \le f \le 31$<br>$0 \le b \le 7$                                                                                                                                                     | Defeue la stu      | •                                                                                |  |  |  |  |
| Operation                      |                                                                                                                                                                                         | Before Instr<br>PC | = address (HERE)                                                                 |  |  |  |  |
| Operation:<br>Status Affected: | skip if (f <b>) = 0<br/>None</b>                                                                                                                                                        | After Instruc      |                                                                                  |  |  |  |  |
| Encoding:                      |                                                                                                                                                                                         | If FLAG            |                                                                                  |  |  |  |  |
| Description:                   | 0110 bbbf ffff<br>If bit 'b' in register 'f' is 0 then the next                                                                                                                         | PC<br>if FLAG∢     | <pre>= address (FALSE); &lt;1&gt; = 1,</pre>                                     |  |  |  |  |
| Description.                   | instruction is skipped.                                                                                                                                                                 | PC                 | = address (TRUE)                                                                 |  |  |  |  |
|                                | If bit 'b' is 0 then the next instruction<br>fetched during the current instruction<br>execution is discarded, and an NOP is<br>executed instead, making this a 2 cycle<br>instruction. |                    |                                                                                  |  |  |  |  |
| Words:                         | 1                                                                                                                                                                                       |                    |                                                                                  |  |  |  |  |
| Cycles:                        | 1(2)                                                                                                                                                                                    |                    |                                                                                  |  |  |  |  |
| Example:                       | HERE BTFSC FLAG,1<br>FALSE GOTO PROCESS_CODE<br>TRUE •<br>•                                                                                                                             |                    |                                                                                  |  |  |  |  |
| Before Instru<br>PC            | uction<br>= address (HERE)                                                                                                                                                              |                    |                                                                                  |  |  |  |  |
| After Instruc                  |                                                                                                                                                                                         |                    |                                                                                  |  |  |  |  |
| if FLAG<<br>PC                 | (1> = 0,<br>= address (TRUE);                                                                                                                                                           |                    |                                                                                  |  |  |  |  |
| if FLAG<                       | :1> = 1,                                                                                                                                                                                |                    |                                                                                  |  |  |  |  |
| PC                             | = address(FALSE)                                                                                                                                                                        |                    |                                                                                  |  |  |  |  |

| COMF                      | Complement f                                                                                                                                                         |  |  |  |  |  |  |  |  |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Syntax:                   | [label] COMF f,d                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Operands:                 | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                     |  |  |  |  |  |  |  |  |
| Operation:                | $(\overline{f}) \to (dest)$                                                                                                                                          |  |  |  |  |  |  |  |  |
| Status Affected:          | Z                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| Encoding:                 | 0010 01df ffff                                                                                                                                                       |  |  |  |  |  |  |  |  |
| Description:              | The contents of register 'f' are comple-<br>mented. If 'd' is 0 the result is stored in<br>the W register. If 'd' is 1 the result is<br>stored back in register 'f'. |  |  |  |  |  |  |  |  |
| Words:                    | 1                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| Cycles:                   | 1                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| Example:                  | COMF REG1,0                                                                                                                                                          |  |  |  |  |  |  |  |  |
| Before Instru<br>REG1     | uction<br>= 0x13                                                                                                                                                     |  |  |  |  |  |  |  |  |
| After Instruc             | tion                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| REG1<br>W                 | = 0x13<br>= 0xEC                                                                                                                                                     |  |  |  |  |  |  |  |  |
| vv                        |                                                                                                                                                                      |  |  |  |  |  |  |  |  |
| DECF                      | Decrement f                                                                                                                                                          |  |  |  |  |  |  |  |  |
| Syntax:                   | [label] DECF f,d                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Operands:                 | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                     |  |  |  |  |  |  |  |  |
| Operation:                | $(f) - 1 \rightarrow (dest)$                                                                                                                                         |  |  |  |  |  |  |  |  |
| Status Affected:          | Z                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| Encoding:                 | 0000 11df ffff                                                                                                                                                       |  |  |  |  |  |  |  |  |
| Description:              | Decrement register 'f'. If 'd' is 0 the<br>result is stored in the W register. If 'd' is<br>1 the result is stored back in register 'f'.                             |  |  |  |  |  |  |  |  |
| Words:                    | 1                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| Cycles:                   | 1                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| Example:                  | DECF CNT, 1                                                                                                                                                          |  |  |  |  |  |  |  |  |
| Before Instru<br>CNT<br>Z | uction<br>= 0x01<br>= 0                                                                                                                                              |  |  |  |  |  |  |  |  |
| After Instruc             |                                                                                                                                                                      |  |  |  |  |  |  |  |  |
| CNT                       | = 0x00                                                                                                                                                               |  |  |  |  |  |  |  |  |
| Z                         | = 1                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|                           |                                                                                                                                                                      |  |  |  |  |  |  |  |  |

| DECFSZ                                                                                                                                                                                                  | Decrement f, Skip if 0                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| Syntax:                                                                                                                                                                                                 | [label] DECFSZ f,d                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |
| Operands:                                                                                                                                                                                               | $\begin{array}{l} 0\leq f\leq 31\\ d\in \ [0,1] \end{array}$                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |
| Operation:                                                                                                                                                                                              | $(f) - 1 \rightarrow d;$ skip if result = 0                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
| Status Affected:                                                                                                                                                                                        | None                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |
| Encoding:                                                                                                                                                                                               | 0010 11df ffff                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
| Description:                                                                                                                                                                                            | The contents of register 'f' are decre-<br>mented. If 'd' is 0 the result is placed in<br>the W register. If 'd' is 1 the result is<br>placed back in register 'f'.<br>If the result is 0, the next instruction,<br>which is already fetched, is discarded<br>and an NOP is executed instead mak-<br>ing it a two cycle instruction. |  |  |  |  |  |  |  |  |  |
| Words:                                                                                                                                                                                                  | 1                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
| Cycles:                                                                                                                                                                                                 | 1(2)                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |
| Example:                                                                                                                                                                                                | HERE DECFSZ CNT, 1<br>GOTO LOOP                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                         | CONTINUE •                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                         | •                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
| Before Instru<br>PC                                                                                                                                                                                     | uction<br>= address (HERE)                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |
| After Instruc<br>CNT<br>if CNT<br>PC<br>if CNT<br>PC                                                                                                                                                    | <pre>= CNT - 1;<br/>= 0,<br/>= address (CONTINUE);</pre>                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |
| GOTO                                                                                                                                                                                                    | Unconditional Branch                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |
| Syntax:                                                                                                                                                                                                 | [ <i>label</i> ] GOTO k                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
| Operands:                                                                                                                                                                                               | $0 \le k \le 511$                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
| Operation:                                                                                                                                                                                              | $k \rightarrow PC < 8:0>;$<br>STATUS<6:5> $\rightarrow PC < 10:9>$                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |
| Status Affected:                                                                                                                                                                                        | None                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |
| Encoding:                                                                                                                                                                                               | 101k kkkk kkkk                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
| Description:<br>GOTO is an unconditional branch. The<br>9-bit immediate value is loaded into PC<br>bits <8:0>. The upper bits of PC are<br>loaded from STATUS<6:5>. GOTO is a<br>two cycle instruction. |                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
| Words:                                                                                                                                                                                                  | 1                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
| Cycles:                                                                                                                                                                                                 | 2                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
| Example:                                                                                                                                                                                                | GOTO THERE                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |
| After Instruc                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
| PC =                                                                                                                                                                                                    | PC = address (THERE)                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |

| SWAPF                   | Swap Nibbles in f                                                                                                                                                     |  |  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Syntax:                 | [label] SWAPF f,d                                                                                                                                                     |  |  |  |  |  |  |  |
| Operands:               | $\begin{array}{l} 0\leq f\leq 31\\ d\in \ [0,1] \end{array}$                                                                                                          |  |  |  |  |  |  |  |
| Operation:              | $(f<3:0>) \rightarrow (dest<7:4>);$<br>$(f<7:4>) \rightarrow (dest<3:0>)$                                                                                             |  |  |  |  |  |  |  |
| Status Affected:        | None                                                                                                                                                                  |  |  |  |  |  |  |  |
| Encoding:               | 0011 10df ffff                                                                                                                                                        |  |  |  |  |  |  |  |
| Description:            | The upper and lower nibbles of register<br>'f' are exchanged. If 'd' is 0 the result is<br>placed in W register. If 'd' is 1 the result<br>is placed in register 'f'. |  |  |  |  |  |  |  |
| Words:                  | 1                                                                                                                                                                     |  |  |  |  |  |  |  |
| Cycles:                 | 1                                                                                                                                                                     |  |  |  |  |  |  |  |
| Example                 | SWAPF REG1, 0                                                                                                                                                         |  |  |  |  |  |  |  |
| Before Instru<br>REG1   | iction<br>= 0xA5                                                                                                                                                      |  |  |  |  |  |  |  |
| After Instruct          | tion                                                                                                                                                                  |  |  |  |  |  |  |  |
| REG1<br>W               | = 0xA5<br>= 0X5A                                                                                                                                                      |  |  |  |  |  |  |  |
| TRIS                    | Load TRIS Register                                                                                                                                                    |  |  |  |  |  |  |  |
| Syntax:                 | [ <i>label</i> ] TRIS f                                                                                                                                               |  |  |  |  |  |  |  |
| Operands:               | f = 5, 6 or 7                                                                                                                                                         |  |  |  |  |  |  |  |
| Operation:              | (W) $\rightarrow$ TRIS register f                                                                                                                                     |  |  |  |  |  |  |  |
| Status Affected:        | None                                                                                                                                                                  |  |  |  |  |  |  |  |
| Encoding:               | 0000 0000 0fff                                                                                                                                                        |  |  |  |  |  |  |  |
| Description:            | TRIS register 'f' (f = 5, 6, or $7^*$ ) is loaded<br>with the contents of the W register                                                                              |  |  |  |  |  |  |  |
| Words:                  | 1                                                                                                                                                                     |  |  |  |  |  |  |  |
| Cycles:                 | 1                                                                                                                                                                     |  |  |  |  |  |  |  |
| Example                 | TRIS PORTA                                                                                                                                                            |  |  |  |  |  |  |  |
| Before Instru<br>W      | iction<br>= 0XA5                                                                                                                                                      |  |  |  |  |  |  |  |
| After Instruct<br>TRISA | tion<br>= 0XA5                                                                                                                                                        |  |  |  |  |  |  |  |

\*A TRIS 7 operation will update the OPTION2 SFR.

| XORLW                                        | Exclusive OR literal with W                                                                                                                                                        |  |  |  |  |  |  |  |  |
|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Syntax:                                      | [ <i>label</i> ] XORLW k                                                                                                                                                           |  |  |  |  |  |  |  |  |
| Operands:                                    | $0 \le k \le 255$                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Operation:                                   | (W) .XOR. $k \rightarrow (W)$                                                                                                                                                      |  |  |  |  |  |  |  |  |
| Status Affected:                             | Z                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Encoding:                                    | 1111 kkkk kkkk                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Description:                                 | The contents of the W register are<br>XOR'ed with the eight bit literal 'k'. The<br>result is placed in the W register.                                                            |  |  |  |  |  |  |  |  |
| Words:                                       | 1                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Cycles:                                      | 1                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Example:                                     | XORLW 0xAF                                                                                                                                                                         |  |  |  |  |  |  |  |  |
| Before Instru<br>W =                         | oxB5                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| After Instruct<br>W =                        | ion<br>0x1A                                                                                                                                                                        |  |  |  |  |  |  |  |  |
| XORWF                                        | Exclusive OR W with f                                                                                                                                                              |  |  |  |  |  |  |  |  |
| Syntax:                                      | [ <i>label</i> ] XORWF f,d                                                                                                                                                         |  |  |  |  |  |  |  |  |
| Operands:                                    | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                                   |  |  |  |  |  |  |  |  |
| Operation:                                   | (W) .XOR. (f) $\rightarrow$ (dest)                                                                                                                                                 |  |  |  |  |  |  |  |  |
| Status Affected:                             | Z                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Encoding:                                    | 0001 10df ffff                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Description:                                 | Exclusive OR the contents of the W<br>register with register 'f'. If 'd' is 0 the<br>result is stored in the W register. If 'd' is<br>1 the result is stored back in register 'f'. |  |  |  |  |  |  |  |  |
| Words:                                       | 1                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Cycles:                                      | 1                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Example                                      | XORWF REG,1                                                                                                                                                                        |  |  |  |  |  |  |  |  |
| Before Instruction<br>REG = 0xAF<br>W = 0xB5 |                                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| After Instruct<br>REG<br>W                   | ion<br>= 0x1A<br>= 0xB5                                                                                                                                                            |  |  |  |  |  |  |  |  |

## 9.0 DEVELOPMENT SUPPORT

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

- Integrated Development Environment
  - MPLAB<sup>®</sup> IDE Software
- Assemblers/Compilers/Linkers
  - MPASM Assembler
  - MPLAB-C17 and MPLAB-C18 C Compilers
  - MPLINK/MPLIB Linker/Librarian
- Simulators
  - MPLAB-SIM Software Simulator
- Emulators
  - MPLAB-ICE Real-Time In-Circuit Emulator
  - PICMASTER<sup>®</sup>/PICMASTER-CE In-Circuit Emulator
  - ICEPIC™
- In-Circuit Debugger
  - MPLAB-ICD for PIC16F877
- Device Programmers
  - PRO MATE<sup>®</sup> II Universal Programmer
  - PICSTART<sup>®</sup> Plus Entry-Level Prototype Programmer
- Low-Cost Demonstration Boards
  - SIMICE
  - PICDEM-1
  - PICDEM-2
  - PICDEM-3
  - PICDEM-17
  - SEEVAL<sup>®</sup>
  - $KEELOQ^{(B)}$

#### 9.1 MPLAB Integrated Development Environment Software

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

- Multiple functionality
  - editor
  - simulator
  - programmer (sold separately)
  - emulator (sold separately)
- A full featured editor
- A project manager
- Customizable tool bar and key mapping
- A status bar
- On-line help

MPLAB allows you to:

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

The ability to use MPLAB with Microchip's simulator, MPLAB-SIM, allows a consistent platform and the ability to easily switch from the cost-effective simulator to the full featured emulator with minimal retraining.

#### 9.2 MPASM Assembler

MPASM is a full featured universal macro assembler for all PICmicro MCU's. It can produce absolute code directly in the form of HEX files for device programmers, or it can generate relocatable objects for MPLINK.

MPASM has a command line interface and a Windows shell and can be used as a standalone application on a Windows 3.x or greater system. MPASM generates relocatable object files, Intel standard HEX files, MAP files to detail memory usage and symbol reference, an absolute LST file which contains source lines and generated machine code, and a COD file for MPLAB debugging.

MPASM features include:

- MPASM and MPLINK are integrated into MPLAB projects.
- MPASM allows user defined macros to be created for streamlined assembly.
- MPASM allows conditional assembly for multi purpose source files.
- MPASM directives allow complete control over the assembly process.

#### 9.3 MPLAB-C17 and MPLAB-C18 C Compilers

The MPLAB-C17 and MPLAB-C18 Code Development Systems are complete ANSI 'C' compilers and integrated development environments for Microchip's PIC17CXXX and PIC18CXXX family of microcontrollers, respectively. These compilers provide powerful integration capabilities and ease of use not found with other compilers.

For easier source level debugging, the compilers provide symbol information that is compatible with the MPLAB IDE memory display.

#### 9.4 MPLINK/MPLIB Linker/Librarian

MPLINK is a relocatable linker for MPASM and MPLAB-C17 and MPLAB-C18. It can link relocatable objects from assembly or C source files along with precompiled libraries using directives from a linker script.

MPLIB is a librarian for pre-compiled code to be used with MPLINK. When a routine from a library is called from another source file, only the modules that contains that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications. MPLIB manages the creation and modification of library files.

MPLINK features include:

- MPLINK works with MPASM and MPLAB-C17 and MPLAB-C18.
- MPLINK allows all memory areas to be defined as sections to provide link-time flexibility.

MPLIB features include:

- MPLIB makes linking easier because single libraries can be included instead of many smaller files.
- MPLIB helps keep code maintainable by grouping related modules together.
- MPLIB commands allow libraries to be created and modules to be added, listed, replaced, deleted, or extracted.

#### 9.5 MPLAB-SIM Software Simulator

The MPLAB-SIM Software Simulator allows code development in a PC host environment by simulating the PICmicro series microcontrollers on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a file or user-defined key press to any of the pins. The execution can be performed in single step, execute until break, or trace mode.

MPLAB-SIM fully supports symbolic debugging using MPLAB-C17 and MPLAB-C18 and MPASM. The Software Simulator offers the flexibility to develop and debug code outside of the laboratory environment making it an excellent multi-project software development tool.

#### 9.6 MPLAB-ICE High Performance Universal In-Circuit Emulator with MPLAB IDE

The MPLAB-ICE Universal In-Circuit Emulator is intended to provide the product development engineer with a complete microcontroller design tool set for PICmicro microcontrollers (MCUs). Software control of MPLAB-ICE is provided by the MPLAB Integrated Development Environment (IDE), which allows editing, "make" and download, and source debugging from a single environment. Interchangeable processor modules allow the system to be easily reconfigured for emulation of different processors. The universal architecture of the MPLAB-ICE allows expansion to support new PICmicro microcontrollers.

The MPLAB-ICE Emulator System has been designed as a real-time emulation system with advanced features that are generally found on more expensive development tools. The PC platform and Microsoft<sup>®</sup> Windows 3.x/95/98 environment were chosen to best make these features available to you, the end user.

MPLAB-ICE 2000 is a full-featured emulator system with enhanced trace, trigger, and data monitoring features. Both systems use the same processor modules and will operate across the full operating speed range of the PICmicro MCU.

### 9.7 PICMASTER/PICMASTER CE

The PICMASTER system from Microchip Technology is a full-featured, professional quality emulator system. This flexible in-circuit emulator provides a high-quality, universal platform for emulating Microchip 8-bit PICmicro microcontrollers (MCUs). PICMASTER systems are sold worldwide, with a CE compliant model available for European Union (EU) countries.

### 9.8 ICEPIC

ICEPIC is a low-cost in-circuit emulation solution for the Microchip Technology PIC16C5X, PIC16C6X, PIC16C7X, and PIC16CXXX families of 8-bit one-timeprogrammable (OTP) microcontrollers. The modular system can support different subsets of PIC16C5X or PIC16CXXX products through the use of interchangeable personality modules or daughter boards. The emulator is capable of emulating without target application circuitry being present.

#### 9.9 MPLAB-ICD In-Circuit Debugger

Microchip's In-Circuit Debugger, MPLAB-ICD, is a powerful, low-cost run-time development tool. This tool is based on the flash PIC16F877 and can be used to develop for this and other PICmicro microcontrollers from the PIC16CXXX family. MPLAB-ICD utilizes the In-Circuit Debugging capability built into the PIC16F87X. This feature, along with Microchip's In-Circuit Serial Programming protocol, offers cost-effective in-circuit flash programming and debugging from the graphical user interface of the MPLAB Integrated Development Environment. This enables a designer to develop and debug source code by watching variables, single-stepping and setting break points. Running at full speed enables testing hardware in real-time. The MPLAB-ICD is also a programmer for the flash PIC16F87X family.

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

| DC Characteristics<br>Power Supply Pins                    |      |             | $\begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise specified)} \\ \mbox{Operating Temperature} & 0^{\circ}C \leq TA \leq +70^{\circ}C \mbox{ (commercial)} \\ & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ (industrial)} \end{array}$ |                  |                |                                                                                                                                   |  |  |  |
|------------------------------------------------------------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Characteristic Sym.                                        |      |             | Min. Typ. <sup>(1)</sup> Max. Units                                                                                                                                                                                                                            |                  | Units          | Conditions                                                                                                                        |  |  |  |
| Supply Voltage VD                                          |      | 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(3)IDDHS optionXT and RC(4) optionsLP option |      |             | 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.



FIGURE 10-4: RESET, WATCHDOG TIMER, AND DEVICE RESET TIMER TIMING - PIC16HV540

#### FIGURE 10-5: BROWN-OUT DETECT TIMING



#### **RESET, WATCHDOG TIMER, AND DEVICE RESET TIMER - PIC16HV540 TABLE 10-3:**

| AC Characteristics |      | Standard Operating Conditions (unless otherwise specified)              |                     |                     |          |       |                          |  |  |
|--------------------|------|-------------------------------------------------------------------------|---------------------|---------------------|----------|-------|--------------------------|--|--|
|                    |      | Operating Temperature $0^{\circ}C \le TA \le +70^{\circ}C$ (commercial) |                     |                     |          |       |                          |  |  |
|                    |      | -40                                                                     | $^{\circ}C \leq TA$ | ≤ +85°C             | (industr | ial)  |                          |  |  |
| Parameter          |      |                                                                         |                     |                     |          |       |                          |  |  |
| No.                | Sym  | Characteristic                                                          | Min.                | Typ. <sup>(1)</sup> | Max.     | Units | Conditions               |  |  |
| 30                 | TmcL | MCLR Pulse Width (low)                                                  | 2                   | _                   | _        | μs    | VDD = 15V, VREG = 5V     |  |  |
| 31                 | Twdt | Watchdog Timer Time-out Period                                          | 9.0*                | 18*                 | 40*      | ms    | VDD = 15V, VREG = 5V     |  |  |
| 32                 | TDRT | Device Reset Timer Period                                               | 9.0*                | 18*                 | 30*      | ms    | VDD = 15V, $VREG = 5V$ , |  |  |
|                    |      |                                                                         | 0.55*               | 1.1*                | 2.5*     |       | RC mode                  |  |  |
| 34                 | Tioz | I/O Hi-impedance from MCLR Low                                          | —                   | —                   | 100*     | ns    |                          |  |  |
| _                  | Трс  | Pin Change Pulse Width                                                  | 2                   | _                   | _        | μs    |                          |  |  |
| 35                 | TBOD | Brown-out Detect Pulse Width                                            | _                   | 2                   |          | μs    | Vreg ≤ Bvdd              |  |  |

 \* These parameters are characterized but not tested.
 Note 1: Data in the Typical ("Typ") column is at VREG = 5V, VDD = 15V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

#### FIGURE 10-6: TIMER0 CLOCK TIMINGS - PIC16HV540



#### **TIMER0 CLOCK REQUIREMENTS - PIC16HV540** TABLE 10-4:

| AC               | Charac | teristics Standard Operating          | Standard Operating Conditions (unless otherwise specified) |                    |        |        |                                                                |  |  |
|------------------|--------|---------------------------------------|------------------------------------------------------------|--------------------|--------|--------|----------------------------------------------------------------|--|--|
|                  |        | Operating Temperatu                   | perature $0^{\circ}C \le TA \le +70^{\circ}C$ (commercial) |                    |        |        |                                                                |  |  |
|                  |        |                                       | $-40^{\circ}C \le TA$                                      | ≤ +85°C            | (indus | trial) |                                                                |  |  |
| Parameter<br>No. | Sym    | Characteristic                        | Min                                                        | Typ <sup>(1)</sup> | Max    | Units  | Conditions                                                     |  |  |
| 40               | Tt0H   | T0CKI High Pulse Width - No Prescaler | 0.5 TCY + 20*                                              | —                  | _      | ns     |                                                                |  |  |
|                  |        | - With Prescaler                      | 10*                                                        | —                  |        | ns     |                                                                |  |  |
| 41               | Tt0L   | T0CKI Low Pulse Width - No Prescaler  | 0.5 TCY + 20*                                              | —                  |        | ns     |                                                                |  |  |
|                  |        | - With Prescaler                      | 10*                                                        | _                  |        | ns     |                                                                |  |  |
| 42               | Tt0P   | T0CKI Period                          | 20 or <u>TCY + 40</u> *<br>N                               |                    |        | ns     | Whichever is greater.<br>N = Prescale Value<br>(1, 2, 4,, 256) |  |  |

\* These parameters are characterized but not tested.

Note 1: Data in the Typical ("Typ") column is at 3.8V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

#### 18-Lead Ceramic Dual In-line with Window (JW) – 300 mil (CERDIP) 12.3



|                            | Units | INCHES* |      |      | MILLIMETERS |       |       |  |
|----------------------------|-------|---------|------|------|-------------|-------|-------|--|
| Dimension                  | MIN   | NOM     | MAX  | MIN  | NOM         | MAX   |       |  |
| Number of Pins             | n     |         | 18   |      |             | 18    |       |  |
| Pitch                      | р     |         | .100 |      |             | 2.54  |       |  |
| Top to Seating Plane       | Α     | .170    | .183 | .195 | 4.32        | 4.64  | 4.95  |  |
| Ceramic Package Height     | A2    | .155    | .160 | .165 | 3.94        | 4.06  | 4.19  |  |
| Standoff                   | A1    | .015    | .023 | .030 | 0.38        | 0.57  | 0.76  |  |
| Shoulder to Shoulder Width |       | .300    | .313 | .325 | 7.62        | 7.94  | 8.26  |  |
| Ceramic Pkg. Width         | E1    | .285    | .290 | .295 | 7.24        | 7.37  | 7.49  |  |
| Overall Length             | D     | .880    | .900 | .920 | 22.35       | 22.86 | 23.37 |  |
| Tip to Seating Plane       | L     | .125    | .138 | .150 | 3.18        | 3.49  | 3.81  |  |
| Lead Thickness             | С     | .008    | .010 | .012 | 0.20        | 0.25  | 0.30  |  |
| Upper Lead Width           | B1    | .050    | .055 | .060 | 1.27        | 1.40  | 1.52  |  |
| Lower Lead Width           | В     | .016    | .019 | .021 | 0.41        | 0.47  | 0.53  |  |
| Overall Row Spacing §      | eB    | .345    | .385 | .425 | 8.76        | 9.78  | 10.80 |  |
| Window Width               | W1    | .130    | .140 | .150 | 3.30        | 3.56  | 3.81  |  |
| Window Length              | .190  | .200    | .210 | 4.83 | 5.08        | 5.33  |       |  |

\* Controlling Parameter
 § Significant Characteristic
 JEDEC Equivalent: MO-036
 Drawing No. C04-010

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