



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 - Microcontrollers</u>"

| Details                    |                                                                           |
|----------------------------|---------------------------------------------------------------------------|
| Product Status             | Active                                                                    |
| Core Processor             | PIC                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 20MHz                                                                     |
| Connectivity               | -                                                                         |
| Peripherals                | POR, WDT                                                                  |
| Number of I/O              | 20                                                                        |
| Program Memory Size        | 3KB (2K x 12)                                                             |
| Program Memory Type        | OTP                                                                       |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 72 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                               |
| Data Converters            | -                                                                         |
| Oscillator Type            | External                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                            |
| Supplier Device Package    | 28-SOIC                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c57-hsi-so |

#### 3.0 ARCHITECTURAL OVERVIEW

The high performance of the PIC16C5X family can be attributed to a number of architectural features commonly found in RISC microprocessors. To begin with, the PIC16C5X 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 twostage pipeline overlaps fetch and execution of instructions. Consequently, all instructions (33) execute in a single cycle except for program branches.

The PIC16C54/CR54 and PIC16C55 address 512 x 12 of program memory, the PIC16C56/CR56 address 1K x 12 of program memory, and the PIC16C57/CR57 and PIC16C58/CR58 address 2K x 12 of program memory. All program memory is internal.

The PIC16C5X 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 PIC16C5X 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 PIC16C5X simple yet efficient. In addition, the learning curve is reduced significantly.

The PIC16C5X 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 (for PIC16C54/56/58) and Table 3-2 (for PIC16C55/57).

#### 6.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 PIC16C54, PIC16CR54, PIC16C56 and PIC16CR56, the register file is composed of 7 Special Function Registers and 25 General Purpose Registers (Figure 6-4).

For the PIC16C55, the register file is composed of 8 Special Function Registers and 24 General Purpose Registers.

For the PIC16C57 and PIC16CR57, the register file is composed of 8 Special Function Registers, 24 General Purpose Registers and up to 48 additional General Purpose Registers that may be addressed using a banking scheme (Figure 6-5).

For the PIC16C58 and PIC16CR58, the register file is composed of 7 Special Function Registers, 25 General Purpose Registers and up to 48 additional General Purpose Registers that may be addressed using a banking scheme (Figure 6-6).

## 6.2.1 GENERAL PURPOSE REGISTER FILE

The register file is accessed either directly or indirectly through the File Select Register (FSR). The FSR Register is described in Section 6.7.

FIGURE 6-4: PIC16C54, PIC16CR54, PIC16C55, PIC16C56, PIC16CR56 REGISTER FILE MAP



- **Note 1:** Not a physical register. See Section 6.7.
  - **2:** PIC16C55 only, in all other devices this is implemented as a general purpose register.

## 6.7 Indirect Data Addressing; INDF and FSR Registers

The INDF Register is not a physical register. Addressing INDF actually addresses the register whose address is contained in the FSR Register (FSR is a *pointer*). This is indirect addressing.

#### **EXAMPLE 6-1: INDIRECT ADDRESSING**

- Register file 08 contains the value 10h
- Register file 09 contains the value 0Ah
- · Load the value 08 into the FSR Register
- A read of the INDF Register will return the value of 10h
- Increment the value of the FSR Register by one (FSR = 09h)
- A read of the INDF register now will return the value of 0Ah.

Reading INDF itself indirectly (FSR = 0) will produce 00h. Writing to the INDF Register indirectly results in a no-operation (although STATUS bits may be affected).

A simple program to clear RAM locations 10h-1Fh using indirect addressing is shown in Example 6-2.

## EXAMPLE 6-2: HOW TO CLEAR RAM USING INDIRECT ADDRESSING

|          | MOVLW | H'10' | ;initialize pointer  |
|----------|-------|-------|----------------------|
|          | MOVWF | FSR   | ; to RAM             |
| NEXT     | CLRF  | INDF  | ;clear INDF Register |
|          | INCF  | FSR,F | ;inc pointer         |
|          | BTFSC | FSR,4 | ;all done?           |
|          | GOTO  | NEXT  | ;NO, clear next      |
| CONTINUE |       |       |                      |
|          |       |       | :YES, continue       |

The FSR is either a 5-bit (PIC16C54, PIC16CR54, PIC16C55, PIC16C56, PIC16CR56) or 7-bit (PIC16C57, PIC16CR57, PIC16CR58, PIC16CR58) wide register. It is used in conjunction with the INDF Register to indirectly address the data memory area.

The FSR<4:0> bits are used to select data memory addresses 00h to 1Fh.

**PIC16C54, PIC16CR54, PIC16C55, PIC16C56, PIC16CR56:** These do not use banking. FSR<6:5> bits are unimplemented and read as '1's.

**PIC16C57, PIC16CR57, PIC16C58, PIC16CR58:** FSR<6:5> are the bank select bits and are used to select the bank to be addressed (00 = bank 0, 01 = bank 1, 10 = bank 2, 11 = bank 3).

#### FIGURE 6-10: DIRECT/INDIRECT ADDRESSING



NOTES:

TABLE 10-2: INSTRUCTION SET SUMMARY

| Mnemonic, |         | Description Cycles           |                  | 12-Bit Opcode |      | ode  | Status                         | Notes |
|-----------|---------|------------------------------|------------------|---------------|------|------|--------------------------------|-------|
| Opera     | nds     | Description                  | Cycles           | MSb           |      | LSb  | Affected                       | Notes |
| ADDWF     | f,d     | Add W and f                  | 1                | 0001          | 11df | ffff | C,DC,Z                         | 1,2,4 |
| ANDWF     | f,d     | AND W with f                 | 1                | 0001          | 01df | ffff | Z                              | 2,4   |
| CLRF      | f       | Clear f                      | 1                | 0000          | 011f | ffff | Z                              | 4     |
| CLRW      | _       | Clear W                      | 1                | 0000          | 0100 | 0000 | Z                              |       |
| COMF      | f, d    | Complement f                 | 1                | 0010          | 01df | ffff | Z                              |       |
| DECF      | f, d    | Decrement f                  | 1                | 0000          | 11df | ffff | Z                              | 2,4   |
| DECFSZ    | f, d    | Decrement f, Skip if 0       | 1(2)             | 0010          | 11df | ffff | None                           | 2,4   |
| INCF      | f, d    | Increment f                  | 1                | 0010          | 10df | ffff | Z                              | 2,4   |
| INCFSZ    | f, d    | Increment f, Skip if 0       | 1 <sup>(2)</sup> | 0011          | 11df | ffff | None                           | 2,4   |
| IORWF     | f, d    | Inclusive OR W with f        | 1                | 0001          | 00df | ffff | Z                              | 2,4   |
| MOVF      | f, d    | Move f                       | 1                | 0010          | 00df | ffff | Z                              | 2,4   |
| MOVWF     | f       | Move W to f                  | 1                | 0000          | 001f | ffff | None                           | 1,4   |
| NOP       | _       | No Operation                 | 1                | 0000          | 0000 | 0000 | None                           |       |
| RLF       | f, d    | Rotate left f through Carry  | 1                | 0011          | 01df | ffff | С                              | 2,4   |
| RRF       | f, d    | Rotate right f through Carry | 1                | 0011          | 00df | ffff | С                              | 2,4   |
| SUBWF     | f, d    | Subtract W from f            | 1                | 0000          | 10df | ffff | C,DC,Z                         | 1,2,4 |
| SWAPF     | f, d    | Swap f                       | 1                | 0011          | 10df | ffff | None                           | 2,4   |
| XORWF     | f, d    | Exclusive OR W with f        | 1                | 0001          | 10df | ffff | Z                              | 2,4   |
| BIT-ORIEN | TED FIL | E REGISTER OPERATIONS        |                  |               |      |      |                                |       |
| BCF       | f, b    | Bit Clear f                  | 1                | 0100          | bbbf | ffff | None                           | 2,4   |
| BSF       | f, b    | Bit Set f                    | 1                | 0101          | bbbf | ffff | None                           | 2,4   |
| BTFSC     | f, b    | Bit Test f, Skip if Clear    | 1 (2)            | 0110          | bbbf | ffff | None                           |       |
| BTFSS     | f, b    | Bit Test f, Skip if Set      | 1 (2)            | 0111          | bbbf | ffff | None                           |       |
| LITERAL A | ND CON  | ITROL OPERATIONS             |                  | •             |      |      |                                |       |
| ANDLW     | k       | AND literal with W           | 1                | 1110          | kkkk | kkkk | Z                              |       |
| CALL      | k       | Call subroutine              | 2                | 1001          | kkkk | kkkk | None                           | 1     |
| CLRWDT    | k       | Clear Watchdog Timer         | 1                | 0000          | 0000 | 0100 | TO, PD                         |       |
| GOTO      | k       | Unconditional branch         | 2                | 101k          | kkkk | kkkk | None                           |       |
| IORLW     | k       | Inclusive OR Literal with W  | 1                | 1101          | kkkk | kkkk | Z                              |       |
| MOVLW     | k       | Move Literal to W            | 1                | 1100          | kkkk | kkkk | None                           |       |
| OPTION    | k       | Load OPTION register         | 1                | 0000          | 0000 | 0010 | None                           |       |
| RETLW     | k       | Return, place Literal in W   | 2                | 1000          | kkkk | kkkk | None                           |       |
| SLEEP     | _       | Go into standby mode         | 1                | 0000          | 0000 | 0011 | $\overline{TO}, \overline{PD}$ |       |
| TRIS      | f       | Load TRIS register           | 1                | 0000          | 0000 | Offf | None                           | 3     |
| XORLW     | k       | Exclusive OR Literal to W    | 1                | 1111          | kkkk | kkkk | Z                              |       |

- **Note 1:** The 9th bit of the program counter will be forced to a '0' by any instruction that writes to the PC except for GOTO (see Section 6.5 for more on program counter).
  - 2: When an I/O register is modified as a function of itself (e.g. MOVF PORTB, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.
  - 3: The instruction TRIS f, where f = 5, 6 or 7 causes the contents of the W register to be written to the tristate latches of PORTA, B or C respectively. A '1' forces the pin to a hi-impedance state and disables the output buffers.
  - **4:** If this instruction is executed on the TMR0 register (and, where applicable, d = 1), the prescaler will be cleared (if assigned to TMR0).

| COMF                                                 | Complement f                                                                                                                                              |                   |      |
|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------|
| Syntax:                                              | [ label ]                                                                                                                                                 | COMF              | f,d  |
| Operands:                                            | $0 \le f \le 31$<br>$d \in [0,1]$                                                                                                                         |                   |      |
| Operation:                                           | $(\overline{f}) \rightarrow (de$                                                                                                                          | est)              |      |
| Status Affected:                                     | Z                                                                                                                                                         |                   |      |
| Encoding:                                            | 0010                                                                                                                                                      | 01df              | ffff |
| Description:                                         | The contents of register 'f' are complemented. 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:                                             | COMF                                                                                                                                                      | REG1,0            |      |
| Before Instru<br>REG1<br>After Instruct<br>REG1<br>W | = 02<br>ion<br>= 02                                                                                                                                       | x13<br>x13<br>xEC |      |

| DECF                                                    | Decrement f                                                                                                                        |            |      |            |
|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|------------|------|------------|
| Syntax:                                                 | [label] DECF f,d                                                                                                                   |            |      |            |
| Operands:                                               | $0 \le f \le 31$<br>$d \in [0,1]$                                                                                                  |            |      |            |
| Operation:                                              | $(f) - 1 \rightarrow$                                                                                                              | (dest)     |      |            |
| Status Affected:                                        | Z                                                                                                                                  |            |      |            |
| Encoding:                                               | 0000                                                                                                                               | 11df       | ffff |            |
| Description:                                            | Decrement 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'. |            |      | gister. If |
| Words:                                                  | 1                                                                                                                                  |            |      |            |
| Cycles:                                                 | 1                                                                                                                                  |            |      |            |
| Example:                                                | DECF                                                                                                                               | CNT,       | 1    |            |
| Before Instru<br>CNT<br>Z<br>After Instruct<br>CNT<br>Z | = 0:<br>= 0<br>tion                                                                                                                | x01<br>x00 |      |            |

| DECFSZ           | Decrement f, Skip if 0                                                                                                                                                                                                                                                                                      |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] DECFSZ f,d                                                                                                                                                                                                                                                                                        |
| Operands:        | $0 \le f \le 31$                                                                                                                                                                                                                                                                                            |
|                  | d ∈ [0,1]                                                                                                                                                                                                                                                                                                   |
| Operation:       | $(f) - 1 \rightarrow d$ ; skip if result = 0                                                                                                                                                                                                                                                                |
| Status Affected: | None                                                                                                                                                                                                                                                                                                        |
| Encoding:        | 0010 11df ffff                                                                                                                                                                                                                                                                                              |
| Description:     | The contents of register 'f' are decremented. If 'd' is 0 the result is placed in the W register. If 'd' is 1 the result is placed back in register 'f'.  If the result is 0, the next instruction, which is already fetched, is discarded and a NOP is executed instead making it a two-cycle instruction. |
| Words:           | 1                                                                                                                                                                                                                                                                                                           |
| Cycles:          | 1(2)                                                                                                                                                                                                                                                                                                        |
| Example:         | HERE DECFSZ CNT, 1                                                                                                                                                                                                                                                                                          |
|                  | GOTO LOOP CONTINUE •                                                                                                                                                                                                                                                                                        |
| Before Instru    | uction                                                                                                                                                                                                                                                                                                      |
| PC               | = address (HERE)                                                                                                                                                                                                                                                                                            |
| After Instruct   |                                                                                                                                                                                                                                                                                                             |
| CNT              | = CNT - 1;                                                                                                                                                                                                                                                                                                  |
| if CNT<br>PC     | = 0,                                                                                                                                                                                                                                                                                                        |
| if CNT           | = address (CONTINUE);<br>≠ 0.                                                                                                                                                                                                                                                                               |
| PC               | = address (HERE+1)                                                                                                                                                                                                                                                                                          |
|                  |                                                                                                                                                                                                                                                                                                             |

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

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

| MOVF                                         | Move f                                                                                                                                                                                                                               |  |  |
|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:                                      | [ label ] MOVF f,d                                                                                                                                                                                                                   |  |  |
| Operands:                                    | $0 \le f \le 31$<br>$d \in [0,1]$                                                                                                                                                                                                    |  |  |
| Operation:                                   | $(f) \rightarrow (dest)$                                                                                                                                                                                                             |  |  |
| Status Affected:                             | Z                                                                                                                                                                                                                                    |  |  |
| Encoding:                                    | 0010 00df ffff                                                                                                                                                                                                                       |  |  |
| Description:                                 | The contents of register 'f' is moved to destination 'd'. If 'd' is 0, destination is the W register. If 'd' is 1, the destination is file register 'f'. 'd' is 1 is useful to test a file register since status flag Z is affected. |  |  |
| Words:                                       | 1                                                                                                                                                                                                                                    |  |  |
| Cycles:                                      | 1                                                                                                                                                                                                                                    |  |  |
| Example:                                     | MOVF FSR, 0                                                                                                                                                                                                                          |  |  |
| After Instruction  W = value in FSR register |                                                                                                                                                                                                                                      |  |  |

| MOVLW                      | Move Lit                                                 | eral to W | ı    |  |
|----------------------------|----------------------------------------------------------|-----------|------|--|
| Syntax:                    | [ label ]                                                | MOVLW     | k    |  |
| Operands:                  | $0 \le k \le 25$                                         | 55        |      |  |
| Operation:                 | $k \rightarrow (W)$                                      |           |      |  |
| Status Affected:           | None                                                     |           |      |  |
| Encoding:                  | 1100                                                     | kkkk      | kkkk |  |
| Description:               | The eight bit literal 'k' is loaded into the W register. |           |      |  |
| Words:                     | 1                                                        |           |      |  |
| Cycles:                    | 1                                                        |           |      |  |
| Example:                   | MOVLW                                                    | 0x5A      |      |  |
| After Instruction W = 0x5A |                                                          |           |      |  |

#### 13.5 Timing Parameter Symbology and Load Conditions

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

- 1. TppS2ppS
- 2. TppS

| Т    |                                         |                    |
|------|-----------------------------------------|--------------------|
| F    | Frequency                               | T Time             |
| Lowe | ercase letters (pp) and their meanings: |                    |
| pp   |                                         |                    |
| 2    | to                                      | mc MCLR            |
| ck   | CLKOUT                                  | osc oscillator     |
| су   | cycle time                              | os OSC1            |
| drt  | device reset timer                      | t0 T0CKI           |
| io   | I/O port                                | wdt watchdog timer |

Uppercase letters and their meanings:

|   | 977 | or oddo rottoro dira trion riiodi.ii.go. |   |              |
|---|-----|------------------------------------------|---|--------------|
| Ī | S   |                                          |   |              |
|   | F   | Fall                                     | Р | Period       |
|   | Н   | High                                     | R | Rise         |
|   | I   | Invalid (Hi-impedance)                   | V | Valid        |
|   | L   | Low                                      | Z | Hi-impedance |

#### FIGURE 13-1: LOAD CONDITIONS FOR DEVICE TIMING SPECIFICATIONS - PIC16CR54A



FIGURE 14-4: TYPICAL RC OSC FREQUENCY vs. VDD, CEXT = 300 PF



FIGURE 14-5: TYPICAL IPD vs. Vdd, WATCHDOG DISABLED



FIGURE 14-19: PORTA, B AND C IOH vs. Voh, VDD = 3 V



FIGURE 14-20: PORTA, B AND C IOH vs. Voh, VDD = 5 V



#### 15.0 ELECTRICAL CHARACTERISTICS - PIC16C54A

Absolute Maximum Ratings(†) Voltage on all other pins with respect to Vss ......—0.6V to (VDD + 0.6V) Total power dissipation<sup>(1)</sup>......800 mW Max. current into an input pin (T0CKI only) ......±500 μA Input clamp current, IK (VI < 0 or VI > VDD)......±20 mA Output clamp current, IOK (VO < 0 or VO > VDD) ......±20 mA 

Note 1: Power dissipation is calculated as follows: Pdis = VDD x {IDD -  $\Sigma$  IOH} +  $\Sigma$  {(VDD-VOH) x IOH} +  $\Sigma$ (VOL x IOL)

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

15.1 DC Characteristics: PIC16C54A-04, 10, 20 (Commercial)
PIC16C54A-04I, 10I, 20I (Industrial)
PIC16LC54A-04 (Commercial)
PIC16LC54A-04I (Industrial)

PIC16LC54A-04

PIC16LC54A-04I<br/>(Commercial, Industrial)Operating Temperature $0^{\circ}C \leq TA \leq +70^{\circ}C$  for commercial<br/> $-40^{\circ}C \leq TA \leq +85^{\circ}C$  for industrialPIC16C54A-04, 10, 20<br/>PIC16C54A-04I, 10I, 20IStandard Operating Conditions (unless otherwise specified)<br/>Operating Temperature $0^{\circ}C \leq TA \leq +70^{\circ}C$  for commercial

Standard Operating Conditions (unless otherwise specified)

Operating Temperature  $0^{\circ}\text{C} \leq \text{TA} \leq +70^{\circ}\text{C}$  for commercial (Commercial, Industrial)  $-40^{\circ}\text{C} \leq \text{TA} \leq +85^{\circ}\text{C}$  for industrial

| Param<br>No. | Symbol | Characteristic/Device             | Min | Тур† | Max | Units | Conditions                           |
|--------------|--------|-----------------------------------|-----|------|-----|-------|--------------------------------------|
|              | IPD    | Power-down Current <sup>(2)</sup> |     |      |     |       |                                      |
| D006         |        | PIC16LC5X                         | _   | 2.5  | 12  | μΑ    | VDD = 2.5V, WDT enabled, Commercial  |
|              |        |                                   | _   | 0.25 | 4.0 | μΑ    | VDD = 2.5V, WDT disabled, Commercial |
|              |        |                                   | _   | 2.5  | 14  | μΑ    | VDD = 2.5V, WDT enabled, Industrial  |
|              |        |                                   | _   | 0.25 | 5.0 | μΑ    | VDD = 2.5V, WDT disabled, Industrial |
| D006A        |        | PIC16C5X                          | _   | 4.0  | 12  | μА    | VDD = 3.0V, WDT enabled, Commercial  |
|              |        |                                   | _   | 0.25 | 4.0 | μΑ    | VDD = 3.0V, WDT disabled, Commercial |
|              |        |                                   | _   | 5.0  | 14  | μΑ    | VDD = 3.0V, WDT enabled, Industrial  |
|              |        |                                   | _   | 0.3  | 5.0 | μΑ    | VDD = 3.0V, WDT disabled, Industrial |

Legend: Rows with standard voltage device data only are shaded for improved readability.

- These parameters are characterized but not tested.
- † Data in "Typ" column is based on characterization results at 25°C. This data is for design guidance only and is not tested.
- Note 1: This is the limit to which VDD can be lowered in SLEEP mode without losing RAM data.
  - 2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as bus loading, oscillator type, bus rate, internal code execution pattern and temperature also have an impact on the current consumption.
    - a) The test conditions for all IDD measurements in active Operation mode <u>are: OSC1</u> = external square wave, from rail-to-rail; all I/O pins tristated, pulled to Vss, T0CKI = VDD, MCLR = VDD; WDT enabled/disabled as specified.
    - b) For standby current measurements, the conditions are the same, except that the device is in SLEEP mode. The power-down current in SLEEP mode does not depend on the oscillator type.
  - 3: Does not include current through REXT. The current through the resistor can be estimated by the formula: IR = VDD/2REXT (mA) with REXT in  $k\Omega$ .

## 15.2 DC Characteristics: PIC16C54A-04E, 10E, 20E (Extended) PIC16LC54A-04E (Extended)

| PIC16LC54A-04E<br>(Extended) |        |                                               |                               | Standard Operating Conditions (unless otherwise specified)<br>Operating Temperature $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for extended |              |      |                                                               |  |  |  |
|------------------------------|--------|-----------------------------------------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------|---------------------------------------------------------------|--|--|--|
|                              |        |                                               |                               | Standard Operating Conditions (unless otherwise specified) Operating Temperature $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for extended    |              |      |                                                               |  |  |  |
| Param<br>No.                 | Symbol | Characteristic                                | Min Typ† Max Units Conditions |                                                                                                                                                               |              |      |                                                               |  |  |  |
|                              | VDD    | Supply Voltage                                |                               |                                                                                                                                                               |              |      |                                                               |  |  |  |
| D001                         |        | PIC16LC54A                                    | 3.0<br>2.5                    |                                                                                                                                                               | 6.25<br>6.25 | -    | XT and RC modes<br>LP mode                                    |  |  |  |
| D001A                        |        | PIC16C54A                                     | 3.5<br>4.5                    | _                                                                                                                                                             | 5.5<br>5.5   | V    | RC and XT modes<br>HS mode                                    |  |  |  |
| D002                         | Vdr    | RAM Data Retention Voltage <sup>(1)</sup>     | _                             | 1.5*                                                                                                                                                          | _            | V    | Device in SLEEP mode                                          |  |  |  |
| D003                         | VPOR   | VDD Start Voltage to ensure<br>Power-on Reset | _                             | Vss                                                                                                                                                           | _            | V    | See Section 5.1 for details on Power-on Reset                 |  |  |  |
| D004                         | SVDD   | VDD Rise Rate to ensure<br>Power-on Reset     | 0.05*                         | _                                                                                                                                                             | _            | V/ms | See Section 5.1 for details on Power-on Reset                 |  |  |  |
|                              | IDD    | Supply Current <sup>(2)</sup>                 |                               |                                                                                                                                                               |              |      |                                                               |  |  |  |
| D010                         |        | PIC16LC54A                                    | _                             | 0.5                                                                                                                                                           | 25           | mA   | Fosc = 4.0 MHz, VDD = 5.5V, RC <sup>(3)</sup> and XT modes    |  |  |  |
|                              |        |                                               | _                             | 11                                                                                                                                                            | 27           | μА   | FOSC = 32 kHz, VDD = 2.5V,<br>LP mode, Commercial             |  |  |  |
|                              |        |                                               | _                             | 11                                                                                                                                                            | 35           | μА   | FOSC = 32 kHz, VDD = 2.5V,<br>LP mode, Industrial             |  |  |  |
|                              |        |                                               | _                             | 11                                                                                                                                                            | 37           | μА   | FOSC = 32 kHz, VDD = 2.5V,<br>LP mode, Extended               |  |  |  |
| D010A                        |        | PIC16C54A                                     | _                             | 1.8                                                                                                                                                           | 3.3          | mA   | Fosc = 4.0 MHz, VDD = 5.5V,<br>RC <sup>(3)</sup> and XT modes |  |  |  |
|                              |        |                                               | _                             | 4.8                                                                                                                                                           | 10           | mA   | FOSC = 10 MHz, VDD = 5.5V,<br>HS mode                         |  |  |  |
|                              |        |                                               | _                             | 9.0                                                                                                                                                           | 20           | mA   | FOSC = 20 MHz, VDD = 5.5V,<br>HS mode                         |  |  |  |

Legend: Rows with standard voltage device data only are shaded for improved readability.

- \* These parameters are characterized but not tested.
- † Data in the Typical ("Typ") column is based on characterization results at 25°C. This data is for design guidance only and is not tested.
- Note 1: This is the limit to which VDD can be lowered in SLEEP mode without losing RAM data.
  - 2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as bus loading, oscillator type, bus rate, internal code execution pattern and temperature also have an impact on the current consumption.
    - a) The test conditions for all IDD measurements in active Operation mode are: OSC1 = external square wave, from rail-to-rail; all I/O pins tristated, pulled to Vss, ToCKI = VDD, MCLR = VDD; WDT enabled/disabled as specified.
    - b) For standby current measurements, the conditions are the same, except that the device is in SLEEP mode. The power-down current in SLEEP mode does not depend on the oscillator type.
  - 3: Does not include current through REXT. The current through the resistor can be estimated by the formula: IR = VDD/2REXT (mA) with REXT in  $k\Omega$ .

#### **Timing Parameter Symbology and Load Conditions** 15.5

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

1. TppS2ppS

Low

2. TppS

| Т    |                                         |                    |
|------|-----------------------------------------|--------------------|
| F    | Frequency                               | T Time             |
| Lowe | ercase letters (pp) and their meanings: |                    |
| рр   |                                         |                    |
| 2    | to                                      | mc MCLR            |
| ck   | CLKOUT                                  | osc oscillator     |
| су   | cycle time                              | os OSC1            |
| drt  | device reset timer                      | t0 T0CKI           |
| io   | I/O port                                | wdt watchdog timer |
| Uppe | ercase letters and their meanings:      |                    |
| S    |                                         |                    |
| F    | Fall                                    | P Period           |
| Н    | High                                    | R Rise             |
| I    | Invalid (Hi-impedance)                  | V Valid            |

Hi-impedance

#### **FIGURE 15-1:** LOAD CONDITIONS FOR DEVICE TIMING SPECIFICATIONS - PIC16C54A



# 17.1 DC Characteristics:PIC16C54C/C55A/C56A/C57C/C58B-04, 20 (Commercial, Industrial) PIC16LC54C/LC55A/LC56A/LC57C/LC58B-04 (Commercial, Industrial) PIC16CR54C/CR56A/CR57C/CR58B-04, 20 (Commercial, Industrial) PIC16LCR54C/LCR56A/LCR57C/LCR58B-04 (Commercial, Industrial)

| PIC16LC5X PIC16LCR5X (Commercial, Industrial)     |        |                                 | Standard Operating Conditions (unless otherwise specified) Operating Temperature $0^{\circ}C \le TA \le +70^{\circ}C$ for commercial $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial      |          |      |    |                                                   |  |
|---------------------------------------------------|--------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------|----|---------------------------------------------------|--|
| PIC16C5X<br>PIC16CR5X<br>(Commercial, Industrial) |        |                                 | Standard Operating Conditions (unless otherwise specified)  Operating Temperature $0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial $-40^{\circ}C \leq TA \leq +85^{\circ}C$ for industrial |          |      |    |                                                   |  |
| Param<br>No.                                      | Symbol | Characteristic/Device           | Min Typ† Max Units Conditions                                                                                                                                                                   |          |      |    |                                                   |  |
|                                                   | IDD    | Supply Current <sup>(2,3)</sup> |                                                                                                                                                                                                 |          |      |    |                                                   |  |
| D010                                              |        | PIC16LC5X                       | _                                                                                                                                                                                               | 0.5      | 2.4  | mA | Fosc = 4.0 MHz, VDD = 5.5V, XT and                |  |
|                                                   |        |                                 | _                                                                                                                                                                                               | 11       | 27   | μΑ | RC modes                                          |  |
|                                                   |        |                                 |                                                                                                                                                                                                 | 14       | 35   | μΑ | Fosc = 32 kHz, VDD = 2.5V, LP mode,<br>Commercial |  |
|                                                   |        |                                 |                                                                                                                                                                                                 | 14       | 33   | μΑ | FOSC = 32 kHz, VDD = 2.5V, LP mode,               |  |
|                                                   |        |                                 |                                                                                                                                                                                                 |          |      |    | Industrial                                        |  |
| D010A                                             |        | PIC16C5X                        | _                                                                                                                                                                                               | 1.8      | 2.4  | mA | Fosc = 4 MHz, VDD = 5.5V, XT and RC               |  |
|                                                   |        |                                 | _                                                                                                                                                                                               | 2.6      | 3.6* | mA | modes                                             |  |
|                                                   |        |                                 | _                                                                                                                                                                                               | 4.5      | 16   | mA | FOSC = 10 MHz, VDD = 3.0V, HS mode                |  |
|                                                   |        |                                 | _                                                                                                                                                                                               | 14       | 32   | μΑ | FOSC = 20 MHz, VDD = 5.5V, HS mode                |  |
|                                                   |        |                                 |                                                                                                                                                                                                 |          |      |    | FOSC = 32 kHz, VDD = 3.0V, LP mode,               |  |
|                                                   |        |                                 | _                                                                                                                                                                                               | 17       | 40   | μΑ | Commercial                                        |  |
|                                                   |        |                                 |                                                                                                                                                                                                 |          |      |    | FOSC = 32 kHz, VDD = 3.0V, LP mode,               |  |
|                                                   |        |                                 |                                                                                                                                                                                                 | <u> </u> |      |    | Industrial                                        |  |

Legend: Rows with standard voltage device data only are shaded for improved readability.

- \* These parameters are characterized but not tested.
- † 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: This is the limit to which VDD can be lowered in SLEEP mode without losing RAM data.
  - 2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as bus loading, oscillator type, bus rate, internal code execution pattern and temperature also have an impact on the current consumption.
    - a) The test conditions for all IDD measurements in active Operation mode are: OSC1 = external square wave, from rail-to-rail; all I/O pins tristated, pulled to Vss, T0CKI = VDD, MCLR = VDD; WDT enabled/disabled as specified
    - b) For standby current measurements, the conditions are the same, except that the device is in SLEEP mode. The power-down current in SLEEP mode does not depend on the oscillator type.
  - 3: Does not include current through REXT. The current through the resistor can be estimated by the formula: IR = VDD/2REXT (mA) with REXT in  $k\Omega$ .

#### 17.5 Timing Diagrams and Specifications

FIGURE 17-6: EXTERNAL CLOCK TIMING - PIC16C5X, PIC16CR5X



TABLE 17-1: EXTERNAL CLOCK TIMING REQUIREMENTS - PIC16C5X, PIC16CR5X

Standard Operating Conditions (unless otherwise specified)

Operating Temperature  $0^{\circ}C \leq TA \leq +70^{\circ}C \text{ for commercial}$   $-40^{\circ}C \leq TA \leq +85^{\circ}C \text{ for industrial}$   $-40^{\circ}C \leq TA \leq +125^{\circ}C \text{ for extended}$ 

| Param<br>No. | Symbol | Characteristic                          | Min  | Typ† | Max   | Units | Conditions       |
|--------------|--------|-----------------------------------------|------|------|-------|-------|------------------|
|              | Fosc   | External CLKIN Frequency <sup>(1)</sup> | DC   | _    | 4.0   | MHz   | XT osc mode      |
|              |        |                                         | DC   | _    | 4.0   | MHz   | HS osc mode (04) |
|              |        |                                         | DC   | _    | 20    | MHz   | HS osc mode (20) |
|              |        |                                         | DC   | _    | 200   | kHz   | LP osc mode      |
|              |        | Oscillator Frequency <sup>(1)</sup>     | DC   | _    | 4.0   | MHz   | RC osc mode      |
|              |        |                                         | 0.45 | _    | 4.0   | MHz   | XT osc mode      |
|              |        |                                         | 4.0  | _    | 4.0   | MHz   | HS osc mode (04) |
|              |        |                                         | 4.0  | _    | 20    | MHz   | HS osc mode (20) |
|              |        |                                         | 5.0  | _    | 200   | kHz   | LP osc mode      |
| 1            | Tosc   | External CLKIN Period <sup>(1)</sup>    | 250  | _    | _     | ns    | XT osc mode      |
|              |        |                                         | 250  | _    | _     | ns    | HS osc mode (04) |
|              |        |                                         | 50   | _    | _     | ns    | HS osc mode (20) |
|              |        |                                         | 5.0  | _    | _     | μS    | LP osc mode      |
|              |        | Oscillator Period <sup>(1)</sup>        | 250  | _    | _     | ns    | RC osc mode      |
|              |        |                                         | 250  | _    | 2,200 | ns    | XT osc mode      |
|              |        |                                         | 250  | _    | 250   | ns    | HS osc mode (04) |
|              |        |                                         | 50   | _    | 250   | ns    | HS osc mode (20) |
|              |        |                                         | 5.0  | _    | 200   | μS    | LP osc mode      |

These parameters are characterized but not tested.

<sup>†</sup> 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 1: All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption.

When an external clock input is used, the "max" cycle time limit is "DC" (no clock) for all devices.

<sup>2:</sup> Instruction cycle period (TcY) equals four times the input oscillator time base period.

NOTES:

#### 20.0 DEVICE CHARACTERIZATION - PIC16LC54C 40MHz

The graphs and tables provided following this note are a statistical summary based on a limited number of samples and are provided for informational purposes only. The performance characteristics listed herein are not tested or guaranteed. In some graphs or tables, the data presented may be outside the specified operating range (e.g., outside specified power supply range) and therefore outside the warranted range.

"Typical" represents the mean of the distribution at 25°C. "Maximum" or "minimum" represents (mean +  $3\sigma$ ) or (mean –  $3\sigma$ ) respectively, where  $\sigma$  is a standard deviation, over the whole temperature range.





## FIGURE 20-7: WDT TIMER TIME-OUT PERIOD vs. VDD<sup>(1)</sup>



TABLE 20-1: INPUT CAPACITANCE

| Pin         | Typical Capacitance (pF) |          |  |  |  |
|-------------|--------------------------|----------|--|--|--|
| FIII        | 18L PDIP                 | 18L SOIC |  |  |  |
| RA port     | 5.0                      | 4.3      |  |  |  |
| RB port     | 5.0                      | 4.3      |  |  |  |
| MCLR        | 17.0                     | 17.0     |  |  |  |
| OSC1        | 4.0                      | 3.5      |  |  |  |
| OSC2/CLKOUT | 4.3                      | 3.5      |  |  |  |
| TOCKI       | 3.2                      | 2.8      |  |  |  |

All capacitance values are typical at  $25^{\circ}$ C. A part-to-part variation of  $\pm 25\%$  (three standard deviations) should be taken into account.

FIGURE 20-8: IOH vs. VOH, VDD = 5 V



#### W

| W Register                 |        |
|----------------------------|--------|
| Value on reset             | 20     |
| Wake-up from SLEEP         | 19, 47 |
| Watchdog Timer (WDT)       |        |
| Period                     | 46     |
| Programming Considerations | 46     |
| Register values on reset   |        |
| WWW, On-Line Support       | 3      |
| x                          |        |
| XORLW                      | 60     |
| XORWF                      | 60     |
| z                          |        |
| Zero (Z) bit               | 9, 29  |