# Microchip Technology - PIC16F506-E/P Datasheet

# E·XFL



#### Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                  |
|----------------------------|-------------------------------------------------------------------------|
| Core Processor             | PIC                                                                     |
| Core Size                  | 8-Bit                                                                   |
| Speed                      | 20MHz                                                                   |
| Connectivity               | -                                                                       |
| Peripherals                | POR, WDT                                                                |
| Number of I/O              | 11                                                                      |
| Program Memory Size        | 1.5KB (1K x 12)                                                         |
| Program Memory Type        | FLASH                                                                   |
| EEPROM Size                | -                                                                       |
| RAM Size                   | 67 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                               |
| Data Converters            | A/D 4x8b                                                                |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                      |
| Mounting Type              | Through Hole                                                            |
| Package / Case             | 14-DIP (0.300", 7.62mm)                                                 |
| Supplier Device Package    | 14-PDIP                                                                 |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f506-e-p |
|                            |                                                                         |

Email: info@E-XFL.COM

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

## Table of Contents

| 1.0   | General Description                                  | 5     |
|-------|------------------------------------------------------|-------|
| 2.0   | PIC12F510/16F506 Device Varieties                    | 7     |
| 3.0   | Architectural Overview                               | 9     |
| 4.0   | Memory Organization                                  | 15    |
| 5.0   | I/O Port                                             | 27    |
| 6.0   | TMR0 Module and TMR0 Register                        | 39    |
| 7.0   | Comparator(s)                                        | 43    |
| 8.0   | Comparator Voltage Reference Module (PIC16F506 only) | 49    |
| 9.0   | Analog-to-Digital (A/D) Converter                    | 51    |
| 10.0  | Special Features Of The CPU                          | 55    |
|       | Instruction Set Summary                              |       |
| 12.0  | Development Support                                  | 79    |
| 13.0  | Electrical Characteristics                           | 83    |
| 14.0  | DC and AC Characteristics Graphs and Charts          | 97    |
| 15.0  | Packaging                                            | . 105 |
| Index |                                                      | . 117 |
| The N | ficrochip Web Site                                   | . 119 |
| Custo | mer Change Notification Service                      | . 119 |
|       | mer Support                                          |       |
| Read  | er Response                                          | . 120 |
| Produ | Ict Identification System                            | . 121 |

# TO OUR VALUED CUSTOMERS

It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced.

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@microchip.com** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. We welcome your feedback.

### **Most Current Data Sheet**

To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at:

http://www.microchip.com

You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000A is version A of document DS30000).

#### Errata

An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies.

To determine if an errata sheet exists for a particular device, please check with one of the following:

- Microchip's Worldwide Web site; http://www.microchip.com
- Your local Microchip sales office (see last page)

When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using.

### **Customer Notification System**

Register on our web site at www.microchip.com to receive the most current information on all of our products.

NOTES:

# 2.0 PIC12F510/16F506 DEVICE VARIETIES

A variety of packaging options are available. Depending on application and production requirements, the proper device option can be selected using the information in this section. When placing orders, please use the PIC12F510/16F506 Product Identification System at the back of this data sheet to specify the correct part number.

### 2.1 Quick Turn Programming (QTP) Devices

Microchip offers a QTP programming service for factory production orders. This service is made available for users who choose not to program medium-to-high quantity units and whose code patterns have stabilized. The devices are identical to the Flash devices, but with all Flash locations and fuse options already programmed by the factory. Certain code and prototype verification procedures do apply before production shipments are available. Please contact your local Microchip Technology sales office for more details.

## 2.2 Serialized Quick Turn Programming<sup>SM</sup> (SQTP<sup>SM</sup>) Devices

Microchip offers a unique programming service, where a few user-defined locations in each device are programmed with different serial numbers. The serial numbers may be random, pseudo-random or sequential.

Serial programming allows each device to have a unique number, which can serve as an entry code, password or ID number.

NOTES:

| TABLE 3-2: PIN DES    |            | - PIC12F51 | 0              |                                                                                                                            |
|-----------------------|------------|------------|----------------|----------------------------------------------------------------------------------------------------------------------------|
| Name                  | I/O/P Type | Input Type | Output<br>Type | Description                                                                                                                |
| GP0/AN0/C1IN+/ICSPDAT | GP0        | TTL        | CMOS           | Bidirectional I/O port. Can be software pro-<br>grammed for internal weak pull-up and wake-up<br>from Sleep on pin change. |
|                       | AN0        | AN         | —              | ADC channel input.                                                                                                         |
|                       | C1IN+      | AN         | —              | Comparator input.                                                                                                          |
|                       | ICSPDAT    | ST         | CMOS           | In-Circuit Serial Programming data pin.                                                                                    |
| GP1/AN1/C1IN-/ICSPCLK | GP1        | TTL        | CMOS           | Bidirectional I/O port. Can be software pro-<br>grammed for internal weak pull-up and wake-up<br>from Sleep on pin change. |
|                       | AN1        | AN         | —              | ADC channel input.                                                                                                         |
|                       | C1IN-      | AN         | —              | Comparator input.                                                                                                          |
|                       | ICSPCLK    | ST         | —              | In-Circuit Serial Programming clock pin.                                                                                   |
| GP2/AN2/T0CKI/C1OUT   | GP2        | TTL        | CMOS           | Bidirectional I/O port.                                                                                                    |
|                       | AN2        | AN         | —              | ADC channel input.                                                                                                         |
|                       | TOCKI      | ST         | —              | Timer0 clock input.                                                                                                        |
|                       | C10UT      | _          | CMOS           | Comparator output.                                                                                                         |
| GP3/MCLR/Vpp          | GP3        | TTL        | —              | Standard TTL input. Can be software pro-<br>grammed for internal weak pull-up and wake-up<br>from Sleep on pin change.     |
|                       | MCLR       | ST         | —              | MCLR input – weak pull-up always enabled in this mode.                                                                     |
|                       | Vpp        | HV         | —              | Programming Voltage input.                                                                                                 |
| GP4/OSC2              | GP4        | TTL        | CMOS           | Bidirectional I/O port.                                                                                                    |
|                       | OSC2       | —          | XTAL           | XTAL oscillator output pin.                                                                                                |
| GP5/OSC1/CLKIN        | GP5        | TTL        | CMOS           | Bidirectional I/O port.                                                                                                    |
|                       | OSC1       | XTAL       | —              | XTAL oscillator input pin.                                                                                                 |
|                       | CLKIN      | ST         |                | EXTRC Schmitt Trigger input.                                                                                               |
| Vdd                   | Vdd        | Р          | _              | Positive supply for logic and I/O pins.                                                                                    |
| Vss                   | Vss        | Р          | _              | Ground reference for logic and I/O pins.                                                                                   |

TABLE 3-2: PIN DESCRIPTIONS – PIC12F510

Legend: I = input, O = output, I/O = input/output, P = power, — = Not Used, TTL = TTL input, ST = Schmitt Trigger input, AN = Analog Voltage, HV = High Voltage



#### FIGURE 5-9: **BLOCK DIAGRAM OF** RC0/RC1 Data Bus D Q Data I/O WR Latch pin<sup>(1)</sup> P<u>ort</u> Q СК W Reg D Q TRIS Latch TRIS 'f' CK Q Reset Comp Pin Enable

RD Port

Vss.

COMP2

Note 1: I/O pins have protection diodes to VDD and

# 6.0 TMR0 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
- External clock from either the T0CKI pin or from the output of the comparator

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

Timer mode is selected by clearing the T0CS bit (OPTION<5>). In Timer mode, the 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.

There are two types of Counter mode. The first Counter mode uses the T0CKI pin to increment Timer0. It is selected by setting the T0CKI bit (OPTION<5>), setting the  $\overline{C1T0CS}$  bit (CM1CON0<4>) and setting the  $\overline{C1OUTEN}$  bit (CM1CON0<6>). 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 "Using Timer0 With An External Clock".

The second Counter mode uses the output of the comparator to increment Timer0. It can be entered in two different ways. The first way is selected by setting the TOCS bit (OPTION<5>), and clearing the C1TOCS bit (CM1CON0<4>) (C1OUTEN [CM1CON0<6>] does not affect this mode of operation). This enables an internal connection between the comparator and the Timer0.

The second way is selected by setting the T0CS bit (OPTION<5>), setting the C1T0CS bit (CM1CON0) and clearing the C10UTEN bit (CM1CON0<6>). This allows the output of the comparator onto the T0CKI pin, while keeping the T0CKI input active. Therefore, any comparator change on the COUT pin is fed back into the T0CKI input. The T0SE bit (OPTION<4>) determines the source edge. Clearing the T0SE bit selects the rising edge. Restrictions on the external clock input as discussed in Section 6.1 "Using Timer0 With An External Clock".

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 "Prescaler"** details the operation of the prescaler.

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







| TABLE 7-1: | REGISTERS ASSOCIATED WITH COMPARATOR MODULE |
|------------|---------------------------------------------|
|            |                                             |

| Add | Name                    | Bit 7 | Bit 6   | Bit 5                | Bit 4                | Bit 3 | Bit 2  | Bit 1   | Bit 0   | Value on<br>POR | Value on<br>All Other<br>Resets |
|-----|-------------------------|-------|---------|----------------------|----------------------|-------|--------|---------|---------|-----------------|---------------------------------|
| 03h | STATUS                  | GPWUF | CWUF    | PA0                  | TO                   | PD    | Z      | DC      | С       | 0001 1xxx       | qq0q quuu                       |
| 07h | CM1CON0 <sup>(1)</sup>  | C1OUT | C10UTEN | C1POL                | C1T0CS               | C10N  | C1NREF | C1PREF  | C1WU    | 1111 1111       | uuuu uuuu                       |
| 08h | CM1CON0 <sup>(2)</sup>  | C1OUT | C10UTEN | C1POL                | C1T0CS               | C10N  | C1NREF | C1PREF  | C1WU    | 1111 1111       | uuuu uuuu                       |
| 0Bh | CM2CON0 <sup>(2)</sup>  | C2OUT | C2OUTEN | C2POL                | C2PREF2              | C2ON  | C2NREF | C2PREF1 | C2WU    | 1111 1111       | uuuu uuuu                       |
| N/A | TRISB <sup>(2)</sup>    | _     | _       | I/O Contro           | I/O Control Register |       |        |         | 11 1111 | 11 1111         |                                 |
| N/A | TRISC <sup>(2)</sup>    | —     | _       | I/O Control Register |                      |       |        | 11 1111 | 11 1111 |                 |                                 |
| N/A | TRISGPIO <sup>(1)</sup> | —     | _       | I/O Contro           | l Register           |       |        |         |         | 11 1111         | 11 1111                         |

Legend: x = Unknown, u = Unchanged, - = Unimplemented, read as '0', q = Depends on condition.

Note 1: PIC12F510 only.

2: PIC16F506 only.

#### FIGURE 8-1: COMPARATOR VOLTAGE REFERENCE BLOCK DIAGRAM



#### TABLE 8-1: REGISTERS ASSOCIATED WITH COMPARATOR VOLTAGE REFERENCE

| Add | Name                   | Bit 7 | Bit 6   | Bit 5 | Bit 4   | Bit 3 | Bit 2  | Bit 1   | Bit 0 | Value on<br>POR | Value on all other Resets |
|-----|------------------------|-------|---------|-------|---------|-------|--------|---------|-------|-----------------|---------------------------|
| 0Ch | VRCON                  | VREN  | VROE    | VRR   | _       | VR3   | VR2    | VR1     | VR0   | 001- 1111       | 001- 1111                 |
| 08h | CM1CON0 <sup>(1)</sup> | C10UT | C10UTEN | C1POL | C1T0CS  | C10N  | C1NREF | C1PREF  | C1WU  | 1111 1111       | uuuu uuuu                 |
| 0Bh | CM2CON0 <sup>(1)</sup> | C2OUT | C2OUTEN | C2POL | C2PREF2 | C2ON  | C2NREF | C2PREF1 | C2WU  | 1111 1111       | uuuu uuuu                 |

 $\label{eq:Legend: Legend: Legend: u = unchanged, - = unimplemented, read as `0`.$ 

Note 1: PIC16F506 only.

# 9.0 ANALOG-TO-DIGITAL (A/D) CONVERTER

The A/D Converter allows conversion of an analog signal into an 8-bit digital signal.

# 9.1 Clock Divisors

The ADC has 4 clock source settings ADCS<1:0>. There are 3 divisor values 16, 8 and 4. The fourth setting is INTOSC with a divisor of 4. These settings will allow a proper conversion when using an external oscillator at speeds from 20 MHz to 350 kHz. Using an external oscillator at a frequency below 350 kHz (TAD > 50  $\mu$ s) requires the ADC oscillator setting to be INTOSC/4 for valid ADC results.

The ADC requires 13 TAD periods to complete a conversion. The divisor values do not affect the number of TAD periods required to perform a conversion. The divisor values determine the length of the TAD period.

When the ADCS<1:0> bits are changed while an ADC conversion is in process, the new ADC clock source will not be selected until the next conversion is started. This clock source selection will be lost when the device enters Sleep.

## 9.1.1 VOLTAGE REFERENCE

There is no external voltage reference for the ADC. The ADC reference voltage will always be VDD.

# 9.1.2 ANALOG MODE SELECTION

The ANS<1:0> bits are used to configure pins for analog input. Upon any Reset, ANS<1:0> defaults to 11. This configures pins ANO, AN1 and AN2 as analog inputs. Pins configured as analog inputs are not available for digital output. Users should not change the ANS bits while a conversion is in process. ANS bits are active regardless of the condition of ADON.

### 9.1.3 ADC CHANNEL SELECTION

The CHS bits are used to select the analog channel to be sampled by the ADC. The CHS<1:0> bits can be changed at any time without adversely effecting a conversion. To acquire an analog signal the CHS<1:0> selection must match one of the pin(s) selected by the ANS<1:0> bits. When the ADC is on (ADON = 1) and a channel is selected that is also being used by the comparator, then both the comparator and the ADC will see the analog voltage on the pin.

Note: It is the users responsibility to ensure that use of the ADC and comparator simultaneously on the same pin, does not adversely affect the signal being monitored or adversely effect device operation. When the CHS<1:0> bits are changed during an ADC conversion, the new channel will not be selected until the current conversion is completed. This allows the current conversion to complete with valid results. All channel selection information will be lost when the device enters Sleep.

| <b>TABLE 9-1</b> : | CHANNEL SELECT (ADCS) |
|--------------------|-----------------------|
|                    | BITS AFTER AN EVENT   |

| Event                 | ADCS<1:0> |
|-----------------------|-----------|
| MCLR                  | 11        |
| Conversion completed  | CS<1:0>   |
| Conversion terminated | CS<1:0>   |
| Power-on              | 11        |
| Wake from Sleep       | 11        |

# 9.1.4 THE GO/DONE BIT

The GO/DONE bit is used to determine the status of a conversion, to start a conversion and to manually halt a conversion in process. Setting the GO/DONE bit starts a conversion. When the conversion is complete, the ADC module clears the GO/DONE bit. A conversion can be terminated by manually clearing the GO/DONE bit while a conversion is in process. Manual termination of a conversion may result in a partially converted result in ADRES.

The GO/DONE bit is cleared when the device enters Sleep, stopping the current conversion. The ADC does not have a dedicated oscillator, it runs off of the instruction clock. Therefore, no conversion can occur in sleep.

The GO/DONE bit cannot be set when ADON is clear.

<sup>© 2007</sup> Microchip Technology Inc.

## 9.1.5 SLEEP

This ADC does not have a dedicated ADC clock, and therefore, no conversion in Sleep is possible. If a conversion is underway and a Sleep command is executed, the GO/DONE and ADON bit will be cleared. This will stop any conversion in process and powerdown the ADC module to conserve power. Due to the nature of the conversion process, the ADRES may contain a partial conversion. At least 1 bit must have been converted prior to Sleep to have partial conversion data in ADRES. The ADCS and CHS bits are reset to their default condition; ANS<1:0> = 11 and CHS<1:0> = 11.

- For accurate conversions, TAD must meet the following:
- + 500 ns < TAD < 50  $\mu s$
- TAD = 1/(FOSC/divisor)

Shaded areas indicate TAD out of range for accurate conversions. If analog input is desired at these frequencies, use INTOSC/4 for the ADC clock source.

| Source | ADCS<br><1:0> | Divisor | 20 <sup>(1)</sup><br>MHz | 16 <sup>(1)</sup><br>MHz | 8 MHz | 4 MHz | 1 MHz | 500<br>kHz | 350<br>kHz | 200<br>kHz | 100<br>kHz | 32 kHz |
|--------|---------------|---------|--------------------------|--------------------------|-------|-------|-------|------------|------------|------------|------------|--------|
| INTOSC | 11            | 4       | _                        | _                        | .5 μs | 1 μs  | _     | _          | _          | _          | —          | _      |
| FOSC   | 10            | 4       | .2 μs                    | .25 μs                   | .5 μs | 1 μs  | 4 μs  | 8 µs       | 11 μs      | 20 µs      | 40 µs      | 125 μs |
| FOSC   | 01            | 8       | .4 μs                    | .5 μs                    | 1 μs  | 2 μs  | 8 µs  | 16 μs      | 23 µs      | 40 µs      | 80 µs      | 250 μs |
| FOSC   | 00            | 16      | .8 μs                    | 1 μs                     | 2 μs  | 4 μs  | 16 µs | 32 µs      | 46 µs      | 80 µs      | 160 μs     | 500 μs |

TABLE 9-2: TAD FOR ADCS SETTINGS WITH VARIOUS OSCILLATORS

**Note 1:** When operating with external oscillator frequencies of 16 MHz or higher, better ADC performance will result from selection of a suitable Fosc divisor value from Table 9-2 than from use of the INTOSC/4 option for the ADC clock.

### TABLE 9-3:EFFECTS OF SLEEP ON ADCON0

|                   | ANS1      | ANS0      | ADCS1 | ADCS0 | CHS1 | CHS0 | GO/DONE | ADON |
|-------------------|-----------|-----------|-------|-------|------|------|---------|------|
| Entering<br>Sleep | Unchanged | Unchanged | 1     | 1     | 1    | 1    | 0       | 0    |
| Wake or<br>Reset  | 1         | 1         | 1     | 1     | 1    | 1    | 0       | 0    |

#### 9.1.6 ANALOG CONVERSION RESULT REGISTER

The ADRES register contains the results of the last conversion. These results are present during the sampling period of the next analog conversion process. After the sampling period is over, ADRES is cleared (= 0). A 'leading one' is then right shifted into the ADRES to serve as an internal conversion complete bit. As each bit weight, starting with the MSB, is converted, the leading one is shifted right and the converted bit is stuffed into ADRES. After a total of 9 right

shifts of the 'leading one' have taken place, the conversion is complete; the 'leading one' has been shifted out and the GO/DONE bit is cleared.

If the GO/DONE bit is cleared in software during a conversion, the conversion stops. The data in ADRES is the partial conversion result. This data is valid for the bit weights that have been converted. The position of the 'leading one' determines the number of bits that have been converted. The bits that were not converted before the GO/DONE was cleared are unrecoverable.

## REGISTER 9-1: ADCON0: A/D CONTROL REGISTER (PIC12F510)

| R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-0   | R/W-0 |
|-------|-------|-------|-------|-------|-------|---------|-------|
| ANS1  | ANS0  | ADCS1 | ADCS0 | CHS1  | CHS0  | GO/DONE | ADON  |
| bit 7 |       |       |       |       |       |         | bit 0 |

| Legend:            |                                                    |                                                                                                                                                                  |                                                                                                          |                                                                                                                       |
|--------------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| R = Read           | able bit                                           | W = Writable bit                                                                                                                                                 | U = Unimplemented bit                                                                                    | , read as '0'                                                                                                         |
| -n = Value         | e at POR                                           | '1' = Bit is set                                                                                                                                                 | '0' = Bit is cleared                                                                                     | x = Bit is unknown                                                                                                    |
| bit 7-6            | 00 = No<br>01 = AN<br>10 = AN                      | <b>0&gt;:</b> ADC Analog Input Pin S<br>pins configured for analog in<br>2 configured as an analog ir<br>2 and AN0 configured as an<br>2, AN1 and AN0 configured | nput<br>iput<br>alog inputs                                                                              |                                                                                                                       |
| bit 5-4            | ADCS<<br>00 = FO<br>01 = FO<br>10 = FO<br>11 = IN  | sc/8<br>sc/4                                                                                                                                                     | s Select bits                                                                                            |                                                                                                                       |
| bit 3-2            | 00 = Ch<br>01 = Ch<br>10 = Ch                      | <b>0&gt;:</b> ADC Channel Select bits<br>annel AN0<br>annel AN1<br>annel AN2<br>V absolute voltage reference                                                     |                                                                                                          |                                                                                                                       |
| bit 1              | 1 = AD0<br>auto<br>0 = AD0                         | omatically cleared by hardwa                                                                                                                                     | Setting this bit starts an Al<br>are when the ADC is done con<br>in progress. Manually clearin           | DC conversion cycle. This bit<br>verting.<br>Ig this bit while a conversion is                                        |
| bit 0              | 1 = AD0                                            | ADC Enable bit<br>C module is operating<br>C module is shut-off and con                                                                                          | sumes no power                                                                                           |                                                                                                                       |
| Note 1:<br>2:      | less of the pir<br>input to the co<br>that the ADC | n function previously defined omparator and the ADC will b                                                                                                       | . The only exception to this is<br>be active at the same time. It is<br>nput does not affect their appli | forced into Analog mode, regard-<br>the comparator, where the analog<br>the users responsibility to ensur-<br>cation. |
| 3:                 |                                                    | s default to 11 after any Res                                                                                                                                    |                                                                                                          |                                                                                                                       |
| <u></u> <i>A</i> . |                                                    | hit is clear the GO/DONE hit                                                                                                                                     | cannot ha sat                                                                                            |                                                                                                                       |

4: If the ADON bit is clear, the GO/DONE bit cannot be set.

# REGISTER 10-2: CONFIG: CONFIGURATION WORD REGISTER (PIC16F506)<sup>(1)</sup>

| —      | _ |  |  | _ | _ | _ | —     |
|--------|---|--|--|---|---|---|-------|
| bit 15 |   |  |  |   |   |   | bit 8 |

| —        | IOSCFS                                           | MCLRE             | CP            | WDTE            | FOSC2             | FOSC1                   | FOSC0         |
|----------|--------------------------------------------------|-------------------|---------------|-----------------|-------------------|-------------------------|---------------|
| bit 7    |                                                  |                   |               |                 |                   |                         | bit 0         |
|          |                                                  |                   |               |                 |                   |                         |               |
| bit 11-7 | Unimplement                                      | ted: Read as 'a   | ,             |                 |                   |                         |               |
| bit 6    | IOSCFS: Internal Oscillator Frequency Select bit |                   |               |                 |                   |                         |               |
|          | 1 = 8 MHz IN                                     | TOSC speed        |               |                 |                   |                         |               |
|          | 0 = 4 MHz IN                                     | TOSC speed        |               |                 |                   |                         |               |
| bit 5    | MCLRE: Mas                                       | ter Clear Enab    | le bit        |                 |                   |                         |               |
|          |                                                  | R pin functions   |               |                 |                   |                         |               |
|          |                                                  | R pin functions   | as RB3, MCL   | R tied interna  | lly to Vdd        |                         |               |
| bit 4    | CP: Code Pro                                     | tection bit       |               |                 |                   |                         |               |
|          | 1 = Code prot                                    |                   |               |                 |                   |                         |               |
|          | 0 = Code prot                                    |                   |               |                 |                   |                         |               |
| bit 3    |                                                  | ndog Timer Ena    | able bit      |                 |                   |                         |               |
|          | 1 = WDT enal                                     |                   |               |                 |                   |                         |               |
|          | 0 = WDT disa                                     |                   |               |                 |                   |                         |               |
| bit 2-0  |                                                  | Oscillator Sele   |               |                 |                   |                         |               |
|          |                                                  | illator and 18 m  |               |                 |                   |                         |               |
|          |                                                  | illator and 18 n  |               |                 |                   |                         |               |
|          |                                                  | illator and 18 n  | -             |                 | KOUT and 1.12     | 5 ms DRT(2)             |               |
|          |                                                  |                   |               |                 | JT and 1.125 ms   |                         |               |
|          |                                                  |                   |               |                 | KOUT and 1.12     |                         |               |
|          |                                                  |                   |               |                 | T and 1.125 ms    |                         |               |
|          | 111 <b>= EXTRC</b>                               | with CLKOUT       | function on F | RB4/OSC2/CLI    | KOUT and 1.12     | 5 ms DRT <sup>(2)</sup> |               |
| Note 1:  | Refer to the "PIC16<br>Configuration Word        | •                 | Programming   | Specification'  | " (DS41258) to a  | determine how           | to access the |
| 2:       | It is the responsibil                            | ity of the applic | ation designe | r to ensure the | e use of the 1.12 | 25 ms (nominal          | ) DRT will    |

2: It is the responsibility of the application designer to ensure the use of the 1.125 ms (nominal) DRT will result in acceptable operation. Refer to Electrical Specifications for VDD rise time and stability requirements for this mode of operation.

## 10.3.1 MCLR ENABLE

This Configuration bit, when unprogrammed (left in the '1' state), enables the external MCLR function. When programmed, the MCLR function is tied to the internal VDD and the pin is assigned to be a I/O. See Figure 10-6.



# 10.4 Power-on Reset (POR)

The PIC12F510/16F506 devices incorporate an onchip Power-on Reset (POR) circuitry, which provides an internal chip Reset for most power-up situations.

The on-chip POR circuit holds the chip in Reset until VDD has reached a high enough level for proper operation. The POR is active regardless of the state of the MCLR enable bit. An internal weak pull-up resistor is implemented using a transistor (refer to Table 13-3 for the pull-up resistor ranges). This will eliminate external RC components usually needed to create an external Power-on Reset. A maximum rise time for VDD is specified. See **Section 13.0 "Electrical Characteristics"** for details.

When the devices start normal operation (exit the Reset condition), device operating parameters (volt-age, frequency, temperature,...) must be met to ensure operation. If these conditions are not met, the devices must be held in Reset until the operating parameters are met.

A simplified block diagram of the on-chip Power-on Reset circuit is shown in Figure 10-7.

The Power-on Reset circuit and the Device Reset Timer (see Section 10.5 "Device Reset Timer (DRT)") circuit are closely related. On power-up, the Reset latch is set and the DRT is reset. The DRT timer begins counting once it detects MCLR, internal or external, to be high. After the time-out period, it will reset the Reset latch and thus end the on-chip Reset signal.

A power-up example where  $\overline{\text{MCLR}}$  is held low is shown in Figure 10-8. VDD is allowed to rise and stabilize before bringing  $\overline{\text{MCLR}}$  high. The chip will actually come out of Reset TDRT msec after  $\overline{\text{MCLR}}$  goes high.

In Figure 10-9, the on-chip Power-on Reset feature is being used (MCLR and VDD are tied together or the pin is programmed to be (GP3/RB3). The VDD is stable before the Start-up timer times out and there is no problem in getting a proper Reset. However, Figure 10-10 depicts a problem situation where VDD rises too slowly. The time between when the DRT senses that MCLR is high and when MCLR and VDD actually reach their full value, is too long. In this situation, when the start-up timer times out, VDD has not reached the VDD (min) value and the chip may not function correctly. For such situations, we recommend that external RC circuits be used to achieve longer POR delay times (Figure 10-9).

| Note: | When the devices start normal operation (exit the Reset condition), device operat- |  |  |  |  |
|-------|------------------------------------------------------------------------------------|--|--|--|--|
|       | ing parameters (voltage, frequency,                                                |  |  |  |  |
|       | temperature, etc.) must be met to ensure                                           |  |  |  |  |
|       | operation. If these conditions are not met,                                        |  |  |  |  |
|       | the device must be held in Reset until the                                         |  |  |  |  |
|       | operating conditions are met.                                                      |  |  |  |  |

For additional information, refer to Application Notes AN522, *"Power-Up Considerations"* (DS00522) and AN607, *"Power-up Trouble Shooting"* (DS00607).





TABLE 10-7: SUMMARY OF REGISTERS ASSOCIATED WITH THE WATCHDOG TIMER

| 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 |
|---------|-----------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------------------------------|---------------------------------|
| N/A     | OPTION <sup>(1)</sup> | GPWU  | GPPU  | TOCS  | T0SE  | PSA   | PS2   | PS1   | PS0   | 1111 1111                     | 1111 1111                       |
| N/A     | OPTION <sup>(2)</sup> | RBWU  | RBPU  | TOCS  | TOSE  | PSA   | PS2   | PS1   | PS0   | 1111 1111                     | 1111 1111                       |

Legend: Shaded boxes = Not used by Watchdog Timer. - = unimplemented, read as '0', u = unchanged.

Note 1: PIC12F510 only.

2: PIC16F506 only.

# 11.0 INSTRUCTION SET SUMMARY

The PIC16 instruction set is highly orthogonal and is comprised of three basic categories.

- Byte-oriented operations
- Bit-oriented operations
- Literal and control operations

Each PIC16 instruction is a 12-bit word divided into an **opcode**, which specifies the instruction type, and one or more **operands** which further specify the operation of the instruction. The formats for each of the categories is presented in Figure 11-1, while the various opcode fields are summarized in Table 11-1.

For **byte-oriented** instructions, 'f' represents a file register designator and 'd' represents a destination designator. The file register designator specifies which file register is to be used by the instruction.

The destination designator specifies where the result of the operation is to be placed. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed in the file register specified in the instruction.

For **bit-oriented** instructions, 'b' represents a bit field designator which selects the number of the bits affected by the operation, while 'f' represents the number of the file in which the bit is located.

For **literal and control** operations, 'k' represents an 8 or 9-bit constant or literal value.

## TABLE 11-1: OPCODE FIELD DESCRIPTIONS

| Field         | Description                                                                                                                                                                         |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| f             | Register file address (0x00 to 0x7F)                                                                                                                                                |
| W             | Working register (accumulator)                                                                                                                                                      |
| b             | Bit address within an 8-bit file register                                                                                                                                           |
| k             | Literal field, constant data or label                                                                                                                                               |
| x             | Don't care location (= $0$ or $1$ )<br>The assembler will generate code with x = $0$ . It is the<br>recommended form of use for compatibility with all<br>Microchip software tools. |
| d             | Destination select;<br>d = 0 (store result in W)<br>d = 1 (store result in file register 'f')<br>Default is d = 1                                                                   |
| label         | Label name                                                                                                                                                                          |
| TOS           | Top-of-Stack                                                                                                                                                                        |
| PC            | Program Counter                                                                                                                                                                     |
| WDT           | Watchdog Timer counter                                                                                                                                                              |
| TO            | Time-out bit                                                                                                                                                                        |
| PD            | Power-down bit                                                                                                                                                                      |
| dest          | Destination, either the W register or the specified register file location                                                                                                          |
| []            | Options                                                                                                                                                                             |
| ( )           | Contents                                                                                                                                                                            |
| $\rightarrow$ | Assigned to                                                                                                                                                                         |
| < >           | Register bit field                                                                                                                                                                  |
| ∈             | In the set of                                                                                                                                                                       |
| italics       | User defined term (font is courier)                                                                                                                                                 |

All instructions are executed within a single instruction cycle, unless a conditional test is true or the program counter is changed as a result of an instruction. In this case, the execution takes two instruction cycles. One instruction cycle consists of four oscillator periods. Thus, for an oscillator frequency of 4 MHz, the normal instruction execution time is 1  $\mu$ s. If a conditional test is true or the program counter is changed as a result of an instruction, the instruction execution time is 2  $\mu$ s.

Figure 11-1 shows the three general formats that the instructions can have. All examples in the figure use the following format to represent a hexadecimal number:

0xhhh

where 'h' signifies a hexadecimal digit.

#### FIGURE 11-1: GENERAL FORMAT FOR INSTRUCTIONS

| Byte-oriented file register operations            |                                                                                       |  |  |  |  |  |  |  |
|---------------------------------------------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 11                                                | 6 5 4 0                                                                               |  |  |  |  |  |  |  |
| OPCODE                                            | d f (FILE #)                                                                          |  |  |  |  |  |  |  |
| d = 1 for desti                                   | d = 0 for destination W<br>d = 1 for destination f<br>f = 5-bit file register address |  |  |  |  |  |  |  |
| Bit-oriented file re                              | gister operations                                                                     |  |  |  |  |  |  |  |
| 11                                                | 87540                                                                                 |  |  |  |  |  |  |  |
| OPCODE                                            | b (BIT #) f (FILE #)                                                                  |  |  |  |  |  |  |  |
|                                                   | Idress<br>egister address<br>I <b>operations</b> (except GOTO)                        |  |  |  |  |  |  |  |
| 11                                                | 8 7 0                                                                                 |  |  |  |  |  |  |  |
| OPCODE                                            | k (literal)                                                                           |  |  |  |  |  |  |  |
| k = 8-bit imm                                     | k = 8-bit immediate value                                                             |  |  |  |  |  |  |  |
| Literal and control operations – GOTO instruction |                                                                                       |  |  |  |  |  |  |  |
| 11                                                | 980                                                                                   |  |  |  |  |  |  |  |
| OPCODE                                            | OPCODE k (literal)                                                                    |  |  |  |  |  |  |  |
| k = 9-bit immediate value                         |                                                                                       |  |  |  |  |  |  |  |

| TRIS             | Load TRIS Register                                                                 |
|------------------|------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] TRIS f                                                            |
| Operands:        | f = 6                                                                              |
| Operation:       | $(W) \to TRIS \text{ register f}$                                                  |
| Status Affected: | None                                                                               |
| Description:     | TRIS register 'f' (f = 6 or 7) is<br>loaded with the contents of the W<br>register |

| XORWF            | Exclusive OR W with f                                                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] XORWF f,d                                                                                                                                                      |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                                |
| Operation:       | (W) .XOR. (f) $\rightarrow$ (dest)                                                                                                                                              |
| Status Affected: | Z                                                                                                                                                                               |
| Description:     | 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'. |

| XORLW            | 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                                                                                                                 |  |  |  |  |  |
| Description:     | The contents of the W register are XOR'ed with the eight-bit literal 'k'. The result is placed in the W register. |  |  |  |  |  |

# 14.0 DC AND CHARACTERISTICS GRAPHS AND CHARTS.

**Note:** The graphs and tables provided following this note are a statistical summary based on a limited number of samples and are provided for informational purposes only. The performance characteristics listed herein are not tested or guaranteed. In some graphs or tables, the data presented may be outside the specified operating range (e.g., outside specified power supply range) and therefore, outside the warranted range.

"Typical" represents the mean of the distribution at 25°C. "Maximum" or "minimum" represents (mean +  $3\sigma$ ) or (mean -  $3\sigma$ ) respectively, where s is a standard deviation, over each temperature range.











© 2007 Microchip Technology Inc.

# 8-Lead Plastic Small Outline (SN) – 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



|                          | Units |             |          | MILLIMETERS |  |  |  |
|--------------------------|-------|-------------|----------|-------------|--|--|--|
| Dime                     | MIN   | NOM         | MAX      |             |  |  |  |
| Number of Pins           | N     | 8           |          |             |  |  |  |
| Pitch                    | е     |             | 1.27 BSC |             |  |  |  |
| Overall Height           | A     | -           | -        | 1.75        |  |  |  |
| Molded Package Thickness | A2    | 1.25        | -        | -           |  |  |  |
| Standoff §               | A1    | 0.10        | -        | 0.25        |  |  |  |
| Overall Width            | E     | 6.00 BSC    |          |             |  |  |  |
| Molded Package Width     | E1    | 3.90 BSC    |          |             |  |  |  |
| Overall Length           | D     | 4.90 BSC    |          |             |  |  |  |
| Chamfer (optional)       | h     | 0.25 – 0.50 |          |             |  |  |  |
| Foot Length              | L     | 0.40 – 1.27 |          |             |  |  |  |
| Footprint                | L1    |             | 1.04 REF |             |  |  |  |
| Foot Angle               | ¢     | 0° – 8°     |          |             |  |  |  |
| Lead Thickness           | С     | 0.17 – 0.25 |          |             |  |  |  |
| Lead Width               | b     | 0.31        | -        | 0.51        |  |  |  |
| Mold Draft Angle Top     | α     | 5°          | -        | 15°         |  |  |  |
| Mold Draft Angle Bottom  | β     | 5°          | -        | 15°         |  |  |  |

Notes:

1. Pin 1 visual index feature may vary, but must be located within 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 0.15 mm per side.

4. 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 C04-057B