



#### 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                      | 4MHz                                                                      |
| Connectivity               | -                                                                         |
| Peripherals                | POR, WDT                                                                  |
| Number of I/O              | 13                                                                        |
| Program Memory Size        | 896B (512 x 14)                                                           |
| Program Memory Type        | ОТР                                                                       |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 80 × 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                                                 |
| Data Converters            | -                                                                         |
| Oscillator Type            | External                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Through Hole                                                              |
| Package / Case             | 18-DIP (0.300", 7.62mm)                                                   |
| Supplier Device Package    | 18-PDIP                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c554-04i-p |
|                            |                                                                           |

Email: info@E-XFL.COM

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

#### **Table of Contents**

|                                          | _   |
|------------------------------------------|-----|
| .0 General Description                   | . 5 |
| .0 PIC16C55X Device Varieties            | . 7 |
| .0       General Description             | . 9 |
| .0 Memory Organization                   | 13  |
|                                          |     |
| 0.0 Special Features of the CPU          | 31  |
| .0 Timer0 Module                         |     |
| 0 Instruction Set Summary                | 53  |
| .0 Development Support                   | 67  |
| 0.0 Electrical Specifications            | 73  |
| 1.0 Packaging Information                | 87  |
| vppendix A: Enhancements                 | 97  |
| ppendix B: Compatibility                 | 97  |
| ndex                                     | 99  |
| Dn-Line Support 1                        | 01  |
| Systems Information and Upgrade Hot Line | 01  |
| Dn-Line Support                          | 02  |
| Product Identification System            | 03  |

# TO OUR VALUED CUSTOMERS

It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced.

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@mail.microchip.com** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. We welcome your feedback.

#### Most Current Data Sheet

To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at:

http://www.microchip.com

You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000A is version A of document DS30000).

#### Errata

An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies.

To determine if an errata sheet exists for a particular device, please check with one of the following:

Microchip's Worldwide Web site; http://www.microchip.com

• Your local Microchip sales office (see last page)

• The Microchip Corporate Literature Center; U.S. FAX: (480) 792-7277

When contacting a sales office or the literature center, please specify which device, revision of silicon and data sheet (include literature number) you are using.

## **Customer Notification System**

Register on our web site at www.microchip.com/cn to receive the most current information on all of our products.

#### TABLE 1-1: PIC16C55X FAMILY OF DEVICES

|             |                                      | PIC16C554                        | PIC16C557                        | PIC16C558                 |
|-------------|--------------------------------------|----------------------------------|----------------------------------|---------------------------|
| Clock       | Maximum Frequency of Operation (MHz) | 20                               | 20                               | 20                        |
| Memory      | EPROM Program Memory<br>(x14 words)  | 512                              | 2K                               | 2K                        |
|             | Data Memory (bytes)                  | 80                               | 128                              | 128                       |
| Peripherals | Timer Module(s)                      | TMR0                             | TMR0                             | TMR0                      |
|             | Interrupt Sources                    | 3                                | 3                                | 3                         |
|             | I/O Pins                             | 13                               | 22                               | 13                        |
| Features    | Voltage Range (Volts)                | 2.5-5.5                          | 2.5-5.5                          | 2.5-5.5                   |
| catares     | Brown-out Reset                      | —                                | —                                | —                         |
|             | Packages                             | 18-pin DIP, SOIC;<br>20-pin SSOP | 28-pin DIP, SOIC;<br>28-pin SSOP | 18-pin DIP, SOIC,<br>SSOP |

I/O current capability. All PIC16C55X Family devices use serial programming with clock pin RB6 and data pin RB7.

# 2.0 PIC16C55X DEVICE VARIETIES

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

# 2.1 UV Erasable Devices

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

Microchip's PICSTART<sup>®</sup> and PROMATE<sup>®</sup> programmers both support programming of the PIC16C55X.

# 2.2 One-Time Programmable (OTP) Devices

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

# 2.3 Quick-Turnaround Production (QTP) Devices

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

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

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

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

#### 4.2.2.3 INTCON Register

The INTCON register is a readable and writable register which contains the various enable and flag bits for all interrupt sources.

| Note: | Interrupt flag bits get set when an interrupt |
|-------|-----------------------------------------------|
|       | condition occurs regardless of the state of   |
|       | its corresponding enable bit or the global    |
|       | enable bit, GIE (INTCON<7>).                  |

| REGISTER 4-3: | ER 4-3: INTCON REGISTER (ADDRESS 0BH OR 8BH)                                                                                                            |                                                                                                                  |              |             |           |              |                 |        |  |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--------------|-------------|-----------|--------------|-----------------|--------|--|--|--|
|               | R/W-0                                                                                                                                                   | Reserved                                                                                                         | R/W-0        | R/W-0       | R/W-0     | R/W-0        | R/W-0           | R/W-x  |  |  |  |
|               | GIE                                                                                                                                                     | —                                                                                                                | T0IE         | INTE        | RBIE      | T0IF         | INTF            | RBIF   |  |  |  |
|               | bit7                                                                                                                                                    |                                                                                                                  |              |             |           |              |                 | bit0   |  |  |  |
|               |                                                                                                                                                         |                                                                                                                  |              |             |           |              |                 |        |  |  |  |
| bit 7         | GIE: Global                                                                                                                                             | Interrupt Ena                                                                                                    | ble bit      |             |           |              |                 |        |  |  |  |
|               |                                                                                                                                                         | = Enables all un-masked interrupts<br>= Disables all interrupts                                                  |              |             |           |              |                 |        |  |  |  |
| bit 6         | Reserved:                                                                                                                                               | Reserved: For future use. Always maintain this bit clear.                                                        |              |             |           |              |                 |        |  |  |  |
| bit 5         | TOIE: TMR(                                                                                                                                              | Overflow Inte                                                                                                    | errupt Enab  | le bit      |           |              |                 |        |  |  |  |
|               |                                                                                                                                                         | <ul><li>1 = Enables the TMR0 interrupt</li><li>0 = Disables the TMR0 interrupt</li></ul>                         |              |             |           |              |                 |        |  |  |  |
| bit 4         | INTE: RB0/                                                                                                                                              | INT External I                                                                                                   | nterrupt En  | able bit    |           |              |                 |        |  |  |  |
|               |                                                                                                                                                         | <ul><li>1 = Enables the RB0/INT external interrupt</li><li>0 = Disables the RB0/INT external interrupt</li></ul> |              |             |           |              |                 |        |  |  |  |
| bit 3         | RBIE: RB P                                                                                                                                              | RBIE: RB Port Change Interrupt Enable bit                                                                        |              |             |           |              |                 |        |  |  |  |
|               | <ul> <li>1 = Enables the RB port change interrupt</li> <li>0 = Disables the RB port change interrupt</li> </ul>                                         |                                                                                                                  |              |             |           |              |                 |        |  |  |  |
| bit 2         | TOIF: TMRC                                                                                                                                              | Overflow Inte                                                                                                    | errupt Flag  | bit         |           |              |                 |        |  |  |  |
|               | <ul> <li>1 = TMR0 register has overflowed (must be cleared in software)</li> <li>0 = TMR0 register did not overflow</li> </ul>                          |                                                                                                                  |              |             |           |              |                 |        |  |  |  |
| bit 1         | INTF: RB0/                                                                                                                                              | INT External li                                                                                                  | nterrupt Fla | g bit       |           |              |                 |        |  |  |  |
|               | <ul> <li>1 = The RB0/INT external interrupt occurred (must be cleared in software)</li> <li>0 = The RB0/INT external interrupt did not occur</li> </ul> |                                                                                                                  |              |             |           |              |                 |        |  |  |  |
| bit 0         | RBIF: RB P                                                                                                                                              | ort Change In                                                                                                    | terrupt Flag | g bit       |           |              |                 |        |  |  |  |
|               |                                                                                                                                                         | t least one of                                                                                                   |              |             |           | must be clea | red in softwa   | re)    |  |  |  |
|               | 0 = None of the RB7:RB4 pins have changed state                                                                                                         |                                                                                                                  |              |             |           |              |                 |        |  |  |  |
|               | Legend:                                                                                                                                                 |                                                                                                                  |              |             |           |              |                 |        |  |  |  |
|               | R = Readat                                                                                                                                              | ole bit                                                                                                          | W = W        | ritable bit | U = Unir  | nplemented   | bit, read as '( | )'     |  |  |  |
|               | - n = Value                                                                                                                                             | at POR reset                                                                                                     | '1' = Bit    | t is set    | '0' = Bit | is cleared   | x = Bit is u    | nknown |  |  |  |

# REGISTER 4-3: INTCON REGISTER (ADDRESS 0BH OR 8BH)

© 1996-2013 Microchip Technology Inc.

#### 4.2.2.4 PCON Register

The PCON register contains a flag bit to differentiate between a Power-on Reset, an external MCLR Reset or WDT Reset. See Section 6.3 and Section 6.4 for detailed RESET operation.

#### **REGISTER 4-4:** PCON REGISTER (ADDRESS 8Eh) U-0 U-0 U-0 R/W-0 U-0 U-0 U-0 U-0 POR bit7 bit 7-2 Unimplemented: Read as '0' bit 1 POR: Power-on Reset status bit 1 = No Power-on Reset occurred 0 = Power-on Reset occurred bit 0 Unimplemented: Read as '0' Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' - n = Value at POR reset '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit0

# 5.2 PORTB and TRISB Registers

PORTB is an 8-bit wide bi-directional port. The corresponding data direction register is TRISB. A '1' in the TRISB register puts the corresponding output driver in a Hi-impedance mode. A '0' in the TRISB register puts the contents of the output latch on the selected pin(s).

Reading PORTB register reads the status of the pins whereas writing to it will write to the port latch. All write operations are read-modify-write operations. So a write to a port implies that the port pins are first read, then this value is modified and written to the port data latch.

Each of the PORTB pins has a weak internal pull-up ( $\approx 200 \ \mu A$  typical). A single control bit can turn on all the pull-ups. This is done by clearing the RBPU (OPTION<7>) bit. The weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are disabled on Power-on Reset.

Four of PORTB's pins, RB7:RB4, have an interrupt-onchange feature. Only pins configured as inputs can cause this interrupt to occur (i.e., any RB7:RB4 pin configured as an output is excluded from the interrupton-change comparison). The input pins (of RB7:RB4) are compared with the old value latched on the last read of PORTB. The "mismatch" outputs of RB7:RB4 are OR'ed together to generate the RBIF interrupt (flag latched in INTCON<0>). This interrupt can wake the device from SLEEP. The user, in the interrupt service routine, can clear the interrupt in the following manner:

- Any read or write of PORTB (this will end the mismatch condition)
- Clear flag bit RBIF

A mismatch condition will continue to set flag bit RBIF. Reading PORTB will end the mismatch condition, and allow flag bit RBIF to be cleared.

The interrupt on mismatch feature, together with software configurable pull-ups on these four pins, allows easy interface to a key pad and make it possible for wake-up on key-depression. (See AN552 in the Microchip *Embedded Control Handbook*.)

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

The interrupt-on-change feature is recommended for wake-up on key depression operation and operations where PORTB is only used for the interrupt-on-change feature. Polling of PORTB is not recommended while using the interrupt-on-change feature.



## FIGURE 5-3: BLOCK DIAGRAM OF RB7:RB4 PINS

# 5.3 PORTC and TRISC Registers<sup>(1)</sup>

PORTC is a 8-bit wide latch. All pins have data direction bits (TRIS registers) which can configure these pins as input or output.

A '1' in the TRISC register puts the corresponding output driver in a Hi-impedance mode. A '0' in the TRISC register puts the contents of the output latch on the selected pin(s).

Reading the PORTC register reads the status of the pins, whereas writing to it will write to the port latch. All write operations are read-modify-write operations. So a write to a port implies that the port pins are first read, then this value is modified and written to the port data latch

FIGURE 5-5: BLOCK DIAGRAM OF

#### PORT PINS RC<7:0> Data Bus D Q Vdd WR PORT ск 🔪 Q P Data Latch Q Ν D I/O pin WR T<u>RISC</u> Q ∘ск҇∢\_ Vss Vss TRIS Latch TTL Input Buffer RD TRISC Q D FN. **RD PORTC**

| Name | Bit # | Buffer Type | Function                 |
|------|-------|-------------|--------------------------|
| RC0  | Bit 0 | TTL         | Bi-directional I/O port. |
| RC1  | Bit 1 | TTL         | Bi-directional I/O port. |
| RC2  | Bit 2 | TTL         | Bi-directional I/O port. |
| RC3  | Bit 3 | TTL         | Bi-directional I/O port. |
| RC4  | Bit 4 | TTL         | Bi-directional I/O port. |
| RC5  | Bit 5 | TTL         | Bi-directional I/O port. |
| RC6  | Bit 6 | TTL         | Bi-directional I/O port. |
| RC7  | Bit 7 | TTL         | Bi-directional I/O port. |

Legend: ST = Schmitt Trigger, TTL = TTL input

#### TABLE 5-6: SUMMARY OF REGISTERS ASSOCIATED WITH PORTC AND TRISC

| Address | Name  | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Value on<br>POR | Value on<br>All Other<br>RESETS |
|---------|-------|--------|--------|--------|--------|--------|--------|--------|--------|-----------------|---------------------------------|
| 07h     | PORTC | RC7    | RC6    | RC5    | RC4    | RC3    | RC2    | RC1    | RC0    | xxxx xxxx       | uuuu uuuu                       |
| 87h     | TRISC | TRISC7 | TRISC6 | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 1111 1111       | 1111 1111                       |

Legend: x = unknown, u = unchanged Note 1: PIC16C557 ONLY.

# 6.0 SPECIAL FEATURES OF THE CPU

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

These are:

- 1. OSC selection
- 2. RESET
- 3. Power-on Reset (POR)
- 4. Power-up Timer (PWRT)
- 5. Oscillator Start-Up Timer (OST)
- 6. Interrupts
- 7. Watchdog Timer (WDT)
- 8. SLEEP
- 9. Code protection
- 10. ID Locations
- 11. In-circuit serial programming<sup>™</sup>

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

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

# 6.1 Configuration Bits

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

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

#### 6.2.3 EXTERNAL CRYSTAL OSCILLATOR CIRCUIT

Either a pre-packaged oscillator can be used or a simple oscillator circuit with TTL gates can be built. Prepackaged oscillators provide a wide operating range and better stability. A well-designed crystal oscillator will provide good performance with TTL gates. Two types of crystal oscillator circuits can be used: one with series resonance, or one with parallel resonance.

Figure 6-3 shows implementation of a parallel resonant oscillator circuit. The circuit is designed to use the fundamental frequency of the crystal. The 74AS04 inverter performs the 180° phase shift that a parallel oscillator requires. The 4.7 k $\Omega$  resistor provides the negative feedback for stability. The 10 k $\Omega$  potentiometers bias the 74AS04 in the linear region. This could be used for external oscillator designs.

#### FIGURE 6-3: EXTERNAL PARALLEL RESONANT CRYSTAL OSCILLATOR CIRCUIT



Figure 6-4 shows a series resonant oscillator circuit. This circuit is also designed to use the fundamental frequency of the crystal. The inverter performs a  $180^{\circ}$  phase shift in a series resonant oscillator circuit. The  $330\Omega$  resistors provide the negative feedback to bias the inverters in their linear region.

#### FIGURE 6-4: EXTERNAL SERIES RESONANT CRYSTAL OSCILLATOR CIRCUIT



# 6.2.4 RC OSCILLATOR

For timing insensitive applications the "RC" device option offers additional cost savings. The RC oscillator frequency is a function of the supply voltage, the resistor (REXT) and capacitor (CEXT) values, and the operating temperature. In addition to this, the oscillator frequency will vary from unit to unit due to normal process parameter variation. Furthermore, the difference in lead frame capacitance between package types will also affect the oscillation frequency, especially for low CEXT values. The user also needs to take into account variation due to tolerance of external R and C components used. Figure 6-5 shows how the R/C combination is connected to the PIC16C55X. For REXT values below 2.2 k $\Omega$ , the oscillator operation may become unstable, or stop completely. For very high REXT values (e.g., 1 M $\Omega$ ), the oscillator becomes sensitive to noise, humidity and leakage. Thus, we recommend to keep REXT between 3 k $\Omega$  and 100 k $\Omega$ .

Although the oscillator will operate with no external capacitor (CEXT = 0 pF), we recommend using values above 20 pF for noise and stability reasons. With no or small external capacitance, the oscillation frequency can vary dramatically due to changes in external capacitances, such as PCB trace capacitance or package lead frame capacitance.

The oscillator frequency, divided by 4, is available on the OSC2/CLKOUT pin, and can be used for test purposes or to synchronize other logic (Figure 3-2 for waveform).



# FIGURE 6-5: RC OSCILLATOR MODE

# 6.4 Power-on Reset (POR), Power-up Timer (PWRT), Oscillator Start-up Timer (OST)

## 6.4.1 POWER-ON RESET (POR)

A Power-on Reset pulse is generated on-chip when VDD rise is detected (in the range of 1.6V - 1.8V). To take advantage of the POR, just tie the MCLR pin through a resistor to VDD. This will eliminate external RC components usually needed to create Power-on Reset. A maximum rise time for VDD is required. See Electrical Specifications for details.

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

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

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

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

The Power-up Timer provides a fixed 72 ms (nominal) timeout on power-up only, from POR. The Power-up Timer operates on an internal RC oscillator. The chip is kept in RESET as long as PWRT is active. The PWRT delay allows the <u>VDD</u> to rise to an acceptable level. A configuration bit, <u>PWRTE</u> can disable (if set) or enable (if cleared or programmed) the Power-up Timer. The Power-Up Time delay will vary from chip to chip and due to VDD, temperature and process variation. See DC parameters for details.

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

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

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

#### 6.4.4 TIMEOUT SEQUENCE

On power-up, the timeout sequence is as follows: First PWRT timeout is invoked after POR has expired, then OST is activated. The total timeout will vary based on oscillator configuration and <u>PWRTE</u> bit status. For example, in RC mode with <u>PWRTE</u> bit erased (PWRT disabled), there will be no timeout at all. Figure 6-7, Figure 6-8 and Figure 6-9 depict timeout sequences.

Since the timeouts occur from the POR pulse, if  $\overline{\text{MCLR}}$  is kept low long enough, the timeouts will expire. Then bringing  $\overline{\text{MCLR}}$  high will begin execution immediately (see Figure 6-8). This is useful for testing purposes or to synchronize more than one PIC16C55X device operating in parallel.

Table 6-5 shows the RESET conditions for some special registers, while Table 6-6 shows the RESET conditions for all the registers.

# PIC16C55X



#### FIGURE 6-10: EXTERNAL POWER-ON RESET CIRCUIT (FOR SLOW VDD POWER-UP)



MCLR/VPP pin breakdown due to Electrostatic Discharge (ESD) or Electrical Overstress (EOS).

#### 7.3.1 SWITCHING PRESCALER ASSIGNMENT

The prescaler assignment is fully under software control (i.e., it can be changed "on the fly" during program execution). To avoid an unintended device RESET, the following instruction sequence (Example 7-1) must be executed when changing the prescaler assignment from Timer0 to WDT. Lines 5-7 are required only if the desired postscaler rate is 1:1 (PS<2:0> = 000) or 1:2 (PS<2:0> = 001).

| EXAMPLE 7-1: | CHANGING PRESCALER |
|--------------|--------------------|
|              | (TIMER0→WDT)       |

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

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

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

|        | (           | · / · ····=···/     |
|--------|-------------|---------------------|
| CLRWDT |             | ;Clear WDT and      |
|        |             | ;prescaler          |
| BSF    | STATUS, RPO |                     |
| MOVLW  | b'xxxx0xxx' | ;Select TMR0, new   |
|        |             | ;prescale value and |
|        |             | ;clock source       |
| MOVWF  | OPTION      |                     |
| BCF    | STATUS, RPO |                     |
|        |             |                     |

# TABLE 7-1: REGISTERS ASSOCIATED WITH TIMER0

| Address | Name   | Bit 7    | Bit 6                    | Bit 5 | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Value on<br>POR | Value on<br>All Other<br>RESETS |
|---------|--------|----------|--------------------------|-------|--------|--------|--------|--------|--------|-----------------|---------------------------------|
| 01h     | TMR0   | Timer0 m | Timer0 module's register |       |        |        |        |        |        |                 | uuuu uuuu                       |
| 0Bh/8Bh | INTCON | GIE      | Reserved                 | TOIE  | INTE   | RBIE   | T0IF   | INTF   | RBIF   | 0000 000x       | 0000 000x                       |
| 81h     | OPTION | RBPU     | INTEDG                   | TOCS  | TOSE   | PSA    | PS2    | PS1    | PS0    | 1111 1111       | 1111 1111                       |
| 85h     | TRISA  | _        | _                        |       | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 1 1111          | 1 1111                          |

Legend: — = Unimplemented locations, read as '0',

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

# PIC16C55X

| SUBWF               | Subtract W from f                                                                                                                                                                  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:             | [ label ] SUBWF f,d                                                                                                                                                                |
| Operands:           | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                 |
| Operation:          | (f) - (W) $\rightarrow$ (dest)                                                                                                                                                     |
| Status<br>Affected: | C, DC, Z                                                                                                                                                                           |
| Encoding:           | 00 0010 dfff ffff                                                                                                                                                                  |
| Description:        | Subtract (2's complement method)<br>W register from register 'f'. If 'd' is 0 the<br>result is stored in the W register. If 'd' is 1<br>the result is stored back in register 'f'. |
| Words:              | 1                                                                                                                                                                                  |
| Cycles:             | 1                                                                                                                                                                                  |
| Example 1:          | SUBWF REG1,1                                                                                                                                                                       |
|                     | Before Instruction                                                                                                                                                                 |
|                     | REG1 = 3                                                                                                                                                                           |
|                     | W = 2                                                                                                                                                                              |
|                     | C = ?                                                                                                                                                                              |
|                     | After Instruction                                                                                                                                                                  |
|                     | REG1 = 1                                                                                                                                                                           |
|                     | W = 2                                                                                                                                                                              |
| Example 2:          | C = 1; result is positive<br>Before Instruction                                                                                                                                    |
| Example 2:          |                                                                                                                                                                                    |
|                     | REG1 = 2<br>W = 2                                                                                                                                                                  |
|                     | C = ?                                                                                                                                                                              |
|                     | After Instruction                                                                                                                                                                  |
|                     | REG1 = 0                                                                                                                                                                           |
|                     | W = 2                                                                                                                                                                              |
|                     | C = 1; result is zero                                                                                                                                                              |
| Example 3:          | Before Instruction                                                                                                                                                                 |
|                     | REG1 = 1                                                                                                                                                                           |
|                     | W = 2                                                                                                                                                                              |
|                     | C = ?                                                                                                                                                                              |
|                     | After Instruction                                                                                                                                                                  |
|                     | REG1 = 0xFF                                                                                                                                                                        |
|                     | W = 2                                                                                                                                                                              |
|                     | C = 0; result is negative                                                                                                                                                          |

| SWAPF                     | Swap Nibbles in f                                                                                                                                                               |  |  |  |  |  |  |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:                   | [ <i>label</i> ] SWAPF f,d                                                                                                                                                      |  |  |  |  |  |  |
| Operands:                 | $0 \le f \le 127$                                                                                                                                                               |  |  |  |  |  |  |
|                           | d ∈ [0,1]                                                                                                                                                                       |  |  |  |  |  |  |
| Operation:                | (f<3:0>) → (dest<7:4>),<br>(f<7:4>) → (dest<3:0>)                                                                                                                               |  |  |  |  |  |  |
| Status Affected:          | None                                                                                                                                                                            |  |  |  |  |  |  |
| Encoding:                 | 00 1110 dfff ffff                                                                                                                                                               |  |  |  |  |  |  |
| Description:              | The upper and lower nibbles of<br>register 'f' are exchanged. If 'd' is 0<br>the result is placed in W register. If 'd'<br>is 1 the result is placed in register 'f'.           |  |  |  |  |  |  |
| Words:                    | 1                                                                                                                                                                               |  |  |  |  |  |  |
| Cycles:                   | 1                                                                                                                                                                               |  |  |  |  |  |  |
| Example                   | SWAPF REG, 0                                                                                                                                                                    |  |  |  |  |  |  |
|                           | Before Instruction                                                                                                                                                              |  |  |  |  |  |  |
|                           | REG1 = 0xA5                                                                                                                                                                     |  |  |  |  |  |  |
|                           | After Instruction                                                                                                                                                               |  |  |  |  |  |  |
|                           | REG1 = 0xA5                                                                                                                                                                     |  |  |  |  |  |  |
|                           | W = 0x5A                                                                                                                                                                        |  |  |  |  |  |  |
| TRIS                      | Load TRIS Register                                                                                                                                                              |  |  |  |  |  |  |
| Syntax:                   | [ <i>label</i> ] TRIS f                                                                                                                                                         |  |  |  |  |  |  |
| Operands: $5 \le f \le 7$ |                                                                                                                                                                                 |  |  |  |  |  |  |
| Operation:                | (W) $\rightarrow$ TRIS register f;                                                                                                                                              |  |  |  |  |  |  |
| Status Affected:          | None                                                                                                                                                                            |  |  |  |  |  |  |
| Encoding:                 | 00 0000 0110 Offf                                                                                                                                                               |  |  |  |  |  |  |
| Description:              | The instruction is supported for code<br>compatibility with the PIC16C5X<br>products. Since TRIS registers are<br>readable and writable, the user can<br>directly address them. |  |  |  |  |  |  |
| Words:                    | 1                                                                                                                                                                               |  |  |  |  |  |  |
| Cycles:                   | 1                                                                                                                                                                               |  |  |  |  |  |  |
| Example                   |                                                                                                                                                                                 |  |  |  |  |  |  |
|                           | To maintain upward compatibility<br>with future PIC MCU products, do                                                                                                            |  |  |  |  |  |  |

To maintain upward compatibility with future PIC MCU products, do not use this instruction.

# 9.0 DEVELOPMENT SUPPORT

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

- Integrated Development Environment
  - MPLAB<sup>®</sup> IDE Software
- Assemblers/Compilers/Linkers
  - MPASM<sup>™</sup> Assembler
  - MPLAB C17 and MPLAB C18 C Compilers
  - MPLINK<sup>™</sup> Object Linker/
  - MPLIB<sup>™</sup> Object Librarian
- Simulators
  - MPLAB SIM Software Simulator
- Emulators
  - MPLAB ICE 2000 In-Circuit Emulator
  - ICEPIC<sup>™</sup> In-Circuit Emulator
- In-Circuit Debugger
- MPLAB ICD
- Device Programmers
  - PRO MATE® II Universal Device Programmer
- PICSTART<sup>®</sup> Plus Entry-Level Development Programmer
- Low Cost Demonstration Boards
  - PICDEM<sup>™</sup>1 Demonstration Board
  - PICDEM 2 Demonstration Board
  - PICDEM 3 Demonstration Board
  - PICDEM 17 Demonstration Board
  - KEELOQ<sup>®</sup> Demonstration Board

## 9.1 MPLAB Integrated Development Environment Software

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

- · An interface to debugging tools
  - simulator
  - programmer (sold separately)
  - emulator (sold separately)
  - in-circuit debugger (sold separately)
- A full-featured editor
- · A project manager
- Customizable toolbar and key mapping
- · A status bar
- On-line help

The MPLAB IDE allows you to:

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

The ability to use MPLAB IDE with multiple debugging tools allows users to easily switch from the costeffective simulator to a full-featured emulator with minimal retraining.

# 9.2 MPASM Assembler

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

The MPASM assembler has a command line interface and a Windows shell. It can be used as a stand-alone application on a Windows 3.x or greater system, or it can be used through MPLAB IDE. 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, an absolute LST file that contains source lines and generated machine code, and a COD file 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.

# 9.3 MPLAB C17 and MPLAB C18 C Compilers

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

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

#### TABLE 9-1: DEVELOPMENT TOOLS FROM MICROCHIP

|                                                                      | PIC12CXX | PIC14000 | PIC16C5X | PIC16C6X | PIC16CXX | PIC16F62) | AT281219   | PIC16C7X | PIC16C8X | PIC16F8X) | PIC16C9X) | X4271219 | (XTOTIOI9 | PIC18CXX | PIC18FXX) | 83CXX<br>52CXX/<br>54CXX/ | хххээн | МСКЕХХХ | MCP2510 |
|----------------------------------------------------------------------|----------|----------|----------|----------|----------|-----------|------------|----------|----------|-----------|-----------|----------|-----------|----------|-----------|---------------------------|--------|---------|---------|
| MPLAB <sup>®</sup> Integrated<br>Development Environment             | >        | ^        | ^        | >        | ~        | >         | >          | >        | >        | >         | >         | >        | >         | >        | >         |                           |        |         |         |
| MPLAB <sup>®</sup> C17 C Compiler                                    |          |          |          |          |          |           |            |          |          |           |           | >        | ~         |          |           |                           |        |         |         |
| MPLAB <sup>®</sup> C18 C Compiler                                    |          |          |          |          |          |           |            |          |          |           |           |          |           | >        | ~         |                           |        |         |         |
| MPASM <sup>TM</sup> Assembler/<br>MPLINK <sup>TM</sup> Object Linker | >        | ~        | ^        | >        | ~        | >         | >          | >        | >        | >         | >         | >        | >         | >        | >         | >                         | >      |         |         |
| MPLAB® ICE In-Circuit Emulator                                       | r <      | >        | >        | >        | >        | **`^      | >          | >        | >        | >         | >         | >        | >         | >        | >         |                           |        |         |         |
| ICEPICTM In-Circuit Emulator                                         | >        |          | >        | >        | >        |           | >          | >        | >        |           | >         |          |           |          |           |                           |        |         |         |
| eb<br>MPLAB® ICD In-Circuit<br>Debugger                              |          |          |          | *>       |          |           | *>         |          |          | >         |           |          |           |          | >         |                           |        |         |         |
| PICSTART <sup>®</sup> Plus Entry Level<br>Development Programmer     | >        | ~        | `        | `        | `        | **`       | `          | `        | ~        | `         | >         | >        | >         | >        | >         |                           |        |         |         |
| PRO MATE® II<br>Universal Device Programmer                          | >        | >        | >        | ~        | ~        | **/       | >          | >        | ^        | >         | >         | >        | >         | >        | >         | >                         | ^      |         |         |
| PICDEM <sup>TM</sup> 1 Demonstration<br>Board                        |          |          | >        |          | >        |           | + <b>-</b> |          | >        |           |           | >        |           |          |           |                           |        |         |         |
| PICDEM <sup>TM</sup> 2 Demonstration<br>Board                        |          |          |          | .↓       |          |           | ÷+         |          |          |           |           |          |           | >        | >         |                           |        |         |         |
| PICDEM <sup>TM</sup> 3 Demonstration<br>Board                        |          |          |          |          |          |           |            |          |          |           | >         |          |           |          |           |                           |        |         |         |
| PICDEM <sup>TM</sup> 14A Demonstration<br>Board                      |          | >        |          |          |          |           |            |          |          |           |           |          |           |          |           |                           |        |         |         |
| PICDEM <sup>TM</sup> 17 Demonstration<br>Board                       |          |          |          |          |          |           |            |          |          |           |           |          | >         |          |           |                           |        |         |         |
| KEELoα <sup>®</sup> Evaluation Kit                                   |          |          |          |          |          |           |            |          |          |           |           |          |           |          |           |                           | >      |         |         |
| KEELoq <sup>®</sup> Transponder Kit                                  |          |          |          |          |          |           |            |          |          |           |           |          |           |          |           |                           | >      |         |         |
| microlD <sup>TM</sup> Programmer's Kit                               |          |          |          |          |          |           |            |          |          |           |           |          |           |          |           |                           |        | ~       |         |
| 125 kHz microlD™<br>Developer's Kit                                  |          |          |          |          |          |           |            |          |          |           |           |          |           |          |           |                           |        | >       |         |
| 125 kHz Anticollision microlD™<br>Developer's Kit                    | v        |          |          |          |          |           |            |          |          |           |           |          |           |          |           |                           |        | >       |         |
| 13.56 MHz Anticollision<br>microlD <sup>TM</sup> Developer's Kit     |          |          |          |          |          |           |            |          |          |           |           |          |           |          |           |                           |        | >       |         |
| MCP2510 CAN Developer's Kit                                          |          |          |          |          |          |           |            |          |          |           |           |          |           |          |           |                           |        |         | `       |

 $\ensuremath{\textcircled{}^{\circ}}$  1996-2013 Microchip Technology Inc.

# 10.2 DC Characteristics: PIC16C55X (Commercial, Industrial, Extended) PIC16LC55X(Commercial, Industrial, Extended)

| DC Cha        | racteris | tics                                        | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial and $0^{\circ}C \le TA \le +70^{\circ}C$ for commercial and $-40^{\circ}C \le TA \le +125^{\circ}C$ for automotive |        |                  |         |                                                             |  |  |
|---------------|----------|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------|---------|-------------------------------------------------------------|--|--|
|               |          | 1                                           | Operating volt                                                                                                                                                                                                                                        | age Vo | D range as de    | scribed | d in DC spec Table 10-1                                     |  |  |
| Param.<br>No. | Sym      | Characteristic                              | Min                                                                                                                                                                                                                                                   | Тур†   | Max              | Unit    | Conditions                                                  |  |  |
|               | VIL      | Input Low Voltage                           |                                                                                                                                                                                                                                                       |        |                  |         |                                                             |  |  |
|               |          | I/O ports                                   |                                                                                                                                                                                                                                                       |        |                  |         |                                                             |  |  |
| D030          |          | with TTL buffer                             | Vss                                                                                                                                                                                                                                                   | —      | 0.8V<br>0.15 Vdd | V       | VDD = 4.5V to 5.5V<br>otherwise                             |  |  |
| D031          |          | with Schmitt Trigger input                  | Vss                                                                                                                                                                                                                                                   |        | 0.2 Vdd          | V       |                                                             |  |  |
| D032          |          | MCLR, RA4/T0CKI,OSC1 (in RC mode)           | Vss                                                                                                                                                                                                                                                   | _      | 0.2 VDD          | V       | (Note1)                                                     |  |  |
| D033          |          | OSC1 (in XT* and HS)                        | Vss                                                                                                                                                                                                                                                   | —      | 0.3 VDD          | V       |                                                             |  |  |
|               |          | OSC1 (in LP*)                               | Vss                                                                                                                                                                                                                                                   | —      | 0.6 Vdd-1.0      | V       |                                                             |  |  |
|               | Vін      | Input High Voltage                          |                                                                                                                                                                                                                                                       |        |                  |         |                                                             |  |  |
|               |          | I/O ports                                   |                                                                                                                                                                                                                                                       | —      |                  |         |                                                             |  |  |
| D040          |          | with TTL buffer                             | 2.0V<br>0.8 + 0.25 VDD                                                                                                                                                                                                                                | _      | Vdd<br>Vdd       | V<br>V  | VDD = 4.5V to 5.5V<br>otherwise                             |  |  |
| D041          |          | with Schmitt Trigger input                  | 0.8V                                                                                                                                                                                                                                                  |        | Vdd              |         |                                                             |  |  |
| D042          |          | MCLR RA4/T0CKI                              | 0.8 Vdd                                                                                                                                                                                                                                               | —      | Vdd              | V       |                                                             |  |  |
| D043<br>D043A |          | OSC1 (XT*, HS and LP*)<br>OSC1 (in RC mode) | 0.7 Vdd<br>0.9 Vdd                                                                                                                                                                                                                                    | —      | Vdd              | V       | (Note1)                                                     |  |  |
| D070          | Ipurb    | PORTB weak pull-up current                  | 50                                                                                                                                                                                                                                                    | 200    | 400              | μΑ      | VDD = 5.0V, VPIN = VSS                                      |  |  |
|               | ١L       | Input Leakage Current <sup>(2)(3)</sup>     |                                                                                                                                                                                                                                                       |        |                  |         |                                                             |  |  |
|               |          | I/O ports (Except PORTA)                    |                                                                                                                                                                                                                                                       |        | ±1.0             | μΑ      | $Vss \le VPIN \le VDD, \text{ pin at hi-impedance}$         |  |  |
| D060          |          | PORTA                                       | —                                                                                                                                                                                                                                                     | —      | ±0.5             | μA      | $Vss \le VPIN \le VDD, pin at hi-impedance$                 |  |  |
| D061          |          | RA4/T0CKI                                   | —                                                                                                                                                                                                                                                     | —      | ±1.0             | μΑ      | $Vss \leq V \text{PIN} \leq V \text{DD}$                    |  |  |
| D063          |          | OSC1, MCLR                                  | —                                                                                                                                                                                                                                                     | —      | ±5.0             | μΑ      | Vss $\leq$ VPIN $\leq$ VDD, XT, HS and LP osc configuration |  |  |
|               | Vol      | Output Low Voltage                          |                                                                                                                                                                                                                                                       |        |                  |         |                                                             |  |  |
| D080          |          | I/O ports                                   | —                                                                                                                                                                                                                                                     | —      | 0.6              | V       | IOL=8.5 mA, VDD=4.5V, -40° to<br>+85°C                      |  |  |
|               |          |                                             | —                                                                                                                                                                                                                                                     | —      | 0.6              | V       | IOL=7.0 mA, VDD=4.5V, +125°C                                |  |  |
| D083          |          | OSC2/CLKOUT                                 | _                                                                                                                                                                                                                                                     | —      | 0.6              | V       | IOL=1.6 mA, VDD=4.5V, -40° to<br>+85°C                      |  |  |
|               |          | (RC only)                                   | —                                                                                                                                                                                                                                                     | —      | 0.6              | V       | IOL=1.2 mA, VDD=4.5V, +125°C                                |  |  |
|               | Vон      | Output High Voltage <sup>(3)</sup>          |                                                                                                                                                                                                                                                       |        |                  |         |                                                             |  |  |
| D090          |          | I/O ports (Except RA4)                      | VDD-0.7                                                                                                                                                                                                                                               | —      | _                | V       | IOH=-3.0 mA, VDD=4.5V, -40° to<br>+85°C                     |  |  |

These parameters are characterized but not tested.

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

**Note 1:** In RC oscillator configuration, the OSC1 pin is a Schmitt Trigger input. It is not recommended that the PIC16C55X be driven with external clock in RC mode.

2: The leakage current on the MCLR pin is strongly dependent on applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages.

3: Negative current is defined as coming out of the pin.



#### **FIGURE 10-8:** RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING

#### **TABLE 10-3**: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER REQUIREMENTS

| Param<br>No. | Sym      | Characteristic                                  | Min    | Тур†         | Max  | Units | Conditions                                         |
|--------------|----------|-------------------------------------------------|--------|--------------|------|-------|----------------------------------------------------|
| 30           | TmcL     | MCLR Pulse Width (low)                          | 2000   |              |      | ns    | -40° to +85°C                                      |
| 31           | Twdt     | Watchdog Timer Timeout Period<br>(No Prescaler) | 7*     | 18           | 33*  | ms    | VDD = 5.0V, -40° to +85°C                          |
| 32           | Tost     | Oscillation Start-up Timer Period               | -      | 1024<br>Tosc | -    | _     | Tosc = OSC1 period                                 |
| 33           | Tpwrt    | Power-up Timer Period                           | 28*    | 72           | 132* | ms    | $VDD = 5.0V, -40^{\circ} \text{ to } +85^{\circ}C$ |
| 34           | Tioz     | I/O hi-impedance from MCLR low                  |        | —            | 2.0* | μS    |                                                    |
| *            | These na | arameters are characterized but not             | tested |              |      |       |                                                    |

These parameters are characterized but not tested.

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

# **11.0 PACKAGING INFORMATION**

# 11.1 Package Marking Information

#### 18-Lead PDIP



#### 28-Lead PDIP



#### 20-Lead SSOP



#### 28-Lead SSOP



#### Example



#### Example



#### Example



## Example



| Legen | d: XXX<br>Y<br>YY<br>WW<br>NNN<br>@3<br>* | Customer-specific information<br>Year code (last digit of calendar year)<br>Year code (last 2 digits of calendar year)<br>Week code (week of January 1 is week '01')<br>Alphanumeric traceability code<br>Pb-free JEDEC designator for Matte Tin (Sn)<br>This package is Pb-free. The Pb-free JEDEC designator (e3)<br>can be found on the outer packaging for this package. |
|-------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note: | be carrie                                 | nt the full Microchip part number cannot be marked on one line, it will d over to the next line, thus limiting the number of available s for customer-specific information.                                                                                                                                                                                                  |

© 1996-2013 Microchip Technology Inc.

#### 28-Lead Plastic Small Outline (SO) - Wide, 300 mil (SOIC)

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging







|                                   | Units      |      | INCHES* |      | MILLIMETERS |       |       |  |
|-----------------------------------|------------|------|---------|------|-------------|-------|-------|--|
| Dimens                            | ion Limits | MIN  | NOM     | MAX  | MIN         | NOM   | MAX   |  |
| Number of Pins                    | n          |      | 28      |      |             | 28    |       |  |
| Pitch                             | р          |      | .050    |      |             | 1.27  |       |  |
| Overall Height                    | А          | .093 | .099    | .104 | 2.36        | 2.50  | 2.64  |  |
| Molded Package Thickness          | A2         | .088 | .091    | .094 | 2.24        | 2.31  | 2.39  |  |
| Standoff §                        | A1         | .004 | .008    | .012 | 0.10        | 0.20  | 0.30  |  |
| Overall Width                     | E          | .394 | .407    | .420 | 10.01       | 10.34 | 10.67 |  |
| Molded Package Width              | E1         | .288 | .295    | .299 | 7.32        | 7.49  | 7.59  |  |
| Overall Length                    | D          | .695 | .704    | .712 | 17.65       | 17.87 | 18.08 |  |
| Chamfer Distance                  | h          | .010 | .020    | .029 | 0.25        | 0.50  | 0.74  |  |
| Foot Length                       | L          | .016 | .033    | .050 | 0.41        | 0.84  | 1.27  |  |
| Foot Angle Top                    | ø          | 0    | 4       | 8    | 0           | 4     | 8     |  |
| Lead Thickness                    | С          | .009 | .011    | .013 | 0.23        | 0.28  | 0.33  |  |
| Lead Width                        | В          | .014 | .017    | .020 | 0.36        | 0.42  | 0.51  |  |
| Mold Draft Angle Top              | α          | 0    | 12      | 15   | 0           | 12    | 15    |  |
| Mold Draft Angle Bottom           | β          | 0    | 12      | 15   | 0           | 12    | 15    |  |
| * O sustan Illin a D sus as store |            |      |         |      |             |       |       |  |

\* Controlling Parameter § Significant Characteristic

Notes:

Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" (0.254mm) per side.

JEDEC Equivalent: MS-013

Drawing No. C04-052

# THE MICROCHIP WEB SITE

Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information:

- **Product Support** Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

# CUSTOMER CHANGE NOTIFICATION SERVICE

Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, access the Microchip web site at www.microchip.com. Under "Support", click on "Customer Change Notification" and follow the registration instructions.

# CUSTOMER SUPPORT

Users of Microchip products can receive assistance through several channels:

- Distributor or Representative
- Local Sales Office
- Field Application Engineer (FAE)
- Technical Support

Customers should contact their distributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document.

Technical support is available through the web site at: http://microchip.com/support