



Welcome to E-XFL.COM

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

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

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

#### Details

| Details                    |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Active                                                                      |
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 4MHz                                                                        |
| Connectivity               | -                                                                           |
| Peripherals                | Brown-out Detect/Reset, POR, WDT                                            |
| Number of I/O              | 13                                                                          |
| Program Memory Size        | 3.5KB (2K x 14)                                                             |
| Program Memory Type        | OTP                                                                         |
| EEPROM Size                | 128 x 8                                                                     |
| RAM Size                   | 128 x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 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/pic16lce625-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**

| 1.0   | General Description                           | 3     |
|-------|-----------------------------------------------|-------|
| 2.0   | PIC16CE62X Device Varieties                   | 5     |
| 3.0   | Architectural Overview                        |       |
| 4.0   | Memory Organization                           | 11    |
| 5.0   | I/O Ports                                     |       |
| 6.0   | EEPROM Peripheral Operation                   | 29    |
| 7.0   | Timer0 Module                                 |       |
| 8.0   | Comparator Module                             | 41    |
| 9.0   | Voltage Reference Module                      | 47    |
| 10.0  | Special Features of the CPU                   | 49    |
| 11.0  | Instruction Set Summary                       | 65    |
|       | Development Support                           |       |
|       | Electrical Specifications                     |       |
| 14.0  | Packaging Information                         | 97    |
| Appe  | ndix A: Code for Accessing EEPROM Data Memory | 103   |
| Index |                                               | 105   |
| On Li | ne Support                                    | . 107 |
| Read  | ne Support<br>er Response                     | 108   |
| PIC1  | 6CE62X Product Identification System          | . 109 |

#### To Our Valued Customers

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

#### New Customer Notification System

Register on our web site (www.microchip.com/cn) to receive the most current information on our products.

#### Errata

An errata sheet may exist for current devices, describing minor operational differences (from the data sheet) and recommended workarounds. 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) 786-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.

#### **Corrections to this Data Sheet**

We constantly strive to improve the quality of all our products and documentation. We have spent a great deal of time to ensure that this document is correct. However, we realize that we may have missed a few things. If you find any information that is missing or appears in error, please:

- Fill out and mail in the reader response form in the back of this data sheet.
- E-mail us at webmaster@microchip.com.

We appreciate your assistance in making this a better document.

## 3.0 ARCHITECTURAL OVERVIEW

The high performance of the PIC16CE62X family can be attributed to a number of architectural features commonly found in RISC microprocessors. To begin with, the PIC16CE62X uses a Harvard architecture in which program and data are accessed from separate memories using separate buses. 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 than 8-bit wide data word. Instruction opcodes are 14-bits 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 single-cycle (200 ns @ 20 MHz) except for program branches.

The table below lists program memory (EPROM), data memory (RAM) and non-volatile memory (EEPROM) for each PIC16CE62X device.

| Device     | Program<br>Memory | RAM<br>Data<br>Memory | EEPROM<br>Data<br>Memory |
|------------|-------------------|-----------------------|--------------------------|
| PIC16CE623 | 512x14            | 96x8                  | 128x8                    |
| PIC16CE624 | 1Kx14             | 96x8                  | 128x8                    |
| PIC16CE625 | 2Kx14             | 128x8                 | 128x8                    |

The PIC16CE62X can directly or indirectly address its register files or data memory. All special function registers including the program counter are mapped in the data memory. The PIC16CE62X family 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 PIC16CE62X simple yet efficient. In addition, the learning curve is reduced significantly.

The PIC16CE62X 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, bit 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.

## FIGURE 3-1: BLOCK DIAGRAM



### 7.3 <u>Prescaler</u>

An 8-bit counter is available as a prescaler for the Timer0 module, or as a postscaler for the Watchdog Timer, respectively (Figure 7-6). For simplicity, this counter is being referred to as "prescaler" throughout this data sheet. Note that there is only one prescaler available which is mutually exclusive between the Timer0 module and the Watchdog Timer. Thus, a prescaler assignment for the Timer0 module means that there is no prescaler for the Watchdog Timer and vice-versa.

The PSA and PS<2:0> bits (OPTION<3:0>) determine the prescaler assignment and prescale ratio.

When assigned to the Timer0 module, all instructions writing to the TMR0 register (i.e., CLRF 1, MOVWF 1, BSF 1, x....etc.) will clear the prescaler. When assigned to WDT, a CLRWDT instruction will clear the prescaler along with the Watchdog Timer. The prescaler is not readable or writable.



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

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

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

| 1.BCF    | STATUS, RPO | ;Skip if already in      |
|----------|-------------|--------------------------|
|          |             | ; Bank 0                 |
| 2.CLRWDT |             | ;Clear WDT               |
| 3.CLRF   | TMR0        | ;Clear TMR0 & Prescaler  |
| 4.BSF    | STATUS, RPO | ;Bank 1                  |
| 5.MOVLW  | '00101111'b | ;These 3 lines (5, 6, 7) |
| 6.MOVWF  | OPTION      | ; are required only if   |
|          |             | ; desired PS<2:0> are    |
| 7.CLRWDT |             | ; 000 or 001             |
| 8.MOVLW  | '00101xxx'b | ;Set Postscaler to       |
| 9.MOVWF  | OPTION      | ; desired WDT rate       |
| 10.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 $\rightarrow$ TIMER0)

| CLRWDT |             | ;Clear WDT and<br>;prescaler |
|--------|-------------|------------------------------|
|        |             | /prebearer                   |
| BSF    | STATUS, RPO |                              |
| MOVLW  | b'xxxx0xxx' | ;Select TMR0, new            |
|        |             | ;prescale value and          |
|        |             | ;clock source                |
| MOVWF  | OPTION_REG  |                              |
| 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 | Fimer0 module register |       |        |        |        |        |        | xxxx xxxx        | uuuu uuuu                       |
| 0Bh/8Bh | INTCON | GIE    | PEIE                   | T0IE  | INTE   | RBIE   | T0IF   | INTF   | RBIF   | 0000 000x        | 0000 000u                       |
| 81h     | OPTION | RBPU   | INTEDG                 | TOCS  | T0SE   | 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', x = unknown, u = unchanged.

Note: Shaded bits are not used by TMR0 module.

#### 8.6 Comparator Interrupts

The comparator interrupt flag is set whenever there is a change in the output value of either comparator. Software will need to maintain information about the status of the output bits, as read from CMCON<7:6>, to determine the actual change that has occurred. The CMIF bit, PIR1<6>, is the comparator interrupt flag. The CMIF bit must be reset by clearing '0'. Since it is also possible to write a '1' to this register, a simulated interrupt may be initiated.

The CMIE bit (PIE1<6>) and the PEIE bit (INTCON<6>) must be set to enable the interrupt. In addition, the GIE bit must also be set. If any of these bits are clear, the interrupt is not enabled, though the CMIF bit will still be set if an interrupt condition occurs.

Note: If a change in the CMCON register (C1OUT or C2OUT) should occur when a read operation is being executed (start of the Q2 cycle), then the CMIF (PIR1<6>) interrupt flag may not get set.

The user, in the interrupt service routine, can clear the interrupt in the following manner:

- a) Any read or write of CMCON. This will end the mismatch condition.
- b) Clear flag bit CMIF.

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

## 8.7 <u>Comparator Operation During SLEEP</u>

When a comparator is active and the device is placed in SLEEP mode, the comparator remains active and the interrupt is functional if enabled. This interrupt will wake-up the device from SLEEP mode when enabled. While the comparator is powered-up, higher sleep currents than shown in the power down current specification will occur. Each comparator that is operational will consume additional current as shown in the comparator specifications. To minimize power consumption while in SLEEP mode, turn off the comparators, CM<2:0> = 111, before entering sleep. If the device wakes-up from sleep, the contents of the CMCON register are not affected.

### 8.8 Effects of a RESET

A device reset forces the CMCON register to its reset state. This forces the comparator module to be in the comparator reset mode, CM<2:0> = 000. This ensures that all potential inputs are analog inputs. Device current is minimized when analog inputs are present at reset time. The comparators will be powered-down during the reset interval.

### 8.9 <u>Analog Input Connection</u> <u>Considerations</u>

A simplified circuit for an analog input is shown in Figure 8-4. Since the analog pins are connected to a digital output, they have reverse biased diodes to VDD and Vss. The analog input therefore, must be between Vss and VDD. If the input voltage deviates from this range by more than 0.6V in either direction, one of the diodes is forward biased and a latch-up may occur. A maximum source impedance of 10 k $\Omega$  is recommended for the analog sources. Any external component connected to an analog input pin, such as a capacitor or a Zener diode, should have very little leakage current.



### FIGURE 8-4: ANALOG INPUT MODEL

#### 10.4.5 TIME-OUT SEQUENCE

On power-up, the time-out sequence is as follows: First PWRT time-out is invoked after POR has expired, then OST is activated. The total time-out 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 time-out at all. Figure 10-8, Figure 10-9 and Figure 10-10 depict time-out sequences.

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

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

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

The power control/status register, PCON (address 8Eh) has two bits.

Bit0 is  $\overline{\text{BOR}}$  (Brown-out).  $\overline{\text{BOR}}$  is unknown on power-on-reset. It must then be set by the user and checked on subsequent resets to see if  $\overline{\text{BOR}} = 0$  indicating that a brown-out has occurred. The  $\overline{\text{BOR}}$  status bit is a don't care and is not necessarily predictable if the brown-out circuit is disabled (by setting BODEN bit = 0 in the Configuration word).

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 power-on-reset must have occurred (VDD may have gone too low).

| Oscillator Configuration | Powe              | er-up     | Brown-out Reset   | Wake-up    |  |
|--------------------------|-------------------|-----------|-------------------|------------|--|
| Oscillator Configuration | <b>PWRTE</b> = 0  | PWRTE = 1 | brown-out neset   | from SLEEP |  |
| XT, HS, LP               | 72 ms + 1024 Tosc | 1024 Tosc | 72 ms + 1024 Tosc | 1024 Tosc  |  |
| RC                       | 72 ms             | _         | 72 ms             | —          |  |

### TABLE 10-3: TIME-OUT IN VARIOUS SITUATIONS

| POR | BOR | TO | PD |                           |
|-----|-----|----|----|---------------------------|
| 0   | Х   | 1  | 1  | Power-on-reset            |
| 0   | Х   | 0  | Х  | Illegal, TO is set on POR |
| 0   | Х   | Х  | 0  | Illegal, PD is set on POR |

**Brown-out Reset** 

WDT Reset

WDT Wake-up

MCLR reset during normal operation

MCLR reset during SLEEP

### TABLE 10-4: STATUS/PCON BITS AND THEIR SIGNIFICANCE

Х

u

0

u

Ο

Legend: x = unknown, u = unchanged

0

1

1

1

1

Х

0

0

u

1

1

1

1

1

1

### 10.9 <u>Code Protection</u>

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 windowed devices. |      |     |           |      |  |  |

#### 10.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. Only the least significant 4 bits of the ID locations are used.

### 10.11 In-Circuit Serial Programming

The PIC16CE62X 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/9XX Programming Specifications (Literature #DS30228).

A typical in-circuit serial programming connection is shown in Figure 10-20.

#### FIGURE 10-20: TYPICAL IN-CIRCUIT SERIAL PROGRAMMING CONNECTION



| BTFSS            | Bit Test f                                                               | i, Skip if S                                                                                                | Set                                       |                           |  |
|------------------|--------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-------------------------------------------|---------------------------|--|
| Syntax:          | [ <i>label</i> ] BTFSS f,b                                               |                                                                                                             |                                           |                           |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b < 7 \end{array}$         |                                                                                                             |                                           |                           |  |
| Operation:       | skip if (f <b>) = 1</b>                                                  |                                                                                                             |                                           |                           |  |
| Status Affected: | None                                                                     |                                                                                                             |                                           |                           |  |
| Encoding:        | 01                                                                       | 11bb                                                                                                        | bfff                                      | ffff                      |  |
| Description:     | instruction<br>If bit 'b' is '<br>fetched du<br>execution,<br>executed i | register 'f' is<br>is skipped.<br>1', then the<br>ring the cur<br>is discarde<br>nstead, ma<br>instruction. | next instru<br>rrent instru<br>d and a No | uction<br>Iction<br>DP is |  |
| Words:           | 1                                                                        |                                                                                                             |                                           |                           |  |
| Cycles:          | 1(2)                                                                     |                                                                                                             |                                           |                           |  |
| Example          | HERE<br>FALSE<br>TRUE                                                    |                                                                                                             | FLAG, 1<br>PROCESS_                       | _CODE                     |  |
|                  | Before In                                                                | struction                                                                                                   |                                           |                           |  |
|                  | After Inst                                                               | ruction<br>if FLAG<1><br>PC = a<br>if FLAG<1>                                                               | = 0,<br>address F                         |                           |  |

| CLRF             | Clear f                                                               |                    |             |           |
|------------------|-----------------------------------------------------------------------|--------------------|-------------|-----------|
| Syntax:          | [label] (                                                             | CLRF f             |             |           |
| Operands:        | $0 \le f \le 12$                                                      | 27                 |             |           |
| Operation:       | $\begin{array}{l} 00h \rightarrow (f) \\ 1 \rightarrow Z \end{array}$ |                    |             |           |
| Status Affected: | Z                                                                     |                    |             |           |
| Encoding:        | 0 0                                                                   | 0001               | lfff        | ffff      |
| Description:     | The conte and the Z                                                   | 0                  | ster 'f' ar | e cleared |
| Words:           | 1                                                                     |                    |             |           |
| Cycles:          | 1                                                                     |                    |             |           |
| Example          | CLRF                                                                  | FLAC               | G_REG       |           |
|                  | Before In                                                             | struction          |             |           |
|                  |                                                                       | FLAG_RE            | EG =        | 0x5A      |
|                  | After Inst                                                            | ruction<br>Flag Re | EG =        | 0x00      |
|                  |                                                                       | Z                  | =           | 1         |

| CALL             | Call Subroutine                                                                                                                                                                                                                               |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:          | [ <i>label</i> ] CALL k                                                                                                                                                                                                                       |  |  |
| Operands:        | $0 \leq k \leq 2047$                                                                                                                                                                                                                          |  |  |
| Operation:       | (PC)+ 1 $\rightarrow$ TOS,<br>k $\rightarrow$ PC<10:0>,<br>(PCLATH<4:3>) $\rightarrow$ PC<12:11>                                                                                                                                              |  |  |
| Status Affected: | None                                                                                                                                                                                                                                          |  |  |
| Encoding:        | 10 0kkk kkkk kkkk                                                                                                                                                                                                                             |  |  |
| Description:     | Call Subroutine. First, return address<br>(PC+1) is pushed onto the stack. The<br>eleven bit immediate address is<br>loaded into PC bits <10:0>. The upper<br>bits of the PC are loaded from<br>PCLATH. CALL is a two-cycle instruc-<br>tion. |  |  |
| Words:           | 1                                                                                                                                                                                                                                             |  |  |
| Cycles:          | 2                                                                                                                                                                                                                                             |  |  |
| Example          | HERE CALL THERE                                                                                                                                                                                                                               |  |  |
|                  | Before Instruction<br>PC = Address HERE<br>After Instruction<br>PC = Address THERE<br>TOS = Address HERE+1                                                                                                                                    |  |  |

| Clear W                                                               |                                                                                                               |                                                                                                                                                                  |                                                                                                                                                                                               |  |
|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [ label ]                                                             | CLRW                                                                                                          |                                                                                                                                                                  |                                                                                                                                                                                               |  |
| None                                                                  |                                                                                                               |                                                                                                                                                                  |                                                                                                                                                                                               |  |
| $\begin{array}{l} 00h \rightarrow (W) \\ 1 \rightarrow Z \end{array}$ |                                                                                                               |                                                                                                                                                                  |                                                                                                                                                                                               |  |
| Z                                                                     |                                                                                                               |                                                                                                                                                                  |                                                                                                                                                                                               |  |
| 0 0                                                                   | 0001                                                                                                          | 0000                                                                                                                                                             | 0011                                                                                                                                                                                          |  |
| W register is cleared. Zero bit (Z) is set.                           |                                                                                                               |                                                                                                                                                                  |                                                                                                                                                                                               |  |
| 1                                                                     |                                                                                                               |                                                                                                                                                                  |                                                                                                                                                                                               |  |
| 1                                                                     |                                                                                                               |                                                                                                                                                                  |                                                                                                                                                                                               |  |
| CLRW                                                                  |                                                                                                               |                                                                                                                                                                  |                                                                                                                                                                                               |  |
| Before Instruction                                                    |                                                                                                               |                                                                                                                                                                  |                                                                                                                                                                                               |  |
| After Inst                                                            | ruction<br>W =                                                                                                | 0x5A<br>0x00<br>1                                                                                                                                                |                                                                                                                                                                                               |  |
|                                                                       | $[label]$ None $00h \rightarrow (V \\ 1 \rightarrow Z$ $Z$ $00$ W register set. 1 $CLRW$ Before In After Inst | $[label] CLRW$ None $00h \rightarrow (W)$ $1 \rightarrow Z$ $Z$ $00 0001$ W register is cleared set. $1$ $CLRW$ Before Instruction $W =$ After Instruction $W =$ | $[label] CLRW$ None $00h \rightarrow (W)$ $1 \rightarrow Z$ Z $00  0001  0000$ W register is cleared. Zero bit set. $1$ $1$ $CLRW$ Before Instruction $W = 0x5A$ After Instruction $W = 0x00$ |  |

 $\odot$  1998-2013 Microchip Technology Inc.

| NOP              | No Operation |      |      |      |  |
|------------------|--------------|------|------|------|--|
| Syntax:          | [ label ]    | NOP  |      |      |  |
| Operands:        | None         |      |      |      |  |
| Operation:       | No operation |      |      |      |  |
| Status Affected: | None         |      |      |      |  |
| Encoding:        | 0 0          | 0000 | 0xx0 | 0000 |  |
| Description:     | No operati   | on.  |      |      |  |
| Words:           | 1            |      |      |      |  |
| Cycles:          | 1            |      |      |      |  |
| Example          | NOP          |      |      |      |  |

| RETFIE           | Return from Interrupt                                                                                                                                                                                             |                        |          |      |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------|------|--|
| Syntax:          | [ label ]                                                                                                                                                                                                         | RETFIE                 |          |      |  |
| Operands:        | None                                                                                                                                                                                                              |                        |          |      |  |
| Operation:       | $TOS \rightarrow PC,$<br>1 $\rightarrow GIE$                                                                                                                                                                      |                        |          |      |  |
| Status Affected: | None                                                                                                                                                                                                              |                        |          |      |  |
| Encoding:        | 00                                                                                                                                                                                                                | 0000                   | 0000     | 1001 |  |
| Description:     | Return from Interrupt. Stack is POPed<br>and Top of Stack (TOS) is loaded in<br>the PC. Interrupts are enabled by<br>setting Global Interrupt Enable bit,<br>GIE (INTCON<7>). This is a two-cycle<br>instruction. |                        |          |      |  |
| Words:           | 1                                                                                                                                                                                                                 |                        |          |      |  |
| Cycles:          | 2                                                                                                                                                                                                                 |                        |          |      |  |
| Example          | RETFIE                                                                                                                                                                                                            |                        |          |      |  |
|                  |                                                                                                                                                                                                                   | rrupt<br>PC =<br>GIE = | TOS<br>1 |      |  |

| OPTION                 | Load Opti                                                                                                                                                                                                                                        | ion Reg | jister |      |  |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------|------|--|
| Syntax:                | [label] (                                                                                                                                                                                                                                        | OPTION  | 1      |      |  |
| Operands:              | None                                                                                                                                                                                                                                             |         |        |      |  |
| Operation:             | $(W) \rightarrow OP$                                                                                                                                                                                                                             | TION    |        |      |  |
| Status Affected:       | None                                                                                                                                                                                                                                             |         |        |      |  |
| Encoding:              | 0.0 0                                                                                                                                                                                                                                            | 0000    | 0110   | 0010 |  |
| Description:<br>Words: | The contents of the W register are<br>loaded in the OPTION register. This<br>instruction is supported for code<br>compatibility with PIC16C5X products.<br>Since OPTION is a readable/writable<br>register, the user can directly<br>address it. |         |        |      |  |
| Cycles:                | 1                                                                                                                                                                                                                                                |         |        |      |  |
| Example                |                                                                                                                                                                                                                                                  |         |        |      |  |
|                        | To maintain upward compatibility<br>with future PIC <sup>®</sup> MCU products, do<br>not use this instruction.                                                                                                                                   |         |        |      |  |

| RETLW            | Return with Literal in W                                                                                                                                                            |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] RETLW k                                                                                                                                                            |
| Operands:        | $0 \le k \le 255$                                                                                                                                                                   |
| Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow PC$                                                                                                                                        |
| Status Affected: | None                                                                                                                                                                                |
| Encoding:        | 11 01xx kkkk kkkk                                                                                                                                                                   |
| Description:     | The W register is loaded with the eight<br>bit literal 'k'. The program counter is<br>loaded from the top of the stack (the<br>return address). This is a two-cycle<br>instruction. |
| Words:           | 1                                                                                                                                                                                   |
| Cycles:          | 2                                                                                                                                                                                   |
| Example          | CALL TABLE ;W contains table<br>;offset value<br>• ;W now has table<br>value                                                                                                        |
| TABLE            | ADDWF PC ;W = offset<br>RETLW k1 ;Begin table<br>RETLW k2 ;<br>•<br>RETLW kn ; End of table                                                                                         |
|                  | Before Instruction                                                                                                                                                                  |
|                  | W = 0x07<br>After Instruction                                                                                                                                                       |
|                  | W = value of k8                                                                                                                                                                     |

# 12.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 Assembler
  - MPLAB-C17 and MPLAB-C18 C Compilers
  - MPLINK/MPLIB Linker/Librarian
- Simulators
  - MPLAB-SIM Software Simulator
- Emulators
  - MPLAB-ICE Real-Time In-Circuit Emulator
  - PICMASTER<sup>®</sup>/PICMASTER-CE In-Circuit Emulator
  - ICEPIC™
- In-Circuit Debugger
  - MPLAB-ICD for PIC16F877
- Device Programmers
  - PRO MATE<sup>®</sup> II Universal Programmer
  - PICSTART<sup>®</sup> Plus Entry-Level Prototype Programmer
- Low-Cost Demonstration Boards
  - SIMICE
  - PICDEM-1
  - PICDEM-2
  - PICDEM-3
  - PICDEM-17
  - SEEVAL®
  - KEELOQ<sup>®</sup>

#### 12.1 <u>MPLAB Integrated Development</u> <u>Environment Software</u>

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

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

MPLAB allows you to:

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

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

#### 12.2 MPASM Assembler

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

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

MPASM features include:

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

#### 12.3 <u>MPLAB-C17 and MPLAB-C18</u> <u>C Compilers</u>

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

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

#### 12.4 MPLINK/MPLIB Linker/Librarian

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

# **13.0 ELECTRICAL SPECIFICATIONS**

### Absolute Maximum Ratings †

| Ambient Temperature under bias                                                                                                     | 40° to +125°C                                      |
|------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| Storage Temperature                                                                                                                | 65° to +150°C                                      |
| Voltage on any pin with respect to Vss (except VDD and MCLR)                                                                       |                                                    |
| Voltage on VDD with respect to VSS                                                                                                 | 0 to +7.0V                                         |
| Voltage on RA4 with respect to Vss                                                                                                 | 8.5V                                               |
| Voltage on MCLR with respect to Vss (Note 2)                                                                                       | 0 to +14V                                          |
| Voltage on RA4 with respect to Vss                                                                                                 |                                                    |
| Total power Dissipation (Note 1)                                                                                                   | 1.0W                                               |
| Maximum Current out of Vss pin                                                                                                     |                                                    |
| Maximum Current into VDD pin                                                                                                       | 250 mA                                             |
| Input Clamp Current, Iк (VI <0 or VI> VDD)                                                                                         | ±20 mA                                             |
| Output Clamp Current, IOK (Vo <0 or Vo>VDD)                                                                                        | ±20 mA                                             |
| Maximum Output Current sunk by any I/O pin                                                                                         | 25 mA                                              |
| Maximum Output Current sourced by any I/O pin                                                                                      | 25 mA                                              |
| Maximum Current sunk by PORTA and PORTB                                                                                            | 200 mA                                             |
| Maximum Current sourced by PORTA and PORTB                                                                                         | 200 mA                                             |
| <b>Note 1:</b> Power dissipation is calculated as follows: PDIS = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD-VOH) = 100 + $\sum$ IOH} | $x \text{ IOH} + \sum (\text{VOI } x \text{ IOL})$ |

2: Voltage spikes below Vss at the MCLR pin, inducing currents greater than 80 mA, may cause latch-up. Thus, a series resistor of 50-100<sup>3</sup>/<sub>4</sub> should be used when applying a "low" level to the MCLR pin rather than pulling this pin directly to Vss.

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





**2:** The maximum rated speed of the part limits the permissible combinations of voltage and frequency. Please reference the Product Identification System section for the maximum rated speed of the parts.





#### 13.6 EEPROM Timing





| Parameter                                           | Symbol  | STANE<br>MOI |      | Vcc = 4.5<br>FAST N |      | Units  | Remarks                                                             |
|-----------------------------------------------------|---------|--------------|------|---------------------|------|--------|---------------------------------------------------------------------|
|                                                     |         | Min.         | Max. | Min.                | Max. |        |                                                                     |
| Clock frequency                                     | FCLK    |              | 100  |                     | 400  | kHz    |                                                                     |
| Clock high time                                     | THIGH   | 4000         | _    | 600                 | _    | ns     |                                                                     |
| Clock low time                                      | TLOW    | 4700         | _    | 1300                | —    | ns     |                                                                     |
| SDA and SCL rise time                               | TR      |              | 1000 | _                   | 300  | ns     | (Note 1)                                                            |
| SDA and SCL fall time                               | TF      | _            | 300  | _                   | 300  | ns     | (Note 1)                                                            |
| START condition hold time                           | THD:STA | 4000         | —    | 600                 | —    | ns     | After this period the first clock pulse is generated                |
| START condition setup time                          | TSU:STA | 4700         | —    | 600                 | —    | ns     | Only relevant for repeated START condition                          |
| Data input hold time                                | THD:DAT | 0            |      | 0                   |      | ns     | (Note 2)                                                            |
| Data input setup time                               | TSU:DAT | 250          | _    | 100                 | _    | ns     |                                                                     |
| STOP condition setup time                           | Tsu:sto | 4000         | _    | 600                 | _    | ns     |                                                                     |
| Output valid from clock                             | TAA     |              | 3500 | —                   | 900  | ns     | (Note 2)                                                            |
| Bus free time                                       | TBUF    | 4700         | _    | 1300                | _    | ns     | Time the bus must be free<br>before a new transmission<br>can start |
| Output fall time from VIH<br>minimum to VIL maximum | TOF     | _            | 250  | 20 + 0.1<br>CB      | 250  | ns     | (Note 1), $CB \le 100 \text{ pF}$                                   |
| Input filter spike suppression (SDA and SCL pins)   | TSP     | _            | 50   | _                   | 50   | ns     | (Note 3)                                                            |
| Write cycle time                                    | Twr     | _            | 10   |                     | 10   | ms     | Byte or Page mode                                                   |
| Endurance                                           |         | 10M<br>1M    | —    | 10M<br>1M           | _    | cycles | 25°C, Vcc = 5.0V, Block<br>Mode (Note 4)                            |

#### TABLE 13-7: AC CHARACTERISTICS

**Note 1:** Not 100% tested. CB = total capacitance of one bus line in pF.

2: As a transmitter, the device must provide an internal minimum delay time to bridge the undefined region (minimum 300 ns) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.

3: The combined TSP and VHYS specifications are due to new Schmitt trigger inputs which provide improved noise spike suppression. This eliminates the need for a TI specification for standard operation.

4: This parameter is not tested but guaranteed by characterization. For endurance estimates in a specific application, please consult the Total Endurance Model which can be obtained on our website.

NOTES:

## 14.0 PACKAGING INFORMATION

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

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



|                            | Units     |      | INCHES* |      |       | <b>1ILLIMETERS</b> | METERS |  |
|----------------------------|-----------|------|---------|------|-------|--------------------|--------|--|
| Dimensio                   | on Limits | MIN  | NOM     | MAX  | MIN   | NOM                | MAX    |  |
| Number of Pins             | n         |      | 18      |      |       | 18                 |        |  |
| Pitch                      | р         |      | .100    |      |       | 2.54               |        |  |
| Top to Seating Plane       | Α         | .170 | .183    | .195 | 4.32  | 4.64               | 4.95   |  |
| Ceramic Package Height     | A2        | .155 | .160    | .165 | 3.94  | 4.06               | 4.19   |  |
| Standoff                   | A1        | .015 | .023    | .030 | 0.38  | 0.57               | 0.76   |  |
| Shoulder to Shoulder Width | 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         | .880 | .900    | .920 | 22.35 | 22.86              | 23.37  |  |
| Tip to Seating Plane       | L         | .125 | .138    | .150 | 3.18  | 3.49               | 3.81   |  |
| Lead Thickness             | С         | .008 | .010    | .012 | 0.20  | 0.25               | 0.30   |  |
| Upper Lead Width           | B1        | .050 | .055    | .060 | 1.27  | 1.40               | 1.52   |  |
| Lower Lead Width           | В         | .016 | .019    | .021 | 0.41  | 0.47               | 0.53   |  |
| Overall Row Spacing        | eB        | .345 | .385    | .425 | 8.76  | 9.78               | 10.80  |  |
| Window Width               | W1        | .130 | .140    | .150 | 3.30  | 3.56               | 3.81   |  |
| Window Length              | W2        | .190 | .200    | .210 | 4.83  | 5.08               | 5.33   |  |

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

## 20-Lead Plastic Shrink Small Outline (SS) - 209 mil, 5.30 mm (SSOP)

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



| Units                    |        | INCHES* |      |      | N    | IILLIMETERS | 5      |
|--------------------------|--------|---------|------|------|------|-------------|--------|
| Dimensior                | Limits | MIN     | NOM  | MAX  | MIN  | NOM         | MAX    |
| Number of Pins           | n      |         | 20   |      |      | 20          |        |
| Pitch                    | р      |         | .026 |      |      | 0.66        |        |
| Overall Height           | A      | .068    | .073 | .078 | 1.73 | 1.85        | 1.98   |
| Molded Package Thickness | A2     | .064    | .068 | .072 | 1.63 | 1.73        | 1.83   |
| Standoff                 | A1     | .002    | .006 | .010 | 0.05 | 0.15        | 0.25   |
| Overall Width            | E      | .299    | .309 | .322 | 7.59 | 7.85        | 8.18   |
| Molded Package Width     | E1     | .201    | .207 | .212 | 5.11 | 5.25        | 5.38   |
| Overall Length           | D      | .278    | .284 | .289 | 7.06 | 7.20        | 7.34   |
| Foot Length              | L      | .022    | .030 | .037 | 0.56 | 0.75        | 0.94   |
| Lead Thickness           | С      | .004    | .007 | .010 | 0.10 | 0.18        | 0.25   |
| Foot Angle               | ¢      | 0       | 4    | 8    | 0.00 | 101.60      | 203.20 |
| Lead Width               | В      | .010    | .013 | .015 | 0.25 | 0.32        | 0.38   |
| Mold Draft Angle Top     | α      | 0       | 5    | 10   | 0    | 5           | 10     |
| Mold Draft Angle Bottom  | β      | 0       | 5    | 10   | 0    | 5           | 10     |

\*Controlling Parameter

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: MO-150

Drawing No. C04-072

NOTES:

# PIC16XXXXX FAMILY

## READER RESPONSE

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

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

| TO:<br>RE: | ······································                 | Total Pages Sent                          |
|------------|--------------------------------------------------------|-------------------------------------------|
|            | n: Name                                                |                                           |
| FIU        |                                                        |                                           |
|            | Company<br>Address                                     |                                           |
|            | City / State / ZIP / Country                           |                                           |
|            | Telephone: ()                                          | FAX: ()                                   |
| Арр        | lication (optional):                                   |                                           |
| Wo         | uld you like a reply?YN                                |                                           |
|            | ice: PIC16xxxxxx family                                | Literature Number: DS40182D               |
| Que        | estions:                                               |                                           |
| 1.         | What are the best features of this document?           |                                           |
| _          |                                                        |                                           |
| 2.         | How does this document meet your hardware and s        | oftware development needs?                |
|            |                                                        |                                           |
| 3.         | Do you find the organization of this document easy t   | to follow? If not, why?                   |
|            |                                                        |                                           |
| 4.         | What additions to the document do you think would      | enhance the structure and subject?        |
|            |                                                        |                                           |
| 5.         | What deletions from the document could be made w       | vithout affecting the overall usefulness? |
|            |                                                        |                                           |
| 6.         | Is there any incorrect or misleading information (what | at and where)?                            |
|            |                                                        |                                           |
| 7.         | How would you improve this document?                   |                                           |
|            |                                                        |                                           |

## PIC16CE62X PRODUCT IDENTIFICATION SYSTEM

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

| PART NOXX X /XX XXX |                                                                                                                                                                                                                            |                                                                                            |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| Pattern:            | 3-Digit Pattern Code for QTP (blank otherwise)                                                                                                                                                                             |                                                                                            |
| Package:            | P = PDIP<br>SO = SOIC (Gull Wing, 300 mil body)<br>SS = SSOP (209 mil)                                                                                                                                                     |                                                                                            |
|                     | JW* = Windowed CERDIP Example<br>a) PIC10                                                                                                                                                                                  | 6CE623-04/P301 =                                                                           |
| Range:              | $ \begin{array}{rcl} & = & -40^{\circ} {\rm C} \ {\rm to} \ +85^{\circ} {\rm C} & & {\rm age, 4} \\ {\rm E} & = & -40^{\circ} {\rm C} \ {\rm to} \ +125^{\circ} {\rm C} & & {\rm D} \\ {\rm b} & {\rm PIC16} \end{array} $ | nercial temp., PDIP pack-<br>4 MHz, normal VDD limits,<br>pattern #301.<br>6CE623-04I/SO = |
| Frequency<br>Range: |                                                                                                                                                                                                                            | trial temp., SOIC pack-<br>4MHz, industrial VDD lim-                                       |
| Device:             | PIC16CE62X :VDD range 3.0V to 5.5V<br>PIC16CE62XT:VDD range 3.0V to 5.5V (Tape and R                                                                                                                                       | eel)                                                                                       |
|                     |                                                                                                                                                                                                                            |                                                                                            |
|                     |                                                                                                                                                                                                                            |                                                                                            |
|                     |                                                                                                                                                                                                                            |                                                                                            |

\* 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)