# E·XFL



Welcome to E-XFL.COM

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

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

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

#### Details

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

Email: info@E-XFL.COM

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

NOTES:

# 3.1 Clocking Scheme/Instruction Cycle

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

# 3.2 Instruction Flow/Pipelining

An "Instruction Cycle" consists of four Q cycles (Q1, Q2, Q3 and Q4). The instruction fetch and execute are pipelined such that fetch takes one instruction cycle

while decode and execute takes another instruction cycle. However, due to the pipelining, each instruction effectively executes in one cycle. If an instruction causes the program counter to change (e.g., GOTO), then two cycles are required to complete the instruction (Example 3-1).

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

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



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

# EXAMPLE 3-1: INSTRUCTION PIPELINE FLOW



All instructions are single cycle, except for any program branches. These take two cycles since the fetch instruction is "flushed" from the pipeline while the new instruction is being fetched and then executed.

# 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                                                                                       |                     |                     | 87h             |  |  |  |
| 08h                                                                                       |                     |                     | 88h             |  |  |  |
| 09h                                                                                       |                     |                     | 89h             |  |  |  |
| 0Ah                                                                                       | PCLAIH              | PCLAIH              | 8Ah             |  |  |  |
| 0Bh                                                                                       | INTCON              | INICON              | 8Bh             |  |  |  |
| 0Ch                                                                                       |                     |                     | 8Ch             |  |  |  |
|                                                                                           |                     | DCON                |                 |  |  |  |
| 0En                                                                                       |                     | PCON                | 8En             |  |  |  |
| 10h                                                                                       |                     |                     |                 |  |  |  |
| 1011<br>11h                                                                               |                     |                     | 9011            |  |  |  |
| 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                                                                                       | General<br>Purpose  |                     | A0h             |  |  |  |
| 6Fh                                                                                       | Register            |                     |                 |  |  |  |
| 70h                                                                                       |                     |                     |                 |  |  |  |
|                                                                                           |                     |                     |                 |  |  |  |
| ı<br>I                                                                                    |                     |                     | $\neg$          |  |  |  |
|                                                                                           |                     |                     |                 |  |  |  |
| 7Fh                                                                                       |                     |                     | FFh             |  |  |  |
| 7111                                                                                      | Bank 0              | Bank 1              |                 |  |  |  |
| Unimplemented data memory locations, read as '0'. <b>Note 1:</b> Not a physical register. |                     |                     |                 |  |  |  |

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

| File<br>Address                         | 5                   |                     | 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                                     |                     |                     |                 |  |  |  |  |
| 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             | 7.011           |  |  |  |  |
|                                         | Purpose<br>Register | Purpose             |                 |  |  |  |  |
|                                         | register            |                     | BFh             |  |  |  |  |
|                                         |                     |                     | C0h             |  |  |  |  |
|                                         |                     |                     |                 |  |  |  |  |
| ſ                                       |                     |                     |                 |  |  |  |  |
|                                         |                     |                     |                 |  |  |  |  |
| 7Eh                                     |                     |                     | FFh             |  |  |  |  |
| 1 ETT 4                                 | Bank 0              | Bank 1              |                 |  |  |  |  |
| Unimp                                   | lemented data mer   | mory locations      | ad 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).                                        |

| REGISTER 4-2: | <b>OPTION REGISTER</b> | (ADDRESS 81H) |
|---------------|------------------------|---------------|
|---------------|------------------------|---------------|

| 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  | T0SE  | 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



# 5.3 PORTC and TRISC Registers<sup>(1)</sup>

PORTC is a 8-bit wide latch. All pins have data direction bits (TRIS registers) which can configure these pins as input or output.

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

Reading the PORTC 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

FIGURE 5-5: BLOCK DIAGRAM OF



| Name | Bit # | Buffer Type | Function                 |
|------|-------|-------------|--------------------------|
| RC0  | Bit 0 | TTL         | Bi-directional I/O port. |
| RC1  | Bit 1 | TTL         | Bi-directional I/O port. |
| RC2  | Bit 2 | TTL         | Bi-directional I/O port. |
| RC3  | Bit 3 | TTL         | Bi-directional I/O port. |
| RC4  | Bit 4 | TTL         | Bi-directional I/O port. |
| RC5  | Bit 5 | TTL         | Bi-directional I/O port. |
| RC6  | Bit 6 | TTL         | Bi-directional I/O port. |
| RC7  | Bit 7 | TTL         | Bi-directional I/O port. |

Legend: ST = Schmitt Trigger, TTL = TTL input

#### TABLE 5-6: SUMMARY OF REGISTERS ASSOCIATED WITH PORTC AND TRISC

| Address | Name  | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Value on<br>POR | Value on<br>All Other<br>RESETS |
|---------|-------|--------|--------|--------|--------|--------|--------|--------|--------|-----------------|---------------------------------|
| 07h     | PORTC | RC7    | RC6    | RC5    | RC4    | RC3    | RC2    | RC1    | RC0    | xxxx xxxx       | uuuu uuuu                       |
| 87h     | TRISC | TRISC7 | TRISC6 | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 1111 1111       | 1111 1111                       |

Legend: x = unknown, u = unchanged Note 1: PIC16C557 ONLY.

### 6.2 Oscillator Configurations

#### 6.2.1 OSCILLATOR TYPES

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

- LP Low Power Crystal
- XT Crystal/Resonator
- HS High Speed Crystal/Resonator
- RC Resistor/Capacitor

# 6.2.2 CRYSTAL OSCILLATOR / CERAMIC RESONATORS

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

#### FIGURE 6-1: CRYSTAL OPERATION (OR CERAMIC RESONATOR) (HS, XT OR LP OSC CONFIGURATION)



FIGURE 6-2: EXTERNAL CLOCK INPUT OPERATION (HS, XT OR LP OSC



#### TABLE 6-1: CAPACITOR SELECTION FOR CERAMIC RESONATORS (PRELIMINARY)

| Ranges                                                                                                                                        | Characterize                  |                                         |                                         |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-----------------------------------------|-----------------------------------------|--|--|--|--|--|
| Mode                                                                                                                                          | Freq                          | OSC2(C2)                                |                                         |  |  |  |  |  |
| ХТ                                                                                                                                            | 455 kHz<br>2.0 MHz<br>4.0 MHz | 22 - 100 pF<br>15 - 68 pF<br>15 - 68 pF | 22 - 100 pF<br>15 - 68 pF<br>15 - 68 pF |  |  |  |  |  |
| HS                                                                                                                                            | 8.0 MHz<br>16.0 MHz           | 10 - 68 pF<br>10 - 22 pF                |                                         |  |  |  |  |  |
| <b>Note 1:</b> Higher capacitance increases the stability of the oscillator but also increases the start-up time. These values are for design |                               |                                         |                                         |  |  |  |  |  |

| of the oscillator but also increases the    |
|---------------------------------------------|
| start-up time. These values are for design  |
| guidance only. Since each resonator has     |
| its own characteristics, the user should    |
| consult with the resonator manufacturer for |
| appropriate values of external compo-       |
| nents                                       |

| TABLE 6-2: | CAPACITOR SELECTION FOR |
|------------|-------------------------|
|            | CRYSTAL OSCILLATOR      |
|            | (PRELIMINARY)           |

| Mode    | Freq                                                                                                                                                             | OSC1(C1)    | OSC2(C2)     |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|
| LP      | 32 kHz                                                                                                                                                           | 68 - 100 pF | 68 - 100 pF  |
|         | 200 kHz                                                                                                                                                          | 15 - 30 pF  | 15 - 30 pF   |
| XT      | 100 kHz                                                                                                                                                          | 68 - 150 pF | 150 - 200 pF |
|         | 2 MHz                                                                                                                                                            | 15 - 30 pF  | 15 - 30 pF   |
|         | 4 MHz                                                                                                                                                            | 15 - 30 pF  | 15 - 30 pF   |
| HS      | 8 MHz                                                                                                                                                            | 15 - 30 pF  | 15 - 30 pF   |
|         | 10 MHz                                                                                                                                                           | 15 - 30 pF  | 15 - 30 pF   |
|         | 20 MHz                                                                                                                                                           | 15 - 30 pF  | 15 - 30 pF   |
| Note 1: | es the stability<br>eases the<br>are for design<br>equired in HS<br>o avoid over-<br>e level specifi-<br>as its own<br>uld consult<br>r for appropri-<br>onents. |             |              |

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

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

# TABLE 6-3: TIMEOUT IN VARIOUS SITUATIONS

| Oscillator    | Pow               | Wake-up from |           |  |
|---------------|-------------------|--------------|-----------|--|
| Configuration | PWRTE = 0         | PWRTE = 1    | SLEEP     |  |
| XT, HS, LP    | 72 ms + 1024 Tosc | 1024 Tosc    | 1024 Tosc |  |
| RC            | 72 ms             | —            | —         |  |

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

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

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





| TABLE 0-7. SUMIMANT OF WATCHDOG TIMEN REGISTERS | TABLE 6-7: | SUMMARY OF WATCHDOG TIMER REGISTERS |
|-------------------------------------------------|------------|-------------------------------------|
|-------------------------------------------------|------------|-------------------------------------|

| Address | Name         | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on POR | Value on all other RESETS |
|---------|--------------|-------|----------|-------|-------|-------|-------|-------|-------|--------------|---------------------------|
| 2007h   | Config. bits |       | Reserved | CP1   | CP0   | PWRTE | WDTE  | FOSC1 | FOSC0 |              |                           |
| 81h     | OPTION       | RBPU  | INTEDG   | TOCS  | TOSE  | PSA   | PS2   | PS1   | PS0   | 1111 1111    | 1111 1111                 |

Legend: x = unknown, u = unchanged, q = value depends on condition, — = unimplemented, read as '0'. Shaded cells are not used by the Watchdog Timer.

# 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



# 8.1 Instruction Descriptions

| ADDLW            | Add Literal and W                                                                                                       |  |  |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ADDLW k                                                                                                |  |  |  |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                                                       |  |  |  |  |  |  |  |
| Operation:       | $(W) + k \to (W)$                                                                                                       |  |  |  |  |  |  |  |
| Status Affected: | C, DC, Z                                                                                                                |  |  |  |  |  |  |  |
| Encoding:        | 11 111x kkkk kkkk                                                                                                       |  |  |  |  |  |  |  |
| Description:     | The contents of the W register are<br>added to the eight bit literal 'k' and the<br>result is placed in the W register. |  |  |  |  |  |  |  |
| Words:           | 1                                                                                                                       |  |  |  |  |  |  |  |
| Cycles:          | 1                                                                                                                       |  |  |  |  |  |  |  |
| Example          | ADDLW 0x15                                                                                                              |  |  |  |  |  |  |  |
|                  | Before Instruction                                                                                                      |  |  |  |  |  |  |  |
|                  | W = 0x10                                                                                                                |  |  |  |  |  |  |  |
|                  | After Instruction                                                                                                       |  |  |  |  |  |  |  |
|                  | W = 0x25                                                                                                                |  |  |  |  |  |  |  |

| ADDWF            | Add W and f                                                                                                                                                               |  |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ADDWF f,d                                                                                                                                                |  |  |  |  |  |  |
| Operands:        | $0 \le f \le 127$                                                                                                                                                         |  |  |  |  |  |  |
|                  | $d \in [0,1]$                                                                                                                                                             |  |  |  |  |  |  |
| Operation:       | $(W) + (f) \to (dest)$                                                                                                                                                    |  |  |  |  |  |  |
| Status Affected: | C, DC, Z                                                                                                                                                                  |  |  |  |  |  |  |
| Encoding:        | 00 0111 dfff ffff                                                                                                                                                         |  |  |  |  |  |  |
| Description:     | Add the contents of the W register<br>with register 'f'. If 'd' is 0 the result is<br>stored in the W register. If 'd' is 1 the<br>result is stored back in register 'f'. |  |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                         |  |  |  |  |  |  |
| Cycles:          | 1                                                                                                                                                                         |  |  |  |  |  |  |
| Example          | ADDWF FSR, 0                                                                                                                                                              |  |  |  |  |  |  |
|                  | Before Instruction                                                                                                                                                        |  |  |  |  |  |  |
|                  | W = 0x17                                                                                                                                                                  |  |  |  |  |  |  |
|                  | FSR = 0xC2                                                                                                                                                                |  |  |  |  |  |  |
|                  | After Instruction                                                                                                                                                         |  |  |  |  |  |  |
|                  | W = 0xD9                                                                                                                                                                  |  |  |  |  |  |  |
|                  | FSR = 0xC2                                                                                                                                                                |  |  |  |  |  |  |

| ANDLW            | DLW AND Literal with W                                                                                              |           |       |      |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------|-----------|-------|------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ANDLW k                                                                                            |           |       |      |  |  |  |  |  |
| Operands:        | $0 \le k \le 2$                                                                                                     | 255       |       |      |  |  |  |  |  |
| Operation:       | (W) .AN                                                                                                             | ID. (k) → | → (W) |      |  |  |  |  |  |
| Status Affected: | Z                                                                                                                   |           |       |      |  |  |  |  |  |
| Encoding:        | 11                                                                                                                  | 1001      | kkkk  | kkkk |  |  |  |  |  |
| Description:     | The contents of W register are<br>AND'ed with the eight bit literal 'k'. The<br>result is placed in the W register. |           |       |      |  |  |  |  |  |
| Words:           | 1                                                                                                                   |           |       |      |  |  |  |  |  |
| Cycles:          | 1                                                                                                                   |           |       |      |  |  |  |  |  |
| Example          | ANDLW                                                                                                               | 0x5F      |       |      |  |  |  |  |  |
|                  | Before Instruction                                                                                                  |           |       |      |  |  |  |  |  |
|                  | W = 0xA3                                                                                                            |           |       |      |  |  |  |  |  |
|                  | After Ins                                                                                                           | struction |       |      |  |  |  |  |  |
|                  | W                                                                                                                   | =         | 0x03  |      |  |  |  |  |  |

| ANDWF                                                                                                                                                       | AND W with f                                                    |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|--|--|--|--|--|--|--|
| Syntax:                                                                                                                                                     | [label] ANDWF f,d                                               |  |  |  |  |  |  |  |
| Operands:                                                                                                                                                   | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$ |  |  |  |  |  |  |  |
| Operation:                                                                                                                                                  | (W) .AND. (f) $\rightarrow$ (dest)                              |  |  |  |  |  |  |  |
| Status Affected:                                                                                                                                            | Z                                                               |  |  |  |  |  |  |  |
| Encoding:                                                                                                                                                   | 00 0101 dfff ffff                                               |  |  |  |  |  |  |  |
| Description: AND the W register with register<br>'d' is 0 the result is stored in the V<br>register. If 'd' is 1 the result is sto<br>back in register 'f'. |                                                                 |  |  |  |  |  |  |  |
| Words:                                                                                                                                                      | 1                                                               |  |  |  |  |  |  |  |
| Cycles:                                                                                                                                                     | 1                                                               |  |  |  |  |  |  |  |
| Example                                                                                                                                                     | ANDWF FSR, 1                                                    |  |  |  |  |  |  |  |
|                                                                                                                                                             | Before Instruction                                              |  |  |  |  |  |  |  |
|                                                                                                                                                             | W = 0x17                                                        |  |  |  |  |  |  |  |
|                                                                                                                                                             | FSR = 0xC2                                                      |  |  |  |  |  |  |  |
|                                                                                                                                                             | After Instruction                                               |  |  |  |  |  |  |  |
|                                                                                                                                                             | W = 0x17                                                        |  |  |  |  |  |  |  |
|                                                                                                                                                             | FSR = 0x02                                                      |  |  |  |  |  |  |  |

-







<sup>© 1996-2013</sup> Microchip Technology Inc.

# 10.1 DC Characteristics: PIC16C55X-04 (Commercial, Industrial, Extended) PIC16C55X-20 (Commercial, Industrial, Extended) HCS1365-04 (Commercial, Industrial, Extended)

| DC Cha        | racterist | $\begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise stated)} \\ \mbox{Operating temperature} & -40^\circ C \leq TA \leq +85^\circ C \mbox{ for industrial and} \\ & 0^\circ C \leq TA \leq +70^\circ C \mbox{ for commercial and} \\ & -40^\circ C \leq TA \leq +125^\circ C \mbox{ for extended} \end{array}$ |            |      |            |        |                                                                                           |
|---------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------|------------|--------|-------------------------------------------------------------------------------------------|
| Param<br>No.  | Sym       | Characteristic                                                                                                                                                                                                                                                                                                                      | Min        | Тур† | Max        | Units  | Conditions                                                                                |
|               | Vdd       | Supply Voltage                                                                                                                                                                                                                                                                                                                      |            |      |            |        |                                                                                           |
| D001          |           | 16LC55X                                                                                                                                                                                                                                                                                                                             | 3.0<br>2.5 | —    | 5.5<br>5.5 | V      | XT and RC osc configuration<br>LP osc configuration                                       |
| D001<br>D001A |           | 16C55X                                                                                                                                                                                                                                                                                                                              | 3.0<br>4.5 |      | 5.5<br>5.5 | V<br>V | XT, RC and LP osc configuration<br>HS osc configuration                                   |
| D002          | Vdr       | RAM Data Retention<br>Voltage <sup>(1)</sup>                                                                                                                                                                                                                                                                                        | —          | 1.5* |            | V      | Device in SLEEP mode                                                                      |
| D003          | VPOR      | VDD Start Voltage to<br>ensure Power-on Reset                                                                                                                                                                                                                                                                                       | -          | Vss  | -          | V      | See Section 6.4, Power-on Reset for details                                               |
| D004          | SVDD      | VDD Rise Rate to ensure<br>Power-on Reset                                                                                                                                                                                                                                                                                           | 0.05*      | —    | —          | V/ms   | See Section 6.4, Power-on Reset for details                                               |
|               | IDD       | Supply Current <sup>(2)</sup>                                                                                                                                                                                                                                                                                                       |            |      |            |        |                                                                                           |
| D010          |           | 16LC55X                                                                                                                                                                                                                                                                                                                             | _          | 1.4  | 2.5        | mA     | XT and RC osc configuration<br>Fosc = 2.0 MHz, VDD = 3.0V, WDT<br>disabled <sup>(4)</sup> |
| D010A         |           |                                                                                                                                                                                                                                                                                                                                     |            | 26   | 53         | μA     | LP osc configuration<br>Fosc = 32 kHz, VDD = 3.0V, WDT<br>disabled                        |
| D010          |           | 16C55X                                                                                                                                                                                                                                                                                                                              | _          | 1.8  | 3.3        | mA     | XT and RC osc configuration<br>Fosc = 4 MHz, VDD = 5.5V,<br>WDT disabled <sup>(4)</sup>   |
| D010A         |           |                                                                                                                                                                                                                                                                                                                                     | _          | 35   | 70         | μΑ     | LP osc configuration,<br>PIC16C55X-04 only<br>Fosc = 32 kHz, VDD = 4.0V,<br>WDT disabled  |
| D013          |           |                                                                                                                                                                                                                                                                                                                                     | —          | 9.0  | 20         | mA     | HS osc configuration<br>Fosc = $20 \text{ MHz}$ , VDD = $5.5 \text{V}$ ,<br>WDT disabled  |

These parameters are characterized but not tested.

† Data is "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 I/O pin loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an impact on the current consumption.

The test conditions for all IDD measurements in active Operation mode are:

<u>OSC1</u> = external square wave, from rail to rail; all I/O pins configured as input, pulled to VDD, MCLR = VDD; WDT enabled/disabled as specified.

- **3:** The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins configured as input and tied to VDD or Vss.
- 4: For RC osc configuration, current through REXT is not included. The current through the resistor can be estimated by the formula Ir = VDD/2REXT (mA) with REXT in kΩ.
- 5: The  $\Delta$  current is the additional current consumed when this peripheral is enabled. This current should be added to the base IDD or IPD measurement.

| Parameter # | Sym      | Characteristic                                                        | Min                          | Тур†    | Max        | Units    |
|-------------|----------|-----------------------------------------------------------------------|------------------------------|---------|------------|----------|
| 10*         | TosH2ckL | OSC1↑ to CLKOUT↓ <sup>(1)</sup>                                       | —                            | 75<br>— | 200<br>400 | ns<br>ns |
| 11*         | TosH2ckH | OSC1↑ to CLKOUT↑ <sup>(1)</sup>                                       | _                            | 75<br>— | 200<br>400 | ns<br>ns |
| 12*         | TckR     | CLKOUT rise time <sup>(1)</sup>                                       | _                            | 35<br>— | 100<br>200 | ns<br>ns |
| 13*         | TckF     | CLKOUT fall time <sup>(1)</sup>                                       | _                            | 35<br>— | 100<br>200 | ns<br>ns |
| 14*         | TckL2ioV | CLKOUT ↓ to Port out valid <sup>(1)</sup>                             | —                            |         | 20         | ns       |
| 15*         | TioV2ckH | Port in valid before CLKOUT <sup>(1)</sup>                            | Tosc +200 ns<br>Tosc +400 ns | _       |            | ns<br>ns |
| 16*         | TckH2iol | Port in hold after CLKOUT $\uparrow$ <sup>(1)</sup>                   | 0                            | _       | _          | ns       |
| 17*         | TosH2ioV | OSC1 <sup>↑</sup> (Q1 cycle) to Port out valid                        | —                            | 50      | 150<br>300 | ns<br>ns |
| 18*         | TosH2iol | OSC1 <sup>↑</sup> (Q2 cycle) to Port input invalid (I/O in hold time) | 100<br>200                   | _       |            | ns<br>ns |
| 19*         | TioV2osH | Port input valid to OSC1↑ (I/O in setup time)                         | 0                            |         | _          | ns       |
| 20*         | TioR     | Port output rise time                                                 |                              | 10<br>— | 40<br>80   | ns<br>ns |
| 21*         | TioF     | Port output fall time                                                 |                              | 10<br>— | 40<br>80   | ns<br>ns |
| 22*         | Tinp     | RB0/INT pin high or low time                                          | 25<br>40                     |         |            | ns<br>ns |
| 23*         | Trbp     | RB<7:4> change interrupt high or low time                             | Тсу                          | _       |            | ns       |

| TABLE 10-2: | <b>CLKOUT AND I/O TIMING REQUIREMENTS</b> |
|-------------|-------------------------------------------|
|             |                                           |

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:** Measurements are taken in RC mode where CLKOUT output is 4 x Tosc.

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

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



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

\* Controlling Parameter § Significant Characteristic

Notes:

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

# **READER RESPONSE**

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

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

| TO:<br>RE: | Technical Publications Manager<br>Reader Response           | Total Pages Sent                  |
|------------|-------------------------------------------------------------|-----------------------------------|
| From       | ). Name                                                     |                                   |
| 1 1011     | Company                                                     |                                   |
|            | Address                                                     |                                   |
|            | City / State / ZIP / Country                                |                                   |
|            | Telephone: ()                                               | FAX: ()                           |
| Appl       | ication (optional):                                         |                                   |
| Wou        | ld you like a reply?YN                                      |                                   |
| Devi       | ce:                                                         | Literature Number: DS40143E       |
| Ques       | stions:                                                     |                                   |
| 1. \       | What are the best features of this document?                |                                   |
| -          |                                                             |                                   |
| -<br>2. H  | How does this document meet your hardware and softwar       | re development needs?             |
| _          |                                                             |                                   |
| _          |                                                             |                                   |
| 3. E       | Do you find the organization of this document easy to follo | ow? If not, why?                  |
| -          |                                                             |                                   |
| -          |                                                             |                                   |
| 4. \       | What additions to the document do you think would enhar     | nce the structure and subject?    |
| -          |                                                             |                                   |
| 5 \        | What deletions from the document could be made without      | affecting the overall usefulness? |
| 0. 1       |                                                             |                                   |
| -          |                                                             |                                   |
| 6. I       | s there any incorrect or misleading information (what and   | where)?                           |
| _          |                                                             |                                   |
| -          |                                                             |                                   |
| 7. H       | How would you improve this document?                        |                                   |
| -          |                                                             |                                   |
| -          |                                                             |                                   |

NOTES: