# 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

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

Email: info@E-XFL.COM

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



## 8/14-Pin, 8-Bit Flash Microcontrollers

#### **Devices Included In This Data Sheet:**

• PIC12F508 • PIC12F509 • PIC16F505

### High-Performance RISC CPU:

- Only 33 Single-Word Instructions to Learn
- All Single-Cycle Instructions Except for Program Branches, which are Two-Cycle
- 12-Bit Wide Instructions
- 2-Level Deep Hardware Stack
- Direct, Indirect and Relative Addressing modes for Data and Instructions
- 8-Bit Wide Data Path
- 8 Special Function Hardware Registers
- Operating Speed:
  - DC 20 MHz clock input (PIC16F505 only)
  - DC 200 ns instruction cycle (PIC16F505 only)
  - DC 4 MHz clock input
  - DC 1000 ns instruction cycle

#### **Special Microcontroller Features:**

- 4 MHz Precision Internal Oscillator:
- Factory calibrated to ±1%
- In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>)
- In-Circuit Debugging (ICD) Support
- Power-On Reset (POR)
- Device Reset Timer (DRT)
- Watchdog Timer (WDT) with Dedicated On-Chip RC Oscillator for Reliable Operation
- Programmable Code Protection
- Multiplexed MCLR Input Pin
- Internal Weak Pull-Ups on I/O Pins
- Power-Saving Sleep mode
- Wake-Wp from Sleep on Pin Change
- Selectable Oscillator Options:
  - INTRC: 4 MHz precision Internal oscillator
  - EXTRC: External low-cost RC oscillator
  - XT: Standard crystal/resonator
  - HS: High-speed crystal/resonator (PIC16F505 only)
  - LP: Power-saving, low-frequency crystal
  - EC: High-speed external clock input (PIC16F505 only)

#### Low-Power Features/CMOS Technology:

- Operating Current:
  - < 175 μA @ 2V, 4 MHz, typical
- Standby Current:
  - 100 nA @ 2V, typical
- Low-Power, High-Speed Flash Technology:
  - 100,000 Flash endurance
  - > 40 year retention
- Fully Static Design
- Wide Operating Voltage Range: 2.0V to 5.5V
- Wide Temperature Range:
  - Industrial: -40°C to +85°C
  - Extended: -40°C to +125°C

#### Peripheral Features (PIC12F508/509):

- 6 I/O Pins:
  - 5 I/O pins with individual direction control
  - 1 input only pin
  - High current sink/source for direct LED drive
  - Wake-on-change
  - Weak pull-ups
- 8-Bit Real-Time Clock/Counter (TMR0) with 8-Bit Programmable Prescaler

#### Peripheral Features (PIC16F505):

- 12 I/O Pins:
  - 11 I/O pins with individual direction control
  - 1 input only pin
  - High current sink/source for direct LED drive
  - Wake-on-change
  - Weak pull-ups
- 8-Bit Real-Time Clock/Counter (TMR0) with 8-Bit Programmable Prescaler

#### **Table of Contents**

| 1.0   | General Description                                          | . 7 |
|-------|--------------------------------------------------------------|-----|
| 2.0   | General Description<br>PIC12F508/509/16F505 Device Varieties | . 9 |
| 3.0   | Architectural Overview                                       | 11  |
| 4.0   | Memory Organization                                          | 17  |
| 5.0   | I/O Port                                                     | 31  |
| 6.0   | Timer0 Module and TMR0 Register                              |     |
| 7.0   | Special Features Of The CPU                                  | 41  |
| 8.0   | Instruction Set Summary<br>Development Support               | 57  |
| 9.0   | Development Support                                          | 65  |
| 10.0  | Electrical Characteristics                                   | 69  |
| 11.0  | DC and AC Characteristics Graphs and Charts                  | 81  |
| 12.0  | Packaging Information                                        | 91  |
| Index | 1                                                            | 05  |
| Tho N | Aicrochin Web Site                                           | 07  |
| Custo | mer Change Notification Service                              | 07  |
| Custo | mer Support                                                  | 07  |
| Read  | er Response                                                  | 80  |
| Produ | ict Identification System                                    | 09  |

### 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@mail.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)
- The Microchip Corporate Literature Center; U.S. FAX: (480) 792-7277

When contacting a sales office or the literature center, 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/cn to receive the most current information on all of our products.

NOTES:

## 3.1 Clocking Scheme/Instruction Cycle

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

#### 3.2 Instruction Flow/Pipelining

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

A fetch cycle begins with the PC incrementing in Q1.

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



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

#### EXAMPLE 3-1: INSTRUCTION PIPELINE FLOW



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

#### 4.9 Indirect Data Addressing: INDF and FSR Registers

The INDF register is not a physical register. Addressing INDF actually addresses the register whose address is contained in the FSR register (FSR is a *pointer*). This is indirect addressing.

#### 4.9.1 INDIRECT ADDRESSING

- Register file 07 contains the value 10h
- Register file 08 contains the value 0Ah
- Load the value 07 into the FSR register
- A read of the INDF register will return the value of 10h
- Increment the value of the FSR register by one (FSR = 08)
- A read of the INDR register now will return the value of 0Ah.

Reading INDF itself indirectly (FSR = 0) will produce 00h. Writing to the INDF register indirectly results in a no operation (although Status bits may be affected).

A simple program to clear RAM locations 10h-1Fh using indirect addressing is shown in Example 4-1.

#### EXAMPLE 4-1: HOW TO CLEAR RAM USING INDIRECT ADDRESSING

| NEXT    | MOVLW<br>MOVWF<br>CLRF<br>INCF<br>BTFSC<br>GOTO | 0x10<br>FSR<br>INDF<br>FSR,F<br>FSR,4<br>NEXT | ;initialize pointer<br>;to RAM<br>;clear INDF<br>;register<br>;inc pointer<br>;all done?<br>;NO, clear next |
|---------|-------------------------------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| CONTINU | JE                                              |                                               |                                                                                                             |
|         | :                                               |                                               | ;YES, continue                                                                                              |
|         | :                                               |                                               |                                                                                                             |
|         |                                                 |                                               |                                                                                                             |

The FSR is a 5-bit wide register. It is used in conjunction with the INDF register to indirectly address the data memory area.

The FSR<4:0> bits are used to select data memory addresses 00h to 1Fh.

**PIC12F508** – Does not use banking. FSR <7:5> are unimplemented and read as '1's.

**PIC12F509** – Uses FSR<5>. Selects between bank 0 and bank 1. FSR<7:6> are unimplemented, read as '1'.

**PIC16F505** – Uses FSR<6:5>. Selects from bank 0 to bank 3. FSR<7> is unimplemented, read as '1'.

#### FIGURE 4-7: DIRECT/INDIRECT ADDRESSING (PIC12F508/509)



#### TABLE 5-1:SUMMARY OF PORT REGISTERS

| Address | Name                    | Bit 7 | Bit 6 | Bit 5     | Bit 4                | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>Power-On<br>Reset | Value on<br>All Other<br>Resets |
|---------|-------------------------|-------|-------|-----------|----------------------|-------|-------|-------|-------|-------------------------------|---------------------------------|
| N/A     | TRISGPIO <sup>(1)</sup> | -     | _     | I/O Contr | ol Registe           | r     |       |       |       | 11 1111                       | 11 1111                         |
| N/A     | TRISB <sup>(2)</sup>    | —     | —     | I/O Contr | ol Registe           | r     |       |       |       | 11 1111                       | 11 1111                         |
| N/A     | TRISC <sup>(2)</sup>    | _     | —     | I/O Contr | I/O Control Register |       |       |       |       | 11 1111                       | 11 1111                         |
| N/A     | OPTION <sup>(1)</sup>   | GPWU  | GPPU  | TOCS      | TOSE                 | 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                       |
| 03h     | STATUS <sup>(1)</sup>   | GPWUF | —     | PAO       | ТО                   | PD    | Z     | DC    | С     | 0-01 1xxx                     | q00q quuu <sup>(3)</sup>        |
| 03h     | STATUS <sup>(2)</sup>   | RBWUF | _     | PAO       | TO                   | PD    | Z     | DC    | С     | 0-01 1xxx                     | q00q quuu <b>(3)</b>            |
| 06h     | GPIO <sup>(1)</sup>     | —     | —     | GP5       | GP4                  | GP3   | GP2   | GP1   | GP0   | xx xxxx                       | uu uuuu                         |
| 06h     | PORTB <sup>(2)</sup>    | _     | _     | RB5       | RB4                  | RB3   | RB2   | RB1   | RB0   | xx xxxx                       | uu uuuu                         |
| 07h     | PORTC <sup>(2)</sup>    | _     | _     | RC5       | RC4                  | RC3   | RC2   | RC1   | RC0   | xx xxxx                       | uu uuuu                         |

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

Note 1: PIC12F508/509 only.

2: PIC16F505 only.

3: If Reset was due to wake-up on pin change, then bit 7 = 1. All other Resets will cause bit 7 = 0.

#### 5.5 I/O Programming Considerations

#### 5.5.1 BIDIRECTIONAL I/O PORTS

Some instructions operate internally as read followed by write operations. The BCF and BSF instructions, for example, read the entire port into the CPU, execute the bit operation and re-write the result. Caution must be used when these instructions are applied to a port where one or more pins are used as input/outputs. For example, a BSF operation on bit 5 of PORTB/GPIO will cause all eight bits of PORTB/GPIO to be read into the CPU, bit 5 to be set and the PORTB/GPIO value to be written to the output latches. If another bit of PORTB/ GPIO is used as a bidirectional I/O pin (say bit 0) and it is defined as an input at this time, the input signal present on the pin itself would be read into the CPU and rewritten to the data latch of this particular pin, overwriting the previous content. As long as the pin stays in the Input mode, no problem occurs. However, if bit 0 is switched into Output mode later on, the content of the data latch may now be unknown.

Example 5-1 shows the effect of two sequential Read-Modify-Write instructions (e.g., BCF, BSF, etc.) on an I/O port.

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

#### EXAMPLE 5-1: READ-MODIFY-WRITE INSTRUCTIONS ON AN I/O PORT(e.g., PIC16F505)

| ;Initial PORTB Se<br>;PORTB<5:3> Input<br>;PORTB<2:0> Output | s                                |                                                    |
|--------------------------------------------------------------|----------------------------------|----------------------------------------------------|
| ;<br>;                                                       | PORTB latch                      | PORTB pins                                         |
| BCF PORTB, 4<br>MOVLW 007h;                                  | ;01 -ppp<br>;10 -ppp<br>;10 -ppp | 11 pppp                                            |
| <b>be</b> '00                                                | , ,                              | d the pin values to<br>CF caused RB5 to<br>(High). |

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

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

#### Q1 | Q2 | Q3 | Q4 | PC + 1 PC + 3 This example shows a write to PORTB followed by a read from PORTB. PC Instruction Fetched MOVWF PORTB MOVF PORTB, W NOP NOP Data setup time = (0.25 TCY - TPD)where: TCY = instruction cycle RB<5.0> TPD = propagation delay Port pin written here Port pin sampled here Therefore, at higher clock frequencies, a write followed by a read may be problematic. Instruction Executed MOVWE PORTE MOVE PORTE W NOP (Write to PORTB) (Read PORTB)

#### FIGURE 5-2: SUCCESSIVE I/O OPERATION (PIC16F505 Shown)

#### 6.1 Using Timer0 with an External Clock

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

#### EXTERNAL CLOCK 6.1.1 **SYNCHRONIZATION**

When no prescaler is used, the external clock input is the same as the prescaler output. The synchronization of TOCKI with the internal phase clocks is accomplished by sampling the prescaler output on the Q2 and Q4 cycles of the internal phase clocks (Figure 6-4). Therefore, it is necessary for T0CKI to be high for at least 2 Tosc (and a small RC delay of 2 Tt0H) and low for at least 2 Tosc (and a small RC delay of 2 Tt0H). Refer to the electrical specification of the desired device.

When a prescaler is used, the external clock input is divided by the asynchronous ripple counter-type prescaler, so that the prescaler output is symmetrical. For the external clock to meet the sampling requirement, the ripple counter must be taken into account. Therefore, it is necessary for TOCKI to have a period of at least 4 Tosc (and a small RC delay of 4 Tt0H) divided by the prescaler value. The only requirement on TOCKI high and low time is that they do not violate the minimum pulse width requirement of Tt0H. Refer to parameters 40, 41 and 42 in the electrical specification of the desired device.

#### TIMER0 INCREMENT DELAY 6.1.2

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



#### 6.2 Prescaler

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

| Note: | The prescaler may be used by either the |  |  |  |  |  |  |
|-------|-----------------------------------------|--|--|--|--|--|--|
|       | Timer0 module or the WDT, but not both. |  |  |  |  |  |  |
|       | Thus, a prescaler assignment for the    |  |  |  |  |  |  |
|       | Timer0 module means that there is no    |  |  |  |  |  |  |
|       | prescaler for the WDT and vice versa.   |  |  |  |  |  |  |

The PSA and PS<2:0> bits (OPTION<3:0>) determine prescaler assignment and prescale ratio.

When assigned to the Timer0 module, all instructions writing to the TMR0 register (e.g., CLRF 1, MOVWF 1, BSF 1, x, etc.) will clear the prescaler. When assigned to WDT, a CLRWDT instruction will clear the prescaler along with the WDT. The prescaler is neither readable nor writable. On a Reset, the prescaler contains all '0's.

#### 6.2.1 SWITCHING PRESCALER ASSIGNMENT

The prescaler assignment is fully under software control (i.e., it can be changed "on-the-fly" during program execution). To avoid an unintended device Reset, the following instruction sequence (Example 6-1) must be executed when changing the prescaler assignment from Timer0 to the WDT.

## EXAMPLE 6-1: CHANGING PRESCALER (TIMER0 $\rightarrow$ WDT)

|        | •           | ,                        |
|--------|-------------|--------------------------|
| CLRWDT |             | ;Clear WDT               |
| CLRF   | TMR0        | ;Clear TMR0 & Prescaler  |
| MOVLW  | `00xx1111'b | ;These 3 lines (5, 6, 7) |
| OPTION |             | ;are required only if    |
|        |             | ;desired                 |
| CLRWDT |             | ;PS<2:0> are 000 or 001  |
| MOVLW  | `00xx1xxx'b | ;Set Postscaler to       |
| OPTION |             | ;desired WDT rate        |
|        |             |                          |

To change the prescaler from the WDT to the Timer0 module, use the sequence shown in Example 6-2. This sequence must be used even if the WDT is disabled. A CLRWDT instruction should be executed before switching the prescaler.

| EXAMPLE 6-2: | CHANGING PRESCALER         |
|--------------|----------------------------|
|              | (WDT $\rightarrow$ TIMER0) |

| CLRWDT           | ;Clear WDT and                  |
|------------------|---------------------------------|
| MOVLW 'xxxx0xxx' | ;prescaler<br>;Select TMR0, new |
| HOVEN AAAAAAAA   | ;prescale value and             |
|                  | ;clock source                   |
| OPTION           |                                 |

#### 7.2 Oscillator Configurations

#### 7.2.1 OSCILLATOR TYPES

The PIC12F508/509/16F505 devices can be operated in up to six different oscillator modes. The user can program up to three Configuration bits (FOSC<1:0> [PIC12F508/509], FOSC<2:0> [PIC16F505]). To select one of these modes:

- LP: Low-Power Crystal
- XT: Crystal/Resonator
- HS: High-Speed Crystal/Resonator (PIC16F505 only)
- INTRC: Internal 4 MHz Oscillator
- EXTRC: External Resistor/Capacitor
- EC: External High-Speed Clock Input (PIC16F505 only)

## 7.2.2 CRYSTAL OSCILLATOR/CERAMIC RESONATORS

In HS (PIC16F505), XT or LP modes, a crystal or ceramic resonator is connected to the (GP5/RB5)/ OSC1/(CLKIN) and (GP4/RB4)/OSC2/(CLKOUT) pins to establish oscillation (Figure 7-1). The PIC12F508/ 509/16F505 oscillator designs require the use of a parallel cut crystal. Use of a series cut crystal may give a frequency out of the crystal manufacturers specifications. When in HS (PIC16F505), XT or LP modes, the device can have an external clock source drive the (GP5/RB5)/OSC1/CLKIN pin (Figure 7-2). When the part is used in this fashion, the output drive levels on the OSC2 pin are very weak. This pin should be left open and unloaded. Also, when using this mode, the external clock should observe the frequency limits for the clock mode chosen (HS, XT or LP).

- Note 1: This device has been designed to perform to the parameters of its data sheet. It has been tested to an electrical specification designed to determine its conformance with these parameters. Due to process differences in the manufacture of this device, this device may have different performance characteristics than its earlier version. These differences may cause this device to perform differently in your application than the earlier version of this device.
  - 2: The user should verify that the device oscillator starts and performs as expected. Adjusting the loading capacitor values and/or the Oscillator mode may be required.



FIGURE 7-2:

EXTERNAL CLOCK INPUT OPERATION (HS, XT OR LP OSC CONFIGURATION)





| Osc<br>Type       | Resonator<br>Freq.                                      | Cap. Range<br>C1 | Cap. Range<br>C2 |  |  |  |
|-------------------|---------------------------------------------------------|------------------|------------------|--|--|--|
| XT                | 4.0 MHz                                                 | 30 pF            | 30 pF            |  |  |  |
| HS <sup>(2)</sup> | 16 MHz                                                  | 10-47 pF         | 10-47 pF         |  |  |  |
| Note 1:           | n guidance<br>has its own<br>ould consult<br>for<br>nal |                  |                  |  |  |  |
| 2:                | 2: PIC16F505 only.                                      |                  |                  |  |  |  |





TABLE 7-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  | T0CS  | 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:** PIC12F508/509 only.

2: PIC16F505 only.

Increment f

INCF

| DECF             | Decrement f                                                                                                                                       |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] DECF f,d                                                                                                                                  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                  |
| Operation:       | $(f) - 1 \rightarrow (dest)$                                                                                                                      |
| Status Affected: | Z                                                                                                                                                 |
| Description:     | Decrement register 'f'. If 'd' is 'o',<br>the result is stored in the W<br>register. If 'd' is '1', the result is<br>stored back in register 'f'. |

Decrement f, Skip if 0

[label] DECFSZ f,d

(f)  $-1 \rightarrow d$ ; skip if result = 0

The contents of register 'f' are decremented. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed back in

If the result is '0', the next instruction, which is already fetched, is discarded and a NOP is executed instead making it a two-cycle

 $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$ 

None

register 'f'.

instruction.

DECFSZ

Syntax:

Operands:

Operation:

Description:

Status Affected:

| [label] INCF f,d                                                                                                                                                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                           |
| (f) + 1 $\rightarrow$ (dest)                                                                                                                                               |
| Z                                                                                                                                                                          |
| The contents of register 'f' are<br>incremented. If 'd' is '0', the result<br>is placed in the W register. If 'd' is<br>'1', the result is placed back in<br>register 'f'. |
| Increment f, Skip if 0                                                                                                                                                     |
|                                                                                                                                                                            |
| [label] INCFSZ f,d                                                                                                                                                         |
| [ <i>label</i> ] INCFSZ f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$                                                                                                           |
| $0 \le f \le 31$                                                                                                                                                           |
| $0 \le f \le 31$<br>$d \in [0,1]$                                                                                                                                          |
| $0 \le f \le 31$<br>d \epsilon [0,1]<br>(f) + 1 \rightarrow (dest), skip if result = 0                                                                                     |
|                                                                                                                                                                            |

| GOTO             | Unconditional Branch                                                                                                                                                                        |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] GOTO k                                                                                                                                                                     |  |  |  |  |  |
| Operands:        | $0 \le k \le 511$                                                                                                                                                                           |  |  |  |  |  |
| Operation:       | $k \rightarrow PC<8:0>;$<br>STATUS<6:5> $\rightarrow PC<10:9>$                                                                                                                              |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                        |  |  |  |  |  |
| Description:     | GOTO is an unconditional branch.<br>The 9-bit immediate value is<br>loaded into PC bits <8:0>. The<br>upper bits of PC are loaded from<br>STATUS<6:5>. GOTO is a two-<br>cycle instruction. |  |  |  |  |  |

| IORLW            | Inclusive OR literal with W                                                                                               |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] IORLW k                                                                                                  |  |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                                                         |  |  |  |  |  |
| Operation:       | (W) .OR. (k) $\rightarrow$ (W)                                                                                            |  |  |  |  |  |
| Status Affected: | Z                                                                                                                         |  |  |  |  |  |
| Description:     | The contents of the W register are<br>OR'ed with the eight-bit literal 'k'.<br>The result is placed in the<br>W register. |  |  |  |  |  |

| IORWF            | Inclusive OR W with f                                                                                                                                                       |  |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [label] IORWF f,d                                                                                                                                                           |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                            |  |  |  |  |  |
| Operation:       | (W).OR. (f) $\rightarrow$ (dest)                                                                                                                                            |  |  |  |  |  |
| Status Affected: | Z                                                                                                                                                                           |  |  |  |  |  |
| Description:     | Inclusive OR the W register with<br>register 'f'. If 'd' is '0', the result is<br>placed in the W register. If 'd' is '1',<br>the result is placed back in register<br>'f'. |  |  |  |  |  |

| MOVWF            | Move W to f                                    |  |  |  |  |  |  |
|------------------|------------------------------------------------|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] MOVWF f                       |  |  |  |  |  |  |
| Operands:        | $0 \le f \le 31$                               |  |  |  |  |  |  |
| Operation:       | $(W) \rightarrow (f)$                          |  |  |  |  |  |  |
| Status Affected: | None                                           |  |  |  |  |  |  |
| Description:     | Move data from the W register to register 'f'. |  |  |  |  |  |  |

| MOVF             | Move f                                                                                                                                                                                                                                                           |  |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [label] MOVF f,d                                                                                                                                                                                                                                                 |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                                                                                                                 |  |  |  |  |  |
| Operation:       | $(f) \rightarrow (dest)$                                                                                                                                                                                                                                         |  |  |  |  |  |
| Status Affected: | Z                                                                                                                                                                                                                                                                |  |  |  |  |  |
| Description:     | The contents of register 'f' are<br>moved to destination 'd'. If 'd' is '0',<br>destination is the W register. If 'd'<br>is '1', the destination is file<br>register 'f'. 'd' = 1 is useful as a<br>test of a file register, since status<br>flag Z is affected. |  |  |  |  |  |

| NOP              | No Operation  |
|------------------|---------------|
| Syntax:          | [label] NOP   |
| Operands:        | None          |
| Operation:       | No operation  |
| Status Affected: | None          |
| Description:     | No operation. |

| MOVLW            | Move Literal to W                                                                                        |  |  |  |  |  |
|------------------|----------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] MOVLW k                                                                                 |  |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                                        |  |  |  |  |  |
| Operation:       | $k \rightarrow (W)$                                                                                      |  |  |  |  |  |
| Status Affected: | None                                                                                                     |  |  |  |  |  |
| Description:     | The eight-bit literal 'k' is loaded<br>into the W register. The "don't<br>cares" will assembled as '0's. |  |  |  |  |  |

| OPTION           | Load OPTION Register                                              |  |  |  |  |  |
|------------------|-------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [label] OPTION                                                    |  |  |  |  |  |
| Operands:        | None                                                              |  |  |  |  |  |
| Operation:       | $(W) \to OPTION$                                                  |  |  |  |  |  |
| Status Affected: | None                                                              |  |  |  |  |  |
| Description:     | The content of the W register is loaded into the OPTION register. |  |  |  |  |  |

### 9.0 DEVELOPMENT SUPPORT

The PIC<sup>®</sup> microcontrollers are supported with a full range of hardware and software development tools:

- Integrated Development Environment
  - MPLAB® IDE Software
- Assemblers/Compilers/Linkers
  - MPASM<sup>™</sup> Assembler
  - MPLAB C18 and MPLAB C30 C Compilers
  - MPLINK<sup>™</sup> Object Linker/
  - MPLIB™ Object Librarian
  - MPLAB ASM30 Assembler/Linker/Library
- Simulators
  - MPLAB SIM Software Simulator
- Emulators
  - MPLAB ICE 2000 In-Circuit Emulator
  - MPLAB REAL ICE™ In-Circuit Emulator
- In-Circuit Debugger
  - MPLAB ICD 2
- Device Programmers
  - PICSTART<sup>®</sup> Plus Development Programmer
  - MPLAB PM3 Device Programmer
  - PICkit<sup>™</sup> 2 Development Programmer
- Low-Cost Demonstration and Development Boards and Evaluation Kits

#### 9.1 MPLAB Integrated Development Environment Software

The MPLAB IDE software brings an ease of software development previously unseen in the 8/16-bit microcontroller market. The MPLAB IDE is a Windows<sup>®</sup> operating system-based application that contains:

- · A single graphical interface to all debugging tools
  - Simulator
  - Programmer (sold separately)
  - Emulator (sold separately)
  - In-Circuit Debugger (sold separately)
- · A full-featured editor with color-coded context
- A multiple project manager
- Customizable data windows with direct edit of contents
- High-level source code debugging
- Visual device initializer for easy register initialization
- · Mouse over variable inspection
- Drag and drop variables from source to watch windows
- · Extensive on-line help
- Integration of select third party tools, such as HI-TECH Software C Compilers and IAR C Compilers

The MPLAB IDE allows you to:

- Edit your source files (either assembly or C)
- One touch assemble (or compile) and download to PIC MCU emulator and simulator tools (automatically updates all project information)
- Debug using:
  - Source files (assembly or C)
  - Mixed assembly and C
  - Machine code

MPLAB IDE supports multiple debugging tools in a single development paradigm, from the cost-effective simulators, through low-cost in-circuit debuggers, to full-featured emulators. This eliminates the learning curve when upgrading to tools with increased flexibility and power.

## **10.0 ELECTRICAL CHARACTERISTICS**

### Absolute Maximum Ratings<sup>(†)</sup>

| Ambient temperature under bias                                                                                      | 40°C to +125°C                   |
|---------------------------------------------------------------------------------------------------------------------|----------------------------------|
| Storage temperature                                                                                                 | 65°C to +150°C                   |
| Voltage on VDD with respect to Vss                                                                                  | 0 to +6.5V                       |
| Voltage on MCLR with respect to Vss                                                                                 | 0 to +13.5V                      |
| Voltage on all other pins with respect to Vss                                                                       | -0.3V to (VDD + 0.3V)            |
| Total power dissipation <sup>(1)</sup>                                                                              | 800 mW                           |
| Max. current out of Vss pin                                                                                         | 200 mA                           |
| Max. current into Vod pin                                                                                           | 150 mA                           |
| Input clamp current, Iк (Vi < 0 or Vi > VDD)                                                                        | ±20 mA                           |
| Output clamp current, IOK (VO < 0 or VO > VDD)                                                                      | ±20 mA                           |
| Max. output current sunk by any I/O pin                                                                             | 25 mA                            |
| Max. output current sourced by any I/O pin                                                                          | 25 mA                            |
| Max. output current sourced by I/O port                                                                             | 75 mA                            |
| Max. output current sunk by I/O port                                                                                | 75 mA                            |
| <b>Note 1:</b> Power dissipation is calculated as follows: PDIS = VDD x {IDD $-\Sigma$ IOH} + $\Sigma$ {(VDD $-V$ O | H) X IOH} + $\Sigma$ (VOL X IOL) |

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

#### 10.2 DC Characteristics: PIC12F508/509/16F505 (Extended)

| DC Cha       | racteris | stics                                         | Standard Operating Conditions (unless otherwise spec<br>Operating Temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ (extended) |                    |             | • • • •  |                                                                            |
|--------------|----------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--------------------|-------------|----------|----------------------------------------------------------------------------|
| Param<br>No. | Sym.     | Characteristic                                | Min.                                                                                                                             | Typ <sup>(1)</sup> | Max.        | Units    | Conditions                                                                 |
| D001         | Vdd      | Supply Voltage                                | 2.0                                                                                                                              |                    | 5.5         | V        | See Figure 10-1                                                            |
| D002         | Vdr      | RAM Data Retention Voltage <sup>(2)</sup>     | _                                                                                                                                | 1.5*               |             | V        | Device in Sleep mode                                                       |
| D003         | VPOR     | VDD Start Voltage to ensure<br>Power-on Reset | —                                                                                                                                | Vss                | —           | V        | See Section 7.4 "Power-on<br>Reset (POR)" for details                      |
| D004         | SVDD     | VDD Rise Rate to ensure<br>Power-on Reset     | 0.05*                                                                                                                            | —                  | —           | V/ms     | See Section 7.4 "Power-on<br>Reset (POR)" for details                      |
| D010         | IDD      | Supply Current <sup>(3,4)</sup>               | _                                                                                                                                | 175<br>0.625       | 275<br>1.1  | μA<br>mA | Fosc = 4 MHz, Vdd = 2.0V<br>Fosc = 4 MHz, Vdd = 5.0V                       |
|              |          |                                               | _                                                                                                                                | 500<br>1.5         | 650<br>2.2  | μA<br>mA | Fosc = 10 MHz, VDD = 3.0V<br>Fosc = 20 MHz, VDD = 5.0V<br>(PIC16F515 only) |
|              |          |                                               | _                                                                                                                                | 11<br>38           | 26<br>110   | μΑ<br>μΑ | Fosc = 32 kHz, VDD = 2.0V<br>Fosc = 32 kHz, VDD = 5.0V                     |
| D020         | IPD      | Power-down Current <sup>(5)</sup>             | _                                                                                                                                | 0.1<br>0.35        | 9.0<br>15.0 | μΑ<br>μΑ | VDD = 2.0V<br>VDD = 5.0V                                                   |
| D022         | Iwdt     | WDT Current <sup>(5)</sup>                    |                                                                                                                                  | 1.0<br>7.0         | 18<br>22    | μΑ<br>μΑ | VDD = 2.0V<br>VDD = 5.0V                                                   |

These parameters are characterized but not tested.

**Note 1:** Data in the Typical ("Typ") column is based on characterization results at 25°C. This data is for design guidance only and is not tested.

- 2: This is the limit to which VDD can be lowered in Sleep mode without losing RAM data.
- **3:** The supply current is mainly a function of the operating voltage and frequency. Other factors such as bus loading, oscillator type, bus rate, internal code execution pattern and temperature also have an impact on the current consumption.
- 4: The test conditions for all IDD measurements in active operation mode are: OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to Vss, T0CKI = VDD, MCLR = VDD; WDT enabled/disabled as specified.
- 5: For standby current measurements, the conditions are the same as IDD, except that the device is in Sleep mode. If a module current is listed, the current is for that specific module enabled and the device in Sleep.









#### 8-Lead Plastic Micro Small Outline Package (MS) [MSOP]

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



|                          | MILLIMETERS      |             |      |      |  |
|--------------------------|------------------|-------------|------|------|--|
| Dimension                | Dimension Limits |             | NOM  | MAX  |  |
| Number of Pins           | Ν                | 8           |      |      |  |
| Pitch                    | е                | 0.65 BSC    |      |      |  |
| Overall Height           | Α                | – – 1.10    |      |      |  |
| Molded Package Thickness | A2               | 0.75        | 0.85 | 0.95 |  |
| Standoff                 | A1               | 0.00        | -    | 0.15 |  |
| Overall Width            | Е                | 4.90 BSC    |      |      |  |
| Molded Package Width     | E1               | 3.00 BSC    |      |      |  |
| Overall Length           | D                | 3.00 BSC    |      |      |  |
| Foot Length              | L                | 0.40        | 0.60 | 0.80 |  |
| Footprint                | L1               | 0.95 REF    |      |      |  |
| Foot Angle               | ¢                | 0° – 8°     |      |      |  |
| Lead Thickness           | с                | 0.08 – 0.23 |      |      |  |
| Lead Width               | b                | 0.22        | _    | 0.40 |  |

#### Notes:

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

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

3. Dimensioning and tolerancing per ASME Y14.5M.

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

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-111B

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

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



|                          | Units            | MILLIMETERS |     |      |
|--------------------------|------------------|-------------|-----|------|
|                          | Dimension Limits | MIN         | NOM | MAX  |
| Number of Pins           | N                | 14          |     |      |
| 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                | 8.65 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-065B

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

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



|                          | Units            | MILLIMETERS |      |      |
|--------------------------|------------------|-------------|------|------|
| Dimensio                 | Dimension Limits |             | NOM  | MAX  |
| Number of Pins           | Ν                | 14          |      |      |
| Pitch                    | е                | 0.65 BSC    |      |      |
| Overall Height           | Α                | -           | -    | 1.20 |
| Molded Package Thickness | A2               | 0.80        | 1.00 | 1.05 |
| Standoff                 | A1               | 0.05        | -    | 0.15 |
| Overall Width            | Е                | 6.40 BSC    |      |      |
| Molded Package Width     | E1               | 4.30        | 4.40 | 4.50 |
| Molded Package Length    | D                | 4.90        | 5.00 | 5.10 |
| Foot Length              | L                | 0.45        | 0.60 | 0.75 |
| Footprint                | L1               | 1.00 REF    |      |      |
| Foot Angle               | ¢                | 0°          | _    | 8°   |
| Lead Thickness           | С                | 0.09        | -    | 0.20 |
| Lead Width               | b                | 0.19        | -    | 0.30 |

#### Notes:

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

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

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

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-087B