



#### 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             | 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        | OTP                                                                      |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 128 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                                                |
| Data Converters            | -                                                                        |
| Oscillator Type            | External                                                                 |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                          |
| Mounting Type              | Through Hole                                                             |
| Package / Case             | 18-DIP (0.300", 7.62mm)                                                  |
| Supplier Device Package    | 18-PDIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c558-04-p |

Email: info@E-XFL.COM

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

NOTES:

### 4.2.2.1 STATUS Register

The STATUS register, shown in Figure 4-2, contains the arithmetic status of the ALU, the RESET status and the bank select bits for data memory.

The STATUS register can be the destination for any instruction, like any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the TO and PD bits are not writable. Therefore, the result of an instruction with the STATUS register as the destination may be different than intended.

For example, CLRF STATUS will clear the upper-three bits and set the Z bit. This leaves the STATUS register as 000uu1uu (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions be used to alter the STATUS register because these instructions do not affect any status bits. For other instructions, not affecting any status bits, see the "Instruction Set Summary".

- Note 1: The IRP and RP1 bits (STATUS<7:6>) are not used by the PIC16C55X and should be programmed as '0'. Use of these bits as general purpose R/W bits is NOT recommended, since this may affect upward compatibility with future products.
  - 2: The <u>C</u> and <u>DC</u> bits operate as a Borrow and <u>Digit</u> Borrow out bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples.

|         | Reserved                                                                                                                                                                                                                                                                                                                 | Reserved                                                                                                                                                                                                                                                                | R/W-0          | R-1            | R-1          | R/W-x           | R/W-x          | R/W-x         |  |  |  |  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------|--------------|-----------------|----------------|---------------|--|--|--|--|
|         | IRP                                                                                                                                                                                                                                                                                                                      | RP1                                                                                                                                                                                                                                                                     | RP0            | TO             | PD           | Z               | DC             | С             |  |  |  |  |
|         | bit7                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                         |                |                |              |                 |                | bit0          |  |  |  |  |
| bit 7   | 1 = Bank 2, 3<br>0 = Bank 0, 1                                                                                                                                                                                                                                                                                           | IRP: Register Bank Select bit (used for Indirect addressing)<br>1 = Bank 2, 3 (100h - 1FFh)<br>0 = Bank 0, 1 (00h - FFh)<br>The IRP bit is reserved on the PIC16C55X, always maintain this bit clear<br>RP1:RP0: Register Bank Select bits (used for Direct addressing) |                |                |              |                 |                |               |  |  |  |  |
| bit 6-5 | RP1:RP0: Register Bank Select bits (used for Direct addressing)<br>11 = Bank 3 (180h - 1FFh)<br>10 = Bank 2 (100h - 17Fh)<br>01 = Bank 1 (80h - FFh)<br>00 = Bank 0 (00h - 7Fh)<br>Each bank is 128 bytes. The RP1 bit is reserved on the PIC16C55X, always maintain this bit clear.                                     |                                                                                                                                                                                                                                                                         |                |                |              |                 |                |               |  |  |  |  |
| bit 4   |                                                                                                                                                                                                                                                                                                                          | bit<br>/er-up, CLRWDT<br>meout occurred                                                                                                                                                                                                                                 |                | or sleep inst  | truction     |                 |                |               |  |  |  |  |
| bit 3   | •                                                                                                                                                                                                                                                                                                                        | own bit<br>/er-up or by the<br>tion of the SLE:                                                                                                                                                                                                                         |                |                |              |                 |                |               |  |  |  |  |
| bit 2   |                                                                                                                                                                                                                                                                                                                          | It of an arithmei<br>It of an arithmei                                                                                                                                                                                                                                  | • •            |                |              |                 |                |               |  |  |  |  |
| bit 1   | reversed)<br>1 = A carry-o                                                                                                                                                                                                                                                                                               | rry/borrow bit (<br>ut from the 4th<br>out from the 4tl                                                                                                                                                                                                                 | low order bit  | of the result  | occurred     | instructions) ( | for borrow the | e polarity is |  |  |  |  |
| bit 0   | 1 = A carry-o                                                                                                                                                                                                                                                                                                            | ow bit (ADDWF ,<br>ut from the Mos<br>out from the Mo                                                                                                                                                                                                                   | st Significant | bit of the res | ult occurred |                 |                |               |  |  |  |  |
| Note 1: | 0 = No carry-out from the Most Significant bit of the result occurred<br>For borrow the polarity is reversed. A subtraction is executed by adding the two's complement of the second<br>operand. For rotate (RRF, RLF) instructions, this bit is loaded with either the high or low order bit of the<br>source register. |                                                                                                                                                                                                                                                                         |                |                |              |                 |                |               |  |  |  |  |
|         | Legend:                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                         |                |                |              |                 |                |               |  |  |  |  |
|         | R = Readable                                                                                                                                                                                                                                                                                                             | ə bit                                                                                                                                                                                                                                                                   | W = Wri        | itable bit     | U = Unim     | plemented bit,  | read as '0'    |               |  |  |  |  |

- n = Value at POR reset

'0' = Bit is cleared

'1' = Bit is set

x = Bit is unknown

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



# 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

#### PORT PINS RC<7:0> Data Bus D Q Vdd WR PORT ск 🔪 Q P Data Latch Q Ν D I/O pin WR T<u>RISC</u> Q ∘ск҇∢\_ Vss Vss TRIS Latch TTL Input Buffer RD TRISC Q D FN. **RD PORTC**

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

## 5.4 I/O Programming Considerations

### 5.4.1 BI-DIRECTIONAL I/O PORTS

Any instruction which writes, operates internally as a read followed by a write operation. The BCF and BSF instructions, for example, read the register into the CPU, execute the bit operation and write the result back to the register. Caution must be used when these instructions are applied to a port with both inputs and outputs defined. For example, a BSF operation on bit5 of PORTB will cause all eight bits of PORTB to be read into the CPU. Then the BSF operation takes place on bit5 and PORTB is written to the output latches. If another bit of PORTB is used as a bi-directional I/O pin (e.g., bit 0) and it is defined as an input at this time, the input signal present on the pin itself would be read into the CPU and re-written to the data latch of this particular pin, overwriting the previous content. As long as the pin stays in the Input mode, no problem occurs. However, if bit 0 is switched into Output mode later on, the content of the data latch may now be unknown.

Reading the port register, reads the values of the port pins. Writing to the port register writes the value to the port latch. When using read-modify-write instructions (ex. BCF, BSF, etc.) on a port, the value of the port pins is read, the desired operation is done to this value, and this value is then written to the port latch.

Example 5-1 shows the effect of two sequential read-modify-write instructions (ex.,  ${\tt BCF}$ ,  ${\tt BSF}$ , etc.) on an I/O port.

A pin actively outputting a low or high should not be driven from external devices at the same time in order to change the level on this pin ("wired-or", "wired-and"). The resulting high output currents may damage the chip.

## 6.4 Power-on Reset (POR), Power-up Timer (PWRT), Oscillator Start-up Timer (OST)

## 6.4.1 POWER-ON RESET (POR)

A Power-on Reset pulse is generated on-chip when VDD rise is detected (in the range of 1.6V - 1.8V). To take advantage of the POR, just tie the MCLR pin through a resistor to VDD. This will eliminate external RC components usually needed to create Power-on Reset. A maximum rise time for VDD is required. See Electrical Specifications for details.

The POR circuit does not produce internal RESET when VDD declines.

When the device starts normal operation (exits the RESET condition), device operating parameters (voltage, frequency, temperature, etc.) must be met to ensure operation. If these conditions are not met, the device must be held in RESET until the operating conditions are met.

For additional information, refer to Application Note AN607 "Power-up Trouble Shooting".

### 6.4.2 POWER-UP TIMER (PWRT)

The Power-up Timer provides a fixed 72 ms (nominal) timeout on power-up only, from POR. The Power-up Timer operates on an internal RC oscillator. The chip is kept in RESET as long as PWRT is active. The PWRT delay allows the <u>VDD</u> to rise to an acceptable level. A configuration bit, <u>PWRTE</u> can disable (if set) or enable (if cleared or programmed) the Power-up Timer. The Power-Up Time delay will vary from chip to chip and due to VDD, temperature and process variation. See DC parameters for details.

### 6.4.3 OSCILLATOR START-UP TIMER (OST)

The Oscillator Start-Up Timer (OST) provides a 1024 oscillator cycle (from OSC1 input) delay after the PWRT delay is over. This ensures that the crystal oscillator or resonator has started and stabilized.

The OST timeout is invoked only for XT, LP and HS modes and only on Power-on Reset or wake-up from SLEEP.

### 6.4.4 TIMEOUT SEQUENCE

On power-up, the timeout sequence is as follows: First PWRT timeout is invoked after POR has expired, then OST is activated. The total timeout will vary based on oscillator configuration and <u>PWRTE</u> bit status. For example, in RC mode with <u>PWRTE</u> bit erased (PWRT disabled), there will be no timeout at all. Figure 6-7, Figure 6-8 and Figure 6-9 depict timeout sequences.

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

Table 6-5 shows the RESET conditions for some special registers, while Table 6-6 shows the RESET conditions for all the 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  | T0SE  | 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.2 Using Timer0 with External Clock

When an external clock input is used for Timer0, it must meet certain requirements. The external clock requirement is due to internal phase clock (Tosc) synchronization. Also, there is a delay in the actual incrementing of Timer0 after synchronization.

### 7.2.1 EXTERNAL CLOCK SYNCHRONIZATION

When no prescaler is used, the external clock input is the same as the prescaler output. The synchronization of T0CKI with the internal phase clocks is accomplished by sampling the prescaler output on the Q2 and Q4 cycles of the internal phase clocks (Figure 7-5). Therefore, it is necessary for T0CKI to be high for at least 2Tosc (and a small RC delay of 20 ns) and low for at least 2Tosc (and a small RC delay of 20 ns). Refer to the electrical specification of the desired device. When a prescaler is used, the external clock input is divided by the asynchronous ripple-counter type prescaler so that the prescaler output is symmetrical. For the external clock to meet the sampling requirement, the ripple-counter must be taken into account. Therefore, it is necessary for TOCKI to have a period of at least 4TOSC (and a small RC delay of 40 ns) divided by the prescaler value. The only requirement on TOCKI high and low time is that they do not violate the minimum pulse width requirement of 10 ns. Refer to parameters 40, 41 and 42 in the electrical specification of the desired device.

### 7.2.2 TIMER0 INCREMENT DELAY

Since the prescaler output is synchronized with the internal clocks, there is a small delay from the time the external clock edge occurs to the time the TMR0 is actually incremented. Figure 7-5 shows the delay from the external clock edge to the timer incrementing.



## 7.3 Prescaler

An 8-bit counter is available as a prescaler for the Timer0 module, or as a postscaler for the Watchdog Timer, respectively (Figure 7-6). For simplicity, this counter is being referred to as "prescaler" throughout this data sheet.

Note: There is only one prescaler available which is mutually exclusive between the Timer0 module and the Watchdog Timer. Thus, a prescaler assignment for the Timer0 module means that there is no prescaler for the Watchdog Timer, and vice-versa. The PSA and PS2:PS0 bits (OPTION<3:0>) determine the prescaler assignment and prescale ratio.

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

© 1996-2013 Microchip Technology Inc.

# PIC16C55X

| BCF              | Bit Clea                             | ar f          |            |          |  |  |
|------------------|--------------------------------------|---------------|------------|----------|--|--|
| Syntax:          | [ label ]                            | BCF 1         | f,b        |          |  |  |
| Operands:        | $0 \le f \le 127$<br>$0 \le b \le 7$ |               |            |          |  |  |
| Operation:       | $0 \rightarrow (f < b >)$            |               |            |          |  |  |
| Status Affected: | None                                 |               |            |          |  |  |
| Encoding:        | 01                                   | 00bb          | bfff       | ffff     |  |  |
| Description:     | Bit 'b' in re                        | gister 'f' is | s cleared. |          |  |  |
| Words:           | 1                                    |               |            |          |  |  |
| Cycles:          | 1                                    |               |            |          |  |  |
| Example          | BCF                                  | FLAG_F        | REG, 7     |          |  |  |
|                  | After Inst                           | G_REG         |            | C7<br>47 |  |  |

|  | Bit | Set | f |
|--|-----|-----|---|
|--|-----|-----|---|

BSF

| Syntax:          | [ <i>label</i> ] BSF f,b                                            |        |        |      |  |  |  |
|------------------|---------------------------------------------------------------------|--------|--------|------|--|--|--|
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$ |        |        |      |  |  |  |
| Operation:       | $1 \rightarrow (f < b >)$                                           |        |        |      |  |  |  |
| Status Affected: | None                                                                |        |        |      |  |  |  |
| Encoding:        | 01                                                                  | 01bb   | bfff   | ffff |  |  |  |
| Description:     | Bit 'b' in register 'f' is set.                                     |        |        |      |  |  |  |
| Words:           | 1                                                                   |        |        |      |  |  |  |
| Cycles:          | 1                                                                   |        |        |      |  |  |  |
| Example          | BSF                                                                 | FLAG_F | REG, 7 | ,    |  |  |  |
|                  | Before Instruction<br>FLAG_REG = 0x0A<br>After Instruction          |        |        |      |  |  |  |
|                  | FLAG_REG = 0x8A                                                     |        |        |      |  |  |  |

| BTFSC            | Bit Test, Skip if Clear                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:          | [ label ] BTFSC f,b                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$                                                                                                                                                                                                     |  |  |  |  |  |  |
| Operation:       | skip if (f <b>) = 0</b>                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| Encoding:        | 01 10bb bfff ffff                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| Description:     | If bit 'b' in register 'f' is '0' then the next<br>instruction is skipped. If bit 'b' is '0' then<br>the next instruction fetched during the<br>current instruction execution is dis-<br>carded, and a NOP is executed instead,<br>making this a two-cycle instruction. |  |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| Cycles:          | 1(2)                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| Example          | HERE BTFSC FLAG,1<br>FALSE GOTO PROCESS_CODE<br>TRUE •<br>•<br>•                                                                                                                                                                                                        |  |  |  |  |  |  |
|                  | Before Instruction                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|                  | PC = address HERE                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                  | After Instruction<br>if FLAG<1> = 0,<br>PC = address TRUE<br>if FLAG<1> = 1,<br>PC = address TRUE                                                                                                                                                                       |  |  |  |  |  |  |
|                  | PC = address FALSE                                                                                                                                                                                                                                                      |  |  |  |  |  |  |

| BTFSS            | Bit Test f, Skip if Set                                                                                                                                                                                                                                                    | CALL                      | Call Subroutine                                                                                                                                                                                                                                        |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] BTFSS f,b                                                                                                                                                                                                                                                        | Syntax:                   | [ <i>label</i> ] CALL k                                                                                                                                                                                                                                |
| Operands:        | $0 \le f \le 127$                                                                                                                                                                                                                                                          | Operands:                 | $0 \le k \le 2047$                                                                                                                                                                                                                                     |
|                  | 0 ≤ b < 7                                                                                                                                                                                                                                                                  | Operation:                | (PC)+ 1 $\rightarrow$ TOS,                                                                                                                                                                                                                             |
| Operation:       | skip if (f <b>) = 1</b>                                                                                                                                                                                                                                                    |                           | $k \rightarrow PC < 10:0>,$                                                                                                                                                                                                                            |
| Status Affected: | None                                                                                                                                                                                                                                                                       |                           | $(PCLATH{<}4:3{>}) \rightarrow PC{<}12:11{>}$                                                                                                                                                                                                          |
| Encoding:        | 01 11bb bfff ffff                                                                                                                                                                                                                                                          | Status Affected:          | None                                                                                                                                                                                                                                                   |
| Description:     | If bit 'b' in register 'f' is '1' then the next<br>instruction is skipped.<br>If bit 'b' is '1', then the next instruction<br>fetched during the current instruction<br>execution, is discarded and a NOP is<br>executed instead, making this a two-<br>cycle instruction. | Encoding:<br>Description: | 100kkkkkkkkkkkCall Subroutine. First, return address(PC+1) is pushed onto the stack. The<br>eleven bit immediate address is<br>loaded into PC bits <10:0>. The upper<br>bits of the PC are loaded from<br>PCLATH. CALL is a two-cycle instruc-<br>tion |
| Words:           | 1                                                                                                                                                                                                                                                                          | Marda                     | tion.                                                                                                                                                                                                                                                  |
| Cycles:          | 1(2)                                                                                                                                                                                                                                                                       | Words:                    | 1                                                                                                                                                                                                                                                      |
| Example          | HERE BTFSS FLAG,1<br>FALSE GOTO PROCESS_CODE                                                                                                                                                                                                                               | Cycles:<br>Example        | 2<br>HERE CALL THERE                                                                                                                                                                                                                                   |
|                  | TRUE<br>Before Instruction<br>PC = address HERE<br>After Instruction<br>if FLAG<1> = 0,<br>PC = address FALSE<br>if FLAG<1> = 1,                                                                                                                                           | CLRF                      | Before Instruction<br>PC = Address HERE<br>After Instruction<br>PC = Address THERE<br>TOS = Address HERE+1<br>Clear f                                                                                                                                  |
|                  | PC = address TRUE                                                                                                                                                                                                                                                          | Syntax:                   | [label] CLRF f                                                                                                                                                                                                                                         |
|                  |                                                                                                                                                                                                                                                                            | Operands:                 | $0 \le f \le 127$                                                                                                                                                                                                                                      |
|                  |                                                                                                                                                                                                                                                                            | Operation:                | $\begin{array}{l} 00h \rightarrow (f) \\ 1 \rightarrow Z \end{array}$                                                                                                                                                                                  |
|                  |                                                                                                                                                                                                                                                                            | Status Affected:          | Z                                                                                                                                                                                                                                                      |
|                  |                                                                                                                                                                                                                                                                            | Encoding:                 | 00 0001 1fff ffff                                                                                                                                                                                                                                      |
|                  |                                                                                                                                                                                                                                                                            | Description:              | The contents of register 'f' are cleared and the Z bit is set.                                                                                                                                                                                         |
|                  |                                                                                                                                                                                                                                                                            | Words:                    | 1                                                                                                                                                                                                                                                      |
|                  |                                                                                                                                                                                                                                                                            | Cycles:                   | 1                                                                                                                                                                                                                                                      |
|                  |                                                                                                                                                                                                                                                                            | Example                   | CLRF FLAG_REG                                                                                                                                                                                                                                          |
|                  |                                                                                                                                                                                                                                                                            |                           | Before Instruction<br>FLAG_REG=0x5A<br>After Instruction<br>FLAG_REG=0x00                                                                                                                                                                              |

# PIC16C55X

| RETFIE           | Return from Interrupt                                                                                                                                                                                             |  |  |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Syntax:          | [label] RETFIE                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| Operands:        | None                                                                                                                                                                                                              |  |  |  |  |  |  |  |
| Operation:       | $TOS \rightarrow PC, \\ 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 \rightarrow PC$                                                                                                                                    |              |      |      |  |  |  |
| 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                                                                                                                                                              | I                     |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--|--|--|--|
| Syntax:          | [ <i>label</i> ] RETLW k                                                                                                                                                              | S                     |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                                                                                                                     | 0                     |  |  |  |  |
| Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow PC$                                                                                                                                          | 0                     |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                  | St                    |  |  |  |  |
| Encoding:        | 11 01xx kkkk kkkk                                                                                                                                                                     | E                     |  |  |  |  |
| Description:     | The W register is loaded with the eight D<br>bit literal 'k'. The program counter is<br>loaded from the top of the stack (the<br>return address). This is a two-cycle<br>instruction. |                       |  |  |  |  |
| Words:           | 1                                                                                                                                                                                     |                       |  |  |  |  |
| Cycles:          | 2                                                                                                                                                                                     |                       |  |  |  |  |
| Example          | CALL TABLE;W contains table<br>;offset value<br>• ;W now has table<br>value<br>•                                                                                                      | W<br>C <u>y</u><br>Ex |  |  |  |  |
| TABLE            | <pre>ADDWF PC ;W = offset RETLW k1 ;Begin table RETLW k2 ;</pre>                                                                                                                      |                       |  |  |  |  |
|                  | 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'. |  |  |  |  |  |  |  |
| /ords:          | 1                                                                                                                                                                                                           |  |  |  |  |  |  |  |
| ycles:          | 1                                                                                                                                                                                                           |  |  |  |  |  |  |  |
| xample          | RLF REG1,0                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|                 | Before Instruction                                                                                                                                                                                          |  |  |  |  |  |  |  |
|                 | <b>REG1</b> = 1110 0110                                                                                                                                                                                     |  |  |  |  |  |  |  |
|                 | C = 0                                                                                                                                                                                                       |  |  |  |  |  |  |  |
|                 | After Instruction                                                                                                                                                                                           |  |  |  |  |  |  |  |
|                 | <b>REG1</b> = 1110 0110                                                                                                                                                                                     |  |  |  |  |  |  |  |
|                 | W = 1100 1100                                                                                                                                                                                               |  |  |  |  |  |  |  |
|                 | C = 1                                                                                                                                                                                                       |  |  |  |  |  |  |  |
|                 |                                                                                                                                                                                                             |  |  |  |  |  |  |  |

NOTES:

## 9.8 MPLAB ICD In-Circuit Debugger

Microchip's In-Circuit Debugger, MPLAB ICD, is a powerful, low cost, run-time development tool. This tool is based on the FLASH PIC MCUs and can be used to develop for this and other PIC microcontrollers. The MPLAB ICD utilizes the in-circuit debugging capability built into the FLASH devices. This feature, along with Microchip's In-Circuit Serial Programming<sup>TM</sup> protocol, offers cost-effective in-circuit FLASH debugging from the graphical user interface of the MPLAB Integrated Development Environment. This enables a designer to develop and debug source code by watching variables, single-stepping and setting break points. Running at full speed enables testing hardware in real-time.

## 9.9 PRO MATE II Universal Device Programmer

The PRO MATE II universal device programmer is a full-featured programmer, capable of operating in Stand-alone mode, as well as PC-hosted mode. The PRO MATE II device programmer is CE compliant.

The PRO MATE II device programmer has programmable VDD and VPP supplies, which allow it to verify programmed memory at VDD min and VDD max for maximum reliability. It has an LCD display for instructions and error messages, keys to enter commands and a modular detachable socket assembly to support various package types. In Stand-alone mode, the PRO MATE II device programmer can read, verify, or program PIC devices. It can also set code protection in this mode.

## 9.10 PICSTART Plus Entry Level Development Programmer

The PICSTART Plus development programmer is an easy-to-use, low cost, prototype programmer. It connects to the PC via a COM (RS-232) port. MPLAB Integrated Development Environment software makes using the programmer simple and efficient.

The PICSTART Plus development programmer supports all PIC devices with up to 40 pins. Larger pin count devices, such as the PIC16C92X and PIC17C76X, may be supported with an adapter socket. The PICSTART Plus development programmer is CE compliant.

## 9.11 PICDEM 1 Low Cost PIC MCU Demonstration Board

The PICDEM 1 demonstration board is a simple board which demonstrates the capabilities of several of Microchip's microcontrollers. The microcontrollers supported are: PIC16C5X (PIC16C54 to PIC16C58A). PIC16C61, PIC16C62X, PIC16C71, PIC16C8X, PIC17C42, PIC17C43 and PIC17C44. All necessary hardware and software is included to run basic demo programs. The user can program the sample microcontrollers provided with the PICDEM 1 demonstration board on a PRO MATE II device programmer, or a PICSTART Plus development programmer, and easily test firmware. The user can also connect the PICDEM 1 demonstration board to the MPLAB ICE incircuit emulator and download the firmware to the emulator for testing. A prototype area is available for the user to build some additional hardware and connect it to the microcontroller socket(s). Some of the features include an RS-232 interface, a potentiometer for simulated analog input, push button switches and eight LEDs connected to PORTB.

## 9.12 PICDEM 2 Low Cost PIC16CXX Demonstration Board

The PICDEM 2 demonstration board is a simple demonstration board that supports the PIC16C62, PIC16C64, PIC16C65, PIC16C73 and PIC16C74 microcontrollers. All the necessary hardware and software is included to run the basic demonstration programs. The user can program the sample microcontrollers provided with the PICDEM 2 demonstration board on a PRO MATE II device programmer, or a PICSTART Plus development programmer, and easily test firmware. The MPLAB ICE in-circuit emulator may also be used with the PICDEM 2 demonstration board to test firmware. A prototype area has been provided to the user for adding additional hardware and connecting it to the microcontroller socket(s). Some of the features include a RS-232 interface, push button switches, a potentiometer for simulated analog input, a serial EEPROM to demonstrate usage of the  $I^2C^{TM}$  bus and separate headers for connection to an LCD module and a keypad.

# 10.0 ELECTRICAL SPECIFICATIONS

| Absolute Maximum Ratings †                                                                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Ambient Temperature under bias40° to +125°C                                                                                                      |
| Storage Temperature                                                                                                                              |
| Voltage on any pin with respect to Vss (except VDD and MCLR)0.6V to VDD +0.6V                                                                    |
| Voltage on VDD with respect to Vss 0 to +7.5V                                                                                                    |
| Voltage on MCLR with respect to Vss0 to +14V                                                                                                     |
| Total power Dissipation (Note 1)1.0W                                                                                                             |
| Maximum Current out of Vss pin                                                                                                                   |
| Maximum Current into VDD pin250 mA                                                                                                               |
| Input Clamp Current, Iικ (VI < 0 or VI > VDD)±20 mA                                                                                              |
| Output Clamp Current, IOK (V0 < 0 or V0 > VDD)±20 mA                                                                                             |
| Maximum Output Current sunk by any I/O pin25 mA                                                                                                  |
| Maximum Output Current sourced by any I/O pin25 mA                                                                                               |
| Maximum Current sunk by PORTA, PORTB and PORTC                                                                                                   |
| Maximum Current sourced by PORTA, PORTB and PORTC                                                                                                |
| <b>Note 1:</b> Power dissipation is calculated as follows: PDIS = VDD x {IDD - $\Sigma$ IOH} + $\Sigma$ {(VDD-VOH) x IOH} + $\Sigma$ (VOI x IOL) |

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

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



|                            |          | INCHES* |      | N    | MILLIMETERS |       |       |
|----------------------------|----------|---------|------|------|-------------|-------|-------|
| Dimensio                   | n 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

### 18-Lead Plastic Small Outline (SO) - Wide, 300 mil (SOIC)

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



| Units                    |           | INCHES* |      |      | MILLIMETERS |       |       |
|--------------------------|-----------|---------|------|------|-------------|-------|-------|
| Dimensi                  | on Limits | MIN     | NOM  | MAX  | MIN         | NOM   | MAX   |
| Number of Pins           | n         |         | 18   |      |             | 18    |       |
| Pitch                    | р         |         | .050 |      |             | 1.27  |       |
| Overall Height           | Α         | .093    | .099 | .104 | 2.36        | 2.50  | 2.64  |
| Molded Package Thickness | A2        | .088    | .091 | .094 | 2.24        | 2.31  | 2.39  |
| Standoff §               | A1        | .004    | .008 | .012 | 0.10        | 0.20  | 0.30  |
| Overall Width            | E         | .394    | .407 | .420 | 10.01       | 10.34 | 10.67 |
| Molded Package Width     | E1        | .291    | .295 | .299 | 7.39        | 7.49  | 7.59  |
| Overall Length           | D         | .446    | .454 | .462 | 11.33       | 11.53 | 11.73 |
| Chamfer Distance         | h         | .010    | .020 | .029 | 0.25        | 0.50  | 0.74  |
| Foot Length              | L         | .016    | .033 | .050 | 0.41        | 0.84  | 1.27  |
| Foot Angle               | ¢         | 0       | 4    | 8    | 0           | 4     | 8     |
| Lead Thickness           | С         | .009    | .011 | .012 | 0.23        | 0.27  | 0.30  |
| Lead Width               | В         | .014    | .017 | .020 | 0.36        | 0.42  | 0.51  |
| Mold Draft Angle Top     | α         | 0       | 12   | 15   | 0           | 12    | 15    |
| Mold Draft Angle Bottom  | β         | 0       | 12   | 15   | 0           | 12    | 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-013

Drawing No. C04-051

## APPENDIX A: ENHANCEMENTS

The following are the list of enhancements over the PIC16C5X microcontroller family:

- Instruction word length is increased to 14 bits. This allows larger page sizes both in program memory (4K now as opposed to 512 before) and register file (up to 128 bytes now versus 32 bytes before).
- 2. A PC high latch register (PCLATH) is added to handle program memory paging. PA2, PA1, PA0 bits are removed from STATUS register.
- 3. Data memory paging is slightly redefined. STATUS register is modified.
- Four new instructions have been added: RETURN, RETFIE, ADDLW, and SUBLW.
   Two instructions TRIS and OPTION are being phased out although they are kept for compatibility with PIC16C5X.
- 5. OPTION and TRIS registers are made addressable.
- 6. Interrupt capability is added. Interrupt vector is at 0004h.
- 7. Stack size is increased to 8 deep.
- 8. RESET vector is changed to 0000h.
- RESET of all registers is revised. Three different RESET (and wake-up) types are recognized. Registers are reset differently.
- 10. Wake-up from SLEEP through interrupt is added.
- 11. Two separate timers, Oscillator Start-up Timer (OST) and Power-up Timer (PWRT) are included for more reliable power-up. These timers are invoked selectively to avoid unnecessary delays on power-up and wake-up.
- 12. PORTB has weak pull-ups and interrupt-onchange feature.
- 13. Timer0 clock input, T0CKI pin is also a port pin (RA4/T0CKI) and has a TRIS bit.
- 14. FSR is made a full 8-bit register.
- 15. "In-circuit programming" is made possible. The user can program PIC16C55X devices using only five pins: VDD, VSS, VPP, RB6 (clock) and RB7 (data in/out).
- 16. PCON status register is added with a Power-on Reset (POR) status bit.
- 17. Code protection scheme is enhanced such that portions of the program memory can be protected, while the remainder is unprotected.
- 18. PORTA inputs are now Schmitt Trigger inputs.

## APPENDIX B: COMPATIBILITY

To convert code written for PIC16C5X to PIC16C55X, the user should take the following steps:

- 1. Remove any program memory page select operations (PA2, PA1, PA0 bits) for CALL, GOTO.
- 2. Revisit any computed jump operations (write to PC or add to PC, etc.) to make sure page bits are set properly under the new scheme.
- 3. Eliminate any data memory page switching. Redefine data variables to reallocate them.
- 4. Verify all writes to STATUS, OPTION, and FSR registers since these have changed.
- 5. Change RESET vector to 0000h.

# APPENDIX C: REVISION HISTORY

### Revision E (January 2013)

Added a note to each package outline drawing.

# PIC16C55X

| PICSTART Plus Entry Level Development Programmer 69 |
|-----------------------------------------------------|
| Port RB Interrupt                                   |
| PORTA                                               |
| PORTB                                               |
| Power Control/Status Register (PCON)                |
| Power-Down Mode (SLEEP)45                           |
| Power-On Reset (POR)                                |
| Power-up Timer (PWRT)                               |
| Prescaler                                           |
| PRO MATE II Universal Device Programmer             |
| Program Memory Organization                         |

# Q

# R

| RC Oscillator      |    |
|--------------------|----|
| Reset              |    |
| RETFIE Instruction | 62 |
| RETLW Instruction  | 62 |
| RETURN Instruction | 62 |
| RLF Instruction    | 62 |
| RRF Instruction    | 63 |

# S

| Serialized Quick-Turnaround-Production (SQTP) Devices | 7    |
|-------------------------------------------------------|------|
| SLEEP Instruction                                     | . 63 |
| Software Simulator (MPLAB SIM)                        | . 68 |
| Special Features of the CPU                           | . 31 |
| Special Function Registers                            | . 15 |
| Stack                                                 | . 21 |
| Status Register                                       | . 17 |
| SUBLW Instruction                                     | . 63 |
| SUBWF Instruction                                     | . 64 |
| SWAPF Instruction                                     | . 64 |

# т

| Timer0                             |        |
|------------------------------------|--------|
| TIMER0                             | 47     |
| TIMER0 (TMR0) Interrupt            | 47     |
| TIMER0 (TMR0) Module               |        |
| TMR0 with External Clock           |        |
| Timer1                             |        |
| Switching Prescaler Assignment     | 51     |
| Timing Diagrams and Specifications | 81     |
| TMR0 Interrupt                     |        |
| TRIS Instruction                   | 64     |
| TRISA                              | 23     |
| TRISB                              | 25, 27 |
| W                                  |        |
| Watchdog Timer (WDT)               | 43     |
| WWW, On-Line Support               |        |
| x                                  |        |
| XORLW Instruction                  | 65     |

# **PRODUCT IDENTIFICATION SYSTEM**

To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office.

|                   | x <u>xx xxx</u>                                                                                                               | Examples:                                                                                                                                                |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device To         | emperature Package Pattern<br>Range                                                                                           | a) PIC17C756–16L Commercial Temp.,<br>PLCC package, 16 MHz,<br>normal VDD limits                                                                         |
| Device            | PIC17C756: Standard VDD range<br>PIC17C756T: (Tape and Reel)<br>PIC17LC756: Extended VDD range                                | <ul> <li>b) PIC17LC756–08/PT Commercial Temp.,<br/>TQFP package, 8MHz,<br/>extended VDD limits</li> <li>c) PIC17C756–33I/PT Industrial Temp.,</li> </ul> |
| Temperature Range | $\begin{array}{rcl} - & = & 0^{\circ}C \text{ to } +70^{\circ}C \\ I & = & -40^{\circ}C \text{ to } +85^{\circ}C \end{array}$ | TQFP package, 33 MHz,<br>normal VDD limits                                                                                                               |
| Package           | CL = Windowed LCC<br>PT = TQFP<br>L = PLCC                                                                                    |                                                                                                                                                          |
| Pattern           | QTP, SQTP, ROM Code (factory specified) or<br>Special Requirements. Blank for OTP and<br>Windowed devices.                    |                                                                                                                                                          |

\* JW Devices are UV erasable and can be programmed to any device configuration. JW Devices meet the electrical requirement of each oscillator type.

## Sales and Support

### Data Sheets

Products supported by a preliminary Data Sheet may have an errata sheet describing minor operational differences and recommended workarounds. To determine if an errata sheet exists for a particular device, please contact one of the following:

1. Your local Microchip sales office

2. The Microchip Worldwide Site (www.microchip.com)