

Welcome to E-XFL.COM

### What is "Embedded - Microcontrollers"?

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

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

### Details

E·XFI

| Details                    |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Active                                                                      |
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 4MHz                                                                        |
| Connectivity               | -                                                                           |
| Peripherals                | POR, WDT                                                                    |
| Number of I/O              | 5                                                                           |
| Program Memory Size        | 768B (512 x 12)                                                             |
| Program Memory Type        | OTP                                                                         |
| EEPROM Size                | 16 x 8                                                                      |
| RAM Size                   | 25 x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                                                   |
| Data Converters            | -                                                                           |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 8-SOIC (0.209", 5.30mm Width)                                               |
| Supplier Device Package    | 8-SOIJ                                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic12ce518-04i-sm |
|                            |                                                                             |

Email: info@E-XFL.COM

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

### Pin Diagram - PIC12C508/509



### Pin Diagram - PIC12C508A/509A, PIC12CE518/519



### Pin Diagram - PIC12CR509A



### **Device Differences**

| Device      | Voltage<br>Range | Oscillator | Oscillator<br>Calibration <sup>2</sup><br>(Bits) | Process<br>Technology<br>(Microns) |
|-------------|------------------|------------|--------------------------------------------------|------------------------------------|
| PIC12C508A  | 3.0-5.5          | See Note 1 | 6                                                | 0.7                                |
| PIC12LC508A | 2.5-5.5          | See Note 1 | 6                                                | 0.7                                |
| PIC12C508   | 2.5-5.5          | See Note 1 | 4                                                | 0.9                                |
| PIC12C509A  | 3.0-5.5          | See Note 1 | 6                                                | 0.7                                |
| PIC12LC509A | 2.5-5.5          | See Note 1 | 6                                                | 0.7                                |
| PIC12C509   | 2.5-5.5          | See Note 1 | 4                                                | 0.9                                |
| PIC12CR509A | 2.5-5.5          | See Note 1 | 6                                                | 0.7                                |
| PIC12CE518  | 3.0-5.5          | -          | 6                                                | 0.7                                |
| PIC12LCE518 | 2.5-5.5          | -          | 6                                                | 0.7                                |
| PIC12CE519  | 3.0-5.5          | -          | 6                                                | 0.7                                |
| PIC12LCE519 | 2.5-5.5          | -          | 6                                                | 0.7                                |

**Note 1:** If you change from the PIC12C50X to the PIC12C50XA or to the PIC12CR50XA, please verify oscillator characteristics in your application.

Note 2: See Section 7.2.5 for OSCCAL implementation differences.

|             |                                               | PIC12C508(A)           | PIC12C509(A)           | PIC12CR509A        | PIC12CE518             | PIC12CE519             | PIC12C671              | PIC12C672              | PIC12CE673       | PIC12CE674       |
|-------------|-----------------------------------------------|------------------------|------------------------|--------------------|------------------------|------------------------|------------------------|------------------------|------------------|------------------|
| Clock       | Maximum<br>Frequency<br>of Operation<br>(MHz) | 4                      | 4                      | 4                  | 4                      | 4                      | 10                     | 10                     | 10               | 10               |
| Memory      | EPROM<br>Program<br>Memory                    | 512 x 12               | 1024 x 12              | 1024 x 12<br>(ROM) | 512 x 12               | 1024 x 12              | 1024 x 14              | 2048 x 14              | 1024 x 14        | 2048 x 14        |
| wemory      | RAM Data<br>Memory<br>(bytes)                 | 25                     | 41                     | 41                 | 25                     | 41                     | 128                    | 128                    | 128              | 128              |
|             | EEPROM<br>Data Memory<br>(bytes)              | —                      | -                      | —                  | 16                     | 16                     | —                      | —                      | 16               | 16               |
| Peripherals | Timer<br>Module(s)                            | TMR0                   | TMR0                   | TMR0               | TMR0                   | TMR0                   | TMR0                   | TMR0                   | TMR0             | TMR0             |
|             | A/D Con-<br>verter (8-bit)<br>Channels        | —                      | _                      | —                  | —                      | —                      | 4                      | 4                      | 4                | 4                |
|             | Wake-up<br>from SLEEP<br>on pin<br>change     | Yes                    | Yes                    | Yes                | Yes                    | Yes                    | Yes                    | Yes                    | Yes              | Yes              |
|             | Interrupt<br>Sources                          | —                      | -                      | _                  |                        |                        | 4                      | 4                      | 4                | 4                |
| Features    | I/O Pins                                      | 5                      | 5                      | 5                  | 5                      | 5                      | 5                      | 5                      | 5                | 5                |
|             | Input Pins                                    | 1                      | 1                      | 1                  | 1                      | 1                      | 1                      | 1                      | 1                | 1                |
|             | Internal<br>Pull-ups                          | Yes                    | Yes                    | Yes                | Yes                    | Yes                    | Yes                    | Yes                    | Yes              | Yes              |
|             | In-Circuit<br>Serial<br>Programming           | Yes                    | Yes                    | —                  | Yes                    | Yes                    | Yes                    | Yes                    | Yes              | Yes              |
|             | Number of<br>Instructions                     | 33                     | 33                     | 33                 | 33                     | 33                     | 35                     | 35                     | 35               | 35               |
|             | Packages                                      | 8-pin DIP,<br>JW, SOIC | 8-pin DIP,<br>JW, SOIC | 8-pin DIP,<br>SOIC | 8-pin DIP,<br>JW, SOIC | 8-pin DIP,<br>JW, SOIC | 8-pin DIP,<br>JW, SOIC | 8-pin DIP,<br>JW, SOIC | 8-pin DIP,<br>JW | 8-pin DIP,<br>JW |

### TABLE 1-1: PIC12CXXX & PIC12CEXXX FAMILY OF DEVICES

All PIC12CXXX & PIC12CEXXX devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability.

All PIC12CXXX & PIC12CEXXX devices use serial programming with data pin GP0 and clock pin GP1.

NOTES:

### 3.0 ARCHITECTURAL OVERVIEW

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

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

|             | Memory           |                |             |                |  |
|-------------|------------------|----------------|-------------|----------------|--|
| Device      | EPROM<br>Program | ROM<br>Program | RAM<br>Data | EEPROM<br>Data |  |
| PIC12C508   | 512 x 12         |                | 25          |                |  |
| PIC12C509   | 1024 x 12        |                | 41          |                |  |
| PIC12C508A  | 512 x 12         |                | 25          |                |  |
| PIC12C509A  | 1024 x 12        |                | 41          |                |  |
| PIC12CR509A |                  | 1024 x 12      | 41          |                |  |
| PIC12CE518  | 512 x 12         |                | 25 x 8      | 16 x 8         |  |
| PIC12CE519  | 1024 x 12        |                | 41 x 8      | 16 x 8         |  |

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

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

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

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

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

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

### 3.1 Clocking Scheme/Instruction Cycle

The clock input (OSC1/CLKIN pin) is internally divided by four to generate four non-overlapping quadrature clocks namely Q1, Q2, Q3 and Q4. Internally, the program counter is incremented every Q1, and the instruction is fetched from program memory and latched into instruction register in Q4. It is decoded and executed during the following Q1 through Q4. The clocks and instruction execution flow is shown in Figure 3-2 and Example 3-1.

### 3.2 Instruction Flow/Pipelining

An Instruction Cycle consists of four Q cycles (Q1, Q2, Q3 and Q4). The instruction fetch and execute are pipelined such that fetch takes one instruction cycle while decode and execute takes another instruction cycle. However, due to the pipelining, each instruction effectively executes in one cycle. If an instruction causes the program counter to change (e.g., GOTO) then two cycles are required to complete the instruction (Example 3-1).

A fetch cycle begins with the program counter (PC) incrementing in Q1.

In the execution cycle, the fetched instruction is latched into the Instruction Register (IR) in cycle Q1. This instruction is then decoded and executed during the Q2, Q3, and Q4 cycles. Data memory is read during Q2 (operand read) and written during Q4 (destination write).

### FIGURE 3-2: CLOCK/INSTRUCTION CYCLE



### EXAMPLE 3-1: INSTRUCTION PIPELINE FLOW



### 4.2 Data Memory Organization

Data memory is composed of registers, or bytes of RAM. Therefore, data memory for a device is specified by its register file. The register file is divided into two functional groups: special function registers and general purpose registers.

The special function registers include the TMR0 register, the Program Counter (PC), the Status Register, the I/O registers (ports), and the File Select Register (FSR). In addition, special purpose registers are used to control the I/O port configuration and prescaler options.

The general purpose registers are used for data and control information under command of the instructions.

For the PIC12C508, PIC12C508A and PIC12CE518, the register file is composed of 7 special function registers and 25 general purpose registers (Figure 4-2).

For the PIC12C509, PIC12C509A, PIC12CR509A, and PIC12CE519 the register file is composed of 7 special function registers, 25 general purpose registers, and 16 general purpose registers that may be addressed using a banking scheme (Figure 4-3).

### 4.2.1 GENERAL PURPOSE REGISTER FILE

The general purpose register file is accessed either directly or indirectly through the file select register FSR (Section 4.8).

#### FIGURE 4-2: PIC12C508, PIC12C508A AND PIC12CE518 REGISTER FILE MAP



| FSR<6:5>-    | •    | 00                  | 01                       |
|--------------|------|---------------------|--------------------------|
| File Address | · ·  |                     | 1                        |
| 00h          |      | INDF <sup>(1)</sup> | 20h                      |
| <b>∲</b> 01h |      | TMR0                |                          |
| 02h          |      | PCL                 | _                        |
| 03h          |      | STATUS              | Addresses map<br>back to |
| 04h          |      | FSR                 | addresses                |
| 05h          |      | OSCCAL              | in Bank 0.               |
| 06h          |      | GPIO                |                          |
| 07h          |      |                     | 1                        |
|              |      | General<br>Purpose  |                          |
|              |      | Registers           |                          |
| 0Fh          |      | 0                   | 2Fh                      |
|              | 10h  |                     | 30h                      |
|              |      | General             | General                  |
|              |      | Purpose             | Purpose                  |
|              |      | Registers           | Registers                |
|              | 1Fh  |                     | 3Fh                      |
|              |      | Bank 0              | Bank 1                   |
| Note 1       | : No | t a physical regi   | ster. See Section 4.8    |
|              |      |                     |                          |

### FIGURE 4-3: PIC12C509, PIC12C509A, PIC12CR509A AND PIC12CE519 REGISTER FILE MAP

### 8.2 Oscillator Configurations

#### 8.2.1 OSCILLATOR TYPES

The PIC12C5XX can be operated in four different oscillator modes. The user can program two configuration bits (FOSC1:FOSC0) to select one of these four modes:

- LP: Low Power Crystal
- XT: Crystal/Resonator
- INTRC: Internal 4 MHz Oscillator
- EXTRC: External Resistor/Capacitor

### 8.2.2 CRYSTAL OSCILLATOR / CERAMIC RESONATORS

In XT or LP modes, a crystal or ceramic resonator is connected to the GP5/OSC1/CLKIN and GP4/OSC2 pins to establish oscillation (Figure 8-2). The PIC12C5XX oscillator design requires the use of a parallel cut crystal. Use of a series cut crystal may give a frequency out of the crystal manufacturers specifications. When in XT or LP modes, the device can have an external clock source drive the GP5/ OSC1/CLKIN pin (Figure 8-3).

### FIGURE 8-2: CRYSTAL OPERATION (OR CERAMIC RESONATOR) (XT OR LP OSC CONFIGURATION)



### FIGURE 8-3: EXTERNAL CLOCK INPUT OPERATION (XT OR LP OSC CONFIGURATION)



#### TABLE 8-1: CAPACITOR SELECTION FOR CERAMIC RESONATORS - PIC12C5XX

| Osc  | Resonator | Cap. Range | Cap. Range |
|------|-----------|------------|------------|
| Type | Freq      | C1         | C2         |
| XT   | 4.0 MHz   | 30 pF      | 30 pF      |

These values are for design guidance only. Since each resonator has its own characteristics, the user should consult the resonator manufacturer for appropriate values of external components.

### TABLE 8-2: CAPACITOR SELECTION FOR CRYSTAL OSCILLATOR -PIC12C5XX

| Osc<br>Type | Resonator<br>Freq     | Cap.Range<br>C1 | Cap. Range<br>C2 |
|-------------|-----------------------|-----------------|------------------|
| LP          | 32 kHz <sup>(1)</sup> | 15 pF           | 15 pF            |
| XT          | 200 kHz               | 47-68 pF        | 47-68 pF         |
|             | 1 MHz                 | 15 pF           | 15 pF            |
|             | 4 MHz                 | 15 pF           | 15 pF            |

Note 1: For VDD > 4.5V, C1 = C2  $\approx$  30 pF is recommended.

These values are for design guidance only. Rs may be required to avoid overdriving crystals with low drive level specification. Since each crystal has its own characteristics, the user should consult the crystal manufacturer for appropriate values of external components.

| ADDWF                                                           | Add W and f                                                                                                                                                       |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                                         | [label] ADDWF f,d                                                                                                                                                 |
| Operands:                                                       | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \left[ 0,1 \right] \end{array}$                                                                                       |
| Operation:                                                      | (W) + (f) $\rightarrow$ (dest)                                                                                                                                    |
| Status Affected:                                                | C, DC, Z                                                                                                                                                          |
| Encoding:                                                       | 0001 11df ffff                                                                                                                                                    |
| Description:                                                    | Add the contents of the W register and register 'f'. If 'd' is 0 the result is stored in the W register. If 'd' is '1' the result is stored back in register 'f'. |
| Words:                                                          | 1                                                                                                                                                                 |
| Cycles:                                                         | 1                                                                                                                                                                 |
| Example:                                                        | ADDWF FSR, 0                                                                                                                                                      |
| Before Instru<br>W =<br>FSR =<br>After Instruct<br>W =<br>FSR = | 0x17<br>0xC2<br>tion<br>0xD9                                                                                                                                      |

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

| ANDLW                 | And literal with W                                                                                                      |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------|
| Syntax:               | [label] ANDLW k                                                                                                         |
| Operands:             | $0 \le k \le 255$                                                                                                       |
| Operation:            | (W).AND. (k) $\rightarrow$ (W)                                                                                          |
| Status Affected:      | Z                                                                                                                       |
| Encoding:             | 1110 kkkk kkkk                                                                                                          |
| Description:          | The contents of the W register are<br>AND'ed with the eight-bit literal 'k'. The<br>result is placed in the W register. |
| Words:                | 1                                                                                                                       |
| Cycles:               | 1                                                                                                                       |
| Example:              | ANDLW 0x5F                                                                                                              |
| Before Instru<br>W =  | iction<br>0xA3                                                                                                          |
| After Instruct<br>W = | tion<br>0x03                                                                                                            |

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

| CALL                  | Subroutine Call                                                                                                                                                                                                                                |  |  |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:               | [ <i>label</i> ] CALL k                                                                                                                                                                                                                        |  |  |
| Operands:             | $0 \le k \le 255$                                                                                                                                                                                                                              |  |  |
| Operation:            | $\begin{array}{l} (\text{PC}) + 1 \rightarrow \text{Top of Stack}; \\ k \rightarrow \text{PC<7:0>}; \\ (\text{STATUS<6:5>}) \rightarrow \text{PC<10:9>}; \\ 0 \rightarrow \text{PC<8>} \end{array}$                                            |  |  |
| Status Affected:      | None                                                                                                                                                                                                                                           |  |  |
| Encoding:             | 1001 kkkk kkkk                                                                                                                                                                                                                                 |  |  |
| Description:          | Subroutine call. First, return address (PC+1) is pushed onto the stack. The eight bit immediate address is loaded into PC bits <7:0>. The upper bits PC<10:9> are loaded from STA-TUS<6:5>, PC<8> is cleared. CALL is a two cycle instruction. |  |  |
| Words:                | 1                                                                                                                                                                                                                                              |  |  |
| Cycles:               | 2                                                                                                                                                                                                                                              |  |  |
| Example:              | HERE CALL THERE                                                                                                                                                                                                                                |  |  |
| Before Instru<br>PC = |                                                                                                                                                                                                                                                |  |  |
|                       | tion<br>address (THERE)<br>address (HERE + 1)                                                                                                                                                                                                  |  |  |

### CLRF

| Syntax:                        | [label] CLRF f                                                         |           |   |  |  |  |  |  |
|--------------------------------|------------------------------------------------------------------------|-----------|---|--|--|--|--|--|
| Operands:                      | $0 \le f \le 31$                                                       |           |   |  |  |  |  |  |
| Operation:                     | $\begin{array}{l} 00h \rightarrow (f); \\ 1 \rightarrow Z \end{array}$ |           |   |  |  |  |  |  |
| Status Affected: Z             |                                                                        |           |   |  |  |  |  |  |
| Encoding: 0000 011f ffff       |                                                                        |           |   |  |  |  |  |  |
| Description:                   | The contents of register 'f' are cleared and the Z bit is set.         |           |   |  |  |  |  |  |
| Words:                         | 1                                                                      |           |   |  |  |  |  |  |
| Cycles:                        | 1                                                                      |           |   |  |  |  |  |  |
| Example:                       | CLRF                                                                   | FLAG_REC  | 3 |  |  |  |  |  |
| Before Instru<br>FLAG_RE       |                                                                        | 0x5A      |   |  |  |  |  |  |
| After Instruct<br>FLAG_RE<br>Z |                                                                        | 0x00<br>1 |   |  |  |  |  |  |

Clear f

| CLRW                                                                                                     | Clear W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:                                                                                                  | [label] CLRW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| Operands:                                                                                                | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| Operation:                                                                                               | $\begin{array}{l} 00h \rightarrow (W); \\ 1 \rightarrow Z \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| Status Affected:                                                                                         | Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| Encoding:                                                                                                | 0000 0100 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Description:                                                                                             | The W register is cleared. Zero bit (Z) is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| Words:                                                                                                   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| Cycles:                                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| Example:                                                                                                 | CLRW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| Before Instru<br>W =                                                                                     | uction<br>0x5A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| After Instruct<br>W =<br>Z =                                                                             | tion<br>0x00<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| CLRWDT                                                                                                   | Clear Watchdog Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| CLRWDT<br>Syntax:                                                                                        | Clear Watchdog Timer<br>[label] CLRWDT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| -                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| Syntax:                                                                                                  | [label] CLRWDT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Syntax:<br>Operands:                                                                                     | [ <i>label</i> ] CLRWDT<br>None<br>$00h \rightarrow WDT;$<br>$0 \rightarrow WDT$ prescaler (if assigned);<br>$1 \rightarrow \overline{TO};$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| Syntax:<br>Operands:<br>Operation:                                                                       | [ <i>label</i> ] CLRWDT<br>None<br>$00h \rightarrow WDT;$<br>$0 \rightarrow WDT$ prescaler (if assigned);<br>$1 \rightarrow \overline{TO};$<br>$1 \rightarrow \overline{PD}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:                                                   | [ <i>label</i> ] CLRWDT<br>None<br>$00h \rightarrow WDT;$<br>$0 \rightarrow WDT$ prescaler (if assigned);<br>$1 \rightarrow \overline{TO};$<br>$1 \rightarrow \overline{PD}$<br>$\overline{TO}, \overline{PD}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:                                      | $ \begin{array}{l lllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                      | $ \begin{array}{l lllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:            | $ \begin{array}{l lllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles: | [ <i>label</i> ] CLRWDT<br>None<br>$O0h \rightarrow WDT;$<br>$0 \rightarrow WDT prescaler (if assigned);$<br>$1 \rightarrow \overline{TO};$<br>$1 \rightarrow \overline{PD}$<br>$\overline{TO}, \overline{PD}$<br>0000  0000  0100<br>The CLRWDT instruction resets the<br>WDT. It also resets the prescaler, if the<br>prescaler is assigned to the WDT and<br>not Timer0. Status bits $\overline{TO}$ and $\overline{PD}$ are<br>set.<br>1<br>1<br>CLRWDT<br>Intercomplete the state of the |  |  |  |  |  |  |

| OPTION Load OPTION Register        |                          |      |      |          |  |  |  |
|------------------------------------|--------------------------|------|------|----------|--|--|--|
| Syntax:                            | [label] OPTION           |      |      |          |  |  |  |
| Operands:                          | None                     |      |      |          |  |  |  |
| Operation:                         | $(W) \rightarrow OPTION$ |      |      |          |  |  |  |
| Status Affected:                   | None                     |      |      |          |  |  |  |
| Encoding:                          | 0000                     | 0000 | 0010 |          |  |  |  |
| Description:                       | The conte<br>into the O  |      | 0    | s loaded |  |  |  |
| Words:                             | 1                        |      |      |          |  |  |  |
| Cycles:                            | 1                        |      |      |          |  |  |  |
| Example                            | OPTION                   |      |      |          |  |  |  |
| Before Instruction<br>W = 0x07     |                          |      |      |          |  |  |  |
| After Instruction<br>OPTION = 0x07 |                          |      |      |          |  |  |  |

| RETLW                 | Return with                                                                                                                                                                         | Liter        | al in W                          |  |  |  |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------------|--|--|--|
| Syntax:               | [label] RE                                                                                                                                                                          | TLW          | k                                |  |  |  |
| Operands:             | $0 \le k \le 255$                                                                                                                                                                   |              |                                  |  |  |  |
| Operation:            | $\begin{array}{l} k \rightarrow (W); \\ TOS \rightarrow PC \end{array}$                                                                                                             |              |                                  |  |  |  |
| Status Affected:      | None                                                                                                                                                                                |              |                                  |  |  |  |
| Encoding:             | 1000 kł                                                                                                                                                                             | kk           | 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                                                                                                                                                                          | ;tab<br>;val | le offset<br>ue.<br>ow has table |  |  |  |
| TABLE                 | ADDWF PC<br>RETLW k1<br>RETLW k2                                                                                                                                                    | ; Beg        | offset<br>in table<br>d of table |  |  |  |
| Before Instru<br>W =  | ox07                                                                                                                                                                                |              |                                  |  |  |  |
| After Instruct<br>W = | tion<br>value of k8                                                                                                                                                                 |              |                                  |  |  |  |

| RLF                                                                                                                                                | Rotate Left f through Carry                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                                                                                                                            | [label] RLF f,d                                                                                                                                                                                                                                                                                                                                                                                            |
| Operands:                                                                                                                                          | $\begin{array}{l} 0\leq f\leq 31\\ d\in \ [0,1] \end{array}$                                                                                                                                                                                                                                                                                                                                               |
| Operation:                                                                                                                                         | See description below                                                                                                                                                                                                                                                                                                                                                                                      |
| Status Affected:                                                                                                                                   | С                                                                                                                                                                                                                                                                                                                                                                                                          |
| Encoding:                                                                                                                                          | 0011 01df ffff                                                                                                                                                                                                                                                                                                                                                                                             |
| Description:                                                                                                                                       | The contents of register 'f' are rotated<br>one bit to the left through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is stored<br>back in register 'f'.                                                                                                                                                                                                |
| Words:                                                                                                                                             | 1                                                                                                                                                                                                                                                                                                                                                                                                          |
| Cycles:                                                                                                                                            | 1                                                                                                                                                                                                                                                                                                                                                                                                          |
| Example:                                                                                                                                           | RLF REG1,0                                                                                                                                                                                                                                                                                                                                                                                                 |
| Before Instru                                                                                                                                      | iction                                                                                                                                                                                                                                                                                                                                                                                                     |
| REG1<br>C                                                                                                                                          | = 1110 0110<br>= 0                                                                                                                                                                                                                                                                                                                                                                                         |
| After Instruct                                                                                                                                     | tion                                                                                                                                                                                                                                                                                                                                                                                                       |
| REG1<br>W                                                                                                                                          | = 1110 0110<br>= 1100 1100                                                                                                                                                                                                                                                                                                                                                                                 |
| C                                                                                                                                                  | = 1                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                            |
| RRF                                                                                                                                                | Rotate Right f through Carry                                                                                                                                                                                                                                                                                                                                                                               |
| RRF<br>Syntax:                                                                                                                                     | Rotate Right f through Carry<br>[ label ] RRF f,d                                                                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                            |
| Syntax:                                                                                                                                            | [ <i>label</i> ] RRF f,d<br>0 ≤ f ≤ 31                                                                                                                                                                                                                                                                                                                                                                     |
| Syntax:<br>Operands:                                                                                                                               | $\begin{bmatrix} label \end{bmatrix} RRF f,d$<br>$0 \le f \le 31$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                                                                         |
| Syntax:<br>Operands:<br>Operation:                                                                                                                 | $ \begin{bmatrix} label \end{bmatrix} RRF f,d \\ 0 \le f \le 31 \\ d \in [0,1] \\ See description below $                                                                                                                                                                                                                                                                                                  |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:                                                                                             | $ [label] RRF f,d  0 \le f \le 31  d \in [0,1]  See description below  C  0011 00df ffff  The contents of register 'f' are rotated  one bit to the right through the Carry  Flag. If 'd' is 0 the result is placed in the  W register. If 'd' is 1 the result is placed  back in register 'f'.$                                                                                                            |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:                                                                                | $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                    |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:                                                      | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>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 the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'<br>T                                                                          |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:                                           | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011  00df  ffff<br>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 the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'.<br>$c \rightarrow register 'f' \rightarrow 1$<br>1                         |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:                                                      | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>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 the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'<br>T                                                                          |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:                                           | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>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 the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'<br>1<br>1<br>RRF REG1,0                                                       |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example:<br>Before Instru-<br>REG1     | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>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 the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'.<br>C register 'f'<br>1<br>1<br>RRF REG1,0<br>interimed<br>= 1110 0110<br>= 0 |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example:<br>Before Instru<br>REG1<br>C | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>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 the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'<br>1<br>1<br>RRF REG1,0<br>interimed<br>= 1110 0110<br>= 0                    |

| SLEEP            | Enter SL                                                                                                                         | EEP Mo                                      | de          |        | S         |
|------------------|----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-------------|--------|-----------|
| Syntax:          | [label]                                                                                                                          | SLEEP                                       |             |        | S         |
| Operands:        | None                                                                                                                             |                                             |             |        | 0         |
| Operation:       | $\begin{array}{l} 00h \rightarrow W\\ 0 \rightarrow WD\\ 1 \rightarrow \overline{TO};\\ 0 \rightarrow \overline{PD} \end{array}$ | /DT;<br>T prescal                           | er;         |        | O<br>Si   |
| Status Affected: | TO, PD,                                                                                                                          | GPWUF                                       |             |        | E         |
| Encoding:        | 0000                                                                                                                             | 0000                                        | 0011        | Ī      | D         |
| Description:     |                                                                                                                                  | status bit (<br>vn status b                 | · · · ·     |        |           |
|                  | GPWUF is                                                                                                                         | s unaffecte                                 | ed.         |        | W         |
|                  | The WDT cleared.                                                                                                                 | and its pre                                 | escaler are | 9      | С         |
|                  | The proce<br>with the o                                                                                                          | essor is put<br>scillator sto<br>.EEP for m | opped. Se   | e sec- | <u>E:</u> |
| Words:           | 1                                                                                                                                |                                             |             |        |           |
| Cycles:          | 1                                                                                                                                |                                             |             |        |           |
| Example:         | SLEEP                                                                                                                            |                                             |             |        |           |

| SUBWF                | Su         | Subtract W from f   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
|----------------------|------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-----------------------------|--|--|
| Syntax:              | [lai       | bel]                | SUBWF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | f,d                          |                             |  |  |
| Operands:            | 0 ≤        | ≦ f ≤ 3             | 51                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                              |                             |  |  |
|                      | d∈         | [0,1                | ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                              |                             |  |  |
| Operation:           | (f)        | – (W                | $) \rightarrow (dest)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                              |                             |  |  |
| Status Affected      | : C,       | DC, Z               | Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                              |                             |  |  |
| Encoding:            | 0          | 000                 | 10df                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ffff                         | ]                           |  |  |
| Description:         | W ı<br>res | registe<br>ult is : | (2's completer from register f | ster 'f'. If 'd<br>W registe | ' is 0 the<br>er. If 'd' is |  |  |
| Words:               | 1          |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| Cycles:              | 1          |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| Example 1:           | SUI        | BWF                 | REG1, 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                              |                             |  |  |
| Before Inst          | ructio     | n                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| REG1                 | =          | 3                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| W                    | =          | 2<br>?              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| After Instru         |            | ŕ                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| REG1                 | =          | 1                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| W                    | =          | 2                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| С                    | =          | 1                   | ; result is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | positive                     |                             |  |  |
| Example 2:           |            |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| Before Inst          | ructio     | n                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| REG1                 | =          | 2                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| W                    | =          | 2<br>?              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| After Instru         | =          | ?                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| REG1                 | =          | 0                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| W                    | _          | 2                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| С                    | =          | 1                   | ; result is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | zero                         |                             |  |  |
| Example 3:           |            |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| Before Inst          | ructio     | n                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| REG1                 | =          | 1                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| W                    | =          | 2<br>?              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| C                    | =          | ?                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| After Instru<br>REG1 | etion      | FF                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
|                      | _          | 2                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |
| W                    |            |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                             |  |  |

### 11.2 DC CHARACTERISTICS:

### PIC12C508/509 (Commercial, Industrial, Extended)

|        |                                         |                                                                                                           | <b>rd Operati</b><br>ng tempera |        | 0°C ≤      | TA ≤ + | s otherwise specified)<br>70°C (commercial)                         |  |
|--------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------|---------------------------------|--------|------------|--------|---------------------------------------------------------------------|--|
| DC CHA | ARACTERISTICS                           | $-40^{\circ}C \le TA \le +85^{\circ}C$ (industrial)<br>$-40^{\circ}C \le TA \le +125^{\circ}C$ (extended) |                                 |        |            |        |                                                                     |  |
|        |                                         | Operati                                                                                                   | na voltage                      | Vod ra |            |        | d in DC spec Section 11.1 and                                       |  |
|        |                                         | Section                                                                                                   |                                 |        | ange de d  |        |                                                                     |  |
| Param  | Characteristic                          | Sym                                                                                                       | Min                             | Тур†   | Max        | Units  | Conditions                                                          |  |
| No.    |                                         |                                                                                                           |                                 |        |            |        |                                                                     |  |
|        | Input Low Voltage                       |                                                                                                           |                                 |        |            |        |                                                                     |  |
|        | I/O ports                               | VIL                                                                                                       |                                 | -      |            |        |                                                                     |  |
| D030   | with TTL buffer                         |                                                                                                           | Vss                             | -      | 0.8V       |        | 4.5 < VDD ≤ 5.5V                                                    |  |
|        |                                         |                                                                                                           |                                 | -      | 0.15VDD    | V      | otherwise                                                           |  |
| D031   | with Schmitt Trigger buffer             |                                                                                                           | Vss                             | -      | 0.15VDD    | V      |                                                                     |  |
| D032   | MCLR, GP2/T0CKI (in EXTRC mode)         |                                                                                                           | Vss                             | -      | 0.15VDD    | V      |                                                                     |  |
| D033   | OSC1 (EXTRC) <sup>(1)</sup>             |                                                                                                           | Vss                             | -      | 0.15Vdd    |        |                                                                     |  |
| D033   | OSC1 (in XT and LP)                     |                                                                                                           | Vss                             | -      | 0.3Vdd     | V      | Note1                                                               |  |
|        | Input High Voltage                      |                                                                                                           |                                 |        |            |        |                                                                     |  |
|        | I/O ports                               | Vih                                                                                                       |                                 | -      |            |        |                                                                     |  |
| D040   | with TTL buffer                         | Vss                                                                                                       | 2.0V                            | -      | Vdd        | V      | $4.5 \le VDD \le 5.5V$                                              |  |
| D040A  |                                         |                                                                                                           | 0.25VDD+<br>0.8V                | -      | Vdd        | V      | otherwise                                                           |  |
| D041   | with Schmitt Trigger buffer             |                                                                                                           | 0.85Vdd                         | -      | Vdd        | V      | For entire VDD range                                                |  |
| D042   | MCLR/GP2/T0CKI                          |                                                                                                           | 0.85Vdd                         | -      | Vdd        | V      | _                                                                   |  |
| D042A  | OSC1 (XT and LP)                        |                                                                                                           | 0.7Vdd                          | -      | Vdd        | V      | Note1                                                               |  |
| D043   | OSC1 (in EXTRC mode)                    |                                                                                                           | 0.85Vdd                         | -      | Vdd        | V      |                                                                     |  |
| D070   | GPIO weak pull-up current               | IPUR                                                                                                      | 50                              | 250    | 400        | μΑ     | VDD = 5V, VPIN = VSS                                                |  |
|        | Input Leakage Current <sup>(2, 3)</sup> |                                                                                                           |                                 |        |            |        | For VDD ≤5.5V                                                       |  |
| D060   | I/O ports                               | ١L                                                                                                        | -1                              | 0.5    | <u>+</u> 1 | μA     | Vss ≤ VPIN ≤ VDD,<br>Pin at hi-impedance                            |  |
| D061   | MCLR, GP2/T0CKI                         |                                                                                                           | 20                              | 130    | 250        | μA     | VPIN = VSS + 0.25V(2)                                               |  |
|        |                                         |                                                                                                           |                                 | 0.5    | +5         | μA     | VPIN = VDD                                                          |  |
| D063   | OSC1                                    |                                                                                                           | -3                              | 0.5    | +3         | μA     | Vss $\leq$ VPIN $\leq$ VDD,<br>XT and LP options                    |  |
|        | Output Low Voltage                      |                                                                                                           |                                 |        |            |        |                                                                     |  |
| D080   | I/O ports/CLKOUT                        | Vol                                                                                                       | -                               | -      | 0.6        | V      | IOL = 8.7 mA, VDD = 4.5V                                            |  |
|        | Output High Voltage                     |                                                                                                           |                                 |        |            |        | •                                                                   |  |
| D090   | I/O ports/CLKOUT <sup>(3)</sup>         | Voh                                                                                                       | Vdd - 0.7                       | -      | -          | V      | IOH = -5.4 mA, VDD = 4.5V                                           |  |
|        | Capacitive Loading Specs on             |                                                                                                           |                                 |        |            |        |                                                                     |  |
|        | Output Pins                             |                                                                                                           |                                 |        |            |        |                                                                     |  |
| D100   | OSC2 pin                                | Cosc2                                                                                                     | -                               | -      | 15         | pF     | In XT and LP modes when<br>external clock is used to drive<br>OSC1. |  |
| D101   | All I/O pins                            | Cio                                                                                                       | -                               | -      | 50         | pF     |                                                                     |  |
| -      | Data in "Typ" column is at 5V 25°C ur   |                                                                                                           |                                 |        |            |        |                                                                     |  |

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

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

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

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

### TABLE 11-5: RESET, WATCHDOG TIMER, AND DEVICE RESET TIMER - PIC12C508/C509

| AC Charac        | teristics | $ \begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise specified)} \\ \mbox{Operating Temperature} & 0^{\circ}C \leq TA \leq +70^{\circ}C \mbox{ (commercial)} \\ & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ (industrial)} \\ & -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ (extended)} \\ \mbox{Operating Voltage VDD range is described in Section 11.1} \end{array} $ |       |                    |       |       |                        |
|------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------|-------|-------|------------------------|
| Parameter<br>No. | Sym       | Characteristic                                                                                                                                                                                                                                                                                                                                                                                      | Min   | Typ <sup>(1)</sup> | Max   | Units | Conditions             |
| 30               | TmcL      | MCLR Pulse Width (low)                                                                                                                                                                                                                                                                                                                                                                              | 2000* | _                  | —     | ns    | VDD = 5 V              |
| 31               | Twdt      | Watchdog Timer Time-out Period<br>(No Prescaler)                                                                                                                                                                                                                                                                                                                                                    | 9*    | 18*                | 30*   | ms    | VDD = 5 V (Commercial) |
| 32               | TDRT      | Device Reset Timer Period <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                            | 9*    | 18*                | 30*   | ms    | VDD = 5 V (Commercial) |
| 34               | Tioz      | I/O Hi-impedance from MCLR Low                                                                                                                                                                                                                                                                                                                                                                      | —     | —                  | 2000* | ns    |                        |

\* These parameters are characterized but not tested.

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

Note 2: See Table 11-6.

### TABLE 11-6: DRT (DEVICE RESET TIMER PERIOD - PIC12C508/C509)

| Oscillator Configuration | POR Reset       | Subsequent Resets |
|--------------------------|-----------------|-------------------|
| IntRC & ExtRC            | 18 ms (typical) | 300 µs (typical)  |
| XT & LP                  | 18 ms (typical) | 18 ms (typical)   |

### FIGURE 11-5: TIMER0 CLOCK TIMINGS - PIC12C508/C509



### TABLE 11-7: TIMER0 CLOCK REQUIREMENTS - PIC12C508/C509

| Operating Tempera |      |                                       |                      |                              |                    |     |       |                                                                |
|-------------------|------|---------------------------------------|----------------------|------------------------------|--------------------|-----|-------|----------------------------------------------------------------|
| Parameter<br>No.  | Sym  | Characteristic                        | •                    | Min                          | Тур <sup>(1)</sup> | Max | Units | Conditions                                                     |
| 40                | Tt0H | T0CKI High Pulse Width - No Prescaler |                      | 0.5 TCY + 20*                | -                  | _   | ns    |                                                                |
|                   |      |                                       | - With Prescaler     | 10*                          | —                  | —   | ns    |                                                                |
| 41                | Tt0L | T0CKI Low Pulse W                     | /idth - No Prescaler | 0.5 TCY + 20*                | —                  | —   | ns    |                                                                |
|                   |      |                                       | - With Prescaler     | 10*                          | _                  | —   | ns    |                                                                |
| 42                | Tt0P | T0CKI Period                          |                      | 20 or <u>Tcy + 40</u> *<br>N | _                  | _   | ns    | Whichever is greater.<br>N = Prescale Value<br>(1, 2, 4,, 256) |

\* These parameters are characterized but not tested.

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

### 12.0 DC AND AC CHARACTERISTICS - PIC12C508/PIC12C509

The graphs and tables provided in this section are for design guidance and are not tested. In some graphs or tables the data presented are outside specified operating range (e.g., outside specified VDD range). This is for information only and devices will operate properly only within the specified range.

The data presented in this section is a statistical summary of data collected on units from different lots over a period of time. "Typical" represents the mean of the distribution while "max" or "min" represents (mean +  $3\sigma$ ) and (mean -  $3\sigma$ ) respectively, where  $\sigma$  is standard deviation.







### 13.3 DC CHARACTERISTICS:

### PIC12C508A/509A (Commercial, Industrial, Extended) PIC12C518/519 (Commercial, Industrial, Extended) PIC12CR509A (Commercial, Industrial, Extended)

|                |                                    |                                                                   | r <b>d Operati</b><br>ng tempera |        | 0°C ≤      | TA ≤ + | s otherwise specified)<br>70°C (commercial)                                                              |  |  |
|----------------|------------------------------------|-------------------------------------------------------------------|----------------------------------|--------|------------|--------|----------------------------------------------------------------------------------------------------------|--|--|
| DC CH          | ARACTERISTICS                      | -40°C ≤ TA ≤ +85°C (industrial)<br>-40°C ≤ TA ≤ +125°C (extended) |                                  |        |            |        |                                                                                                          |  |  |
|                |                                    | Operatii<br>Section                                               |                                  | VDD ra |            |        | d in DC spec Section 13.1 and                                                                            |  |  |
| Param          | Characteristic                     | Sym                                                               | Min                              | Typ†   | Max        | Units  | Conditions                                                                                               |  |  |
| No.            |                                    |                                                                   |                                  |        |            |        |                                                                                                          |  |  |
|                | Input Low Voltage                  |                                                                   |                                  |        |            |        |                                                                                                          |  |  |
|                | I/O ports                          | VIL                                                               |                                  |        |            |        |                                                                                                          |  |  |
| D030           | with TTL buffer                    |                                                                   | Vss                              | -      | 0.8V       | V      | For $4.5V \le VDD \le 5.5V$                                                                              |  |  |
|                |                                    |                                                                   | Vss                              | -      | 0.15Vdd    | V      | otherwise                                                                                                |  |  |
| D031           | with Schmitt Trigger buffer        |                                                                   | Vss                              | -      | 0.2VDD     | V      |                                                                                                          |  |  |
| D032           | MCLR, GP2/T0CKI (in EXTRC mode)    |                                                                   | Vss                              | -      | 0.2Vdd     | V      |                                                                                                          |  |  |
| D033           | OSC1 (in EXTRC mode)               |                                                                   | Vss                              | -      | 0.2VDD     |        | Note 1                                                                                                   |  |  |
| D033           | OSC1 (in XT and LP)                |                                                                   | Vss                              | -      | 0.3VDD     | V      | Note 1                                                                                                   |  |  |
|                | Input High Voltage                 | .,                                                                |                                  |        |            |        |                                                                                                          |  |  |
| <b>B</b> a 4 a | I/O ports                          | Vih                                                               |                                  | -      | .,         |        |                                                                                                          |  |  |
| D040           | with TTL buffer                    |                                                                   | 0.25Vdd +<br>0.8V                | -      | Vdd        | V      | $4.5V \le VDD \le 5.5V$                                                                                  |  |  |
| D040A          |                                    |                                                                   | 2.0V                             | -      | Vdd        | V      | otherwise                                                                                                |  |  |
| D041           | with Schmitt Trigger buffer        |                                                                   | 0.8Vdd                           | -      | Vdd        | V      | For entire VDD range                                                                                     |  |  |
| D042           | MCLR, GP2/T0CKI                    |                                                                   | 0.8Vdd                           | -      | Vdd        | V      |                                                                                                          |  |  |
|                | OSC1 (XT and LP)                   |                                                                   | 0.7Vdd                           | -      | Vdd        | V      | Note 1                                                                                                   |  |  |
| D043           | OSC1 (in EXTRC mode)               |                                                                   | 0.9Vdd                           | -      | Vdd        | V      |                                                                                                          |  |  |
| D070           | GPIO weak pull-up current (Note 4) | IPUR                                                              | 30                               | 250    | 400        | μA     | VDD = 5V, VPIN = VSS                                                                                     |  |  |
|                | MCLR pull-up current               | -                                                                 | -                                | -      | 30         | μΑ     | VDD = 5V, VPIN = VSS                                                                                     |  |  |
|                | Input Leakage Current (Notes 2, 3) |                                                                   |                                  |        |            | _      |                                                                                                          |  |  |
| D060           | I/O ports                          | lı∟                                                               | -                                | -      | <u>+</u> 1 | μA     | Vss ≤ VPIN ≤ VDD, Pin at hi-<br>impedance                                                                |  |  |
| D061           | TOCKI                              |                                                                   | -                                | -      | <u>+</u> 5 | μΑ     | $Vss \le Vpin \le Vdd$                                                                                   |  |  |
| D063           | OSC1                               |                                                                   | -                                | -      | <u>+</u> 5 | μA     | Vss $\leq$ VPIN $\leq$ VDD, XT and LP osc configuration                                                  |  |  |
|                | Output Low Voltage                 |                                                                   |                                  |        |            |        |                                                                                                          |  |  |
| D080           | I/O ports                          | Vol                                                               | -                                | -      | 0.6        | V      | IOL = 8.5 mA, VDD = 4.5V,<br>−40°C to +85°C                                                              |  |  |
| D080A          |                                    |                                                                   | -                                | -      | 0.6        | V      | IOL = 7.0 mA, VDD = 4.5V,<br>−40°C to +125°C                                                             |  |  |
|                | Output High Voltage                |                                                                   |                                  |        |            |        |                                                                                                          |  |  |
| D090           | I/O ports (Note 3)                 | Voн                                                               | Vdd - 0.7                        | -      | -          | V      | Юн = -3.0 mA, VDD = 4.5V,<br>−40°C to +85°C                                                              |  |  |
| D090A          |                                    |                                                                   | Vdd - 0.7                        | -      | -          | V      | $IOH = -2.5 \text{ mA}, \text{VDD} = 4.5 \text{V}, -40^{\circ}\text{C} \text{ to } +125^{\circ}\text{C}$ |  |  |
|                | Capacitive Loading Specs on        |                                                                   |                                  |        |            |        |                                                                                                          |  |  |
|                | Output Pins                        |                                                                   |                                  |        |            | _      |                                                                                                          |  |  |
| D100           | OSC2 pin                           | COSC2                                                             | -                                | -      | 15         | pF     | In XT and LP modes when exter-<br>nal clock is used to drive OSC1.                                       |  |  |
| D101           | All I/O pins                       | Сю                                                                | -                                | -      | 50         | pF     |                                                                                                          |  |  |

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

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

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

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

4: This spec. applies when GP3/MCLR is configured as MCLR. The leakage current of the MCLR circuit is higher than the standard I/O logic.

# TABLE 13-1: PULL-UP RESISTOR RANGES\* - PIC12C508A, PIC12C509A, PIC12CR509A, PIC12CE518, PIC12CE519, PIC12LC508A, PIC12LC509A, PIC12LCR509A, PIC12LCE518 and PIC12LCE519

| VDD (Volts) | Temperature (°C) | perature (°C) Min Typ |      | Max  | Units |
|-------------|------------------|-----------------------|------|------|-------|
|             |                  | GP0                   | /GP1 |      |       |
| 2.5         | -40              | 38K                   | 42K  | 63K  | Ω     |
|             | 25               | 42K                   | 48K  | 63K  | Ω     |
|             | 85               | 42K                   | 49K  | 63K  | Ω     |
|             | 125              | 50K                   | 55K  | 63K  | Ω     |
| 5.5         | -40              | 15K                   | 17K  | 20K  | Ω     |
|             | 25               | 18K                   | 20K  | 23K  | Ω     |
|             | 85               | 19K                   | 22K  | 25K  | Ω     |
|             | 125              | 22K                   | 24K  | 28K  | Ω     |
|             |                  | G                     | P3   |      |       |
| 2.5         | -40              | 285K                  | 346K | 417K | Ω     |
|             | 25               | 343K                  | 414K | 532K | Ω     |
|             | 85               | 368K                  | 457K | 532K | Ω     |
|             | 125              | 431K                  | 504K | 593K | Ω     |
| 5.5         | -40              | 247K                  | 292K | 360K | Ω     |
|             | 25               | 288K                  | 341K | 437K | Ω     |
|             | 85               | 306K                  | 371K | 448K | Ω     |
|             | 125              | 351K                  | 407K | 500K | Ω     |

\* These parameters are characterized but not tested.

### TABLE 13-6: DRT (DEVICE RESET TIMER PERIOD) - PIC12C508A, PIC12C509A, PIC12CE518, PIC12CE519, PIC12LC508A, PIC12LC509A, PIC12LCR509A, PIC12LCE518 and PIC12LCE519

| Oscillator Configuration | POR Reset                      | Subsequent Resets               |  |  |
|--------------------------|--------------------------------|---------------------------------|--|--|
| IntRC & ExtRC            | 18 ms (typical) <sup>(1)</sup> | 300 µs (typical) <sup>(1)</sup> |  |  |
| XT & LP                  | 18 ms (typical) <sup>(1)</sup> | 18 ms (typical) <sup>(1)</sup>  |  |  |

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

### FIGURE 13-5: TIMER0 CLOCK TIMINGS - PIC12C508A, PIC12C509A, PIC12CE518, PIC12CE519, PIC12LC508A, PIC12LC509A, PIC12LCR509A, PIC12LCE518 and PIC12LCE519



### TABLE 13-7: TIMER0 CLOCK REQUIREMENTS - PIC12C508A, PIC12C509A, PIC12CE518, PIC12CE519, PIC12LC508A, PIC12LC509A, PIC12LCR509A, PIC12LCE518 and PIC12LCE519

| AC Characteristics |      |                    |                      |                              |                    |     |       |                                                                |
|--------------------|------|--------------------|----------------------|------------------------------|--------------------|-----|-------|----------------------------------------------------------------|
| Parameter<br>No.   | Sym  | Characteristic     |                      | Min                          | Тур <sup>(1)</sup> | Max | Units | Conditions                                                     |
| 40                 | Tt0H | T0CKI High Pulse V | 0.5 TCY + 20*        | -                            | —                  | ns  |       |                                                                |
|                    |      |                    | - With Prescaler     | 10*                          | -                  | —   | ns    |                                                                |
| 41                 | Tt0L | T0CKI Low Pulse W  | /idth - No Prescaler | 0.5 TCY + 20*                | -                  | —   | ns    |                                                                |
|                    |      |                    | - With Prescaler     | 10*                          | -                  | —   | ns    |                                                                |
| 42                 | Tt0P | T0CKI Period       |                      | 20 or <u>Tcy + 40</u> *<br>N | _                  |     | ns    | Whichever is greater.<br>N = Prescale Value<br>(1, 2, 4,, 256) |

\* These parameters are characterized but not tested.

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

### TABLE 13-8: EEPROM MEMORY BUS TIMING REQUIREMENTS - PIC12CE5XX ONLY.

| AC Characteristics                                                                   | Standard Operating Conditions (unless otherwise specified)Operating Temperature $0^{\circ}C \le TA \le +70^{\circ}C$ , Vcc = 3.0V to 5.5V (commercial) $-40^{\circ}C \le TA \le +85^{\circ}C$ , Vcc = 3.0V to 5.5V (industrial) $-40^{\circ}C \le TA \le +125^{\circ}C$ , Vcc = 4.5V to 5.5V (extended)Operating Voltage VDD range is described in Section 13.1 |                      |                     |        |                                                                                                                                              |  |  |
|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|---------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Parameter                                                                            | Symbol                                                                                                                                                                                                                                                                                                                                                          | Min                  | Max                 | Units  | Conditions                                                                                                                                   |  |  |
| Clock frequency                                                                      | FCLK                                                                                                                                                                                                                                                                                                                                                            |                      | 100<br>100<br>400   | kHz    | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V                                                                   |  |  |
| Clock high time                                                                      | Тнідн                                                                                                                                                                                                                                                                                                                                                           | 4000<br>4000<br>600  |                     | ns     |                                                                                                                                              |  |  |
| Clock low time                                                                       | TLOW                                                                                                                                                                                                                                                                                                                                                            | 4700<br>4700<br>1300 |                     | ns     |                                                                                                                                              |  |  |
| SDA and SCL rise time<br>(Note 1)                                                    | TR                                                                                                                                                                                                                                                                                                                                                              |                      | 1000<br>1000<br>300 | ns     |                                                                                                                                              |  |  |
| SDA and SCL fall time                                                                | TF                                                                                                                                                                                                                                                                                                                                                              | _                    | 300                 | ns     | (Note 1)                                                                                                                                     |  |  |
| START condition hold time                                                            | THD:STA                                                                                                                                                                                                                                                                                                                                                         | 4000<br>4000<br>600  |                     | ns     |                                                                                                                                              |  |  |
| START condition setup time                                                           | TSU:STA                                                                                                                                                                                                                                                                                                                                                         | 4700<br>4700<br>600  |                     | ns     | $\begin{array}{l} 4.5V \leq Vcc \leq 5.5V \mbox{ (E Temp range)} \\ 3.0V \leq Vcc \leq 4.5V \\ 4.5V \leq Vcc \leq 5.5V \end{array}$          |  |  |
| Data input hold time                                                                 | THD:DAT                                                                                                                                                                                                                                                                                                                                                         | 0                    |                     | ns     | (Note 2)                                                                                                                                     |  |  |
| Data input setup time                                                                | TSU:DAT                                                                                                                                                                                                                                                                                                                                                         | 250<br>250<br>100    |                     | ns     | $\begin{array}{l} 4.5V \leq Vcc \leq 5.5V \mbox{ (E Temp range)} \\ 3.0V \leq Vcc \leq 4.5V \\ 4.5V \leq Vcc \leq 5.5V \end{array}$          |  |  |
| STOP condition setup time                                                            | Tsu:sto                                                                                                                                                                                                                                                                                                                                                         | 4000<br>4000<br>600  |                     | ns     | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V                                                                   |  |  |
| Output valid from clock<br>(Note 2)                                                  | ΤΑΑ                                                                                                                                                                                                                                                                                                                                                             |                      | 3500<br>3500<br>900 | ns     | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V                                                                   |  |  |
| Bus free time: Time the bus must<br>be free before a new transmis-<br>sion can start | TBUF                                                                                                                                                                                                                                                                                                                                                            | 4700<br>4700<br>1300 |                     | ns     | $\begin{array}{l} 4.5 V \leq V cc \leq 5.5 V \mbox{ (E Temp range)} \\ 3.0 V \leq V cc \leq 4.5 V \\ 4.5 V \leq V cc \leq 5.5 V \end{array}$ |  |  |
| Output fall time from VIH<br>minimum to VIL maximum                                  | TOF                                                                                                                                                                                                                                                                                                                                                             | 20+0.1<br>CB         | 250                 | ns     | (Note 1), CB ≤ 100 pF                                                                                                                        |  |  |
| Input filter spike suppression (SDA and SCL pins)                                    | TSP                                                                                                                                                                                                                                                                                                                                                             |                      | 50                  | ns     | (Notes 1, 3)                                                                                                                                 |  |  |
| Write cycle time                                                                     | Twc                                                                                                                                                                                                                                                                                                                                                             | —                    | 4                   | ms     |                                                                                                                                              |  |  |
| Endurance                                                                            |                                                                                                                                                                                                                                                                                                                                                                 | 1M                   | _                   | cycles | 25°C, Vcc = 5.0V, Block Mode (Note 4)                                                                                                        |  |  |

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 Microchip's website.

### **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 (602) 786-7578.

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

| To:  | Technical Publications Manager Total Pages Sent                                            |  |  |  |  |  |  |  |
|------|--------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| RE:  | Reader Response                                                                            |  |  |  |  |  |  |  |
| Fror | n: Name                                                                                    |  |  |  |  |  |  |  |
|      | Company                                                                                    |  |  |  |  |  |  |  |
|      | Address                                                                                    |  |  |  |  |  |  |  |
|      | City / State / ZIP / Country                                                               |  |  |  |  |  |  |  |
|      | Telephone: () FAX: ()                                                                      |  |  |  |  |  |  |  |
|      | lication (optional):                                                                       |  |  |  |  |  |  |  |
| Wou  | uld you like a reply?YN                                                                    |  |  |  |  |  |  |  |
| Dev  | ice: PIC12C5XX Literature Number: DS40139E                                                 |  |  |  |  |  |  |  |
| Que  | estions:                                                                                   |  |  |  |  |  |  |  |
| 1.   | What are the best features of this document?                                               |  |  |  |  |  |  |  |
|      |                                                                                            |  |  |  |  |  |  |  |
|      |                                                                                            |  |  |  |  |  |  |  |
| 2.   | 2. How does this document meet your hardware and software development needs?               |  |  |  |  |  |  |  |
|      |                                                                                            |  |  |  |  |  |  |  |
| з    | Do you find the organization of this data sheet easy to follow? If not, why?               |  |  |  |  |  |  |  |
| 0.   |                                                                                            |  |  |  |  |  |  |  |
|      |                                                                                            |  |  |  |  |  |  |  |
| 4.   | . What additions to the data sheet do you think would enhance the structure and subject?   |  |  |  |  |  |  |  |
|      |                                                                                            |  |  |  |  |  |  |  |
|      |                                                                                            |  |  |  |  |  |  |  |
| 5.   | What deletions from the data sheet could be made without affecting the overall usefulness? |  |  |  |  |  |  |  |
|      |                                                                                            |  |  |  |  |  |  |  |
| 6.   | Is there any incorrect or misleading information (what and where)?                         |  |  |  |  |  |  |  |
|      |                                                                                            |  |  |  |  |  |  |  |
|      |                                                                                            |  |  |  |  |  |  |  |
| 7.   | How would you improve this document?                                                       |  |  |  |  |  |  |  |
|      |                                                                                            |  |  |  |  |  |  |  |
| 8    | How would you improve our software, systems, and silicon products?                         |  |  |  |  |  |  |  |
| 0.   |                                                                                            |  |  |  |  |  |  |  |