

Welcome to E-XFL.COM

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

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

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

#### Details

E·XFI

| 2 0 0 0 0                  |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Active                                                                      |
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 4MHz                                                                        |
| Connectivity               | -                                                                           |
| Peripherals                | POR, WDT                                                                    |
| Number of I/O              | 12                                                                          |
| Program Memory Size        | 1.5KB (1K x 12)                                                             |
| Program Memory Type        | ОТР                                                                         |
| EEPROM Size                | -                                                                           |
| RAM Size                   | 72 x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 5.5V                                                                 |
| Data Converters            | -                                                                           |
| Oscillator Type            | External                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 14-SOIC (0.154", 3.90mm Width)                                              |
| Supplier Device Package    | 14-SOIC                                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lc505-04i-sl |
|                            |                                                                             |

Email: info@E-XFL.COM

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

### 3.1 Clocking Scheme/Instruction Cycle

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

### 3.2 Instruction Flow/Pipelining

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

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

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



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

### EXAMPLE 3-1: INSTRUCTION PIPELINE FLOW



### 4.2.2 SPECIAL FUNCTION REGISTERS

The Special Function Registers (SFRs) are registers used by the CPU and peripheral functions to control the operation of the device (Table 4-1). The Special Function Registers can be classified into two sets. The Special Function Registers associated with the "core" functions are described in this section. Those related to the operation of the peripheral features are described in the section for each peripheral feature.

| Address            | Name   | Bit 7                  | Bit 6      | Bit 5      | Bit 4       | Bit 3       | Bit 2        | Bit 1  | Bit 0     | Value on<br>Power-On<br>Reset | Value on<br>All Other<br>Resets <sup>(2)</sup> |
|--------------------|--------|------------------------|------------|------------|-------------|-------------|--------------|--------|-----------|-------------------------------|------------------------------------------------|
| 00h                | INDF   | Uses conte             | nts of FSF | to addres  | s data me   | mory (not a | physical reg | ister) |           | xxxx xxxx                     | uuuu uuuu                                      |
| 01h                | TMR0   | 8-bit real-ti          | me clock/c | ounter     |             |             |              |        |           | xxxx xxxx                     | uuuu uuuu                                      |
| 02h <sup>(1)</sup> | PCL    | Low order 8 bits of PC |            |            |             |             |              |        | 1111 1111 | 1111 1111                     |                                                |
| 03h                | STATUS | RBWUF                  | _          | PAO        | TO          | PD          | Z            | DC     | С         | 0001 1xxx                     | q00q quuu <sup>(1)</sup>                       |
| 04h                | FSR    | Indirect dat           | a memory   | address p  | ointer      |             |              |        |           | 110x xxxx                     | 11uu uuuu                                      |
| 05h                | OSCCAL | CAL5                   | CAL4       | CAL3       | CAL2        | CAL1        | CAL0         | _      | _         | 1000 00                       | uuuu uu                                        |
| N/A                | TRISB  | —                      |            | I/O contro | l registers |             |              |        |           | 11 1111                       | 11 1111                                        |
| N/A                | TRISC  | —                      |            | I/O contro | l registers |             |              |        |           | 11 1111                       | 11 1111                                        |
| N/A                | OPTION | RBWU                   | RBPU       | TOCS       | TOSE        | PSA         | PS2          | PS1    | PS0       | 1111 1111                     | 1111 1111                                      |
| 06h                | PORTB  | —                      |            | RB5        | RB4         | RB3         | RB2          | RB1    | RB0       | xx xxxx                       | uu uuuu                                        |
| 07h                | PORTC  | —                      |            | RC5        | RC4         | RC3         | RC2          | RC1    | RC0       | xx xxxx                       | uu uuuu                                        |

### TABLE 4-1:SPECIAL FUNCTION REGISTER (SFR) SUMMARY

Legend: Shaded cells not used by Port Registers, read as '0', — = unimplemented, read as '0', x = unknown, u = unchanged, q = depends on condition.

Note 1: If reset was due to wake-up on pin change, then bit 7 = 1. All other rests will cause bit 7 = 0.

Note 2: Other (non-power-up) resets include external reset through MCLR, watchdog timer and wake-up on pin change reset.

### 4.3 STATUS Register

This register contains the arithmetic status of the ALU, the RESET status and the page preselect bit.

The STATUS register can be the destination for any instruction, as with 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  $\overline{TO}$  and  $\overline{PD}$  bits are not writable. Therefore, the result of an instruction with the STATUS register as 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  $000u \ u1uu$  (where u = unchanged).

It is recommended, therefore, that only BCF, BSF and MOVWF instructions be used to alter the STATUS register, because these instructions do not affect the Z, DC or C bits from the STATUS register. For other instructions, which do affect STATUS bits, see Instruction Set Summary.

## REGISTER 4-1: STATUS REGISTER (ADDRESS:03h)

| R/W-0  | R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W-0                                             | R-1        | R-1   | R/W-x                          | R/W-x | R/W-x      |                                                                                       |  |  |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|------------|-------|--------------------------------|-------|------------|---------------------------------------------------------------------------------------|--|--|
| RBWUF  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PA0                                               | TO         | PD    | Z                              | DC    | C          | R = Readable bit                                                                      |  |  |
| bit7   | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 5                                                 | 4          | 3     | 2                              | 1     | bitO       | W = Writable bit<br>U = Unimplemented bit,<br>read as '0'<br>- n = Value at POR reset |  |  |
| bit 7: |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |            |       |                                |       |            |                                                                                       |  |  |
| bit 6: | Unimplem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ented                                             |            |       |                                |       |            |                                                                                       |  |  |
| bit 5: | <ul> <li>5: PA0: Program page preselect bits</li> <li>1 = Page 1 (200h - 3FFh)</li> <li>0 = Page 0 (000h - 1FFh)</li> <li>Each page is 512 bytes.</li> <li>Using the PA0 bit as a general purpose read/write bit in devices which do not use it for program page preselect is not recommended, since this may affect upward compatibility with future products.</li> </ul>                                                                                                                 |                                                   |            |       |                                |       |            |                                                                                       |  |  |
| bit 4: | TO: Time-out bit<br>1 = After power-up, CLRWDT instruction, or SLEEP instruction<br>0 = A WDT time-out occurred                                                                                                                                                                                                                                                                                                                                                                            |                                                   |            |       |                                |       |            |                                                                                       |  |  |
| bit 3: | <b>PD</b> : Power-down bit         1 = After power-up or by the CLRWDT instruction         0 = By execution of the SLEEP instruction                                                                                                                                                                                                                                                                                                                                                       |                                                   |            |       |                                |       |            |                                                                                       |  |  |
| bit 2: | <ul> <li>Z: Zero bit</li> <li>1 = The result of an arithmetic or logic operation is zero</li> <li>0 = The result of an arithmetic or logic operation is not zero</li> </ul>                                                                                                                                                                                                                                                                                                                |                                                   |            |       |                                |       |            |                                                                                       |  |  |
| bit 1: | DC: Digit carry/borrow bit (for ADDWF and SUBWF instructions) ADDWF 1 = A carry from the 4th low order bit of the result occurred 0 = A carry from the 4th low order bit of the result did not occur SUBWF 1 = A borrow from the 4th low order bit of the result did not occur 0 = A borrow from the 4th low order bit of the result did not occur 0 = A borrow from the 4th low order bit of the result did not occur 0 = A borrow from the 4th low order bit of the result did not occur |                                                   |            |       |                                |       |            |                                                                                       |  |  |
| bit 0: | ADDWF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ,                                                 | r addwf, s | SUBWF | REF, RLF inst                  | ,     | RRF or R   |                                                                                       |  |  |
|        | 1 = A carry<br>0 = A carry                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <ul> <li>occurred</li> <li>did not occ</li> </ul> | cur        |       | rrow did not o<br>rrow occurre |       | Load bit v | vith LSB or MSB, respectively                                                         |  |  |

## TABLE 5-1: SUMMARY OF PORT REGISTERS

| Address | Name   | Bit 7 | Bit 6 | Bit 5      | Bit 4                 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>Power-On<br>Reset | Value on<br>All Other Resets |
|---------|--------|-------|-------|------------|-----------------------|-------|-------|-------|-------|-------------------------------|------------------------------|
| N/A     | TRISB  | —     | _     | I/O contro | I/O control registers |       |       |       |       | 11 1111                       | 11 1111                      |
| N/A     | TRISC  | —     | _     | I/O contro | l registers           |       |       |       |       | 11 1111                       | 11 1111                      |
| N/A     | OPTION | RBWU  | RBPU  | TOCS       | TOSE                  | PSA   | PS2   | PS1   | PS0   | 1111 1111                     | 1111 1111                    |
| 03h     | STATUS | RBWUF | _     | PAO        | TO                    | PD    | Z     | DC    | С     | 0001 1xxx                     | q00q quuu <sup>(1)</sup>     |
| 06h     | PORTB  | —     | —     | RB5        | RB4                   | RB3   | RB2   | RB1   | RB0   | xx xxxx                       | uu uuuu                      |
| 07h     | PORTC  |       |       | RC5        | RC4                   | RC3   | RC2   | RC1   | RC0   | xx xxxx                       | uu uuuu                      |

Legend: Shaded cells not used by Port Registers, read as '0', — = unimplemented, read as '0', x = unknown, u = unchanged, q = depends on condition.

Note 1: If reset was due to wake-up on pin change, then bit 7 = 1. All other rests will cause bit 7 = 0.

### 5.5 I/O Programming Considerations

#### 5.5.1 BI-DIRECTIONAL I/O PORTS

Some instructions operate internally as read followed by write operations. The BCF and BSF instructions, for example, read the entire port into the CPU, execute the bit operation and re-write the result. Caution must be used when these instructions are applied to a port where one or more pins are used as input/outputs. For example, a BSF operation on bit5 of PORTB will cause all eight bits of PORTB to be read into the CPU, bit5 to be set and the PORTB value to be written to the output latches. If another bit of PORTB is used as a bidirectional I/O pin (say bit0) 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 rewritten 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 bit0 is switched into output mode later on, the content of the data latch may now be unknown.

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

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

### EXAMPLE 5-1: READ-MODIFY-WRITE INSTRUCTIONS ON AN I/O PORT

; Initial PORTB Settings ; PORTB<5:3> Inputs ; PORTB<2:0> Outputs ; ; PORTB latch PORTB pins -----; BCF ;--01 -ppp --11 pppp PORTB, 5 BCF PORTB, 4 ;--10 -ppp --11 pppp MOVLW 007h ;

TRIS PORTB

; ;Note that the user may have expected the pin ;values to be --00 pppp. The 2nd BCF caused ;RB5 to be latched as the pin value (High).

;--10 -ppp

--11 pppp

#### 5.5.2 SUCCESSIVE OPERATIONS ON I/O PORTS

The actual write to an I/O port happens at the end of an instruction cycle, whereas for reading, the data must be valid at the beginning of the instruction cycle (Figure 5-2). Therefore, care must be exercised if a write followed by a read operation is carried out on the same I/O port. The sequence of instructions should allow the pin voltage to stabilize (load dependent) before the next instruction causes that file to be read into the CPU. Otherwise, the previous state of that pin may be read into the CPU rather than the new state. When in doubt, it is better to separate these instructions with a NOP or another instruction not accessing this I/O port.

## 6.0 TIMER0 MODULE AND TMR0 REGISTER

The Timer0 module has the following features:

- 8-bit timer/counter register, TMR0
- Readable and writable
- 8-bit software programmable prescaler
- Internal or external clock select
  - Edge select for external clock

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

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

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

The prescaler may be used by either the Timer0 module or the Watchdog Timer, but not both. 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 values of 1:2, 1:4,..., 1:256 are selectable. Section 6.2 details the operation of the prescaler.

A summary of registers associated with the Timer0 module is found in Table 6-1.

### FIGURE 6-1: TIMER0 BLOCK DIAGRAM



### 7.7 <u>Time-Out Sequence, Power Down,</u> and Wake-up from SLEEP Status Bits (TO/PD/RBWUF)

The  $\overline{\text{TO}}$ ,  $\overline{\text{PD}}$ , and RBWUF bits in the STATUS register can be tested to determine if a RESET condition has been caused by a power-up condition, a  $\overline{\text{MCLR}}$  or Watchdog Timer (WDT) reset.

| <b>TABLE 7-7:</b> | TO/PD/RBWUF STATUS |
|-------------------|--------------------|
|                   | AFTER RESET        |

| RBWUF | TO | PD | RESET caused by                     |
|-------|----|----|-------------------------------------|
| 0     | 0  | 0  | WDT wake-up from<br>SLEEP           |
| 0     | 0  | u  | WDT time-out (not from SLEEP)       |
| 0     | 1  | 0  | MCLR wake-up from<br>SLEEP          |
| 0     | 1  | 1  | Power-up                            |
| 0     | u  | u  | MCLR not during SLEEP               |
| 1     | 1  | 0  | Wake-up from SLEEP on<br>pin change |

Legend: u = unchanged

Note 1: The TO, PD, and RBWUF bits maintain their status (u) until a reset occurs. A low-pulse on the MCLR input does not change the TO, PD, and RBWUF status bits.

### 7.8 Reset on Brown-Out

A brown-out is a condition where device power (VDD) dips below its minimum value, but not to zero, and then recovers. The device should be reset in the event of a brown-out.

To reset PIC16C505 devices when a brown-out occurs, external brown-out protection circuits may be built, as shown in Figure 7-12 and Figure 7-13.

### FIGURE 7-12: BROWN-OUT PROTECTION CIRCUIT 1



### FIGURE 7-13: BROWN-OUT PROTECTION CIRCUIT 2



This brown-out circuit is less expensive, although less accurate. Transistor Q1 turns off when VDD is below a certain level such that:

$$V_{DD} \bullet \frac{R1}{R1 + R2} = 0.7V$$

**Note 1:** Pin must be confirmed as  $\overline{MCLR}$ .

### FIGURE 7-14: BROWN-OUT PROTECTION CIRCUIT 3



This brown-out protection circuit employs Microchip Technology's MCP809 microcontroller supervisor. There are 7 different trip point selections to accommodate 5V to 3V systems.

### 7.12 In-Circuit Serial Programming

The PIC16C505 microcontrollers can be serially programmed while in the end application circuit. This is simply done with two lines for clock and data, and three other lines for power, ground, and the programming voltage. This allows customers to manufacture boards with unprogrammed devices, and then program the microcontroller just before shipping the product. This also allows the most recent firmware or a custom firmware to be programmed.

The device is placed into a program/verify mode by holding the RB1 and RB0 pins low while raising the  $\overline{\text{MCLR}}$  (VPP) pin from VIL to VIHH (see programming specification). RB1 becomes the programming clock and RB0 becomes the programming data. Both RB1 and RB0 are Schmitt Trigger inputs in this mode.

After reset, a 6-bit command is then supplied to the device. Depending on the command, 14 bits of program data are then supplied to or from the device, depending if the command was a load or a read. For complete details of serial programming, please refer to the PIC16C505 Programming Specifications.

A typical in-circuit serial programming connection is shown in Figure 7-15.

### FIGURE 7-15: TYPICAL IN-CIRCUIT SERIAL PROGRAMMING CONNECTION



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

| ANDLW                           | And literal with W                     |                        |              |           |  |  |  |
|---------------------------------|----------------------------------------|------------------------|--------------|-----------|--|--|--|
| Syntax:                         | [ <i>label</i> ] ANDLW k               |                        |              |           |  |  |  |
| Operands:                       | $0 \le k \le 28$                       | 55                     |              |           |  |  |  |
| Operation:                      | (W).AND                                | . (k) $\rightarrow$ (V | V)           |           |  |  |  |
| Status Affected:                | Z                                      |                        |              |           |  |  |  |
| Encoding:                       | 1110                                   | kkkk                   | kkkk         |           |  |  |  |
| Description:                    | The conte<br>AND'ed v<br>The resulter. | vith the e             | ight-bit lit | eral 'k'. |  |  |  |
| Words:                          | 1                                      |                        |              |           |  |  |  |
| Cycles:                         | 1                                      |                        |              |           |  |  |  |
| Example:                        | ANDLW                                  | 0x5F                   |              |           |  |  |  |
| Before Instru<br>W =            | oxA3                                   |                        |              |           |  |  |  |
| After Instruction<br>W = $0x03$ |                                        |                        |              |           |  |  |  |

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

| BCF                                   | Bit Clear               | r f                                                                |           |    |  |  |  |
|---------------------------------------|-------------------------|--------------------------------------------------------------------|-----------|----|--|--|--|
| Syntax:                               | [label]                 | BCF f,t                                                            | )         |    |  |  |  |
| Operands:                             |                         | $\begin{array}{l} 0 \leq f \leq 31 \\ 0 \leq b \leq 7 \end{array}$ |           |    |  |  |  |
| Operation:                            | $0 \rightarrow (f < b)$ | >)                                                                 |           |    |  |  |  |
| Status Affected:                      | None                    |                                                                    |           |    |  |  |  |
| Encoding:                             | 0100                    | bbbf                                                               | ffff      |    |  |  |  |
| Description:                          | Bit 'b' in r            | egister 'f'                                                        | is cleare | d. |  |  |  |
| Words:                                | 1                       |                                                                    |           |    |  |  |  |
| Cycles:                               | 1                       |                                                                    |           |    |  |  |  |
| Example:                              | BCF                     | FLAG_REG                                                           | 5, 7      |    |  |  |  |
| Before Instruction<br>FLAG_REG = 0xC7 |                         |                                                                    |           |    |  |  |  |
| After Instruc<br>FLAG_R               | tion<br>EG = 0x47       | 7                                                                  |           |    |  |  |  |

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

## CLRF Clear f

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

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

| SWAPF                      | Swap Nibbles in f                                                                                                                                              |  |  |  |  |  |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:                    | [ <i>label</i> ] SWAPF f,d                                                                                                                                     |  |  |  |  |  |
| Operands:                  | $\begin{array}{l} 0\leq f\leq 31\\ d\in [0,1] \end{array}$                                                                                                     |  |  |  |  |  |
| Operation:                 | (f<3:0>) → (dest<7:4>);<br>(f<7:4>) → (dest<3:0>)                                                                                                              |  |  |  |  |  |
| Status Affected:           | None                                                                                                                                                           |  |  |  |  |  |
| Encoding:                  | 0011 10df ffff                                                                                                                                                 |  |  |  |  |  |
| Description:               | The upper and lower nibbles of register 'f' are exchanged. If 'd' is 0, the result is placed in W register. If 'd' is 1, the result is placed in register 'f'. |  |  |  |  |  |
| Words:                     | 1                                                                                                                                                              |  |  |  |  |  |
| Cycles:                    | 1                                                                                                                                                              |  |  |  |  |  |
| Example                    | SWAPF REG1, 0                                                                                                                                                  |  |  |  |  |  |
| Before Instru<br>REG1      | uction<br>= 0xA5                                                                                                                                               |  |  |  |  |  |
| After Instruc<br>REG1<br>W | tion<br>= 0xA5<br>= 0X5A                                                                                                                                       |  |  |  |  |  |

| TRIS                  | Load TRIS Register                                                                 |  |  |  |  |  |
|-----------------------|------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:               | [label] TRIS f                                                                     |  |  |  |  |  |
| Operands:             | f = 6                                                                              |  |  |  |  |  |
| Operation:            | (W) $\rightarrow$ TRIS register f                                                  |  |  |  |  |  |
| Status Affected:      | None                                                                               |  |  |  |  |  |
| Encoding:             | 0000 0000 Offf                                                                     |  |  |  |  |  |
| Description:          | TRIS register 'f' (f = 6 or 7) is<br>loaded with the contents of the W<br>register |  |  |  |  |  |
| Words:                | 1                                                                                  |  |  |  |  |  |
| Cycles:               | 1                                                                                  |  |  |  |  |  |
| Example               | TRIS PORTB                                                                         |  |  |  |  |  |
| Before Instru<br>W    | uction<br>= 0XA5                                                                   |  |  |  |  |  |
| After Instruc<br>TRIS | tion<br>= 0XA5                                                                     |  |  |  |  |  |

|                                                                                    | Exclusive OR literal with W                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:                                                                            | [ <i>label</i> ] XORLW k                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| Operands:                                                                          | $0 \le k \le 255$                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Operation:                                                                         | (W) .XOR. $k \rightarrow (W)$                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| Status Affected:                                                                   | Z                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Encoding:                                                                          | 1111 kkkk kkkk                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| Description:                                                                       | The contents of the W register are XOR'ed with the eight bit literal 'k'. The result is placed in the W register.                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Words:                                                                             | 1                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Cycles:                                                                            | 1                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Example:                                                                           | XORLW 0xAF                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| Before Instru<br>W =                                                               | uction<br>0xB5                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| XORWF                                                                              | Exclusive OR W with f                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| Curatava                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| Syntax:                                                                            | [ <i>label</i> ] XORWF f,d                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| Syntax:<br>Operands:                                                               | $ [ label ] XORWF f,d \\ 0 \le f \le 31 \\ d \in [0,1] $                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|                                                                                    | $0 \le f \le 31$                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| Operands:                                                                          | $\begin{array}{l} 0\leq f\leq 31\\ d\in [0,1] \end{array}$                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| Operands:<br>Operation:                                                            | $0 \le f \le 31$<br>$d \in [0,1]$<br>(W) .XOR. (f) $\rightarrow$ (dest)                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:                                        | $0 \le f \le 31$<br>$d \in [0,1]$<br>(W) .XOR. (f) $\rightarrow$ (dest)<br>Z                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:                           | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in [0,1] \\ (W) . XOR. (f) \rightarrow (dest) \\ Z \\ \hline \hline \\ 0001  10df  ffff \\ \hline \\ Exclusive OR the contents of the \\ W register with register 'f'. If 'd' is 0, \\ the result is stored in the W register. If 'd' is 1, the result is stored \\ \end{array}$                                                                                                  |  |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:           | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in [0,1] \\ (W) \ .XOR. \ (f) \rightarrow (dest) \\ \hline Z \\ \hline \hline 0001 \ 10df \ fff \\ \hline Exclusive \ OR \ the \ contents \ of \ the \\ W \ register \ with \ register \ 'f'. \ If \ 'd' \ is \ 0, \\ the \ result \ is \ stored \ in \ the \ W \ register \ 'f'. \\ \hline d' \ is \ 1, \ the \ result \ is \ stored \\ back \ in \ register \ 'f'. \end{array}$ |  |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words: | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in [0,1] \\ (W) .XOR. (f) \rightarrow (dest) \\ \hline Z \\ \hline \hline 0001  10df  ffff \\ \hline Exclusive OR the contents of the \\ W register with register 'f'. If 'd' is 0, \\ the result is stored in the W register. If 'd' is 1, the result is stored \\ back in register 'f'. \\ 1 \\ \hline \end{array}$                                                             |  |  |  |  |  |  |

| W            | =     | 0xB5 |
|--------------|-------|------|
| After Instru | ction |      |
| REG          | =     | 0x1A |
| W            | =     | 0xB5 |

### 10.1 DC CHARACTERISTICS:

### PIC16C505-04 (Commercial, Industrial, Extended) PIC16C505-20(Commercial, Industrial, Extended)

Standard Operating Co Operating Temperature

Standard Operating Conditions (unless otherwise specified) Operating Temperature  $0^{\circ}C \le TA \le +70^{\circ}C$  (commercial)

DC Characteristics Power Supply Pins  $0^{\circ}C \le TA \le +70^{\circ}C$  (commercial) -40^{\circ}C \le TA \le +85^{\circ}C (industrial)

 $-40^{\circ}C \le TA \le +125^{\circ}C$  (extended)

| Parm.<br>No. | Characteristic                                                  | Sym   | Min   | Typ <sup>(1)</sup>          | Max                         | Units                      | Conditions                                                                                                                                                                                                                                |
|--------------|-----------------------------------------------------------------|-------|-------|-----------------------------|-----------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D001         | Supply Voltage                                                  | Vdd   | 3.0   |                             | 5.5                         | V                          | See Figure 10-1 through Figure 10-3                                                                                                                                                                                                       |
| D002         | RAM Data Retention<br>Voltage <sup>(2)</sup>                    | Vdr   | _     | 1.5*                        | _                           | V                          | Device in SLEEP mode                                                                                                                                                                                                                      |
| D003         | VDD Start Voltage to ensure<br>Power-on Reset                   | VPOR  | —     | Vss                         | —                           | V                          | See section on Power-on Reset for details                                                                                                                                                                                                 |
| D004         | VDD Rise Rate to ensure<br>Power-on Reset                       | SVDD  | 0.05* | —                           | —                           | V/ms                       | See section on Power-on Reset for details                                                                                                                                                                                                 |
| D010         | Supply Current <sup>(3)</sup>                                   | IDD   | <br>  | 0.8<br>0.6<br>3<br>4<br>4.5 | 1.4<br>1.0<br>7<br>12<br>16 | mA<br>mA<br>mA<br>mA<br>mA | Fosc = 4MHz, VDD = 5.5V, WDT disabled (Note 4)*<br>Fosc = 4MHz, VDD = 3.0V, WDT disabled (Note 4)<br>Fosc = 10MHz, VDD = 3.0V, WDT disabled (Note 6)<br>Fosc = 20MHz, VDD = 4.5V, WDT disabled<br>Fosc = 20MHz, VDD = 5.5V, WDT disabled* |
|              |                                                                 |       | —     | 19                          | 27                          | μA                         | Fosc = 32kHz, VDD = 3.0V, WDT disabled (Note 6)                                                                                                                                                                                           |
| D020         | Power-Down Current <sup>(5)</sup>                               | IPD   |       | 0.25<br>0.4<br>3<br>5       | 4<br>5.5<br>8<br>14         | μΑ<br>μΑ<br>μΑ<br>μΑ       | VDD = 3.0V (Note 6)<br>$VDD = 4.5V^* (Note 6)$<br>VDD = 5.5V, Industrial<br>VDD = 5.5V, Extended Temp.                                                                                                                                    |
| D022         | WDT Current <sup>(5)</sup>                                      | ΔIWDT | _     | 2.2                         | 5                           | μA                         | VDD = 3.0V (Note 6)                                                                                                                                                                                                                       |
| 1A           | LP Oscillator Operating<br>Frequency<br>RC Oscillator Operating | Fosc  | 0     | _                           | 200                         | kHz                        | All temperatures                                                                                                                                                                                                                          |
|              | Frequency<br>XT Oscillator Operating                            |       | 0     | _                           | 4                           | MHz                        | All temperatures                                                                                                                                                                                                                          |
|              | Frequency<br>HS Oscillator Operating                            |       | 0     | _                           | 4                           | MHz                        | All temperatures                                                                                                                                                                                                                          |
|              | Frequency                                                       |       | 0     |                             | 20                          | MHz                        | All temperatures                                                                                                                                                                                                                          |

\* These parameters are characterized but not tested.

Note 1: Data in the Typical ("Typ") column is based on characterization results at 25°C. This data is for design guidance only and is not tested.
 2: This is the limit to which VDD can be lowered in SLEEP mode without losing RAM data.

**3:** The supply current is mainly a function of the operating voltage and frequency. Other factors such as bus loading, oscillator type, bus rate, internal code execution pattern and temperature also have an impact on the current consumption.

a) The test conditions for all IDD measurements in active operation mode are:

OSC1 = external square wave, from rail-to-rail; all I/O pins tristated, pulled to VSS, TOCKI = VDD,  $\overline{MCLR}$  = VDD; WDT enabled/disabled as specified.

b) For standby current measurements, the conditions are the same, except that the device is in SLEEP mode.

4: Does not include current through Rext. The current through the resistor can be estimated by the formula: IR = VDD/2Rext (mA) with Rext in kOhm.

5: 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 in hi-impedance state and tied to VDD or VSS.

6: Commercial temperature range only.

| VDD (Volts) | Temperature (°C) | Min   | Тур    | Max  | Units |
|-------------|------------------|-------|--------|------|-------|
|             |                  | RB0/R | B1/RB4 |      |       |
| 2.5         | -40              | 38K   | 42K    | 63K  | W     |
|             | 25               | 42K   | 48K    | 63K  | W     |
|             | 85               | 42K   | 49K    | 63K  | W     |
|             | 125              | 50K   | 55K    | 63K  | W     |
| 5.5         | -40              | 15K   | 17K    | 20K  | W     |
|             | 25               | 18K   | 20K    | 23K  | W     |
|             | 85               | 19K   | 22K    | 25K  | W     |
|             | 125              | 22K   | 24K    | 28K  | W     |
|             |                  | R     | B3     |      |       |
| 2.5         | -40              | 285K  | 346K   | 417K | W     |
|             | 25               | 343K  | 414K   | 532K | W     |
|             | 85               | 368K  | 457K   | 532K | W     |
|             | 125              | 431K  | 504K   | 593K | W     |
| 5.5         | -40              | 247K  | 292K   | 360K | W     |
|             | 25               | 288K  | 341K   | 437K | W     |
|             | 85               | 306K  | 371K   | 448K | W     |
|             | 125              | 351K  | 407K   | 500K | W     |

# TABLE 10-1: PULL-UP RESISTOR RANGES - PIC16C505

\* These parameters are characterized but not tested.

**TABLE 10-2:** 

## 10.5 <u>Timing Diagrams and Specifications</u>



**EXTERNAL CLOCK TIMING REQUIREMENTS - PIC16C505** 

| AC Chara         | cteristics | $\begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise specified)}\\ \mbox{Operating Temperature} & 0^{\circ}C \leq TA \leq +70^{\circ}C \mbox{ (commercial),}\\ & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ (industrial),}\\ & -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ (extended)}\\ \mbox{Operating Voltage VDD range is described in Section 10.1} \end{array}$ |     |                    |        |       |                               |
|------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------|--------|-------|-------------------------------|
| Parameter<br>No. | Sym        | Characteristic                                                                                                                                                                                                                                                                                                                                                                                  | Min | Typ <sup>(1)</sup> | Max    | Units | Conditions                    |
| 1A               | Fosc       | External CLKIN Frequency <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                         | DC  |                    | 4      | MHz   | XT osc mode                   |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 | DC  | —                  | 4      | MHz   | HS osc mode<br>(PIC16C505-04) |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 | DC  | —                  | 20     | MHz   | HS osc mode<br>(PIC16C505-20) |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 | DC  | —                  | 200    | kHz   | LP osc mode                   |
|                  |            | Oscillator Frequency <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                             | DC  | _                  | 4      | MHz   | EXTRC osc mode                |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 | 0.1 | —                  | 4      | MHz   | XT osc mode                   |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 | 4   | —                  | 4      | MHz   | HS osc mode<br>(PIC16C505-04) |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 | DC  | _                  | 200    | kHz   | LP osc mode                   |
| 1                | Tosc       | External CLKIN Period <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                            | 250 | _                  | _      | ns    | XT osc mode                   |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 | 50  | —                  | _      | ns    | HS osc mode<br>(PIC16C505-20) |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 |     | —                  | —      | μs    | LP osc mode                   |
|                  |            | Oscillator Period <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                                | 250 | —                  | —      | ns    | EXTRC osc mode                |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 | 250 | -                  | 10,000 | ns    | XT osc mode                   |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 | 250 | _                  | 250    | ns    | HS ocs mode<br>(PIC16C505-04) |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 | 50  | -                  | 250    | ns    | HS ocs mode<br>(PIC16C505-20) |
|                  |            |                                                                                                                                                                                                                                                                                                                                                                                                 | 5   | —                  | —      | μs    | LP osc mode                   |
| 2                | Тсү        | Instruction Cycle Time                                                                                                                                                                                                                                                                                                                                                                          | —   | 4/Fosc             | DC     | ns    |                               |

\* These parameters are characterized but not tested.

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

2: All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption.

200

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

ns

## 11.0 DC AND AC CHARACTERISTICS -PIC16C505

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

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

### FIGURE 11-1: CALIBRATED INTERNAL RC FREQUENCY RANGE VS. TEMPERATURE (VDD = 5.0V) (INTERNAL RC IS CALIBRATED TO 25°C, 5.0V)





# 14-Lead Plastic Dual In-Line (P) – 300 mil Body [PDIP]

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





Е

eВ

С



|                            | Units    |      | INCHES   |      |
|----------------------------|----------|------|----------|------|
| Dimensior                  | n Limits | MIN  | NOM      | MAX  |
| Number of Pins             | Ν        |      | 14       |      |
| Pitch                      | е        |      | .100 BSC |      |
| Top to Seating Plane       | А        | —    | -        | .210 |
| Molded Package Thickness   | A2       | .115 | .130     | .195 |
| Base to Seating Plane      | A1       | .015 | -        | -    |
| Shoulder to Shoulder Width | E        | .290 | .310     | .325 |
| Molded Package Width       | E1       | .240 | .250     | .280 |
| Overall Length             | D        | .735 | .750     | .775 |
| Tip to Seating Plane       | L        | .115 | .130     | .150 |
| Lead Thickness             | С        | .008 | .010     | .015 |
| Upper Lead Width           | b1       | .045 | .060     | .070 |
| Lower Lead Width           | b        | .014 | .018     | .022 |
| Overall Row Spacing §      | eB       | -    | -        | .430 |

Notes:

1. Pin 1 visual index feature may vary, but must be located with the hatched area.

2. § Significant Characteristic.

3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" per side.

4. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing C04-005B

14-Lead Plastic Small Outline (SL) - Narrow, 3.90 mm Body [SOIC]

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



## RECOMMENDED LAND PATTERN

|                       | Units            | N        | ILLIMETER | S    |  |
|-----------------------|------------------|----------|-----------|------|--|
| Dimensior             | Dimension Limits |          | NOM       | MAX  |  |
| Contact Pitch         | E                | 1.27 BSC |           |      |  |
| Contact Pad Spacing   | С                |          | 5.40      |      |  |
| Contact Pad Width     | X                |          |           | 0.60 |  |
| Contact Pad Length    | Y                |          |           | 1.50 |  |
| Distance Between Pads | Gx               | 0.67     |           |      |  |
| Distance Between Pads | G                | 3.90     |           |      |  |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing No. C04-2065A

## 14-Lead Plastic Thin Shrink Small Outline (ST) - 4.4 mm Body [TSSOP]

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



|                          | N    | AILLIMETER:    | s        |      |  |
|--------------------------|------|----------------|----------|------|--|
| Dimension                | MIN  | NOM            | MAX      |      |  |
| Number of Pins           | N    |                | 14       |      |  |
| Pitch                    | е    |                | 0.65 BSC |      |  |
| Overall Height           | Α    | 1.20           |          |      |  |
| Molded Package Thickness | A2   | 0.80 1.00 1.05 |          |      |  |
| Standoff                 | A1   | 0.05 - 0.15    |          |      |  |
| Overall Width            | E    | 6.40 BSC       |          |      |  |
| Molded Package Width     | E1   | 4.30 4.40 4.50 |          |      |  |
| Molded Package Length    | D    | 4.90 5.00 5.10 |          |      |  |
| Foot Length              | L    | 0.45           | 0.60     | 0.75 |  |
| Footprint                | (L1) | 1.00 REF       |          |      |  |
| Foot Angle               | φ    | 0°             | -        | 8°   |  |
| Lead Thickness           | С    | 0.09 - 0.20    |          |      |  |
| Lead Width               | b    | 0.19           | -        | 0.30 |  |

Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.15mm per side.

3. Dimensioning and tolerancing per ASME Y14.5M

BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing No. C04-087C Sheet 2 of 2

## INDEX

| Α                                                                          |          |
|----------------------------------------------------------------------------|----------|
| ALU                                                                        | 7        |
| Applications                                                               |          |
| Architectural Overview                                                     |          |
| Assembler                                                                  |          |
| MPASM Assembler                                                            | 52       |
| В                                                                          |          |
| -                                                                          |          |
| Block Diagram                                                              |          |
| On-Chip Reset Circuit                                                      | 33       |
| Timer0<br>TMR0/WDT Prescaler                                               |          |
|                                                                            |          |
| Watchdog Timer<br>Brown-Out Protection Circuit                             | 30<br>26 |
|                                                                            |          |
| C                                                                          |          |
| C Compilers                                                                |          |
| MPLAB C18                                                                  | 52       |
| CAL0 bit                                                                   | 16       |
| CAL1 bit                                                                   | 16       |
| CAL2 bit                                                                   | 16       |
| CAL3 bit                                                                   | 16       |
| CALFST bit                                                                 | 16       |
| CALSLW bit                                                                 | 16       |
| Carry                                                                      |          |
| Clocking Scheme                                                            |          |
| Code Protection                                                            | . 27, 37 |
| Configuration Bits                                                         | 27       |
| Configuration Word                                                         |          |
| Customer Change Notification Service                                       |          |
| Customer Notification Service                                              |          |
| Customer Support                                                           | 85       |
| D                                                                          |          |
| DC and AC Characteristics                                                  | 69       |
| Development Support                                                        |          |
| Device Varieties                                                           |          |
| Digit Carry                                                                |          |
| E                                                                          |          |
| _                                                                          |          |
| Errata                                                                     | 2        |
| F                                                                          |          |
| Family of Devices                                                          |          |
| PIC16C505                                                                  |          |
| FSR                                                                        | 10       |
| I                                                                          |          |
| I/O Interfacing                                                            |          |
| I/O Ports                                                                  |          |
| I/O Programming Considerations                                             |          |
| ID Locations                                                               |          |
| INDF                                                                       |          |
| Indirect Data Addressing                                                   |          |
| Instruction Cycle                                                          | 10       |
|                                                                            |          |
|                                                                            | 10       |
| Instruction Flow/Pipelining<br>Instruction Set Summary<br>Internet Address | 10<br>40 |

| L                                                                                  |   |
|------------------------------------------------------------------------------------|---|
| Loading of PC 1                                                                    | 7 |
| Μ                                                                                  |   |
| Memory Organization 1                                                              | 1 |
| Data Memory 1                                                                      |   |
| Program Memory 1                                                                   |   |
| Microchip Internet Web Site                                                        |   |
| MPLAB ASM30 Assembler, Linker, Librarian                                           |   |
| MPLAB Integrated Development Environment Software 5<br>MPLAB PM3 Device Programmer |   |
| MPLAB REAL ICE In-Circuit Emulator System                                          |   |
| MPLINK Object Linker/MPLIB Object Librarian                                        |   |
| 0                                                                                  |   |
| OPTION Register1                                                                   | 5 |
| OSC selection                                                                      |   |
| OSCCAL Register                                                                    |   |
| Oscillator Configurations                                                          |   |
| Oscillator Types                                                                   |   |
| HS24                                                                               | 8 |
| LP                                                                                 | 8 |
| RC                                                                                 | - |
| XT24                                                                               | 8 |
| P                                                                                  |   |
| Package Marking Information                                                        | 3 |
| Packaging Information                                                              | 3 |
| POR                                                                                |   |
| Device Reset Timer (DRT) 27, 3                                                     |   |
| PD                                                                                 |   |
| Power-On Reset (POR)                                                               |   |
| PORTB                                                                              |   |
| Power-Down Mode                                                                    |   |
| Prescaler                                                                          |   |
| Program Counter                                                                    |   |
| Q                                                                                  |   |
| Q cycles                                                                           | 0 |
| R                                                                                  |   |
| RC Oscillator                                                                      | 0 |
| Read Modify Write                                                                  |   |
| Reader Response                                                                    |   |
| Register File Map                                                                  |   |
| Registers                                                                          |   |
| Special Function 1                                                                 | 3 |
| Reset 2                                                                            |   |
| Reset on Brown-Out                                                                 |   |
| Revision History                                                                   | 1 |
| S                                                                                  |   |
| SLEEP                                                                              | 7 |
| Software Simulator (MPLAB SIM) 55                                                  | 3 |
| Special Features of the CPU 2                                                      |   |
| Special Function Registers 1                                                       |   |
| Stack                                                                              |   |
| STATUS                                                                             |   |
| STATUS Register 1                                                                  | 4 |
| T                                                                                  |   |
| Timer0                                                                             | _ |
| Switching Prescaler Assignment                                                     |   |
| Timer0                                                                             |   |
| Timer0 (TMR0) Module                                                               |   |
| TMR0 with External Clock                                                           |   |
| Timing Parameter Symbology and Load Conditions                                     |   |
| TRIS Registers                                                                     |   |
|                                                                                    |   |

# THE MICROCHIP WEB SITE

Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information:

- Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

# CUSTOMER CHANGE NOTIFICATION SERVICE

Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, access the Microchip web site at www.microchip.com. Under "Support", click on "Customer Change Notification" and follow the registration instructions.

## **CUSTOMER SUPPORT**

Users of Microchip products can receive assistance through several channels:

- Distributor or Representative
- Local Sales Office
- Field Application Engineer (FAE)
- Technical Support

Customers should contact their distributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document.

Technical support is available through the web site at: http://microchip.com/support

### **PIC16C505 Product Identification System**



Please contact your local sales office for exact ordering procedures.

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

Please specify which device, revision of silicon and Data Sheet (include Literature #) you are using.

#### **New Customer Notification System**

Register on our web site (www.microchip.com/cn) to receive the most current information on our products.