



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                   |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | PIC                                                                      |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 20MHz                                                                    |
| Connectivity               | -                                                                        |
| Peripherals                | POR, WDT                                                                 |
| Number of I/O              | 32                                                                       |
| Program Memory Size        | 3KB (2K x 12)                                                            |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 134 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                |
| Data Converters            | -                                                                        |
| Oscillator Type            | External                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 44-TQFP                                                                  |
| Supplier Device Package    | 44-TQFP (10x10)                                                          |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f59t-i-pt |

Email: info@E-XFL.COM

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

### Pin Diagrams



| Name        | Function                        | Input<br>Type | Output<br>Type | Description                                                                                                                   |  |  |
|-------------|---------------------------------|---------------|----------------|-------------------------------------------------------------------------------------------------------------------------------|--|--|
| RA0         | RA0                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
| RA1         | RA1                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
| RA2         | RA2                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
| RA3         | RA3                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
| RB0         | RB0                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
| RB1         | RB1                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
| RB2         | RB2                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
| RB3         | RB3                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
| RB4         | RB4                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
| RB5         | RB5                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
| RB6/ICSPCLK | RB6                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
|             | ICSPCLK                         | ST            | _              | Serial Programming Clock                                                                                                      |  |  |
| RB7/ICSPDAT | RB7                             | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |
|             | ICSPDAT                         | ST            | CMOS           | Serial Programming I/O                                                                                                        |  |  |
| TOCKI       | TOCKI                           | ST            | —              | Clock input to Timer0. Must be tied to Vss or VDD, if not in use, to reduce current consumption.                              |  |  |
| MCLR/Vpp    | MCLR                            | ST            | —              | Active-low Reset to device. Voltage on the MCLR/VPP pin must not exceed VDD to avoid unintended entering of Programming mode. |  |  |
|             | Vpp                             | ΗV            | _              | Programming voltage input                                                                                                     |  |  |
| OSC1/CLKIN  | OSC1                            | XTAL          | —              | Oscillator crystal input                                                                                                      |  |  |
|             | CLKIN                           | ST            | _              | External clock source input                                                                                                   |  |  |
| OSC2/CLKOUT | OSC2                            | —             | XTAL           | Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode.                                       |  |  |
|             | CLKOUT                          | —             | CMOS           | In RC mode, OSC2 pin can output CLKOUT, which has 1/4 the frequency of OSC1.                                                  |  |  |
| Vdd         | Vdd                             | Power         |                | Positive supply for logic and I/O pins                                                                                        |  |  |
| Vss         | Vss                             | Power         |                | Ground reference for logic and I/O pins                                                                                       |  |  |
| O =         | input<br>output<br>Schmitt Trig | ger input     | _              | I/O= input/outputCMOS= CMOS output= Not UsedXTAL= Crystal input/outputTTL= TTL inputHV= High Voltage                          |  |  |

TABLE 2-1: PIC16F54 PINOUT DESCRIPTION

| Name        | Function                      | Input<br>Type | Output<br>Type | Description                                                                                                                   |  |  |  |
|-------------|-------------------------------|---------------|----------------|-------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| RA0         | RA0                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RA1         | RA1                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RA2         | RA2 TTL C                     |               | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RA3         | RA3                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RB0         | RB0                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RB1         | RB1                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RB2         | RB2                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RB3         | RB3                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RB4         | RB4                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RB5         | RB5                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RB6/ICSPCLK | RB6                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
|             | ICSPCLK                       | ST            |                | Serial programming clock                                                                                                      |  |  |  |
| RB7/ICSPDAT | RB7                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
|             | ICSPDAT                       | ST            | CMOS           | Serial programming I/O                                                                                                        |  |  |  |
| RC0         | RC0                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RC1         | RC1                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RC2         | RC2                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RC3         | RC3                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RC4         | RC4                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RC5         | RC5                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RC6         | RC6                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| RC7         | RC7                           | TTL           | CMOS           | Bidirectional I/O pin                                                                                                         |  |  |  |
| TOCKI       | TOCKI                         | ST            | —              | Clock input to Timer0. Must be tied to Vss or VDD, if not in use, to reduce current consumption.                              |  |  |  |
| MCLR/Vpp    | MCLR                          | ST            | _              | Active-low Reset to device. Voltage on the MCLR/VPP pin must not exceed VDD to avoid unintended entering of Programming mode. |  |  |  |
|             | Vpp                           | ΗV            | _              | Programming voltage input                                                                                                     |  |  |  |
| OSC1/CLKIN  | OSC1                          | XTAL          | —              | Oscillator crystal input                                                                                                      |  |  |  |
|             | CLKIN                         | ST            | —              | External clock source input                                                                                                   |  |  |  |
| OSC2/CLKOUT | OSC2                          |               | XTAL           | Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode.                                       |  |  |  |
|             | CLKOUT                        | —             | CMOS           | In RC mode, OSC2 pin outputs CLKOUT, which has 1/4 the frequency of OSC1.                                                     |  |  |  |
| Vdd         | Vdd                           | Power         | —              | Positive supply for logic and I/O pins                                                                                        |  |  |  |
| Vss         | Vss                           | Power         | _              | Ground reference for logic and I/O pins                                                                                       |  |  |  |
| N/C         | N/C                           | _             | _              | Unused, do not connect                                                                                                        |  |  |  |
|             | put<br>utput<br>chmitt Trigge | r input       | — =            | input/outputCMOS = CMOS outputNot UsedXTAL = Crystal input/outputTTL inputHV = High Voltage                                   |  |  |  |

# TABLE 2-2: PIC16F57 PINOUT DESCRIPTION

| RA0<br>RA1<br>RA2<br>RA3<br>RB0<br>RB1<br>RB2<br>RB3<br>RB4<br>RB5<br>RB6<br>CSPCLK<br>RB7<br>CSPDAT | Type           TTL           TTL | Type<br>CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS | Bidirectional I/O pin<br>Bidirectional I/O pin |  |  |
|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| RA1<br>RA2<br>RA3<br>RB0<br>RB1<br>RB2<br>RB3<br>RB4<br>RB5<br>RB6<br>CSPCLK<br>RB7                  | TTL                                                                                                                                                            | CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS                 | Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin                                                   |  |  |
| RA3<br>RB0<br>RB1<br>RB2<br>RB3<br>RB4<br>RB5<br>RB6<br>CSPCLK<br>RB7                                | TTL<br>TTL<br>TTL<br>TTL<br>TTL<br>TTL<br>TTL                                                                                                                                                                                                                                                              | CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS                 | Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin                                                                                                     |  |  |
| RA3<br>RB0<br>RB1<br>RB2<br>RB3<br>RB4<br>RB5<br>RB6<br>CSPCLK<br>RB7                                | TTL<br>TTL<br>TTL<br>TTL<br>TTL<br>TTL<br>TTL                                                                                                                                                                                                                                                              | CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS                         | Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin                                                                                                     |  |  |
| RB0<br>RB1<br>RB2<br>RB3<br>RB4<br>RB5<br>RB6<br>CSPCLK<br>RB7                                       | TTL<br>TTL<br>TTL<br>TTL<br>TTL<br>TTL                                                                                                                                                                                                                                                                     | CMOS<br>CMOS<br>CMOS<br>CMOS<br>CMOS                                 | Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin                                                                                                                              |  |  |
| RB1<br>RB2<br>RB3<br>RB4<br>RB5<br>RB6<br>CSPCLK<br>RB7                                              | TTL<br>TTL<br>TTL<br>TTL<br>TTL                                                                                                                                                                                                                                                                            | CMOS<br>CMOS<br>CMOS<br>CMOS                                         | Bidirectional I/O pin<br>Bidirectional I/O pin<br>Bidirectional I/O pin                                                                                                                                                       |  |  |
| RB2<br>RB3<br>RB4<br>RB5<br>RB6<br>CSPCLK<br>RB7                                                     | TTL<br>TTL<br>TTL<br>TTL                                                                                                                                                                                                                                                                                   | CMOS<br>CMOS<br>CMOS                                                 | Bidirectional I/O pin<br>Bidirectional I/O pin                                                                                                                                                                                |  |  |
| RB3<br>RB4<br>RB5<br>RB6<br>CSPCLK<br>RB7                                                            | TTL<br>TTL<br>TTL                                                                                                                                                                                                                                                                                          | CMOS<br>CMOS                                                         | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RB4<br>RB5<br>RB6<br>CSPCLK<br>RB7                                                                   | TTL<br>TTL                                                                                                                                                                                                                                                                                                 | CMOS                                                                 |                                                                                                                                                                                                                               |  |  |
| RB5<br>RB6<br>CSPCLK<br>RB7                                                                          | TTL                                                                                                                                                                                                                                                                                                        |                                                                      |                                                                                                                                                                                                                               |  |  |
| RB6<br>CSPCLK<br>RB7                                                                                 |                                                                                                                                                                                                                                                                                                            |                                                                      | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| CSPCLK<br>RB7                                                                                        |                                                                                                                                                                                                                                                                                                            | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RB7                                                                                                  | ST                                                                                                                                                                                                                                                                                                         |                                                                      | Serial programming clock                                                                                                                                                                                                      |  |  |
|                                                                                                      | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| COFDAI                                                                                               | ST                                                                                                                                                                                                                                                                                                         | CMOS                                                                 | Serial programming I/O                                                                                                                                                                                                        |  |  |
| RC0                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RC1                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RC2                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RC3                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RC4                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RC4<br>RC5                                                                                           | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
|                                                                                                      |                                                                                                                                                                                                                                                                                                            |                                                                      |                                                                                                                                                                                                                               |  |  |
| RC6                                                                                                  |                                                                                                                                                                                                                                                                                                            | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RC7                                                                                                  |                                                                                                                                                                                                                                                                                                            | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RD0                                                                                                  |                                                                                                                                                                                                                                                                                                            | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RD1                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RD2                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RD3                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RD4                                                                                                  |                                                                                                                                                                                                                                                                                                            | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RD5                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RD6                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RD7                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RE4                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RE5                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RE6                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| RE7                                                                                                  | TTL                                                                                                                                                                                                                                                                                                        | CMOS                                                                 | Bidirectional I/O pin                                                                                                                                                                                                         |  |  |
| TOCKI                                                                                                | ST                                                                                                                                                                                                                                                                                                         |                                                                      | Clock input to Timer0. Must be tied to VSS or VDD, if not in use, to reduc<br>current consumption.                                                                                                                            |  |  |
| MCLR                                                                                                 | ST                                                                                                                                                                                                                                                                                                         | —                                                                    | Active-low Reset to device. Voltage on the MCLR/VPP pin must not exceed VDD to avoid unintended entering of Programming mode.                                                                                                 |  |  |
| Vpp                                                                                                  | ΗV                                                                                                                                                                                                                                                                                                         | -                                                                    | Programming voltage input                                                                                                                                                                                                     |  |  |
| OSC1                                                                                                 | XTAL                                                                                                                                                                                                                                                                                                       | _                                                                    | Oscillator crystal input                                                                                                                                                                                                      |  |  |
| CLKIN ST — External clock source input                                                               |                                                                                                                                                                                                                                                                                                            |                                                                      | External clock source input                                                                                                                                                                                                   |  |  |
| OSC2                                                                                                 | _                                                                                                                                                                                                                                                                                                          | XTAL                                                                 | Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode.                                                                                                                                       |  |  |
| CLKOUT                                                                                               | _                                                                                                                                                                                                                                                                                                          | CMOS                                                                 | In RC mode, OSC2 pin outputs CLKOUT, which has 1/4 the frequency o OSC1.                                                                                                                                                      |  |  |
| VDD                                                                                                  | Power                                                                                                                                                                                                                                                                                                      | _                                                                    | Positive supply for logic and I/O pins                                                                                                                                                                                        |  |  |
| Vss                                                                                                  | Power                                                                                                                                                                                                                                                                                                      | _                                                                    | Ground reference for logic and I/O pins                                                                                                                                                                                       |  |  |
|                                                                                                      | •                                                                                                                                                                                                                                                                                                          | I/O =                                                                | input/output CMOS = CMOS output                                                                                                                                                                                               |  |  |
| t                                                                                                    |                                                                                                                                                                                                                                                                                                            |                                                                      | Not Used XTAL = Crystal input/output                                                                                                                                                                                          |  |  |
|                                                                                                      | DSC1<br>SLKIN<br>DSC2<br>KOUT<br>VDD<br>VSS                                                                                                                                                                                                                                                                | DSC1 XTAL<br>SLKIN ST<br>DSC2 —<br>KOUT —<br>VDD Power               | DSC1 XTAL —<br>SLKIN ST —<br>DSC2 — XTAL<br>KOUT — CMOS<br>VDD Power —<br>VSS Power —<br>I/O =<br>— =                                                                                                                         |  |  |

TABLE 2-3: PIC16F59 PINOUT DESCRIPTION

### 3.2 Data Memory Organization

Data memory is composed of registers or bytes of RAM. Therefore, data memory for a device is specified by its register file. The register file is divided into two functional groups: Special Function Registers (SFR) and General Purpose Registers (GPR).

The Special Function Registers include the TMR0 register, the Program Counter (PC), the STATUS register, the I/O registers (ports) and the File Select Register (FSR). In addition, Special Purpose Registers are used to control the I/O port configuration and prescaler options.

The General Purpose Registers are used for data and control information under command of the instructions.

For the PIC16F54, the register file is composed of 7 Special Function Registers and 25 General Purpose Registers (Figure 3-3).

For the PIC16F57, the register file is composed of 8 Special Function Registers, 8 General Purpose Registers and 64 additional General Purpose Registers that may be addressed using a banking scheme (Figure 3-4).

For the PIC16F59, the register file is composed of 10 Special Function Registers, 6 General Purpose Registers and 128 additional General Purpose Registers that may be addressed using a banking scheme (Figure 3-5).

#### 3.2.1 GENERAL PURPOSE REGISTER FILE

The register file is accessed either directly or indirectly through the File Select Register (FSR). The FSR register is described in **Section 3.7 "Indirect Data Addressing; INDF and FSR Registers"**.

| FIGURE 3-3:  | PIC16F54 REGISTER FILE<br>MAP |
|--------------|-------------------------------|
| File Address |                               |



#### FIGURE 3-4: PIC16F57 REGISTER FILE MAP





NOTES:

# 6.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 high-impedance), since the I/O control registers (TRISA, TRISB, TRISC, TRISD and TRISE) are all set.

#### 6.1 PORTA

PORTA is a 4-bit I/O register. Only the low order 4 bits are used (PORTA<3:0>). The high order 4 bits (PORTA<7:4>) are unimplemented and read as '0's.

#### 6.2 PORTB

PORTB is an 8-bit I/O register (PORTB<7:0>).

#### 6.3 PORTC

PORTC is an 8-bit I/O register (PORTC<7:0>) for the PIC16F57 and PIC16F59.

PORTC is a General Purpose Register for the PIC16F54.

#### 6.4 PORTD

PORTD is an 8-bit I/O register (PORTD<7:0>) for the PIC16F59.

PORTD is a General Purpose Register for the PIC16F54 and PIC16F57.

#### 6.5 PORTE

PORTE is an 4-bit I/O register for the PIC16F59. Only the high order 4 bits are used (PORTE<7:4>). The low order 4 bits (PORTE<3:0>) are unimplemented and read as '0's.

PORTE is a General Purpose Register for the PIC16F54 and PIC16F57.

#### 6.6 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 High-Impedance (Input) 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.

# 6.7 I/O Interfacing

The equivalent circuit for an I/O port pin is shown in Figure 6-1. 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, TRISC, TRISD and TRISE) 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 6-1:

#### EQUIVALENT CIRCUIT FOR A SINGLE I/O PIN



# 7.0 TIMER0 MODULE AND TMR0 REGISTER

The Timer0 module has the following features:

- 8-bit Timer/Counter register, TMR0
  - Readable and writable
- 8-bit software programmable prescaler
- Internal or external clock select
  - Edge select for external clock

Figure 7-1 is a simplified block diagram of the Timer0 module.

Timer mode is selected by clearing the T0CS bit (OPTION<5>). In Timer mode, the Timer0 module will increment every instruction cycle (without prescaler). If TMR0 register is written, the increment is inhibited for the following two cycles (Figure 7-2 and Figure 7-3). The user can work around this by writing an adjusted value to the TMR0 register.

Counter mode is selected by setting the T0CS bit (OPTION<5>). In this mode, Timer0 will increment either on every rising or falling edge of pin T0CKI. The incrementing edge is determined by the source edge select bit T0SE (OPTION<4>). Clearing the T0SE bit selects the rising edge. Restrictions on the external clock input are discussed in detail in **Section 7.1** "Using Timer0 with an External Clock".

Note: The prescaler may be used by either the Timer0 module or the Watchdog Timer, but not both.

The prescaler assignment is controlled in software by the control bit PSA (OPTION<3>). Clearing the PSA bit will assign the prescaler to Timer0. The prescaler is not readable or writable. When the prescaler is assigned to the Timer0 module, prescale values of 1:2, 1:4,..., 1:256 are selectable. **Section 7.2 "Prescaler"** details the operation of the prescaler.

A summary of registers associated with the Timer0 module is found in Table 7-1.



| FIGURE 7-2: | TIMER0 TIMING: INTERNAL CLOCK/NO PRESCALER |  |
|-------------|--------------------------------------------|--|
|             |                                            |  |

| PC<br>(Program       | Q1 Q2 Q3 Q4 | Q1 Q2 Q3 Q4     | Q1 Q2 Q3 Q4            | Q1 Q2 Q3 Q4            | Q1 Q2 Q3 Q4            | Q1 Q2 Q3 Q4            | Q1 Q2 Q3 Q4                | Q1 Q2 Q3 Q4                |
|----------------------|-------------|-----------------|------------------------|------------------------|------------------------|------------------------|----------------------------|----------------------------|
| Counter)             | ( PC - 1 )  | PC              | ( PC + 1 )             | PC + 2 )               | PC + 3                 | ( PC + 4 )             | PC + 5 (                   | PC + 6                     |
| Instruction<br>Fetch |             | MOVWF TMR0      | MOVF TMR0,W                |                            |
| Timer0               | το χ        | <u>Τ0 + 1 χ</u> | <u>T0+2</u> X          | NTO X                  | <u>NT0 }</u>           | <u>мто X</u>           | NT0 + 1 X                  | NT0 + 2 X                  |
| Executed             |             | 1               | Write TMR0<br>executed | Read TMR0<br>reads NT0 | Read TMR0<br>reads NT0 | Read TMR0<br>reads NT0 | Read TMR0<br>reads NT0 + 1 | Read TMR0<br>reads NT0 + 2 |

© 2007 Microchip Technology Inc.

#### 7.1 Using Timer0 with an External Clock

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

#### 7.1.1 EXTERNAL CLOCK SYNCHRONIZATION

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

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

#### 7.1.2 TIMER0 INCREMENT DELAY

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





#### 7.2 Prescaler

An 8-bit counter is available as a prescaler for the Timer0 module, or as a postscaler for the Watchdog Timer (WDT), respectively (Section 8.2.1 "WDT Period"). 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 PS<2:0> 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.

# 9.0 INSTRUCTION SET SUMMARY

Each PIC16F5X instruction is a 12-bit word divided into an opcode, which specifies the instruction type, and one or more operands which further specify the operation of the instruction. The PIC16F5X instruction set summary in Table 9-2 groups the instructions into byteoriented, bit-oriented, and literal and control operations. Table 9-1 shows the opcode field descriptions.

For **byte-oriented** instructions, 'f' represents a file register designator and 'd' represents a destination designator. The file register designator is used to specify which one of the 32 file registers in that bank is to be used by the instruction.

The destination designator specifies where the result of the operation is to be placed. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed in the file register specified in the instruction.

For **bit-oriented** instructions, 'b' represents a bit field designator which selects the number of the bit affected by the operation, while 'f' represents the number of the file in which the bit is located.

For **literal and control** operations, 'k' represents an 8- or 9-bit constant or literal value.

| TABLE 9-1: | OPCODE FIELD |
|------------|--------------|
|            | DESCRIPTIONS |

| DESCRIPTIONS  |                                           |  |  |  |  |
|---------------|-------------------------------------------|--|--|--|--|
| Field         | Description                               |  |  |  |  |
| f             | Register file address (0x00 to 0x1F)      |  |  |  |  |
| W             | Working register (accumulator)            |  |  |  |  |
| b             | Bit address within an 8-bit file register |  |  |  |  |
| k             | Literal field, constant data or label     |  |  |  |  |
| x             | Don't care location (= 0 or 1)            |  |  |  |  |
|               | The assembler will generate code with     |  |  |  |  |
|               | x = 0. It is the recommended form of use  |  |  |  |  |
|               | for compatibility with all Microchip      |  |  |  |  |
|               | software tools.                           |  |  |  |  |
| d             | Destination select;                       |  |  |  |  |
|               | d = 0 (store result in W)                 |  |  |  |  |
|               | d = 1 (store result in file register 'f') |  |  |  |  |
|               | Default is d = 1                          |  |  |  |  |
| label         | Label name                                |  |  |  |  |
| TOS           | Top-of-Stack                              |  |  |  |  |
| PC            | Program Counter                           |  |  |  |  |
| WDT           | Watchdog Timer Counter                    |  |  |  |  |
| TO            | Time-out bit                              |  |  |  |  |
| PD            | Power-down bit                            |  |  |  |  |
| dest          | Destination, either the W register or the |  |  |  |  |
|               | specified register file location          |  |  |  |  |
| []            | Options                                   |  |  |  |  |
| ( )           | Contents                                  |  |  |  |  |
| $\rightarrow$ | Assigned to                               |  |  |  |  |
| < >           | Register bit field                        |  |  |  |  |
| ∈             | In the set of                             |  |  |  |  |
| italics       | User defined term                         |  |  |  |  |
|               |                                           |  |  |  |  |

All instructions are executed within one single instruction cycle, unless a conditional test is true or the program counter is changed as a result of an instruction. In this case, the execution takes two instruction cycles. One instruction cycle consists of four oscillator periods. Thus, for an oscillator frequency of 4 MHz, the normal instruction execution time would be 1  $\mu$ s. If a conditional test is true or the program counter is changed as a result of an instruction, the instruction execution time would be 2  $\mu$ s.

Figure 9-1 shows the three general formats that the instructions can have. All examples in the figure use the following format to represent a hexadecimal number:

0xhhh

where 'h' signifies a hexadecimal digit.

#### FIGURE 9-1: GENERAL FORMAT FOR INSTRUCTIONS

| Byte-oriented file register operations                                                                                                   |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| <b>11 6 5 4</b> 0                                                                                                                        |  |  |  |  |  |  |
| OPCODE d f (FILE #)                                                                                                                      |  |  |  |  |  |  |
| d = 0 for destination W<br>d = 1 for destination f<br>f = 5-bit file register address                                                    |  |  |  |  |  |  |
| Bit-oriented file register operations                                                                                                    |  |  |  |  |  |  |
| <u>11 8754 0</u>                                                                                                                         |  |  |  |  |  |  |
| OPCODE b (BIT #) f (FILE #)                                                                                                              |  |  |  |  |  |  |
| <ul> <li>b = 3-bit bit address</li> <li>f = 5-bit file register address</li> <li>Literal and control operations (except GOTO)</li> </ul> |  |  |  |  |  |  |
| <b>11 8 7</b> 0                                                                                                                          |  |  |  |  |  |  |
| OPCODE k (literal)                                                                                                                       |  |  |  |  |  |  |
| k = 8-bit immediate value                                                                                                                |  |  |  |  |  |  |
| Literal and control operations - GOTO instruction                                                                                        |  |  |  |  |  |  |
| <b>11 9 8</b> 0                                                                                                                          |  |  |  |  |  |  |
| OPCODE k (literal)                                                                                                                       |  |  |  |  |  |  |
| k = 9-bit immediate value                                                                                                                |  |  |  |  |  |  |

| ADDWF                                                       | Add W                                                            | and f                                       |                                                                                |  |
|-------------------------------------------------------------|------------------------------------------------------------------|---------------------------------------------|--------------------------------------------------------------------------------|--|
| Syntax:                                                     | [ <i>label</i> ] ADDWF f, d                                      |                                             |                                                                                |  |
| Operands:                                                   | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$ |                                             |                                                                                |  |
| Operation:                                                  | (W) + (f)                                                        | $\rightarrow$ (dest)                        |                                                                                |  |
| Status Affected:                                            | C, DC, Z                                                         |                                             |                                                                                |  |
| Encoding:                                                   | 0001                                                             | 11df                                        | ffff                                                                           |  |
| Description:                                                | and registresult is a                                            | ster 'f'. If '<br>stored in t<br>the result | of the W register<br>d' is '0', the<br>the W register. If<br>is stored back in |  |
| Words:                                                      | 1                                                                |                                             |                                                                                |  |
| Cycles:                                                     | 1                                                                |                                             |                                                                                |  |
| Example:                                                    | ADDWF                                                            | TEMP_RE                                     | EG, 0                                                                          |  |
| Before Instr<br>W<br>TEMP_I<br>After Instruc<br>W<br>TEMP_I | =<br>REG =<br>ction =                                            | 0x17<br>0xC2<br>0xD9<br>0xC2                |                                                                                |  |

| ANDWF                                                      | AND W with f                                                                                                                                                                              |
|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                                    | [ <i>label</i> ] ANDWF f, d                                                                                                                                                               |
| Operands:                                                  | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                                          |
| Operation:                                                 | (W) .AND. (f) $\rightarrow$ (dest)                                                                                                                                                        |
| Status Affected:                                           | Z                                                                                                                                                                                         |
| Encoding:                                                  | 0001 01df ffff                                                                                                                                                                            |
| Description:                                               | The contents of the W register are<br>AND'ed with register 'f'. If 'd' is '0',<br>the result is stored in the W<br>register. If 'd' is '1', the result is<br>stored back in register 'f'. |
| Words:                                                     | 1                                                                                                                                                                                         |
| Cycles:                                                    | 1                                                                                                                                                                                         |
| Example:                                                   | ANDWF TEMP_REG, 1                                                                                                                                                                         |
| Before Instru<br>W<br>TEMP_<br>After Instruc<br>W<br>TEMP_ | = 0x17<br>REG = 0xC2<br>tion<br>= 0x17                                                                                                                                                    |

| ANDLW            | AND lite        | ral with V             | N                                        |           |
|------------------|-----------------|------------------------|------------------------------------------|-----------|
| Syntax:          | [label]         | ANDLW                  | k                                        |           |
| Operands:        | $0 \le k \le 2$ | 55                     |                                          |           |
| Operation:       | (W).AND         | . (k) $\rightarrow$ (\ | N)                                       |           |
| Status Affected: | Z               |                        |                                          |           |
| Encoding:        | 1110            | kkkk                   | kkkk                                     |           |
| Description:     | AND'ed          | with the e             | e W regis<br>ight-bit lit<br>ed in the \ | eral 'k'. |
| Words:           | 1               |                        |                                          |           |
| Cycles:          | 1               |                        |                                          |           |
| Example:         | ANDLW           | H'5F'                  |                                          |           |
| Before Instru    | uction          |                        |                                          |           |
| W =              | 0/0/10          |                        |                                          |           |
| After Instruc    |                 |                        |                                          |           |
| W =              | 0x03            |                        |                                          |           |

| BCF                                      | Bit Clear f                                                        |     |
|------------------------------------------|--------------------------------------------------------------------|-----|
| Syntax:                                  | [label] BCF f, b                                                   |     |
| Operands:                                | $\begin{array}{l} 0 \leq f \leq 31 \\ 0 \leq b \leq 7 \end{array}$ |     |
| Operation:                               | $0 \rightarrow (f{<}b{>})$                                         |     |
| Status Affected:                         | None                                                               |     |
| Encoding:                                | 0100 bbbf ffff                                                     |     |
| Description:                             | Bit 'b' in register 'f' is cleare                                  | ed. |
| Words:                                   | 1                                                                  |     |
| Cycles:                                  | 1                                                                  |     |
| Example:                                 | BCF FLAG_REG, 7                                                    |     |
| Before Instru<br>FLAG_F<br>After Instruc | REG = 0xC7                                                         |     |
| FLAG_F                                   | REG = 0x47                                                         |     |

| GOTO                   | Unconditional Branch                                                                                                                                                                        |         |          |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------|
| Syntax:                | [ label ]                                                                                                                                                                                   | GOTO    | k        |
| Operands:              | $0 \le k \le 5$                                                                                                                                                                             | 11      |          |
| Operation:             | $k \rightarrow PC < STATUS$                                                                                                                                                                 | ,       | PC<10:9> |
| Status Affected:       | None                                                                                                                                                                                        |         |          |
| Encoding:              | 101k                                                                                                                                                                                        | kkkk    | kkkk     |
| Description:           | GOTO is an unconditional branch.<br>The 9-bit immediate value is<br>loaded into PC bits <8:0>. The<br>upper bits of PC are loaded from<br>STATUS<6:5>. GOTO is a two-<br>cycle instruction. |         |          |
| Words:                 | 1                                                                                                                                                                                           |         |          |
| Cycles:                | 2                                                                                                                                                                                           |         |          |
| Example:               | GOTO TH                                                                                                                                                                                     | IERE    |          |
| After Instruct<br>PC = | ion<br>address                                                                                                                                                                              | G (THER | E)       |

| INCF                                                    | Increment f                                                                                                                                                                |
|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                                 | [ <i>label</i> ] INCF 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:                                               | 0010 10df ffff                                                                                                                                                             |
| Description:                                            | The contents of register 'f' are<br>incremented. If 'd' is '0', the result<br>is placed in the W register. If 'd' is<br>'1', the result is placed back in<br>register 'f'. |
| Words:                                                  | 1                                                                                                                                                                          |
| Cycles:                                                 | 1                                                                                                                                                                          |
| Example:                                                | INCF CNT, 1                                                                                                                                                                |
| Before Instru<br>CNT<br>Z<br>After Instruct<br>CNT<br>Z | = 0xFF<br>= 0                                                                                                                                                              |

| INCFSZ                                                                          | Increment f, Skip if 0                                                                                                                                                                                                                                                                                                                          |
|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                                                         | [label] INCFSZ f, d                                                                                                                                                                                                                                                                                                                             |
| Operands:                                                                       | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                                                                                                                                                                                                |
| Operation:                                                                      | (f) + 1 $\rightarrow$ (dest), skip if result = 0                                                                                                                                                                                                                                                                                                |
| Status Affected:                                                                | None                                                                                                                                                                                                                                                                                                                                            |
| Encoding:                                                                       | 0011 11df ffff                                                                                                                                                                                                                                                                                                                                  |
| Description:                                                                    | The contents of register 'f' are<br>incremented. If 'd' is '0', the result<br>is placed in the W register. If 'd' is<br>'1', the result is placed back in<br>register 'f'. If the result is '0', then<br>the next instruction, which is<br>already fetched, is discarded and<br>a NOP is executed instead making<br>it a two-cycle instruction. |
| Words:                                                                          | 1                                                                                                                                                                                                                                                                                                                                               |
| Cycles:                                                                         | 1(2)                                                                                                                                                                                                                                                                                                                                            |
| <u>Example</u> :                                                                | HERE INCFSZ CNT, 1<br>GOTO LOOP<br>CONTINUE •<br>•                                                                                                                                                                                                                                                                                              |
| Before Instruct<br>PC<br>After Instructi<br>CNT<br>if CNT<br>PC<br>if CNT<br>PC | = address (HERE)                                                                                                                                                                                                                                                                                                                                |

# PIC16F5X

| IORLW            | Inclusive OR literal with W                                                                                               |
|------------------|---------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] IORLW k                                                                                                  |
| Operands:        | $0 \le k \le 255$                                                                                                         |
| Operation:       | (W) .OR. (k) $\rightarrow$ (W)                                                                                            |
| Status Affected: | Z                                                                                                                         |
| Encoding:        | 1101 kkkk kkkk                                                                                                            |
| Description:     | The contents of the W register are<br>OR'ed with the eight-bit literal 'k'.<br>The result is placed in the W<br>register. |
| Words:           | 1                                                                                                                         |
| Cycles:          | 1                                                                                                                         |
| Example:         | IORLW 0x35                                                                                                                |
| Before Instru    | uction                                                                                                                    |
| • •              | 0x9A                                                                                                                      |
| After Instruc    |                                                                                                                           |
| W =              | 0xBF                                                                                                                      |
| Z =              | 0                                                                                                                         |

| IORWF                                                           | Inclusive OR W with f                                                                                                                                                       |  |  |
|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:                                                         | [ <i>label</i> ] IORWF f, d                                                                                                                                                 |  |  |
| Operands:                                                       | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                            |  |  |
| Operation:                                                      | (W).OR. (f) $\rightarrow$ (dest)                                                                                                                                            |  |  |
| Status Affected:                                                | Z                                                                                                                                                                           |  |  |
| Encoding:                                                       | 0001 00df ffff                                                                                                                                                              |  |  |
| Description:                                                    | Inclusive OR the W register with<br>register 'f'. If 'd' is '0', the result is<br>placed in the W register. If 'd' is '1',<br>the result is placed back in<br>register 'f'. |  |  |
| Words:                                                          | 1                                                                                                                                                                           |  |  |
| Cycles:                                                         | 1                                                                                                                                                                           |  |  |
| Example:                                                        | IORWF RESULT, 0                                                                                                                                                             |  |  |
| Before Instru<br>RESUL<br>W<br>After Instruc<br>RESUL<br>W<br>Z | T = 0x13<br>= 0x91<br>tion                                                                                                                                                  |  |  |

| MOVF                 | Move f                                                                                                                                                                                                                                                       |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:              | [ <i>label</i> ] MOVF f, d                                                                                                                                                                                                                                   |
| Operands:            | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \left[0,1\right] \end{array}$                                                                                                                                                                                    |
| Operation:           | $(f) \rightarrow (dest)$                                                                                                                                                                                                                                     |
| Status Affected:     | Z                                                                                                                                                                                                                                                            |
| Encoding:            | 0010 00df ffff                                                                                                                                                                                                                                               |
| Description:         | The contents of register 'f' is<br>moved to destination 'd'. If 'd' is '0',<br>destination is the W register. If 'd'<br>is '1', the destination is file<br>register 'f'. 'd' is '1' is useful to test<br>a file register since Status flag Z is<br>affected. |
| Words:               | 1                                                                                                                                                                                                                                                            |
| Cycles:              | 1                                                                                                                                                                                                                                                            |
| <u>Example</u> :     | MOVF FSR, 0                                                                                                                                                                                                                                                  |
| After Instruc<br>W = | tion<br>= value in FSR register                                                                                                                                                                                                                              |

| MOVLW                 | Move Literal to W |                            |      |      |
|-----------------------|-------------------|----------------------------|------|------|
| Syntax:               | [ label ]         | MOVLW                      | k    |      |
| Operands:             | $0 \le k \le 2$   | 55                         |      |      |
| Operation:            | $k \to (W)$       |                            |      |      |
| Status Affected:      | None              |                            |      |      |
| Encoding:             | 1100              | kkkk                       | kkkk | ]    |
| Description:          | 0                 | t-bit litera<br>V registei |      | ided |
| Words:                | 1                 |                            |      |      |
| Cycles:               | 1                 |                            |      |      |
| Example:              | MOVLW             | 0x5A                       |      |      |
| After Instruct<br>W = | ion<br>0x5A       |                            |      |      |

# PIC16F5X

| 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 XOR'ed with the eight-bit literal 'k'. The result is placed in the W register. |
| Words:                                        | 1                                                                                                                 |
| Cycles:                                       | 1                                                                                                                 |
| Example:                                      | XORLW <b>OxAF</b>                                                                                                 |
| Before Instru<br>W =<br>After Instruct<br>W = | 0xB5                                                                                                              |

| XORWF                      | Exclusive OR W with f                                            |                |                                                                                            |
|----------------------------|------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------|
| Syntax:                    | [ label ]                                                        | XORWF          | f, d                                                                                       |
| Operands:                  | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$ |                |                                                                                            |
| Operation:                 | (W) .XOF                                                         | $R.(f) \to (c$ | dest)                                                                                      |
| Status Affected:           | Z                                                                |                |                                                                                            |
| Encoding:                  | 0001                                                             | 10df           | ffff                                                                                       |
| Description:               | W registe<br>'0', the re<br>register.                            | er with reg    | contents of the<br>gister 'f'. If 'd' is<br>ored in the W<br>, the result is<br>ister 'f'. |
| Words:                     | 1                                                                |                |                                                                                            |
| Cycles:                    | 1                                                                |                |                                                                                            |
| Example:                   | XORWF                                                            | REG,1          |                                                                                            |
| Before Instru<br>REG       |                                                                  | кАF            |                                                                                            |
| W                          | •••                                                              | kB5            |                                                                                            |
| After Instruct<br>REG<br>W | = 0                                                              | <1A<br>≺B5     |                                                                                            |

### 10.2 MPASM Assembler

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

The MPASM Assembler generates relocatable object files for the MPLINK Object Linker, Intel<sup>®</sup> standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code and COFF files for debugging.

The MPASM Assembler features include:

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

#### 10.3 MPLAB C18 and MPLAB C30 C Compilers

The MPLAB C18 and MPLAB C30 Code Development Systems are complete ANSI C compilers for Microchip's PIC18 and PIC24 families of microcontrollers and the dsPIC30 and dsPIC33 family of digital signal controllers. These compilers provide powerful integration capabilities, superior code optimization and ease of use not found with other compilers.

For easy source level debugging, the compilers provide symbol information that is optimized to the MPLAB IDE debugger.

#### 10.4 MPLINK Object Linker/ MPLIB Object Librarian

The MPLINK Object Linker combines relocatable objects created by the MPASM Assembler and the MPLAB C18 C Compiler. It can link relocatable objects from precompiled libraries, using directives from a linker script.

The MPLIB Object Librarian manages the creation and modification of library files of precompiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications.

The object linker/library features include:

- Efficient linking of single libraries instead of many smaller files
- Enhanced code maintainability by grouping related modules together
- Flexible creation of libraries with easy module listing, replacement, deletion and extraction

# 10.5 MPLAB ASM30 Assembler, Linker and Librarian

MPLAB ASM30 Assembler produces relocatable machine code from symbolic assembly language for dsPIC30F devices. MPLAB C30 C Compiler uses the assembler to produce its object file. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include:

- Support for the entire dsPIC30F instruction set
- Support for fixed-point and floating-point data
- · Command line interface
- Rich directive set
- Flexible macro language
- MPLAB IDE compatibility

## 10.6 MPLAB SIM Software Simulator

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

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

# 11.4 Timing Parameter Symbology and Load Conditions

The timing parameter symbols have been created with one of the following formats:

1. TppS2ppS

2. TppS

| 2. TppS                               |                                            |                    |  |  |  |  |  |
|---------------------------------------|--------------------------------------------|--------------------|--|--|--|--|--|
| т                                     |                                            |                    |  |  |  |  |  |
| F                                     | Frequency                                  | T Time             |  |  |  |  |  |
| Lowe                                  | Lowercase letters (pp) and their meanings: |                    |  |  |  |  |  |
| рр                                    |                                            |                    |  |  |  |  |  |
| 2                                     | to                                         | mc MCLR            |  |  |  |  |  |
| ck                                    | CLKOUT                                     | osc oscillator     |  |  |  |  |  |
| су                                    | cycle time                                 | os OSC1            |  |  |  |  |  |
| drt                                   | device reset timer                         | t0 T0CKI           |  |  |  |  |  |
| io                                    | I/O port                                   | wdt watchdog timer |  |  |  |  |  |
| Uppercase letters and their meanings: |                                            |                    |  |  |  |  |  |
| S                                     |                                            |                    |  |  |  |  |  |
| F                                     | Fall                                       | P Period           |  |  |  |  |  |
| н                                     | High                                       | R Rise             |  |  |  |  |  |
| I                                     | Invalid (High-impedance)                   | V Valid            |  |  |  |  |  |
| L                                     | Low                                        | Z High-impedance   |  |  |  |  |  |

#### FIGURE 11-2: LOAD CONDITIONS FOR DEVICE TIMING SPECIFICATIONS – PIC16F5X



#### 11.5 Timing Diagrams and Specifications

#### FIGURE 11-3: EXTERNAL CLOCK TIMING





#### FIGURE 11-5: RESET, WATCHDOG TIMER, AND DEVICE RESET TIMER TIMING -- PIC16F5X

#### TABLE 11-3: RESET, WATCHDOG TIMER AND DEVICE RESET TIMER – PIC16F5X

| AC CHARACTERISTICS |      |                                                  | $\begin{tabular}{lllllllllllllllllllllllllllllllllll$ |            |            |       |                                                  |  |
|--------------------|------|--------------------------------------------------|-------------------------------------------------------|------------|------------|-------|--------------------------------------------------|--|
| Param<br>No.       | Sym. | Characteristic                                   | Min.                                                  | Тур†       | Max.       | Units | Conditions                                       |  |
| 30                 | TMCL | MCLR Pulse Width (low)                           | 2000*                                                 | _          | —          | ns    | Vdd = 5.0V                                       |  |
| 31                 | Twdt | Watchdog Timer Time-out Period<br>(No Prescaler) | 9.0*<br>9.0*                                          | 18*<br>18* | 30*<br>40* | ms    | VDD = 5.0V (industrial)<br>VDD = 5.0V (extended) |  |
| 32                 | Tdrt | Device Reset Timer Period                        | 9.0*<br>9.0*                                          | 18*<br>18* | 30*<br>40* | ms    | VDD = 5.0V (industrial)<br>VDD = 5.0V (extended) |  |
| 34                 | Tioz | I/O high-impedance from MCLR                     | 100*                                                  | 300*       | 2000*      | ns    |                                                  |  |

\* These parameters are characterized but not tested.

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

# 12.0 PACKAGING INFORMATION

# 12.1 Package Marketing Information



\* Standard PIC device marking consists of Microchip part number, year code, week code, and traceability code. For PIC device 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.



For the most current package drawings, please see the Microchip Packaging Specification located at

#### 28-Lead Plastic Shrink Small Outline (SS) – 5.30 mm Body [SSOP]

|                          | Units            | MILLIMETERS |       |       |  |  |
|--------------------------|------------------|-------------|-------|-------|--|--|
|                          | Dimension Limits | MIN         | NOM   | MAX   |  |  |
| Number of Pins           | N                | 28          |       |       |  |  |
| Pitch                    | е                | 0.65 BSC    |       |       |  |  |
| Overall Height           | А                | -           | -     | 2.00  |  |  |
| Molded Package Thickness | A2               | 1.65        | 1.75  | 1.85  |  |  |
| Standoff                 | A1               | 0.05        | -     | -     |  |  |
| Overall Width            | E                | 7.40        | 7.80  | 8.20  |  |  |
| Molded Package Width     | E1               | 5.00        | 5.30  | 5.60  |  |  |
| Overall Length           | D                | 9.90        | 10.20 | 10.50 |  |  |
| Foot Length              | L                | 0.55        | 0.75  | 0.95  |  |  |
| Footprint                | L1               | 1.25 REF    |       |       |  |  |
| Lead Thickness           | С                | 0.09        | -     | 0.25  |  |  |
| Foot Angle               | φ                | 0°          | 4°    | 8°    |  |  |
| Lead Width               | b                | 0.22        | -     | 0.38  |  |  |

Note:

Notes:

- 1. Pin 1 visual index feature may vary, but must be located within the hatched area.
- 2. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.20 mm per side.
- 3. Dimensioning and tolerancing per ASME Y14.5M.
  - BSC: Basic Dimension. Theoretically exact value shown without tolerances.
  - REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-073B