



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | PIC                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 20MHz                                                                     |
| Connectivity               | l²C                                                                       |
| Peripherals                | POR, Temp Sensor, WDT                                                     |
| Number of I/O              | 20                                                                        |
| Program Memory Size        | 7KB (4K x 14)                                                             |
| Program Memory Type        | ОТР                                                                       |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 192 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 6V                                                                 |
| Data Converters            | Slope A/D                                                                 |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Through Hole                                                              |
| Package / Case             | 28-DIP (0.300", 7.62mm)                                                   |
| Supplier Device Package    | 28-SPDIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic14000-20i-sp |

Email: info@E-XFL.COM

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





#### TABLE 4-2: CALIBRATION CONSTANT ADDRESSES

| Address          | Data                                      |
|------------------|-------------------------------------------|
| 0FC0h            | K <sub>REF</sub> , exponent               |
| 0FC1h            | K <sub>REF</sub> , mantissa high byte     |
| 0FC2h            | K <sub>REF</sub> , mantissa middle byte   |
| 0FC3h            | K <sub>REF</sub> , mantissa low byte      |
| 0FC4h            | K <sub>BG</sub> , exponent                |
| 0FC5h            | $K_{BG}$ , mantissa high byte             |
| 0FC6h            | $K_{BG}$ , mantissa middle byte           |
| 0FC7h            | K <sub>BG</sub> , mantissa low byte       |
| 0FC8h            | V <sub>THERM</sub> , exponent             |
| 0FC9h            | V <sub>THERM</sub> , mantissa high byte   |
| 0FCAh            | V <sub>THERM</sub> , mantissa middle byte |
| 0FCBh            | V <sub>THERM</sub> , mantissa low byte    |
| 0FCCh            | K <sub>TC</sub> , exponent                |
| 0FCDh            | $K_{TC}$ , mantissa high byte             |
| 0FCEh            | $K_{TC}$ , mantissa middle byte           |
| 0FCFh            | $K_{TC}$ , mantissa low byte              |
| 0FD0h            | F <sub>osc</sub> , unsigned byte          |
| 0FD1h            | reserved                                  |
| 0FD2h            | T <sub>WDT</sub> , unsigned byte          |
| 0FD3h -<br>0FF8h | reserved                                  |
| 0FF9h-Fh         | calibration space checksums               |

## 4.2 Data Memory Organization

The data memory (Figure 4-2) is partitioned into two banks which contain the general purpose registers and the special function registers. Bank 0 is selected when the RP0 bit in the STATUS register is cleared. Bank 1 is selected when the RP0 bit in the STATUS register is set. Each bank extends up to 7Fh (128 bytes). The first 32 locations of each bank are reserved for the Special Function Registers. Several Special Function Registers are mapped in both Bank 0 and Bank 1. The general purpose registers, implemented as static RAM, are located from address 20h through 7Fh, and A0 through FF.

#### 4.2.1 GENERAL PURPOSE REGISTER FILE

The register file is accessed either directly, or indirectly through the file select register FSR (Section 4.4).

#### FIGURE 4-2: REGISTER FILE MAP

|     | File Address                                 |                                              |     |  |  |  |  |
|-----|----------------------------------------------|----------------------------------------------|-----|--|--|--|--|
| 00h | Indirect add.(*)                             | Indirect addr.(*)                            | 80h |  |  |  |  |
| 01h | TMR0                                         | OPTION                                       | 81h |  |  |  |  |
| 02h | PCL                                          | PCL                                          | 82h |  |  |  |  |
| 03h | STATUS                                       | STATUS                                       | 83h |  |  |  |  |
| 04h | FSR                                          | FSR                                          | 84h |  |  |  |  |
| 05h | PORTA                                        | TRISA                                        | 85h |  |  |  |  |
| 06h | RESERVED                                     | RESERVED                                     | 86h |  |  |  |  |
| 07h | PORTC                                        | TRISC                                        | 87h |  |  |  |  |
| 08h | PORTD                                        | TRISD                                        | 88h |  |  |  |  |
| 09h |                                              |                                              | 89h |  |  |  |  |
| 0Ah | PCLATH                                       | PCLATH                                       | 8Ah |  |  |  |  |
| 0Bh | INTCON                                       | INTCON                                       | 8Bh |  |  |  |  |
| 0Ch | PIR1                                         | PIE1                                         | 8Ch |  |  |  |  |
| 0Dh |                                              |                                              | 8Dh |  |  |  |  |
| 0Eh | ADTMRL                                       | PCON                                         | 8Eh |  |  |  |  |
| 0Fh | ADTMRH                                       | SLPCON                                       | 8Fh |  |  |  |  |
| 10h |                                              |                                              | 90h |  |  |  |  |
| 11h |                                              |                                              | 91h |  |  |  |  |
| 12h |                                              |                                              | 92h |  |  |  |  |
| 13h | I <sup>2</sup> CBUF                          | I <sup>2</sup> CADD                          | 93h |  |  |  |  |
| 14h | I <sup>2</sup> CCON                          | I <sup>2</sup> CSTAT                         | 94h |  |  |  |  |
| 15h | ADCAPL                                       |                                              | 95h |  |  |  |  |
| 16h | ADCAPH                                       |                                              | 96h |  |  |  |  |
| 17h |                                              |                                              | 97h |  |  |  |  |
| 18h |                                              |                                              | 98h |  |  |  |  |
| 19h |                                              |                                              | 99h |  |  |  |  |
| 1Ah |                                              |                                              | 9Ah |  |  |  |  |
| 1Bh |                                              | PREFA                                        | 9Bh |  |  |  |  |
| 1Ch |                                              | PREFB                                        | 9Ch |  |  |  |  |
| 1Dh |                                              | CMCON                                        | 9Dh |  |  |  |  |
| 1Eh |                                              | MISC                                         | 9Eh |  |  |  |  |
| 1Fh | ADCON0                                       | ADCON1                                       | 9Fh |  |  |  |  |
| 20h |                                              |                                              | A0h |  |  |  |  |
| 7F  | General<br>Purpose<br>Register<br>(96 Bytes) | General<br>Purpose<br>Register<br>(96 Bytes) | FF  |  |  |  |  |

\* Not a physical register.

Shaded areas are unimplemented memory locations, read as '0's.

#### 4.4 Indirect Addressing, INDF and FSR Registers

The INDF register is not a physical register. Addressing the INDF register will cause indirect addressing.

Indirect addressing is possible by using the INDF register. Any instruction using the INDF register actually accesses data pointed to by the file select register (FSR). Reading INDF itself indirectly will produce 00h. Writing to the INDF register indirectly results in a no-operation (although status bits may be affected). An effective 9-bit address is obtained by concatenating the 8-bit FSR register and the IRP bit (STATUS<7>), as shown in Figure 4-10. However, IRP is not used in the PIC14000.

A simple program to clear RAM location 20h-2Fh using indirect addressing is shown in Example 4-2.

## EXAMPLE 4-2: INDIRECT ADDRESSING

|      | movlw | 0x20  | ;initialize pointer  |
|------|-------|-------|----------------------|
|      | movf  | FSR   | ;to RAM              |
| NEXT | clrf  | INDF  | ;clear INDF register |
|      | incf  | FSR   | ;inc pointer         |
|      | btfss | FSR,4 | ;all done?           |
|      | goto  | NEXT  | ;no clear next       |
|      |       |       | ;yes continue        |

CONTINUE:



## FIGURE 4-10: INDIRECT/INDIRECT ADDRESSING

# 6.0 TIMER MODULES

The PIC14000 contains two general purpose timer modules, Timer0 (TMR0) and the Watchdog Timer (WDT). The ADTMR is described in the A/D section.

The Timer0 module is identical to the Timer0 module of the PIC16C7X enhanced core products. It is an 8-bit overflow counter.

The Timer0 module has a programmable prescaler option. This prescaler can be assigned to either the Timer0 module or the Watchdog Timer (WDT). PSA (OPTION<3>) assigns the prescaler, and PS2:PS0 (OPTION<2:0>) determines the prescaler value. Timer0 can increment at the following rates: 1:1 (when prescaler assigned to Watchdog Timer), 1:2, 1:4, 1:8, 1:16, 1:32, 1:64, 1:128, 1:256.

The Timer0 module has the following features:

- 8-bit timer
- Readable and writable (file address 01h)
- 8-bit software programmable prescaler
- Interrupt on overflow from FFh to 00h

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

The Timer0 module will increment every instruction cycle (without prescaler). If TMR0 is written, increment is inhibited for the following two cycles (Figure 6-2 and Figure 6-3). The user can compensate by writing an adjusted value to TMR0.



# FIGURE 6-1: TIMER0 AND WATCHDOG TIMER BLOCK DIAGRAM

© 1996 Microchip Technology Inc.

#### 7.5.1.1 ADDRESSING

Once the I<sup>2</sup>C module has been enabled, the I<sup>2</sup>C waits for a START to occur. Following the START, the 8-bits are shifted into the I<sup>2</sup>CSR. All incoming bits are sampled with the rising edge of the clock (SCL) line. The I<sup>2</sup>CSR<7:1> is compared to the I<sup>2</sup>CADD register. The address is compared on the falling edge of the eighth clock (SCL) pulse. If the addresses match, and the BF and I<sup>2</sup>COV bits are clear, the following things happen:

- I<sup>2</sup>CSR loaded into I<sup>2</sup>CBUF
- Buffer Full (BF) bit is set
- ACK pulse is generated
- I<sup>2</sup>C Interrupt Flag (I<sup>2</sup>CIF) is set (interrupt is generated if enabled (I<sup>2</sup>CIE set) on falling edge of ninth SCL pulse.

In 10-bit address mode, two address bytes need to be received by the slave (Figure 7-5). The five most significant bits (MSbs) of the first address byte specify if this is a 10-bit address. The R/W bit (bit 0) must specify a write, so the slave device will received the second address byte. For a 10-bit address the first byte would equal '1 1 1 1 0 A9 A8 0', where A9 and A8 are the two MSbs of the address. The sequence of events for 10-bit address are as follows, with steps 7-9 for slave-transmitter:

- 1. Receive first (high) byte of address (I<sup>2</sup>CIF, BF and UA are set).
- Update I<sup>2</sup>CADD with second (low) byte of address (clears UA and releases SCL line).
- 3. Read I<sup>2</sup>CBUF (clears BF) and clear I<sup>2</sup>CIF.

- 4. Receive second (low) byte of address (I<sup>2</sup>CIF, BF and UA are set).
- Update I<sup>2</sup>CADD with first (high) byte of address (clears UA, if match releases SCL line).
- 6. Read I<sup>2</sup>CBUF (clears BF) and clear I<sup>2</sup>CIF
- 7. Receive Repeated START.
- 8. Receive first (high) byte of address (I<sup>2</sup>CIF and BF are set).
- 9. Read I<sup>2</sup>CBUF (clears BF) and clear I<sup>2</sup>CIF.

#### 7.5.1.2 RECEPTION

When the  $R/\overline{W}$  bit of the address byte is clear and an address match occurs, the  $R/\overline{W}$  bit of the I<sup>2</sup>CSTAT register is cleared. The received address is loaded into the I<sup>2</sup>CBUF.

When the address byte overflow condition exists then no acknowledge ( $\overline{ACK}$ ) pulse is given. An overflow condition is defined as either the BF bit (I<sup>2</sup>CSTAT<0>) is set or the I<sup>2</sup>COV bit (I<sup>2</sup>CCON<6>) is set (Figure 7-14).

An  $I^2CIF$  interrupt is generated for each data transfer byte. The  $I^2CIF$  bit must be cleared in software, and the  $I^2CSTAT$  register is used to determine the status of the byte. In master mode with slave enabled, three interrupt sources are possible. Reading BF, P and S will indicate the source of the interrupt.

**Caution:** BF is set after receipt of eight bits and automatically cleared after the I<sup>2</sup>CBUF is read. However, the flag is not actually cleared until receipt of the acknowledge pulse. Otherwise extra reads appear to be valid.

## FIGURE 7-14: I<sup>2</sup>C WAVEFORMS FOR RECEPTION (7-BIT ADDRESS)



# FIGURE 7-17: OPERATION OF THE I<sup>2</sup>C IN IDLE\_MODE, RCV\_MODE OR XMIT\_MODE

| IDLE_M               | ODE (7-bit):                 |                              |                             |                       |                              |  |
|----------------------|------------------------------|------------------------------|-----------------------------|-----------------------|------------------------------|--|
| if (Addr_            | match)                       | {                            | Set interrupt;              |                       |                              |  |
| . –                  |                              |                              | if (R/W = 1)                | {                     | Send $\overline{ACK} = 0;$   |  |
|                      |                              |                              |                             |                       | set XMIT_MODE;               |  |
|                      |                              |                              | _                           | }                     |                              |  |
|                      |                              |                              | else if $(R/\overline{W} =$ | 0) set RC             | CV_MODE;                     |  |
|                      |                              | }                            |                             |                       |                              |  |
| RCV_M                | DDE:                         |                              |                             |                       |                              |  |
| if ((I2CB            | UF=Full) OR (I <sup>2</sup>  | COV = 1))                    |                             |                       |                              |  |
|                      | { Set I <sup>2</sup> CC      | DV;                          |                             |                       |                              |  |
|                      | Do not a                     | acknowledge;                 |                             |                       |                              |  |
|                      | }                            | 12000 12001                  | _                           |                       |                              |  |
| else                 | { transfer                   | TECSR → FCBU                 | -;                          |                       |                              |  |
|                      | send AC                      | r = 0,                       |                             |                       |                              |  |
| Receive              | 8-bits in I <sup>2</sup> CSR |                              |                             |                       |                              |  |
| Set inter            | rupt:                        |                              |                             |                       |                              |  |
|                      |                              |                              |                             |                       |                              |  |
| XMIT_M               | ODE:                         |                              |                             |                       |                              |  |
| While ((I            | 2CBUF = Empty                | /) AND (CKP=0))              | Hold SCL Low;               |                       |                              |  |
| Send by<br>Set inter | ie;<br>rupt:                 |                              |                             |                       |                              |  |
| if (ACK F            | Received = 1)                | ł                            | End of transm               | ission:               |                              |  |
| ii (/ tort i         |                              | t                            | Go back to IDI              | LE MOD                | DE:                          |  |
|                      |                              | }                            |                             |                       | ,                            |  |
| else if (Ā           | CK Received =                | 0) Go back to X              | MIT_MODE;                   |                       |                              |  |
|                      |                              |                              |                             |                       |                              |  |
| If (High             | byte addr mate               | $h AND (R/\overline{W} = 0)$ | )                           |                       |                              |  |
| n (nigh_             | { PRIOR                      | ADDR MATCH                   | ,<br>= FALSE:               |                       |                              |  |
|                      | Set inter                    | rupt;                        | ,                           |                       |                              |  |
|                      | if ((I2CB                    | UF = Full) OR ((I            | 2COV = 1))                  |                       |                              |  |
|                      |                              | { Set I2                     | COV;                        |                       |                              |  |
|                      |                              | Do not                       | acknowledge;                |                       |                              |  |
|                      |                              | }                            |                             |                       |                              |  |
|                      | else                         | { Set UA                     | x = 1;                      |                       |                              |  |
|                      |                              | Send A                       | ACK = 0;                    |                       |                              |  |
|                      |                              | VVnije<br>Cloar I            |                             | dated) H              | IOID SCL IOW;                |  |
|                      |                              | Receiv                       | JA = 0,<br>velow, addr. by  | dα.                   |                              |  |
|                      |                              | Set int                      | errupt.                     | 10,                   |                              |  |
|                      |                              | Set U/                       | λ = 1;                      |                       |                              |  |
|                      |                              | If (Low                      | _byte_addr_ma               | atch)                 |                              |  |
|                      |                              |                              | { PRIO                      | R_ADDR                | R_MATCH = TRUE;              |  |
|                      |                              |                              | Send                        | $\overline{ACK} = 0;$ | ;                            |  |
|                      |                              |                              | while                       | (I2CADD               | o not updated) Hold SCL low; |  |
|                      |                              |                              | Clear                       | UA = 0;               |                              |  |
|                      |                              |                              | Set R                       | CV_MOD                | DE;                          |  |
|                      |                              |                              | }                           |                       |                              |  |
|                      |                              | }                            |                             |                       |                              |  |
|                      | }                            |                              |                             |                       |                              |  |
| else if (H           | ligh_byte_addr_              | _match AND (R/W              | = 1)                        |                       |                              |  |
|                      | { if (PRIO                   | R_ADDR_MATCH                 | ł)                          |                       |                              |  |
|                      |                              | { send A                     | <u>.</u> CK = 0;            |                       |                              |  |
|                      |                              | set XM                       | IIT_MODE;                   |                       |                              |  |
|                      |                              | }                            |                             |                       |                              |  |
|                      | else PRIOR A                 | ADDR MATCH =                 | FALSE;                      |                       |                              |  |
|                      | }                            |                              | - 1                         |                       |                              |  |
|                      | ,                            |                              |                             |                       |                              |  |

**Caution:** Reading or writing the ADTMR register during an A/D conversion cycle can produce unpredictable results and is not recommended.

| Note: | The                                         | correct    | sequence      | for   | writing  | the  |  |
|-------|---------------------------------------------|------------|---------------|-------|----------|------|--|
|       | ADT                                         | MR regis   | ter is HI byt | e fol | lowed by | / LO |  |
|       | byte. Reversing this order will prevent the |            |               |       |          |      |  |
|       | A/D                                         | timer fror | m running.    |       |          |      |  |

During conversion one or both of the following events will occur:

- 1. capture event
- 2. timer overflow

In a capture event, the comparator trips when the slope voltage on the CDAC output exceeds the input voltage, causing the comparator output to transition from high to low. This causes a transfer of the current timer count to the capture register and sets the ADCIF flag (PIR1<1>).

A CPU interrupt will be generated if bit ADCIE (PIE1<1>) is set to '1' (interrupt enabled). In addition, the Global Interrupt Enable and Peripheral Interrupt Enables (INTCON<7,6>) must also be set. Software is responsible for clearing the ADCIF flag prior to the next conversion cycle. Note that this interrupt can only occur once per conversion cycle.

In a timer overflow condition, the timer rolls over from FFFFh to 0000h, and a capture overflow flag (OVFIF) is asserted (PIR1<0>). The timer continues to increment following a timer overflow. A CPU interrupt can be generated if bit OVFIE (PIE1<0>) is set (interrupt enabled). In addition, the Global Interrupt Enable and Peripheral Interrupt Enables (INTCON<7,6>) must also be set. Software is responsible for clearing the OVFIF flag prior to the next conversion cycle.



#### FIGURE 8-1: A/D BLOCK DIAGRAM

## 8.6 Programmable Current Source

Four configuration bits (ADCON1<7:4>) are used to control a programmable current source for generating the ramp voltage to the A/D comparator. It allows compensation for full-scale input voltage, clock frequency and CDAC capacitor tolerance variations. The current values range from 0 to 33.75  $\mu$ A (nominal) in 2.25  $\mu$ A increments. The intermediate values of the current source are as follows:

| ADCON1<7:4> |   |   |   | Current Source<br>Output              |
|-------------|---|---|---|---------------------------------------|
| 0           | 0 | 0 | 0 | OFF - all current<br>sources disabled |
| 0           | 0 | 0 | 1 | 2.25 μΑ                               |
| 0           | 0 | 1 | 0 | 4.5 μΑ                                |
| 0           | 0 | 1 | 1 | 6.75 μΑ                               |
| 0           | 1 | 0 | 0 | 9 μΑ                                  |
| 0           | 1 | 0 | 1 | 11.25 μΑ                              |
| 0           | 1 | 1 | 0 | 13.5 μA                               |
| 0           | 1 | 1 | 1 | 15.75 μΑ                              |
| 1           | 0 | 0 | 0 | 18 μA                                 |
| 1           | 0 | 0 | 1 | 20.25 μΑ                              |
| 1           | 0 | 1 | 0 | 22.5 μΑ                               |
| 1           | 0 | 1 | 1 | 24.75 μΑ                              |
| 1           | 1 | 0 | 0 | 27 μΑ                                 |
| 1           | 1 | 0 | 1 | 29.25 μΑ                              |
| 1           | 1 | 1 | 0 | 31.5 μA                               |
| 1           | 1 | 1 | 1 | 33.75 μA                              |

| <b>TABLE 8-2:</b> | PROGRAMMABLE CURRENT |
|-------------------|----------------------|
|                   | SOURCE SELECTION     |

The programmable current source output is tied to the CDAC pin and is used to charge an external capacitor to generate the ramp voltage for the A/D comparator. (Refer to Figure 8-1.) This capacitor should have a low voltage-coefficient as found in teflon, polypropylene, or polystyrene capacitors, for optimum results. The capacitor must be discharged at the beginning of each conversion cycle by asserting ADRST (ADCON0<1>) for at least 200  $\mu$ s to allow a complete discharge. Asserting ADRST disables the current sources internally. Current flow begins when ADRST is cleared.

Two registers PREFA (9Bh) and PREFB (9Ch) are used to select the reference output voltages. The PREFx<7:3> bits select the output from the coarse ladder, while PREFx<2:0> bits are for the fine-tune adjustment. Table 9-1 and Table 9-2 show the reference decoding.

These voltages are visible at either RC0/REFA or RD3/REFB pins by setting the CMAOE (CMCON<1>) or CMBOE (CMCON<5>) bits. Setting CMxOE does not affect the reference voltages. It only enables the pin function regardless of the port TRIS register setting. These outputs are not buffered, so they cannot directly drive any DC loads.

The reference outputs are also connected to two independent comparators, COMPA and COMPB. Thus, the references can be used to set the comparator trippoints. The A/D converter can also monitor the reference outputs via A/D channels 8 and 9. Refer to Section 8 for the description of the A/D operation.

The programmable reference output is designed to track the output from the level shift network. However, there will always be some mismatch due to component drift. For best accuracy, the A/D should be used to periodically calibrate the references to the desired set-point.

#### FIGURE 9-3: COMPARATOR AND PROGRAMMABLE REFERENCE BLOCK DIAGRAM (ONE OF TWO SHOWN)



| 9Dh           | Bit 7 | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1 | Bit 0 |  |
|---------------|-------|--------|-------|-------|-------|--------|-------|-------|--|
| CMCON         | U     | CMBOUT | CMBOE | CPOLB | U     | CMAOUT | CMAOE | CPOLA |  |
| Read/Write    | _     | R      | R/W   | R/W   | _     | R      | R/W   | R/W   |  |
| POR value 00h | 0     | 0      | 0     | 0     | 0     | 0      | 0     | 0     |  |
|               |       |        |       |       |       |        |       |       |  |

| FIGURE 9-5: | COMPARATOR | CONTROL | REGISTER |
|-------------|------------|---------|----------|
|             |            |         |          |

| Bit | Name   | Function                                                                                                                                                                                       |
|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| B7  | _      | Unimplemented. Read as '0'.                                                                                                                                                                    |
|     |        | Comparator B Output                                                                                                                                                                            |
| B6  | CMBOUT | Reading this bit returns the status of the comparator B output. Writes to this bit have no effect.                                                                                             |
|     |        | Comparator B Output Enable                                                                                                                                                                     |
| B5  | CMBOE  | <ul> <li>1 = Comparator B output is available on RD2/CMPB pin and Reference B output is available on RD3/REFB pin.</li> <li>0 = RD2/CMPB and RD3/REFB assume normal PORTD function.</li> </ul> |
|     |        | Comparator B Polarity Bit                                                                                                                                                                      |
| B4  | CPOLB  | <ul><li>1 = Invert the output of comparator B.</li><li>0 = Do not invert the output of comparator B.</li></ul>                                                                                 |
| B3  | _      | Unimplemented. Read as '0'.                                                                                                                                                                    |
|     |        | Comparator A Output                                                                                                                                                                            |
| B2  | CMAOUT | Reading this bit returns the status of the comparator A output. Writes to this bit have no effect.                                                                                             |
|     |        | Comparator A Output Enable                                                                                                                                                                     |
| B1  | CMAOE  | <ul> <li>1 = Comparator A output is available on RC1/CMPA pin and Reference A output is available on RC0/REFA pin.</li> <li>0 = RC0/REFA and RC1/CMPA assume normal PORTC function.</li> </ul> |
|     |        | Comparator A Polarity Bit                                                                                                                                                                      |
| B0  | CPOLA  | <ul><li>1 = Invert the output of comparator A.</li><li>0 = Do not invert the output of comparator A.</li></ul>                                                                                 |

## 10.2 Oscillator Configurations

The PIC14000 can be operated with two different oscillator options. The user can program a configuration word (CONFIG<0>) to select one of these:

- HS High Speed Crystal/Ceramic Resonator (CONFIG<0> ='0')
- IN Internal oscillator (CONFIG<0> ='1') (Default)
- 10.2.1 INTERNAL OSCILLATOR CIRCUIT

The PIC14000 includes an internal oscillator option that offers additional cost and board-space savings. No external components are required. The nominal operating frequency is 4 MHz. The frequency is measured and stored into the calibration space in EPROM. By selecting IN mode OSC1/PBTN becomes a digital input (with weak internal pull-up resistor) and can be read via bit MISC<0>. Writes to this location have no effect. The OSC1/PBTN input is capable of generating an interrupt to the CPU if enabled (Section 10.6). Also, the OSC2 pin becomes a digital output for general purpose use and is accessed via MISC<1>. Writes to this bit directly affect the OSC2 pin. Reading this bit returns the contents of the output latch. The MISC register format is shown in Figure 10-2.

The OSC2 pin can also output the IN oscillator frequency, divided-by-four, by setting INCLKEN (MISC<2>).

**Note:** The OSC2 output buffer provides less drive than standard I/O.

| 9Eh           | Bit 7 | Bit 6  | Bit 5  | Bit 4               | Bit 3 | Bit 2   | Bit 1 | Bit 0 |
|---------------|-------|--------|--------|---------------------|-------|---------|-------|-------|
| MISC          | SMHOG | SPGNDB | SPGNDA | I <sup>2</sup> CSEL | SMBUS | INCLKEN | OSC2  | OSC1  |
| Read/Write    | R/W   | R/W    | R/W    | R/W                 | R/W   | R/W     | R/W   | R     |
| POR value 00h | 0     | 0      | 0      | 0                   | 0     | 0       | 0     | Х     |

| Bit | Name                | Function                                                                                                                                                                                                                                                  |
|-----|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| В7  | SMHOG               | SMHOG enable<br>1 = Stretch $I^2$ C CLK signal (hold low) when receive data buffer is full (refer to<br>Section 7.5.4). For pausing $I^2$ C transfers while preventing interruptions of A/D<br>conversions.<br>0 = Disable $I^2$ C CLK stretch.           |
| B6  | SPGNDB              | Serial Port Ground Select<br>1 = PORTD<1:0> ground reference is the RD5/AN5 pin.<br>0 = PORTD<1:0> ground reference is Vss.                                                                                                                               |
| В5  | SPGNDA              | Serial Port Ground Select<br>1 = PORTC<7:6> ground reference is the RA1/AN1 pin.<br>0 = PORTC<7:6> ground reference is Vss.                                                                                                                               |
| B4  | I <sup>2</sup> CSEL | I <sup>2</sup> C Port select Bit.<br>1 = PORTD<1:0> are used as the I <sup>2</sup> C clock and data lines.<br>0 = PORTC<7:6> are used as the I <sup>2</sup> C clock and data lines.                                                                       |
| В3  | SMBus               | SMBus-Compatibility Select<br>1 = SMBus compatibility mode is enabled. PORTC<7:6> and PORTD<1:0> have<br>SMBus-compatible input thresholds.<br>0 = SMBus-compatibility is disabled. PORTC<7:6> and PORTD<1:0> have Schmitt Trig-<br>ger input thresholds. |
| B2  | INCLKEN             | Oscillator Output Select (available in IN mode only).<br>1 = Output IN oscillator signal divided by four on OSC2 pin.<br>0 = Disconnect IN oscillator signal from OSC2 pin.                                                                               |
| B1  | OSC2                | OSC2 output port bit (available in IN mode only).<br>Writes to this location affect the OSC2 pin in IN mode. Reads return the value of the output latch.                                                                                                  |
| В0  | OSC1                | OSC1 input port bit (available in IN mode only).<br>Reads from this location return the status of the OSC1 pin in IN mode. Writes have no<br>effect.                                                                                                      |

## FIGURE 10-2: MISC REGISTER

| POR | TO | PD | Meaning                                                                             |  |  |  |  |
|-----|----|----|-------------------------------------------------------------------------------------|--|--|--|--|
| 0   | 1  | 1  | Power-On Reset                                                                      |  |  |  |  |
| 0   | 0  | Х  | Illegal, TO is set on POR                                                           |  |  |  |  |
| 0   | Х  | 0  | Illegal, PD is set on POR                                                           |  |  |  |  |
| 1   | 0  | 1  | WDT reset during normal operation                                                   |  |  |  |  |
| 1   | 0  | 0  | WDT time-out wakeup from sleep                                                      |  |  |  |  |
| 1   | 1  | 1  | MCLR reset during normal operation                                                  |  |  |  |  |
| 1   | 1  | 0  | MCLR reset during SLEEP or HIBERNATE, or interrupt wake-up from SLEEP or HIBERNATE. |  |  |  |  |

#### 10.4 Low-Voltage Detector

The PIC14000 contains an integrated low-voltage detector. The supply voltage is divided and compared to the bandgap reference output. If the supply voltage (VDD) falls below VTRIP-, then the low-voltage detector will cause  $\overline{LVD}$  (PCON<0>) to be reset. This bit can be read by software to determine if a low voltage condition occurred. This bit must be set by software.

The nominal values of the low-voltage detector trip points are as follows:

- VTRIP- = 2.55V
- VTRIP+ = 2.60V
- Hysteresis (VTRIP+ VTRIP-) = 55 mV

#### 10.5 <u>Power-on Reset (POR), Power-up</u> <u>Timer (PWRT) and Oscillator Start-up</u> <u>Timer (OST)</u>

#### 10.5.1 POWER-ON RESET (POR)

A Power-on Reset pulse is generated on-chip when VDD rise is detected (in the range of 1.5V - 2.1V). To take advantage of the POR, just tie the  $\overline{\text{MCLR}}$  pin directly (or through a resistor) to VDD. This will eliminate external RC components usually needed to create a Power-on Reset. A maximum rise time for VDD is specified. See Electrical Specifications for details.

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

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

#### 10.5.2 POWER-UP TIMER (PWRT)

The Power-up Timer provides a fixed 72 ms (nominal) time-out on power-up only, from  $\overrightarrow{POR}$ . The power-up timer operates from a local internal oscillator. The chip is kept in reset as long as PWRT is active. The PWRT delay allows the VDD to rise to an acceptable level. A configuration bit,  $\overrightarrow{PWRTE}$ , can disable (if set, or unprogrammed) or enable (if cleared, or programmed) the power-up timer.

The power-up timer delay will vary from chip to chip and due to VDD and temperature.

10.5.3 OSCILLATOR START-UP TIMER (OST)

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

10.5.4 IN OSCILLATOR START-UP

There is an 8-cycle delay in IN mode to ensure stability only after a Power-on Reset (POR) or wake-up from SLEEP.

#### 10.7.1 WDT PERIOD

The WDT has a nominal time-out period of 18 ms (with no prescaler). The time-out periods vary with temperature, VDD and process variations (see DC specs). If longer time-out periods are desired, a prescaler with a division ratio of up to 1:128 can be assigned to the WDT under software control by writing to the OPTION registers. Thus, time-out periods up to 2.3 seconds can be realized. The CLRWDT and SLEEP instructions clear the WDT and the prescaler, if assigned to the WDT, and prevent it from timing out and generating a device RESET.

The  $\overline{\text{TO}}$  bit in the status register will be cleared upon a watchdog timer time-out. The WDT time-out period (no prescaler) is measured and stored in calibration space at location 0FD2h.

#### 10.7.2 WDT PROGRAMMING CONSIDERATIONS

It should also be taken into account that under worst-case conditions (minimum VDD, maximum temperature, maximum WDT prescaler) it may take several seconds before a WDT time-out occurs. Refer to Section 6.3 for prescaler switching considerations.

#### 10.8 <u>Power Management Options</u>

The PIC14000 has several power management options to prolong battery lifetime. The SLEEP instruction halts the CPU and can turn off the on-chip oscillators. The CPU can be in SLEEP mode, yet the A/D converter can continue to run. Several bits are included in the SLPCON register (8Fh) to control power to analog modules.

| Function                                  | Summary                                                                      |
|-------------------------------------------|------------------------------------------------------------------------------|
| CPU Clock                                 | OFF during SLEEP/HIBERNATE mode, ON otherwise                                |
| Main Oscillator                           | ON if NOT in SLEEP mode. In SLEEP mode, controlled by OSCOFF bit, SLPCON<3>. |
| Watchdog Timer                            | Controlled by WDTE, 2007h<2> and HIBEN, SLPCON<7>                            |
| Temperature Sensor                        | Controlled by TEMPOFF, SLPCON<1>                                             |
| Low-voltage Detector                      | Controlled by REFOFF, SLPCON<5>                                              |
| Comparator and<br>Programmable References | Controlled by CMOFF, SLPCON<2>                                               |
| A/D Comparator                            | Controlled by ADOFF, SLPCON<0>                                               |
| Programmable Current Source               | Controlled by ADOFF, SLPCON<0> and ADCON1<7:4>                               |
| Slope Reference Voltage Divider           | Controlled by ADOFF, SLPCON<0>                                               |
| Level Shift Networks                      | Controlled by LSOFF, SLPCON<4>                                               |
| Bandgap Reference                         | Controlled by REFOFF, SLPCON<5>                                              |
| Voltage Regulator Control                 | Always ON. Does not consume power if unconnected.                            |
| Power On Reset                            | Always ON, except in SLEEP/HIBERNATE mode                                    |

#### TABLE 10-6: SUMMARY OF POWER MANAGEMENT OPTIONS

**Note:** Refer to analog specs for individual peripheral operating currents.

# PIC14000

| CLRWDT           | Clear Wa                                                                                                                                           | tchdog                                                               | Timer                                    |                                     |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------|-------------------------------------|--|
| Syntax:          | [label] CLRWDT                                                                                                                                     |                                                                      |                                          |                                     |  |
| Operands:        | None                                                                                                                                               |                                                                      |                                          |                                     |  |
| Operation:       | $\begin{array}{l} 00h \rightarrow WDT \\ 0 \rightarrow WDT \ prescaler, \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow \overline{PD} \end{array}$ |                                                                      |                                          |                                     |  |
| Status Affected: | TO, PD                                                                                                                                             |                                                                      |                                          |                                     |  |
| Encoding:        | 00                                                                                                                                                 | 0000                                                                 | 0110                                     | 0100                                |  |
| Description:     | CLRWDT ins<br>dog Timer.<br>of the WD<br>are set.                                                                                                  | struction r<br>It also re<br>T. Status I                             | esets the v<br>sets the pr<br>pits TO an | Watch-<br>re <u>sca</u> ler<br>d PD |  |
| Words:           | 1                                                                                                                                                  |                                                                      |                                          |                                     |  |
| Cycles:          | 1                                                                                                                                                  |                                                                      |                                          |                                     |  |
| Example          | CLRWDT                                                                                                                                             |                                                                      |                                          |                                     |  |
|                  | Before In<br>After Inst                                                                                                                            | struction<br>WDT cour<br>ruction<br>WDT cour<br>WDT pres<br>TO<br>PD | nter =<br>scaler=<br>=<br>=              | ?<br>0x00<br>0<br>1<br>1            |  |

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

| COMF               | Complement f                                                                                                                                            |      |        |      |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|------|
| Syntax:            | [ <i>label</i> ] COMF f,d                                                                                                                               |      |        |      |
| Operands:          | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \left[0,1\right] \end{array}$                                                                              |      |        |      |
| Operation:         | $(\bar{\mathrm{f}})  ightarrow (\mathrm{de})$                                                                                                           | st)  |        |      |
| Status Affected:   | Z                                                                                                                                                       |      |        |      |
| Encoding:          | 00                                                                                                                                                      | 1001 | dfff   | ffff |
| Description:       | The contents of register 'f' are comple-<br>mented. If 'd' is 0 the result is stored in<br>W. If 'd' is 1 the result is stored back in<br>register 'f'. |      |        |      |
| Words:             | 1                                                                                                                                                       |      |        |      |
| Cycles:            | 1                                                                                                                                                       |      |        |      |
| Example            | COMF                                                                                                                                                    | REC  | G1,0   |      |
| Before Instruction |                                                                                                                                                         |      | 1      |      |
|                    | After loot                                                                                                                                              | REG1 | = 0x13 | 3    |
|                    | After Inst                                                                                                                                              | REG1 | = 0x13 | 3    |
|                    |                                                                                                                                                         | W    | = 0xE  | C    |

| DECFSZ           | Decrement f, Skip if 0                                                                                                                                                                                                                                                                                                         |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:          | [label] DECFSZ f,d                                                                                                                                                                                                                                                                                                             |  |  |  |
| Operands:        | 0 ≤ f ≤ 127<br>d ∈ [0,1]                                                                                                                                                                                                                                                                                                       |  |  |  |
| Operation:       | (f) - 1 $\rightarrow$ (dest); skip if result = 0                                                                                                                                                                                                                                                                               |  |  |  |
| Status Affected: | None                                                                                                                                                                                                                                                                                                                           |  |  |  |
| Encoding:        | 00 1011 dfff ffff                                                                                                                                                                                                                                                                                                              |  |  |  |
| Description:     | The contents of register 'f' are decre-<br>mented. If 'd' is 0 the result is placed in<br>the W register. If 'd' is 1 the result is<br>placed back in register 'f'.<br>If the result is 0, the next instruction,<br>which is already fetched, is discarded. A<br>NOP is executed instead making it a two<br>cycle instruction. |  |  |  |
| Words:           | 1                                                                                                                                                                                                                                                                                                                              |  |  |  |
| Cycles:          | 1(2)                                                                                                                                                                                                                                                                                                                           |  |  |  |
| Example          | HERE DECFSZ CNT, 1<br>GOTO LOOP<br>CONTINUE •                                                                                                                                                                                                                                                                                  |  |  |  |
|                  | •                                                                                                                                                                                                                                                                                                                              |  |  |  |
|                  | $\begin{array}{rcl} Before \ Instruction \\ PC &= & address \ {\tt HERE} \\ After \ Instruction \\ CNT &= & CNT - 1 \\ if \ CNT &= & 0, \\ PC &= & address \ {\tt CONTINUE} \\ if \ {\tt CNT} \neq & 0, \\ PC &= & address \ {\tt HERE} + 1 \\ \end{array}$                                                                    |  |  |  |

| NOP              | No Operation |              |      |      |  |  |
|------------------|--------------|--------------|------|------|--|--|
| Syntax:          | [ label ]    | NOP          |      |      |  |  |
| Operands:        | None         |              |      |      |  |  |
| Operation:       | No opera     | No operation |      |      |  |  |
| Status Affected: | None         |              |      |      |  |  |
| Encoding:        | 00           | 0000         | 0xx0 | 0000 |  |  |
| Description:     | No operat    | ion.         |      |      |  |  |
| Words:           | 1            |              |      |      |  |  |
| Cycles:          | 1            |              |      |      |  |  |
| Example          | NOP          |              |      |      |  |  |

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

| OPTION                                       | Load Option Register                                                                                                                                                                                                                                    |  |  |  |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:                                      | [label] OPTION                                                                                                                                                                                                                                          |  |  |  |
| Operands:                                    | None                                                                                                                                                                                                                                                    |  |  |  |
| Operation:                                   | $(W) \rightarrow OPTION$                                                                                                                                                                                                                                |  |  |  |
| Status Affected:                             | None                                                                                                                                                                                                                                                    |  |  |  |
| Encoding:                                    | 00 0000 0110 0010                                                                                                                                                                                                                                       |  |  |  |
| Description:<br>Words:<br>Cycles:<br>Example | The contents of the W register are<br>loaded in the OPTION register. This<br>instruction is supported for code com-<br>patibility with PIC16C5X products.<br>Since OPTION is a readable/writable<br>register, the user can directly address<br>it.<br>1 |  |  |  |
|                                              | To maintain upward compatibility<br>with future PIC16CXX products, do<br>not use this instruction.                                                                                                                                                      |  |  |  |
|                                              |                                                                                                                                                                                                                                                         |  |  |  |

| RETLW            | Return with Literal in W                                                                                                                                                            |                                |                                                              |      |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--------------------------------------------------------------|------|--|
| Syntax:          | [ label ]                                                                                                                                                                           | RETLW                          | k                                                            |      |  |
| Operands:        | $0 \le k \le 25$                                                                                                                                                                    | 55                             |                                                              |      |  |
| Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow PC$                                                                                                                                        |                                |                                                              |      |  |
| Status Affected: | None                                                                                                                                                                                |                                |                                                              |      |  |
| Encoding:        | 11                                                                                                                                                                                  | 01xx                           | kkkk                                                         | kkkk |  |
| Description:     | The W register is loaded with the eight<br>bit literal 'k'. The program counter is<br>loaded from the top of the stack (the<br>return address). This is a two cycle<br>instruction. |                                |                                                              |      |  |
| Words:           | 1                                                                                                                                                                                   |                                |                                                              |      |  |
| Cycles:          | 2                                                                                                                                                                                   |                                |                                                              |      |  |
| Example          | CALL TABLE                                                                                                                                                                          | ;W c<br>;off<br>;W r           | ;W contains table<br>;offset value<br>;W now has table value |      |  |
| TABLE            | ADDWF PC<br>RETLW kl<br>RETLW k2<br>•<br>•<br>RETLW kn                                                                                                                              | ;W =<br>;Beg<br>;<br>;<br>; Er | = offset<br>gin table<br>nd of table                         | 3    |  |
|                  | Before In                                                                                                                                                                           | struction                      |                                                              |      |  |
|                  |                                                                                                                                                                                     | W =                            | 0x07                                                         |      |  |
|                  | After Inst                                                                                                                                                                          | ruction<br>W =                 | value of k                                                   | 8    |  |



FIGURE 14-1: BANDGAP REFERENCE OUTPUT VOLTAGE vs. TEMPERATURE (TYPICAL DEVICES SHOWN)







© 1996 Microchip Technology Inc.

Preliminary

# APPENDIX A: PIC16/17 MICROCONTROLLERS

A.1 PIC14000 Devices



## A.9 Pin Compatibility

Devices that have the same package type and VDD, VSS and MCLR pin locations are said to be pin compatible. This allows these different devices to operate in the same socket. Compatible devices may only requires minor software modification to allow proper operation in the application socket (ex., PIC16C56 and PIC16C61 devices). Not all devices in the same package size are pin compatible; for example, the PIC16C62 is compatible with the PIC16C63, but not the PIC16C55.

Pin compatibility does not mean that the devices offer the same features. As an example, the PIC16C54 is pin compatible with the PIC16C71, but does not have an A/D converter, weak pull-ups on PORTB, or interrupts.

| Pin Compatible Devices                                                                                                                                                                                                                                      | Package          |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| PIC12C508, PIC12C509                                                                                                                                                                                                                                        | 8-pin            |
| PIC16C54, PIC16C54A,<br>PIC16CR54A,<br>PIC16C56,<br>PIC16C58A, PIC16CR58A,<br>PIC16C61,<br>PIC16C554, PIC16C556, PIC16C558<br>PIC16C620, PIC16C621, PIC16C622,<br>PIC16C710, PIC16C71, PIC16C711,<br>PIC16C83, PIC16CR83,<br>PIC16C84, PIC16C84A, PIC16CR84 | 18-pin<br>20-pin |
| PIC16C55,<br>PIC16C57, PIC16CR57B                                                                                                                                                                                                                           | 28-pin           |
| PIC16C62, PIC16CR62, PIC16C62A, PIC16C63,<br>PIC16C72, PIC16C73, PIC16C73A                                                                                                                                                                                  | 28-pin           |
| PIC16C64, PIC16CR64, PIC16C64A,<br>PIC16C65, PIC16C65A,<br>PIC16C74, PIC16C74A                                                                                                                                                                              | 40-pin           |
| PIC17C42, PIC17C43, PIC17C44                                                                                                                                                                                                                                | 40-pin           |

#### TABLE A-1: PIN COMPATIBLE DEVICES

#### Note the following details of the code protection feature on PICmicro<sup>®</sup> MCUs.

- The PICmicro family meets the specifications contained in the Microchip Data Sheet.
- Microchip believes that its family of PICmicro microcontrollers is one of the most secure products of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the PICmicro microcontroller in a manner outside the operating specifications contained in the data sheet. The person doing so may be engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not
  mean that we are guaranteeing the product as "unbreakable".
- Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our product.

If you have any further questions about this matter, please contact the local sales office nearest to you.

Information contained in this publication regarding device applications and the like is intended through suggestion only and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. No representation or warranty is given and no liability is assumed by Microchip Technology Incorporated with respect to the accuracy or use of such information, or infringement of patents or other intellectual property rights arising from such use or otherwise. Use of Microchip's products as critical components in life support systems is not authorized except with express written approval by Microchip. No licenses are conveyed, implicitly or otherwise, under any intellectual property rights.

#### Trademarks

The Microchip name and logo, the Microchip logo, FilterLab, KEELOQ, microID, MPLAB, PIC, PICmicro, PICMASTER, PICSTART, PRO MATE, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

dsPIC, ECONOMONITOR, FanSense, FlexROM, fuzzyLAB, In-Circuit Serial Programming, ICSP, ICEPIC, microPort, Migratable Memory, MPASM, MPLIB, MPLINK, MPSIM, MXDEV, PICC, PICDEM, PICDEM.net, rfPIC, Select Mode and Total Endurance are trademarks of Microchip Technology Incorporated in the U.S.A.

Serialized Quick Turn Programming (SQTP) is a service mark of Microchip Technology Incorporated in the U.S.A.

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

© 2002, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.





Microchip received QS-9000 quality system certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona in July 1999. The Company's quality system processes and procedures are QS-9000 compliant for its PICmicro® 8-bit MCUs, KEELoq® code hopping devices, Serial EEPROMs and microperipheral products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001 certified.