



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             | Obsolete                                                                    |
|----------------------------|-----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 4MHz                                                                        |
| Connectivity               | -                                                                           |
| Peripherals                | POR, WDT                                                                    |
| Number of I/O              | 13                                                                          |
| Program Memory Size        | 3.5KB (2K x 14)                                                             |
| Program Memory Type        | ОТР                                                                         |
| EEPROM Size                | -                                                                           |
| RAM Size                   | 128 x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 5.5V                                                                 |
| Data Converters            | -                                                                           |
| Oscillator Type            | External                                                                    |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                             |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 20-SSOP (0.209", 5.30mm Width)                                              |
| Supplier Device Package    | 20-SSOP                                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lc558t-04-ss |
|                            |                                                                             |

Email: info@E-XFL.COM

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

## 3.0 ARCHITECTURAL OVERVIEW

The high performance of the PIC16C55X family can be attributed to a number of architectural features commonly found in RISC microprocessors. To begin with, the PIC16C55X uses a Harvard architecture in which program and data are accessed from separate memories using separate busses. This improves bandwidth over traditional von Neumann architecture where program and data are fetched from the same memory. Separating program and data memory further allows instructions to be sized differently from 8-bit wide data words. Instruction opcodes are 14-bit wide making it possible to have all single word instructions. A 14-bit wide program memory access bus fetches a 14-bit instruction in a single cycle. A two-stage pipeline overlaps fetch and execution of instructions. Consequently, all instructions (35) execute in a singlecycle (200 ns @ 20 MHz) except for program branches. The table below lists the memory (EPROM and RAM).

| Device    | Program<br>Memory<br>(EPROM) | Data<br>Memor<br>(RAM) |  |
|-----------|------------------------------|------------------------|--|
| PIC16C554 | 512                          | 80                     |  |
| PIC16C557 | 2 K                          | 128                    |  |
| PIC16C558 | 2 K                          | 128                    |  |

The PIC16C554 addresses 512 x 14 on-chip program memory. The PIC16C557 and PIC16C558 addresses 2 K x 14 program memory. All program memory is internal.

The PIC16C55X can directly or indirectly address its register files or data memory. All special function registers, including the program counter, are mapped into the data memory. The PIC16C55X has an orthogonal (symmetrical) instruction set that makes it possible to carry out any operation on any register using any Addressing mode. This symmetrical nature and lack of 'special optimal situations' make programming with the PIC16C55X simple yet efficient. In addition, the learning curve is reduced significantly.

The PIC16C55X devices contain an 8-bit ALU and working register. The ALU is a general purpose arithmetic unit. It performs arithmetic and Boolean functions between data in the working register and any register file.

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

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

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

A simplified block diagram is shown in Figure 3-1, with a description of the device pins in Table 3-1.

## 4.0 MEMORY ORGANIZATION

## 4.1 Program Memory Organization

The PIC16C55X has a 13-bit program counter capable of addressing an 8 K x 14 program memory space. Only the first 512 x 14 (0000h - 01FFh) for the PIC16C554 and 2K x 14 (0000h - 07FFh) for the PIC16C557 and PIC16C558 are physically implemented. Accessing a location above these boundaries will cause a wrap-around within the first 512 x 14 spaces in the PIC16C554, or 2K x 14 space of the PIC16C558 and PIC16C557. The RESET vector is at 0000h and the interrupt vector is at 0004h (Figure 4-1, Figure 4-2).





#### FIGURE 4-2:

#### PROGRAM MEMORY MAP AND STACK FOR THE PIC16C557 AND PIC16C558



### 4.2 Data Memory Organization

The data memory (Figure 4-3 through Figure 4-5) is partitioned into two banks which contain the General Purpose Registers (GPR) and the Special Function Registers (SFR). Bank 0 is selected when the RP0 bit (STATUS <5>) is cleared. Bank 1 is selected when the RP0 bit is set. The Special Function Registers are located in the first 32 locations of each Bank. Register locations 20-6Fh (Bank 0) on the PIC16C554 and 20-7Fh (Bank 0) and A0-BFh (Bank 1) on the PIC16C558 and PIC16C557 are General Purpose Registers implemented as static RAM. Some special purpose registers are mapped in Bank 1.

#### 4.2.1 GENERAL PURPOSE REGISTER FILE

The register file is organized as  $80 \times 8$  in the PIC16C554 and 128 x 8 in the PIC16C557 and PIC16C558. Each can be accessed either directly or indirectly through the File Select Register, FSR (Section 4.4).

#### 4.2.2.1 STATUS Register

The STATUS register, shown in Figure 4-2, contains the arithmetic status of the ALU, the RESET status and the bank select bits for data memory.

The STATUS register can be the destination for any instruction, like any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the TO and PD bits are not writable. Therefore, the result of an instruction with the STATUS register as the destination may be different than intended.

For example, CLRF STATUS will clear the upper-three bits and set the Z bit. This leaves the STATUS register as 000uu1uu (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions be used to alter the STATUS register because these instructions do not affect any status bits. For other instructions, not affecting any status bits, see the "Instruction Set Summary".

- Note 1: The IRP and RP1 bits (STATUS<7:6>) are not used by the PIC16C55X and should be programmed as '0'. Use of these bits as general purpose R/W bits is NOT recommended, since this may affect upward compatibility with future products.
  - 2: The <u>C</u> and <u>DC</u> bits operate as a Borrow and <u>Digit</u> Borrow out bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples.

|         | Reserved                                                                                                                                                                                                                                                                             | Reserved                               | R/W-0   | R-1        | R-1      | R/W-x          | R/W-x       | R/W-x         |  |  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|---------|------------|----------|----------------|-------------|---------------|--|--|
|         | IRP                                                                                                                                                                                                                                                                                  | RP1                                    | RP0     | TO         | PD       | Z              | DC          | С             |  |  |
|         | bit7                                                                                                                                                                                                                                                                                 |                                        |         |            |          |                |             | bit0          |  |  |
| bit 7   | IRP: Register Bank Select bit (used for Indirect addressing)<br>1 = Bank 2, 3 (100h - 1FFh)<br>0 = Bank 0, 1 (00h - FFh)<br>The IRP bit is reserved on the PIC16C55X, always maintain this bit clear                                                                                 |                                        |         |            |          |                |             |               |  |  |
| bit 6-5 | RP1:RP0: Register Bank Select bits (used for Direct addressing)<br>11 = Bank 3 (180h - 1FFh)<br>10 = Bank 2 (100h - 17Fh)<br>01 = Bank 1 (80h - FFh)<br>00 = Bank 0 (00h - 7Fh)<br>Each bank is 128 bytes. The RP1 bit is reserved on the PIC16C55X, always maintain this bit clear. |                                        |         |            |          |                |             |               |  |  |
| bit 4   | TO: Timeout bit<br>1 = After power-up, CLRWDT instruction, or SLEEP instruction<br>0 = A WDT timeout occurred                                                                                                                                                                        |                                        |         |            |          |                |             |               |  |  |
| bit 3   | <b>PD</b> : Power-down bit<br>1 = After power-up or by the CLRWDT instruction<br>0 = By execution of the SLEEP instruction                                                                                                                                                           |                                        |         |            |          |                |             |               |  |  |
| bit 2   |                                                                                                                                                                                                                                                                                      | It of an arithmei<br>It of an arithmei | • •     |            |          |                |             |               |  |  |
| bit 1   | <ul> <li>DC: Digit carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions) (for borrow the polarity reversed)</li> <li>1 = A carry-out from the 4th low order bit of the result occurred</li> <li>0 = No carry-out from the 4th low order bit of the result</li> </ul>            |                                        |         |            |          |                |             | e polarity is |  |  |
| bit 0   | C: Carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions)<br>1 = A carry-out from the Most Significant bit of the result occurred<br>0 = No carry-out from the Most Significant bit of the result occurred                                                                       |                                        |         |            |          |                |             |               |  |  |
| Note 1: |                                                                                                                                                                                                                                                                                      |                                        |         |            |          |                |             |               |  |  |
|         | Legend:                                                                                                                                                                                                                                                                              |                                        |         |            |          |                |             |               |  |  |
|         | R = Readable                                                                                                                                                                                                                                                                         | ə bit                                  | W = Wri | itable bit | U = Unim | plemented bit, | read as '0' |               |  |  |

- n = Value at POR reset

'0' = Bit is cleared

'1' = Bit is set

x = Bit is unknown









## TABLE 5-3: PORTB FUNCTIONS

| Name    | Bit # | Buffer Type           | Function                                                                                                                       |
|---------|-------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------|
| RB0/INT | Bit 0 | TTL/ST <sup>(1)</sup> | Bi-directional I/O port. Internal software programmable weak pull-up.                                                          |
| RB1     | Bit 1 | TTL                   | Bi-directional I/O port. Internal software programmable weak pull-up.                                                          |
| RB2     | Bit 2 | TTL                   | Bi-directional I/O port. Internal software programmable weak pull-up.                                                          |
| RB3     | Bit 3 | TTL                   | Bi-directional I/O port. Internal software programmable weak pull-up.                                                          |
| RB4     | Bit 4 | TTL                   | Bi-directional I/O port (with interrupt-on-change). Internal software programmable weak pull-up.                               |
| RB5     | Bit 5 | TTL                   | Bi-directional I/O port (with interrupt-on-change). Internal software programmable weak pull-up.                               |
| RB6     | Bit 6 | TTL/ST <sup>(2)</sup> | Bi-directional I/O port (with interrupt-on-change). Internal software programmable weak pull-up. Serial programming clock pin. |
| RB7     | Bit 7 | TTL/ST <sup>(2)</sup> | Bi-directional I/O port (with interrupt-on-change). Internal software programmable weak pull-up. Serial programming data pin.  |

Legend: ST = Schmitt Trigger, TTL = TTL input

Note 1: This buffer is a Schmitt Trigger input when configured as the external interrupt.

2: This buffer is a Schmitt Trigger input when used in Serial Programming mode.

## TABLE 5-4: SUMMARY OF REGISTERS ASSOCIATED WITH PORTB AND TRISB

| 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 |
|----------|--------|--------|----------|--------|--------|--------|--------|--------|--------|-----------------|---------------------------------|
| 06h      | PORTB  | RB7    | RB6      | RB5    | RB4    | RB3    | RB2    | RB1    | RB0    | xxxx xxxx       | uuuu uuuu                       |
| 86h      | TRISB  | TRISB7 | TRISB6   | TRISB5 | TRISB4 | TRISB3 | TRISB2 | TRISB1 | TRISB0 | 1111 1111       | 1111 1111                       |
| 81h      | OPTION | RBPU   | INTEDG   | TOCS   | TOSE   | PSA    | PS2    | PS1    | PS0    | 1111 1111       | 1111 1111                       |
| 0BH, 8BH | INTCON | GIE    | Reserved | TOIE   | INTE   | BRIE   | T0IF   | INTF   | RBIF   | 0000 000x       | 0000 000x                       |

Legend: x = unknown, u = unchanged

Note 1: Shaded bits are not used by PORTB.

#### 6.4.5 POWER CONTROL/STATUS REGISTER (PCON)

Bit1 is POR (Power-on Reset). It is a '0' on Power-on Reset and unaffected otherwise. The user must write a '1' to this bit following a Power-on Reset. On a subsequent RESET if POR is '0', it will indicate that a Poweron Reset must have occurred (VDD may have gone too low).

## TABLE 6-3: TIMEOUT IN VARIOUS SITUATIONS

| Oscillator    | Powe              | Power-up  |           |  |  |  |
|---------------|-------------------|-----------|-----------|--|--|--|
| Configuration | PWRTE = 0         | PWRTE = 1 | SLEEP     |  |  |  |
| XT, HS, LP    | 72 ms + 1024 Tosc | 1024 Tosc | 1024 Tosc |  |  |  |
| RC            | 72 ms             | _         | —         |  |  |  |

### TABLE 6-4: STATUS BITS AND THEIR SIGNIFICANCE

| POR | то | PD |                                    |  |
|-----|----|----|------------------------------------|--|
| 0   | 1  | 1  | Power-on Reset                     |  |
| 0   | 0  | Х  | Illegal, TO is set on POR          |  |
| 0   | Х  | 0  | Illegal, PD is set on POR          |  |
| 1   | 0  | u  | WDT Reset                          |  |
| 1   | 0  | 0  | WDT Wake-up                        |  |
| 1   | u  | u  | MCLR Reset during normal operation |  |
| 1   | 1  | 0  | MCLR Reset during SLEEP            |  |

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

#### 6.5.1 RB0/INT INTERRUPT

An external interrupt on RB0/INT pin is edge triggered: either rising if INTEDG bit (OPTION<6>) is set, or falling if INTEDG bit is clear. When a valid edge appears on the RB0/INT pin, the INTF bit (INTCON<1>) is set. This interrupt can be disabled by clearing the INTE control bit (INTCON<4>). The INTF bit must be cleared in software in the interrupt service routine before reenabling this interrupt. The RB0/INT interrupt can wake-up the processor from SLEEP, if the INTE bit was set prior to going into SLEEP. The status of the GIE bit decides whether or not the processor branches to the interrupt vector following wake-up. See Section 6.8 for details on SLEEP and Figure 6-14 for timing of wakeup from SLEEP through RB0/INT interrupt.

#### 6.5.2 TMR0 INTERRUPT

An overflow (FFh  $\rightarrow$  00h) in the TMR0 register will set the T0IF (INTCON<2>) bit. The interrupt can be enabled/disabled by setting/clearing T0IE (INTCON<5>) bit. For operation of the Timer0 module, see Section 7.0.

#### 6.5.3 PORTB INTERRUPT

An input change on PORTB <7:4> sets the RBIF (INTCON<0>) bit. The interrupt can be enabled/disabled by setting/clearing the RBIE (INTCON<4>) bit. For operation of PORTB (Section 5.2).

**Note:** 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 get set.



FIGURE 6-12: INT PIN INTERRUPT TIMING

Note 1: INTF flag is sampled here (every Q1).

- 2: Interrupt latency = 3-4 TCY where TCY = instruction cycle time. Latency is the same whether Inst (PC) is a single cycle or a 2-cycle instruction.
- 3: CLKOUT is available only in RC Oscillator mode.
- 4: For minimum width of INT pulse, refer to AC specs.
- 5: INTF is enabled to be set anytime during the Q4-Q1 cycles.

## 6.9 Code Protection

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

| Note: | Microchip  | does   | not   | recommend | code |
|-------|------------|--------|-------|-----------|------|
|       | protecting | windov | ved d | evices.   |      |

### 6.10 ID Locations

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

### 6.11 In-Circuit Serial Programming™

The PIC16C55X microcontrollers can be serially programmed while in the end application circuit. This is simply done with two lines for clock and data, and three other lines for power, ground, and the programming voltage. This allows customers to manufacture boards with unprogrammed devices, and then program the microcontroller just before shipping the product. This also allows the most recent firmware or a custom firmware to be programmed.

The device is placed into a Program/Verify mode by holding the RB6 and RB7 pins low while raising the MCLR (VPP) pin from VIL to VIHH (see programming specification). RB6 becomes the programming clock and RB7 becomes the programming data. Both RB6 and RB7 are Schmitt Trigger inputs in this mode.

After RESET, to place the device into Programming/ Verify mode, the program counter (PC) is at location 00h. A 6-bit command is then supplied to the device. Depending on the command, 14 bits of program data are then supplied to or from the device, depending if the command was a load or a read. For complete details of serial programming, please refer to the PIC16C6X/7X Programming Specifications (Literature #DS30228).

A typical in-circuit serial programming connection is shown in Figure 6-15.

#### FIGURE 6-15: TYPICAL IN-CIRCUIT SERIAL PROGRAMMING CONNECTION



## 7.0 TIMER0 MODULE

The Timer0 module timer/counter has the following features:

- 8-bit timer/counter
- Readable and writable
- 8-bit software programmable prescaler
- · Internal or external clock select
- Interrupt on overflow from FFh to 00h
- 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 TMR0 will increment every instruction cycle (without prescaler). If Timer0 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 TMR0.

Counter mode is selected by setting the T0CS bit. In this mode Timer0 will increment either on every rising or falling edge of pin RA4/T0CKI. The incrementing edge is determined by the source edge (T0SE) control bit (OPTION<4>). Clearing the TOSE bit selects the rising edge. Restrictions on the external clock input are discussed in detail in Section 7.2.

The prescaler is shared between the Timer0 module and the Watchdog Timer. 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 value of 1:2, 1:4, ..., 1:256 are selectable. Section 7.3 details the operation of the prescaler.

## 7.1 TIMER0 Interrupt

Timer0 interrupt is generated when the TMR0 register timer/counter overflows from FFh to 00h. This overflow sets the T0IF bit. The interrupt can be masked by clearing the T0IE bit (INTCON<5>). The T0IF bit (INTCON<2>) must be cleared in software by the Timer0 module interrupt service routine before reenabling this interrupt. The Timer0 interrupt cannot wake the processor from SLEEP since the timer is shut off during SLEEP. See Figure 7-4 for Timer0 interrupt timing.



## FIGURE 7-2: TIMER0 (TMR0) TIMING: INTERNAL CLOCK/NO PRESCALER



# PIC16C55X

| CLRW             | Clear W                              |                                                                       |              |        |  |  |  |
|------------------|--------------------------------------|-----------------------------------------------------------------------|--------------|--------|--|--|--|
| Syntax:          | [ label ]                            | [label] CLRW                                                          |              |        |  |  |  |
| Operands:        | None                                 |                                                                       |              |        |  |  |  |
| Operation:       | $00h \rightarrow (V 1 \rightarrow Z$ | $\begin{array}{l} 00h \rightarrow (W) \\ 1 \rightarrow Z \end{array}$ |              |        |  |  |  |
| Status Affected: | Z                                    |                                                                       |              |        |  |  |  |
| Encoding:        | 00                                   | 0001                                                                  | 0000         | 0011   |  |  |  |
| Description:     | W register set.                      | is clear                                                              | ed. Zero bit | (Z) is |  |  |  |
| Words:           | 1                                    |                                                                       |              |        |  |  |  |
| Cycles:          | 1                                    |                                                                       |              |        |  |  |  |
| Example          | CLRW                                 |                                                                       |              |        |  |  |  |
|                  | Before In                            | structio                                                              | n            |        |  |  |  |
|                  | W                                    | =                                                                     | 0x5A         |        |  |  |  |
|                  | After Inst                           | ruction                                                               |              |        |  |  |  |
|                  | W                                    | =                                                                     | 0x00         |        |  |  |  |
|                  | Z                                    | =                                                                     | 1            |        |  |  |  |

| COMF             | Complement f                                        |                             |                              |      |  |  |  |  |
|------------------|-----------------------------------------------------|-----------------------------|------------------------------|------|--|--|--|--|
| Syntax:          | [ label ]                                           | [label] COMF f,d            |                              |      |  |  |  |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                  |                             |                              |      |  |  |  |  |
| Operation:       | $(\overline{f}) \rightarrow (des$                   | st)                         |                              |      |  |  |  |  |
| Status Affected: | Z                                                   |                             |                              |      |  |  |  |  |
| Encoding:        | 00                                                  | 1001                        | dfff                         | ffff |  |  |  |  |
| Description:     | The conter<br>compleme<br>stored in V<br>stored bac | nted. If 'd<br>V. If 'd' is | ' is 0 the re<br>1 the resul |      |  |  |  |  |
| Words:           | 1                                                   |                             |                              |      |  |  |  |  |
| Cycles:          | 1                                                   |                             |                              |      |  |  |  |  |
| Example          | COMF                                                | REG1,0                      | )                            |      |  |  |  |  |
|                  | Before In                                           | struction                   |                              |      |  |  |  |  |
|                  | REG                                                 | 1 =                         | 0x13                         |      |  |  |  |  |
|                  | After Inst                                          | ruction                     |                              |      |  |  |  |  |
|                  | REG                                                 | 1 =                         | 0x13                         |      |  |  |  |  |
|                  | W                                                   | =                           | 0xEC                         |      |  |  |  |  |

| Clear Watchdog Timer                                                                                                                                     |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [label] CLRWDT                                                                                                                                           |  |  |  |  |  |  |
| None                                                                                                                                                     |  |  |  |  |  |  |
| $\begin{array}{l} 00h \rightarrow WDT \\ 0 \rightarrow WDT \text{ prescaler,} \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow \overline{PD} \end{array}$ |  |  |  |  |  |  |
| TO, PD                                                                                                                                                   |  |  |  |  |  |  |
| 00 0000 0110 0100                                                                                                                                        |  |  |  |  |  |  |
| CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. Status bits TO<br>and PD are set.                           |  |  |  |  |  |  |
| 1                                                                                                                                                        |  |  |  |  |  |  |
| 1                                                                                                                                                        |  |  |  |  |  |  |
| CLRWDT                                                                                                                                                   |  |  |  |  |  |  |
| Before Instruction<br>WDT counter = ?<br>After Instruction<br>WDT counter = $0x00$<br>WDT prescaler = $0$<br>TO = $1$<br>PD = $1$                        |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |

.....

| DECF             | Decrement f                                                                                                                                 |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:          | [ <i>label</i> ] DECF f,d                                                                                                                   |  |  |  |
| Operands:        | 0 ≤ f ≤ 127<br>d ∈ [0,1]                                                                                                                    |  |  |  |
| Operation:       | (f) - 1 $\rightarrow$ (dest)                                                                                                                |  |  |  |
| Status Affected: | Z                                                                                                                                           |  |  |  |
| Encoding:        | 00 0011 dfff ffff                                                                                                                           |  |  |  |
| Description:     | Decrement register 'f'. If 'd' is 0 the<br>result is stored in the W register. If 'd'<br>is 1 the result is stored back in register<br>'f'. |  |  |  |
| Words:           | 1                                                                                                                                           |  |  |  |
| Cycles:          | 1                                                                                                                                           |  |  |  |
| Example          | DECF CNT, 1                                                                                                                                 |  |  |  |
|                  | Before Instruction<br>CNT = 0x01<br>Z = 0<br>After Instruction<br>CNT = 0x00<br>Z = 1                                                       |  |  |  |
|                  |                                                                                                                                             |  |  |  |

| RRF               | Rotate Right f through Carry                                                                                                                                                                                 |                                               |                  |                    |            |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|------------------|--------------------|------------|--|
| Syntax:           | [ <i>label</i> ] RRF f,d                                                                                                                                                                                     |                                               |                  |                    |            |  |
| Operands:         | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \left[0,1\right] \end{array}$                                                                                                                                   |                                               |                  |                    |            |  |
| Operation:        | See desc                                                                                                                                                                                                     | ription b                                     | below            |                    |            |  |
| Status Affected:  | С                                                                                                                                                                                                            |                                               |                  |                    |            |  |
| Encoding:         | 00                                                                                                                                                                                                           | 1100                                          | dff              | f                  | ffff       |  |
| Description:      | The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in<br>the W register. If 'd' is 1 the result is<br>placed back in register 'f'. |                                               |                  |                    |            |  |
|                   | C Register f                                                                                                                                                                                                 |                                               |                  |                    |            |  |
|                   |                                                                                                                                                                                                              |                                               | Regist           | ter f              | ┠╼         |  |
| Words:            | 1                                                                                                                                                                                                            |                                               | Regist           | ter f              | ]-•        |  |
| Words:<br>Cycles: | 1<br>1                                                                                                                                                                                                       | ] <b>→</b> [                                  | Regist           | ter f              | <b>]</b> • |  |
|                   | •                                                                                                                                                                                                            |                                               |                  | ter f              | <u>}-</u>  |  |
| Cycles:           | 1                                                                                                                                                                                                            |                                               | REG              |                    | <u>-</u>   |  |
| Cycles:           | 1<br>RRF                                                                                                                                                                                                     | struction                                     | REG              | \$1,0              | 0          |  |
| Cycles:           | 1<br>RRF<br>Before Ins                                                                                                                                                                                       | struction                                     | REG<br>n<br>1110 | \$1,0              | .0         |  |
| Cycles:           | 1<br>RRF<br>Before In<br>REG                                                                                                                                                                                 | struction<br>1 = 1<br>= (                     | REG<br>n<br>1110 | \$1,0              | .0         |  |
| Cycles:           | 1<br>RRF<br>Before In:<br>REG<br>C<br>After Insti<br>REG                                                                                                                                                     | struction<br>1 = 1<br>= 0<br>ruction          | REG<br>n<br>1110 | \$1,0              | -          |  |
| Cycles:           | 1<br>RRF<br>Before Ins<br>REG<br>C<br>After Instr                                                                                                                                                            | struction<br>1 = 2<br>= 0<br>ruction<br>1 = 2 | REG<br>N<br>L110 | ;1,0<br>011<br>011 | .0         |  |

#### SLEEP

| Syntax:          | [ <i>label</i><br>]                                                                                                                                                                                                                                        | SLEEP |      |      |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|------|--|
| Operands:        | None                                                                                                                                                                                                                                                       |       |      |      |  |
| Operation:       | $\begin{array}{l} 00h \rightarrow WDT, \\ 0 \rightarrow WDT \text{ prescaler,} \\ 1 \rightarrow \overline{TO}, \\ 0 \rightarrow \overline{PD} \end{array}$                                                                                                 |       |      |      |  |
| Status Affected: | $\overline{\text{TO}}, \overline{\text{PD}}$                                                                                                                                                                                                               |       |      |      |  |
| Encoding:        | 00                                                                                                                                                                                                                                                         | 0000  | 0110 | 0011 |  |
| Description:     | The power-down status bit, <u>PD</u> is<br>cleared. Timeout status bit, <u>TO</u> is<br>set. Watchdog Timer and its<br>prescaler are cleared.<br>The processor is put into SLEEP<br>mode with the oscillator stopped.<br>See Section 6.8 for more details. |       |      |      |  |
| Words:           | 1                                                                                                                                                                                                                                                          |       |      |      |  |
| Cycles:          | 1                                                                                                                                                                                                                                                          |       |      |      |  |
| Example:         | SLEEP                                                                                                                                                                                                                                                      |       |      |      |  |

| SUBLW               | Subtract W from Literal                       |                    |             |             |  |  |
|---------------------|-----------------------------------------------|--------------------|-------------|-------------|--|--|
| Syntax:             | [ <i>label</i> ] SUBLW k                      |                    |             |             |  |  |
| Operands:           | $0 \le k \le 255$                             |                    |             |             |  |  |
| Operation:          | $k - (W) \to (W)$                             |                    |             |             |  |  |
| Status<br>Affected: | C, DC, Z                                      |                    |             |             |  |  |
| Encoding:           | 11                                            | 11 110x kkkk kkkk  |             |             |  |  |
| Description:        | The W regist<br>plement met<br>'k'. The resul | hod) fror          | n the eight | bit literal |  |  |
| Words:              | 1                                             |                    |             |             |  |  |
| Cycles:             | 1                                             |                    |             |             |  |  |
| Example 1:          | SUBLW                                         | 0x02               |             |             |  |  |
|                     | Before Inst                                   | ruction            |             |             |  |  |
|                     | W                                             | = 1                |             |             |  |  |
|                     | С                                             | = ?                | )           |             |  |  |
|                     | After Instru                                  | After Instruction  |             |             |  |  |
|                     | W                                             | = 1                |             |             |  |  |
|                     | С                                             | = 1                | ; result is | positive    |  |  |
| Example 2:          | Before Inst                                   | ruction            |             |             |  |  |
|                     | W                                             | = 2                | <u>2</u>    |             |  |  |
|                     | С                                             | = ?                | )           |             |  |  |
|                     | After Instru                                  | After Instruction  |             |             |  |  |
|                     | W                                             | = 0                | )           |             |  |  |
|                     | С                                             | = 1                | ; result is | s zero      |  |  |
| Example 3:          | Before Inst                                   | Before Instruction |             |             |  |  |
|                     | W                                             | = 3                | 3           |             |  |  |
|                     | С                                             | = ?                | <b>)</b>    |             |  |  |
|                     | After Instru                                  | ction              |             |             |  |  |
|                     | W                                             |                    | )xFF        |             |  |  |
|                     | C                                             | = 0                | ); result i | s nega-     |  |  |

tive

 $\odot$  1996-2013 Microchip Technology Inc.

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

## 9.8 MPLAB ICD In-Circuit Debugger

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

## 9.9 PRO MATE II Universal Device Programmer

The PRO MATE II universal device programmer is a full-featured programmer, capable of operating in Stand-alone mode, as well as PC-hosted mode. The PRO MATE II device programmer is CE compliant.

The PRO MATE II device programmer has programmable VDD and VPP supplies, which allow it to verify programmed memory at VDD min and VDD max for maximum reliability. It has an LCD display for instructions and error messages, keys to enter commands and a modular detachable socket assembly to support various package types. In Stand-alone mode, the PRO MATE II device programmer can read, verify, or program PIC devices. It can also set code protection in this mode.

## 9.10 PICSTART Plus Entry Level Development Programmer

The PICSTART Plus development programmer is an easy-to-use, low cost, prototype programmer. It connects to the PC via a COM (RS-232) port. MPLAB Integrated Development Environment software makes using the programmer simple and efficient.

The PICSTART Plus development programmer supports all PIC devices with up to 40 pins. Larger pin count devices, such as the PIC16C92X and PIC17C76X, may be supported with an adapter socket. The PICSTART Plus development programmer is CE compliant.

## 9.11 PICDEM 1 Low Cost PIC MCU Demonstration Board

The PICDEM 1 demonstration board is a simple board which demonstrates the capabilities of several of Microchip's microcontrollers. The microcontrollers supported are: PIC16C5X (PIC16C54 to PIC16C58A). PIC16C61, PIC16C62X, PIC16C71, PIC16C8X, PIC17C42, PIC17C43 and PIC17C44. All necessary hardware and software is included to run basic demo programs. The user can program the sample microcontrollers provided with the PICDEM 1 demonstration board on a PRO MATE II device programmer, or a PICSTART Plus development programmer, and easily test firmware. The user can also connect the PICDEM 1 demonstration board to the MPLAB ICE incircuit emulator and download the firmware to the emulator for testing. A prototype area is available for the user to build some additional hardware and connect it to the microcontroller socket(s). Some of the features include an RS-232 interface, a potentiometer for simulated analog input, push button switches and eight LEDs connected to PORTB.

## 9.12 PICDEM 2 Low Cost PIC16CXX Demonstration Board

The PICDEM 2 demonstration board is a simple demonstration board that supports the PIC16C62, PIC16C64, PIC16C65, PIC16C73 and PIC16C74 microcontrollers. All the necessary hardware and software is included to run the basic demonstration programs. The user can program the sample microcontrollers provided with the PICDEM 2 demonstration board on a PRO MATE II device programmer, or a PICSTART Plus development programmer, and easily test firmware. The MPLAB ICE in-circuit emulator may also be used with the PICDEM 2 demonstration board to test firmware. A prototype area has been provided to the user for adding additional hardware and connecting it to the microcontroller socket(s). Some of the features include a RS-232 interface, push button switches, a potentiometer for simulated analog input, a serial EEPROM to demonstrate usage of the  $I^2C^{TM}$  bus and separate headers for connection to an LCD module and a keypad.

## PIC16C55X



## 18-Lead Plastic Dual In-line (P) – 300 mil (PDIP)

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



|                            | Units | INCHES* |      |      | MILLIMETERS |       |       |
|----------------------------|-------|---------|------|------|-------------|-------|-------|
| Dimension Limits           |       | MIN     | NOM  | MAX  | MIN         | NOM   | MAX   |
| Number of Pins             | n     |         | 18   |      |             | 18    |       |
| Pitch                      | р     |         | .100 |      |             | 2.54  |       |
| Top to Seating Plane       | А     | .140    | .155 | .170 | 3.56        | 3.94  | 4.32  |
| Molded Package Thickness   | A2    | .115    | .130 | .145 | 2.92        | 3.30  | 3.68  |
| Base to Seating Plane      | A1    | .015    |      |      | 0.38        |       |       |
| Shoulder to Shoulder Width | Е     | .300    | .313 | .325 | 7.62        | 7.94  | 8.26  |
| Molded Package Width       | E1    | .240    | .250 | .260 | 6.10        | 6.35  | 6.60  |
| Overall Length             | D     | .890    | .898 | .905 | 22.61       | 22.80 | 22.99 |
| Tip to Seating Plane       | L     | .125    | .130 | .135 | 3.18        | 3.30  | 3.43  |
| Lead Thickness             | С     | .008    | .012 | .015 | 0.20        | 0.29  | 0.38  |
| Upper Lead Width           | B1    | .045    | .058 | .070 | 1.14        | 1.46  | 1.78  |
| Lower Lead Width           | В     | .014    | .018 | .022 | 0.36        | 0.46  | 0.56  |
| Overall Row Spacing §      | eВ    | .310    | .370 | .430 | 7.87        | 9.40  | 10.92 |
| Mold Draft Angle Top       | α     | 5       | 10   | 15   | 5           | 10    | 15    |
| Mold Draft Angle Bottom    | β     | 5       | 10   | 15   | 5           | 10    | 15    |

\* 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-001 Drawing No. C04-007

#### 28-Lead Ceramic Dual In-line with Window (JW) - 300 mil (CERDIP)

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



|                            | Units     | nits INCHES* |       |       | MILLIMETERS |       |       |
|----------------------------|-----------|--------------|-------|-------|-------------|-------|-------|
| Dimensio                   | on Limits | MIN          | NOM   | MAX   | MIN         | NOM   | MAX   |
| Number of Pins             | n         |              | 28    |       |             | 28    |       |
| Pitch                      | р         |              | .100  |       |             | 2.54  |       |
| Top to Seating Plane       | Α         | .170         | .183  | .195  | 4.32        | 4.64  | 4.95  |
| Ceramic Package Height     | A2        | .155         | .160  | .165  | 3.94        | 4.06  | 4.19  |
| Standoff                   | A1        | .015         | .023  | .030  | 0.38        | 0.57  | 0.76  |
| Shoulder to Shoulder Width | E         | .300         | .313  | .325  | 7.62        | 7.94  | 8.26  |
| Ceramic Pkg. Width         | E1        | .285         | .290  | .295  | 7.24        | 7.37  | 7.49  |
| Overall Length             | D         | 1.430        | 1.458 | 1.485 | 36.32       | 37.02 | 37.72 |
| Tip to Seating Plane       | L         | .135         | .140  | .145  | 3.43        | 3.56  | 3.68  |
| Lead Thickness             | С         | .008         | .010  | .012  | 0.20        | 0.25  | 0.30  |
| Upper Lead Width           | B1        | .050         | .058  | .065  | 1.27        | 1.46  | 1.65  |
| Lower Lead Width           | В         | .016         | .019  | .021  | 0.41        | 0.47  | 0.53  |
| Overall Row Spacing §      | eB        | .345         | .385  | .425  | 8.76        | 9.78  | 10.80 |
| Window Width               | W1        | .130         | .140  | .150  | 3.30        | 3.56  | 3.81  |
| Window Length              | W2        | .290         | .300  | .310  | 7.37        | 7.62  | 7.87  |

Significant Characteristic JEDEC Equivalent: MO-058 Drawing No. C04-080

## **PRODUCT IDENTIFICATION SYSTEM**

To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office.

|                   | x <u>xx</u> xxx                                                                                                               | Examples:                                                                                                                                                |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device To         | emperature Package Pattern<br>Range                                                                                           | a) PIC17C756–16L Commercial Temp.,<br>PLCC package, 16 MHz,<br>normal VDD limits                                                                         |
| Device            | PIC17C756: Standard VDD range<br>PIC17C756T: (Tape and Reel)<br>PIC17LC756: Extended VDD range                                | <ul> <li>b) PIC17LC756–08/PT Commercial Temp.,<br/>TQFP package, 8MHz,<br/>extended VDD limits</li> <li>c) PIC17C756–33I/PT Industrial Temp.,</li> </ul> |
| Temperature Range | $\begin{array}{rcl} - & = & 0^{\circ}C \text{ to } +70^{\circ}C \\ I & = & -40^{\circ}C \text{ to } +85^{\circ}C \end{array}$ | TQFP package, 33 MHz,<br>normal VDD limits                                                                                                               |
| Package           | CL = Windowed LCC<br>PT = TQFP<br>L = PLCC                                                                                    |                                                                                                                                                          |
| Pattern           | QTP, SQTP, ROM Code (factory specified) or<br>Special Requirements. Blank for OTP and<br>Windowed devices.                    |                                                                                                                                                          |

\* JW Devices are UV erasable and can be programmed to any device configuration. JW Devices meet the electrical requirement of each oscillator type.

## Sales and Support

#### Data Sheets

Products supported by a preliminary Data Sheet may have an errata sheet describing minor operational differences and recommended workarounds. To determine if an errata sheet exists for a particular device, please contact one of the following:

1. Your local Microchip sales office

2. The Microchip Worldwide Site (www.microchip.com)

NOTES:

#### Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.

## QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV = ISO/TS 16949=

#### Trademarks

The Microchip name and logo, the Microchip logo, dsPIC, FlashFlex, KEELOQ, KEELOQ logo, MPLAB, PIC, PICmicro, PICSTART, PIC<sup>32</sup> logo, rfPIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor, MTP, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

Analog-for-the-Digital Age, Application Maestro, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial Programming, ICSP, Mindi, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, mTouch, Omniscient Code Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit, PICtail, REAL ICE, rfLAB, Select Mode, SQI, Serial Quad I/O, Total Endurance, TSHARC, UniWinDriver, WiperLock, ZENA and Z-Scale are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

GestIC and ULPP are registered trademarks of Microchip Technology Germany II GmbH & Co. & KG, a subsidiary of Microchip Technology Inc., in other countries.

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

© 1996-2013, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

Printed on recycled paper.

ISBN: 9781620769737

Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and mulfacture of development systems is ISO 9001:2000 certified.