

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

| Betalls                    |                                                                            |
|----------------------------|----------------------------------------------------------------------------|
| Product Status             | Active                                                                     |
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 4MHz                                                                       |
| Connectivity               | -                                                                          |
| Peripherals                | POR, WDT                                                                   |
| Number of I/O              | 13                                                                         |
| Program Memory Size        | 3.5KB (2K x 14)                                                            |
| Program Memory Type        | ОТР                                                                        |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 128 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                                                  |
| Data Converters            | -                                                                          |
| Oscillator Type            | External                                                                   |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 18-SOIC (0.295", 7.50mm Width)                                             |
| Supplier Device Package    | 18-SOIC                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c558-04e-so |

Email: info@E-XFL.COM

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

# FIGURE 3-1: BLOCK DIAGRAM



# 4.0 MEMORY ORGANIZATION

## 4.1 Program Memory Organization

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





#### FIGURE 4-2:

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



### 4.2 Data Memory Organization

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

#### 4.2.1 GENERAL PURPOSE REGISTER FILE

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

## FIGURE 4-3:

### DATA MEMORY MAP FOR THE PIC16C554

| File<br>Address                                   | 3                   |                     | File<br>Address |
|---------------------------------------------------|---------------------|---------------------|-----------------|
| 00h                                               | INDF <sup>(1)</sup> | INDF <sup>(1)</sup> | 80h             |
| 01h                                               | TMR0                | OPTION              | 81h             |
| 02h                                               | PCL                 | PCL                 | 82h             |
| 03h                                               | STATUS              | STATUS              | 83h             |
| 04h                                               | FSR                 | FSR                 | 84h             |
| 05h                                               | PORTA               | TRISA               | 85h             |
| 06h                                               | PORTB               | TRISB               | 86h             |
| 07h                                               | 1 OILIB             | THE                 | 87h             |
| 08h                                               |                     |                     | 88h             |
| 09h                                               |                     |                     | 89h             |
| 0Ah                                               | PCLATH              | PCLATH              | 8Ah             |
| 0Bh                                               | INTCON              | INTCON              | 8Bh             |
| 0Ch                                               |                     |                     | 8Ch             |
| 0Dh                                               |                     |                     | 8Dh             |
| 0Eh                                               |                     | PCON                | 8Eh             |
| 0Eh                                               |                     | 10011               | 8Fh             |
| 10h                                               |                     |                     | 90h             |
| 11h                                               |                     |                     | 91h             |
| 12h                                               |                     |                     | 92h             |
| 13h                                               |                     |                     | 93h             |
| 14h                                               |                     |                     | 94h             |
| 15h                                               |                     |                     | 95h             |
| 16h                                               |                     |                     | 96h             |
| 17h                                               |                     |                     | 97h             |
| 18h                                               |                     |                     | 98h             |
| 19h                                               |                     |                     | 99h             |
| 1Ah                                               |                     |                     | 9Ah             |
| 1Bh                                               |                     |                     | 9Bh             |
| 1Ch                                               |                     |                     | 9Ch             |
| 1Dh                                               |                     |                     | 9Dh             |
| 1Eh                                               |                     |                     | 9Eh             |
| 1Fh                                               |                     |                     | 9Fh             |
| 20h                                               |                     |                     | A0h             |
| -                                                 | General             |                     | 7.011           |
|                                                   | Purpose<br>Register |                     |                 |
| 6Fh                                               | regiotor            |                     |                 |
| 70h                                               |                     |                     |                 |
|                                                   |                     |                     |                 |
| ſ                                                 |                     |                     |                 |
|                                                   |                     |                     |                 |
| 7Fh                                               |                     |                     | FFh             |
| ,,,,,                                             | Bank 0              | Bank 1              |                 |
| Unimplemented data memory locations, read as '0'. |                     |                     |                 |
| Note 1:                                           | Not a physical regi |                     |                 |
|                                                   |                     |                     |                 |

#### FIGURE 4-4: DATA MEMORY MAP FOR THE PIC16C557

|                  | IHE                 | PIC16C557           |                                                                                           |  |  |  |
|------------------|---------------------|---------------------|-------------------------------------------------------------------------------------------|--|--|--|
| File<br>Address  | 8                   |                     | File<br>Address                                                                           |  |  |  |
| 00h              | INDF <sup>(1)</sup> | INDF <sup>(1)</sup> | 80h                                                                                       |  |  |  |
| 01h              | TMR0                | OPTION              | 81h                                                                                       |  |  |  |
| 02h              | PCL                 | PCL                 | 82h                                                                                       |  |  |  |
| 03h              | STATUS              | STATUS              | 83h                                                                                       |  |  |  |
| 04h              | FSR                 | FSR                 | 84h                                                                                       |  |  |  |
| 05h              | PORTA               | TRISA               | 85h                                                                                       |  |  |  |
| 06h              | PORTB               | TRISB               | 86h                                                                                       |  |  |  |
| 07h              | PORTC               | TRISC               | 87h                                                                                       |  |  |  |
| 08h              |                     |                     | 88h                                                                                       |  |  |  |
| 09h              |                     |                     | 89h                                                                                       |  |  |  |
| 0Ah              | PCLATH              | PCLATH              | 8Ah                                                                                       |  |  |  |
| 0Bh              | INTCON              | INTCON              | 8Bh                                                                                       |  |  |  |
| 0Ch              |                     |                     | 8Ch                                                                                       |  |  |  |
| 0Dh              |                     |                     | 8Dh                                                                                       |  |  |  |
| 0Eh              |                     | PCON                | 8Eh                                                                                       |  |  |  |
| 0Fh              |                     |                     | 8Fh                                                                                       |  |  |  |
| 10h              |                     |                     | 90h                                                                                       |  |  |  |
| 11h              |                     |                     | 91h                                                                                       |  |  |  |
| 12h              |                     |                     | 92h                                                                                       |  |  |  |
| 13h              |                     |                     | 93h                                                                                       |  |  |  |
| 14h              |                     |                     | 94h                                                                                       |  |  |  |
| 15h              |                     |                     | 95h                                                                                       |  |  |  |
| 16h              |                     |                     | 96h                                                                                       |  |  |  |
| 17h              |                     |                     | 97h                                                                                       |  |  |  |
| 18h              |                     |                     | 98h                                                                                       |  |  |  |
| 19h              |                     |                     | 99h                                                                                       |  |  |  |
| 1Ah              |                     |                     | 9Ah                                                                                       |  |  |  |
| 1Bh              |                     |                     | 9Bh                                                                                       |  |  |  |
| 1Ch              |                     |                     | 9Ch                                                                                       |  |  |  |
| 1Dh              |                     |                     | 9Dh                                                                                       |  |  |  |
| 1Eh              |                     |                     | 9Eh                                                                                       |  |  |  |
| 1Fh              |                     |                     | 9Fh                                                                                       |  |  |  |
| 20h              |                     |                     | A0h                                                                                       |  |  |  |
|                  | General             | General             |                                                                                           |  |  |  |
|                  | Purpose<br>Register | Purpose<br>Register |                                                                                           |  |  |  |
|                  |                     |                     | BFh                                                                                       |  |  |  |
|                  |                     |                     | C0h                                                                                       |  |  |  |
|                  |                     |                     |                                                                                           |  |  |  |
|                  |                     |                     |                                                                                           |  |  |  |
|                  |                     |                     |                                                                                           |  |  |  |
| 7Fh              |                     |                     | FFh                                                                                       |  |  |  |
| ,,,,,            | Bank 0              | Bank 1              |                                                                                           |  |  |  |
| Unimp<br>Note 1: |                     |                     | Unimplemented data memory locations, read as '0'. <b>Note 1:</b> Not a physical register. |  |  |  |

bit 5

#### 4.2.2.2 OPTION Register

The OPTION register is a readable and writable register which contains various control bits to configure the TMR0/WDT prescaler, the external RB0/INT interrupt, TMR0 and the weak pull-ups on PORTB.

| Note 1: To achieve a 1:1 prescaler assignment for |
|---------------------------------------------------|
| TMR0, assign the prescaler to the WDT             |
| (PSA = 1).                                        |

| R/W-1 | R/W-1  | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 |
|-------|--------|-------|-------|-------|-------|-------|-------|
| RBPU  | INTEDG | TOCS  | TOSE  | PSA   | PS2   | PS1   | PS0   |
| bit7  |        |       |       |       |       |       | bit0  |
|       |        |       |       |       |       |       |       |

- bit 7 RBPU: PORTB Pull-up Enable bit
  - 1 = PORTB pull-ups are disabled
  - 0 = PORTB pull-ups are enabled by individual port latch values

#### bit 6 **INTEDG**: Interrupt Edge Select bit

- 1 = Interrupt on rising edge of RB0/INT pin
- 0 = Interrupt on falling edge of RB0/INT pin
- TOCS: TMR0 Clock Source Select bit
  - 1 = Transition on RA4/T0CKI pin
  - 0 = Internal instruction cycle clock (CLKOUT)
- bit 4 TOSE: TMR0 Source Edge Select bit
  - 1 = Increment on high-to-low transition on RA4/T0CKI pin
  - 0 = Increment on low-to-high transition on RA4/T0CKI pin

#### bit 3 **PSA**: Prescaler Assignment bit

- 1 = Prescaler is assigned to the WDT
- 0 = Prescaler is assigned to the Timer0 module

#### bit 2-0 PS2:PS0: Prescaler Rate Select bits

| Bit Value | TMR0 Rate | WDT Rate |
|-----------|-----------|----------|
| 000       | 1:2       | 1:1      |
| 001       | 1:4       | 1:2      |
| 010       | 1:8       | 1:4      |
| 011       | 1:16      | 1:8      |
| 100       | 1:32      | 1:16     |
| 101       | 1:64      | 1:32     |
| 110       | 1 : 128   | 1:64     |
| 111       | 1 : 256   | 1 : 128  |

| Legend:                  |                  |                      |                    |
|--------------------------|------------------|----------------------|--------------------|
| R = Readable bit         | W = Writable bit | U = Unimplemented    | bit, read as '0'   |
| - n = Value at POR reset | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown |





# 5.0 I/O PORTS

The PIC16C554 and PIC16C558 have two ports, PORTA and PORTB. The PIC16C557 has three ports, PORTA, PORTB and PORTC.

# 5.1 PORTA and TRISA Registers

PORTA is a 5-bit wide latch. RA4 is a Schmitt Trigger input and an open-drain output. Port RA4 is multiplexed with the T0CKI clock input. All other RA port pins have Schmitt Trigger input levels and full CMOS output drivers. All pins have data direction bits (TRIS registers) which can configure these pins as input or output.

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

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

**Note 1:** On RESET, the TRISA register is set to all inputs.

FIGURE 5-1: BLOCK DIAGRAM OF PORT PINS RA<3:0>



## FIGURE 5-2: BL

BLOCK DIAGRAM OF RA4









## 6.5 Interrupts

The PIC16C55X has 3 sources of interrupt:

- External interrupt RB0/INT
- TMR0 overflow interrupt
- PORTB change interrupts (pins RB7:RB4)

The interrupt control register (INTCON) records individual interrupt requests in flag bits. It also has individual and global interrupt enable bits.

A global interrupt enable bit, GIE (INTCON<7>) enables (if set) all un-masked interrupts or disables (if cleared) all interrupts. Individual interrupts can be disabled through their corresponding enable bits in INTCON register. GIE is cleared on RESET.

The "Return from Interrupt" instruction, RETFIE, exits the interrupt routine as well as sets the GIE bit, which re-enables RB0/INT interrupts.

The INT pin interrupt, the RB port change interrupt and the TMR0 overflow interrupt flags are contained in the INTCON register.

When an interrupt is responded to, the GIE is cleared to disable any further interrupt, the return address is pushed into the stack and the PC is loaded with 0004h. Once in the interrupt service routine the source(s) of the interrupt can be determined by polling the interrupt flag bits. The interrupt flag bit(s) must be cleared in software before re-enabling interrupts to avoid RB0/INT recursive interrupts. For external interrupt events, such as the INT pin or PORTB change interrupt, the interrupt latency will be three or four instruction cycles. The exact latency depends when the interrupt event occurs (Figure 6-12). The latency is the same for one or two cycle instructions. Once in the interrupt service routine, the source(s) of the interrupt can be determined by polling the interrupt flag bits. The interrupt flag bit(s) must be cleared in software before re-enabling interrupts to avoid multiple interrupt requests. Individual interrupt flag bits are set regardless of the status of their corresponding mask bit or the GIE bit.

- Note 1: Individual interrupt flag bits are set regardless of the status of their corresponding mask bit or the GIE bit.
  - 2: When an instruction that clears the GIE bit is executed, any interrupts that were pending for execution in the next cycle are ignored. The CPU will execute a NOP in the cycle immediately following the instruction which clears the GIE bit. The interrupts which were ignored are still pending to be serviced when the GIE bit is set again.



© 1996-2013 Microchip Technology Inc.

# 7.0 TIMER0 MODULE

The Timer0 module timer/counter has the following features:

- 8-bit timer/counter
- Readable and writable
- 8-bit software programmable prescaler
- · Internal or external clock select
- Interrupt on overflow from FFh to 00h
- Edge select for external clock

Figure 7-1 is a simplified block diagram of the Timer0 module.

Timer mode is selected by clearing the T0CS bit (OPTION<5>). In Timer mode, the TMR0 will increment every instruction cycle (without prescaler). If Timer0 is written, the increment is inhibited for the following two cycles (Figure 7-2 and Figure 7-3). The user can work around this by writing an adjusted value to TMR0.

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

The prescaler is shared between the Timer0 module and the Watchdog Timer. The prescaler assignment is controlled in software by the control bit PSA (OPTION<3>). Clearing the PSA bit will assign the prescaler to Timer0. The prescaler is not readable or writable. When the prescaler is assigned to the Timer0 module, prescale value of 1:2, 1:4, ..., 1:256 are selectable. Section 7.3 details the operation of the prescaler.

# 7.1 TIMER0 Interrupt

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



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



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

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

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

.....

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

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

| RETURN           | Return from Subroutine                                                                                                                                  |              |      |      |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------|------|--|--|--|
| Syntax:          | [ label ]                                                                                                                                               | RETUR        | N    |      |  |  |  |
| Operands:        | None                                                                                                                                                    |              |      |      |  |  |  |
| Operation:       | $TOS\toF$                                                                                                                                               | ъС           |      |      |  |  |  |
| Status Affected: | None                                                                                                                                                    |              |      |      |  |  |  |
| Encoding:        | 00                                                                                                                                                      | 0000         | 0000 | 1000 |  |  |  |
| Description:     | Return from subroutine. The stack is<br>POPed and the top of the stack (TOS)<br>is loaded into the program counter.<br>This is a two-cycle instruction. |              |      |      |  |  |  |
| Words:           | 1                                                                                                                                                       |              |      |      |  |  |  |
| Cycles:          | 2                                                                                                                                                       |              |      |      |  |  |  |
| Example          | RETURN                                                                                                                                                  |              |      |      |  |  |  |
|                  | After Inte<br>PC                                                                                                                                        | rrupt<br>= T | OS   |      |  |  |  |

| RETLW            | Return with Literal in W                                                                                                                                                            | F             |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| Syntax:          | [ <i>label</i> ] RETLW k                                                                                                                                                            | Sy            |
| Operands:        | $0 \le k \le 255$                                                                                                                                                                   | O             |
| Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow PC$                                                                                                                                        | O             |
| Status Affected: | None                                                                                                                                                                                | St            |
| Encoding:        | 11 01xx kkkk kkkk                                                                                                                                                                   | Er            |
| 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. | De            |
| Words:           | 1                                                                                                                                                                                   |               |
| Cycles:          | 2                                                                                                                                                                                   |               |
| Example          | CALL TABLE;W contains table<br>;offset value<br>;W now has table<br>value                                                                                                           | W<br>Cy<br>E> |
| TABLE            | ADDWF PC ;W = offset<br>RETLW k1 ;Begin table<br>RETLW k2 ;<br>•<br>•<br>RETLW kn ; End of table<br>Before Instruction                                                              |               |
|                  | W = 0x07                                                                                                                                                                            |               |
|                  | After Instruction                                                                                                                                                                   |               |
|                  | W = value of k8                                                                                                                                                                     |               |

| RLF             | Rotate Left f through Carry                                                                                                                                                                                 |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| yntax:          | [ <i>label</i> ] RLF f,d                                                                                                                                                                                    |
| )perands:       | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in  [0,1] \end{array}$                                                                                                                                           |
| peration:       | See description below                                                                                                                                                                                       |
| tatus Affected: | С                                                                                                                                                                                                           |
| ncoding:        | 00 1101 dfff ffff                                                                                                                                                                                           |
| escription:     | 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<br>the W register. If 'd' is 1 the result is<br>stored back in register 'f'. |
| Vords:          | 1                                                                                                                                                                                                           |
| ycles:          | 1                                                                                                                                                                                                           |
| xample          | RLF REG1,0                                                                                                                                                                                                  |
|                 | Before Instruction                                                                                                                                                                                          |
|                 | $\begin{array}{rcl} REG1 &= 1110 & 0110 \\ C &= 0 \end{array}$                                                                                                                                              |
|                 | After Instruction                                                                                                                                                                                           |
|                 | <b>REG1</b> = 1110 0110                                                                                                                                                                                     |
|                 | W = 1100 1100                                                                                                                                                                                               |
|                 | C = 1                                                                                                                                                                                                       |

NOTES:

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

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

These parameters are characterized but not tested.

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

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

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

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

# 10.3 Timing Parameter Symbology

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

#### 1. TppS2ppS

2. TppS

| т      |                                         |    |              |  |
|--------|-----------------------------------------|----|--------------|--|
| F      | Frequency                               | Т  | Time         |  |
| Lowerc | ase subscripts (pp) and their meanings: |    |              |  |
| рр     |                                         |    |              |  |
| ck     | CLKOUT                                  | OS | OSC1         |  |
| io     | I/O port                                | t0 | TOCKI        |  |
| mc     | MCLR                                    |    |              |  |
| Upperc | ase letters and their meanings:         |    |              |  |
| S      |                                         |    |              |  |
| F      | Fall                                    | Р  | Period       |  |
| Н      | High                                    | R  | Rise         |  |
| I      | Invalid (Hi-impedance)                  | V  | Valid        |  |
| L      | Low                                     | Z  | Hi-impedance |  |

# FIGURE 10-5: LOAD CONDITIONS









# TABLE 10-4: TIMER0 CLOCK REQUIREMENTS

| Param<br>No. | Sym  | Characteristic         |                | Min                    | Тур† | 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 Width  | No Prescaler   | 0.5 TCY + 20*          | _    | _   | ns    |                                       |
|              |      |                        | With Prescaler | 10*                    | _    | —   | ns    |                                       |
| 42           | Tt0P | T0CKI Period           |                | <u>Tcy + 40</u> *<br>N |      | _   | ns    | N = prescale value<br>(1, 2, 4,, 256) |

\* These parameters are characterized but not tested.

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

# FIGURE 10-10: LOAD CONDITIONS



© 1996-2013 Microchip Technology Inc.

NOTES:

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

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



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

\* Controlling Parameter § Significant Characteristic

Notes:

Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" (0.254mm) per side. JEDEC Equivalent: MO-150 Drawing No. C04-072

© 1996-2013 Microchip Technology Inc.

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

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

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

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

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

#### Trademarks

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

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

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

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

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

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

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

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

Printed on recycled paper.

ISBN: 9781620769737

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

# Worldwide Sales and Service

#### AMERICAS

Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: http://www.microchip.com/ support Web Address: www.microchip.com

Atlanta Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455

Boston Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

Chicago Itasca, IL Tel: 630-285-0071 Fax: 630-285-0075

**Cleveland** Independence, OH Tel: 216-447-0464 Fax: 216-447-0643

**Dallas** Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

Detroit Farmington Hills, MI Tel: 248-538-2250 Fax: 248-538-2260

Indianapolis Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453

Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608

Santa Clara Santa Clara, CA Tel: 408-961-6444 Fax: 408-961-6445

Toronto Mississauga, Ontario, Canada Tel: 905-673-0699 Fax: 905-673-6509

#### ASIA/PACIFIC

Asia Pacific Office Suites 3707-14, 37th Floor Tower 6, The Gateway Harbour City, Kowloon Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431 Australia - Sydney

Tel: 61-2-9868-6733 Fax: 61-2-9868-6755

**China - Beijing** Tel: 86-10-8569-7000 Fax: 86-10-8528-2104

**China - Chengdu** Tel: 86-28-8665-5511 Fax: 86-28-8665-7889

**China - Chongqing** Tel: 86-23-8980-9588 Fax: 86-23-8980-9500

**China - Hangzhou** Tel: 86-571-2819-3187 Fax: 86-571-2819-3189

**China - Hong Kong SAR** Tel: 852-2943-5100 Fax: 852-2401-3431

**China - Nanjing** Tel: 86-25-8473-2460

Fax: 86-25-8473-2470 China - Qingdao Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

**China - Shanghai** Tel: 86-21-5407-5533 Fax: 86-21-5407-5066

**China - Shenyang** Tel: 86-24-2334-2829 Fax: 86-24-2334-2393

**China - Shenzhen** Tel: 86-755-8864-2200 Fax: 86-755-8203-1760

**China - Wuhan** Tel: 86-27-5980-5300 Fax: 86-27-5980-5118

**China - Xian** Tel: 86-29-8833-7252 Fax: 86-29-8833-7256

**China - Xiamen** Tel: 86-592-2388138 Fax: 86-592-2388130

**China - Zhuhai** Tel: 86-756-3210040 Fax: 86-756-3210049

#### ASIA/PACIFIC

India - Bangalore Tel: 91-80-3090-4444 Fax: 91-80-3090-4123

India - New Delhi Tel: 91-11-4160-8631 Fax: 91-11-4160-8632

India - Pune Tel: 91-20-2566-1512 Fax: 91-20-2566-1513

**Japan - Osaka** Tel: 81-6-6152-7160 Fax: 81-6-6152-9310

**Japan - Tokyo** Tel: 81-3-6880- 3770 Fax: 81-3-6880-3771

**Korea - Daegu** Tel: 82-53-744-4301 Fax: 82-53-744-4302

Korea - Seoul Tel: 82-2-554-7200 Fax: 82-2-558-5932 or 82-2-558-5934

**Malaysia - Kuala Lumpur** Tel: 60-3-6201-9857 Fax: 60-3-6201-9859

**Malaysia - Penang** Tel: 60-4-227-8870 Fax: 60-4-227-4068

Philippines - Manila Tel: 63-2-634-9065 Fax: 63-2-634-9069

**Singapore** Tel: 65-6334-8870 Fax: 65-6334-8850

**Taiwan - Hsin Chu** Tel: 886-3-5778-366 Fax: 886-3-5770-955

**Taiwan - Kaohsiung** Tel: 886-7-213-7828 Fax: 886-7-330-9305

**Taiwan - Taipei** Tel: 886-2-2508-8600 Fax: 886-2-2508-0102

**Thailand - Bangkok** Tel: 66-2-694-1351 Fax: 66-2-694-1350

#### EUROPE

Austria - Wels Tel: 43-7242-2244-39 Fax: 43-7242-2244-393 Denmark - Copenhagen Tel: 45-4450-2828

France - Paris Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

Fax: 45-4485-2829

**Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

**Italy - Milan** Tel: 39-0331-742611 Fax: 39-0331-466781

**Netherlands - Drunen** Tel: 31-416-690399 Fax: 31-416-690340

**Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

**UK - Wokingham** Tel: 44-118-921-5869 Fax: 44-118-921-5820

11/29/12