



#### Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                   |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | PIC                                                                      |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 4MHz                                                                     |
| Connectivity               | -                                                                        |
| Peripherals                | POR, WDT                                                                 |
| Number of I/O              | 3                                                                        |
| Program Memory Size        | 384B (256 x 12)                                                          |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 16 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                |
| Data Converters            | -                                                                        |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                       |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 8-VFDFN Exposed Pad                                                      |
| Supplier Device Package    | 8-DFN (2x3)                                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic10f200-e-mc |
|                            |                                                                          |

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

### **Pin Diagrams**



#### FIGURE 2: 8-PIN PDIP



### FIGURE 3: 8-PIN DFN



#### **Table of Contents**

| 1.0   | General Description                               | 4  |
|-------|---------------------------------------------------|----|
| 2.0   | PIC10F200/202/204/206 Device Varieties            | 5  |
| 3.0   | Architectural Overview                            | 6  |
| 4.0   | Memory Organization                               | 11 |
| 5.0   | I/O Port                                          | 20 |
| 6.0   | Timer0 Module and TMR0 Register (PIC10F200/202)   | 23 |
| 7.0   | Timer() Module and TMR0 Register (PIC10F204/206). | 27 |
| 8.0   | Comparator Module                                 | 31 |
| 9.0   | Special Features of the CPU                       | 35 |
| 10.0  | Instruction Set Summary                           | 45 |
| 11.0  | Development Support Electrical Characteristics    | 53 |
| 12.0  | Electrical Characteristics                        | 57 |
| 13.0  | DC and AC Characteristics Graphs and Tables       | 67 |
| 14.0  | Packaging Information                             | 75 |
| The N | Iicrochip Web Site                                | 85 |
| Custo | mer Change Notification Service                   | 85 |
| Custo | mer Support<br>ict Identification System          | 85 |
| Produ | ct Identification System                          | 86 |

## 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**. 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., DS30000000A is version A of document DS30000000).

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



#### 3.1 Clocking Scheme/Instruction Cycle

FIGURE 3-3:

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

**CLOCK/INSTRUCTION CYCLE** 

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



#### 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.10 Indirect Addressing

- Register file 09 contains the value 10h
- Register file 0A contains the value 0Ah
- · Load the value 09 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 = 0A)
- 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

|         | MOVLW | 0x10  | ;initialize pointer |
|---------|-------|-------|---------------------|
|         | MOVWF | FSR   | ;to RAM             |
| NEXT    | CLRF  | INDF  | ;clear INDF         |
|         |       |       | ;register           |
|         | INCF  | FSR,F | ;inc pointer        |
|         | BTFSC | FSR,4 | ;all done?          |
|         | GOTO  | NEXT  | ;NO, clear next     |
| CONTINU | E     |       |                     |
|         |       | :     | ;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.

Note: PIC10F200/202/204/206 – Do not use banking. FSR <7:5> are unimplemented and read as '1's.

#### FIGURE 4-6: DIRECT/INDIRECT ADDRESSING (PIC10F200/202/204/206)



#### **TABLE 5-2:** SUMMARY OF PORT REGISTERS

| Address | Name     | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3                | Bit 3 Bit 2 Bit 1 Bit 0 |     | Bit 0 | Value on<br>Power-On<br>Reset | Value on<br>All Other Resets |
|---------|----------|-------|-------|-------|-------|----------------------|-------------------------|-----|-------|-------------------------------|------------------------------|
| N/A     | TRISGPIO | _     | _     | _     | —     | I/O Control Register |                         |     |       | 1111                          | 1111                         |
| N/A     | OPTION   | GPWU  | GPPU  | TOCS  | TOSE  | PSA                  | PS2                     | PS1 | PS0   | 1111 1111                     | 1111 1111                    |
| 03h     | STATUS   | GPWUF | CWUF  | _     | то    | PD                   | Z                       | DC  | С     | 00-1 1xxx                     | qq-q quuu <b>(1), (2)</b>    |
| 06h     | GPIO     | —     | —     | —     | —     | GP3                  | GP2                     | GP1 | GP0   | xxxx                          | uuuu                         |

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

г

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

2: If Reset was due to wake-up on comparator change, then bit 6 = 1. All other Resets will cause bit 6 = 0.

#### 5.4 I/O Programming Considerations

#### 5.4.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 rewrite 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 2 of GPIO will cause all eight bits of GPIO to be read into the CPU, bit 2 to be set and the GPIO value to be written to the output latches. If another bit of 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           |

| ;<br>;  |       |   | GPIO latch | GPIO pins            |
|---------|-------|---|------------|----------------------|
| ;       |       |   |            |                      |
| BCF     | GPIO, | 1 | ; pp01     | pp11                 |
| BCF     | GPIO, | 0 | ; pp10     | pp11                 |
| MOVLW   | 007h; |   |            |                      |
| TRIS    | GPIO  |   | ; pp10     | pp11                 |
| ;       |       |   |            |                      |
| Note 1: | -     |   |            | ed the pin values to |

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

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

#### 6.1.2 TIMER0 INCREMENT DELAY

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





3: The arrows indicate the points in time where sampling occurs.

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

| EXAMP  | PLE 6-1:             | CHANGING PRESCALER (TIMER0 $\rightarrow$ WDT) |
|--------|----------------------|-----------------------------------------------|
| CLRWDT |                      | ;Clear WDT                                    |
| CLRF   | TMR0                 | ;Clear TMR0 & Prescaler                       |
| MOVLW  | `00xx1111 <i>'</i> 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                             |

#### FIGURE 8-3: ANALOG INPUT MODE



| Address | Name     | Bit 7  | Bit 6  | Bit 5 | Bit 4   | Bit 3     | Bit 2      | Bit 1 | Bit 0 | Value on<br>POR | Value on<br>All Other<br>Resets |
|---------|----------|--------|--------|-------|---------|-----------|------------|-------|-------|-----------------|---------------------------------|
| 03h     | STATUS   | GPWUF  | CWUF   | _     | TO      | PD        | Z          | DC    | С     | 00-1 1xxx       | qq0q quuu                       |
| 07h     | CMCON0   | CMPOUT | COUTEN | POL   | CMPT0CS | CMPON     | CNREF      | CPREF | CWU   | 1111 1111       | uuuu uuuu                       |
| N/A     | TRISGPIO | —      | _      | _     | —       | I/O Contr | ol Registe | er    |       | 1111            | 1111                            |

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

### 9.2 Oscillator Configurations

#### 9.2.1 OSCILLATOR TYPES

The PIC10F200/202/204/206 devices are offered with Internal Oscillator mode only.

• INTOSC: Internal 4 MHz Oscillator

#### 9.2.2 INTERNAL 4 MHz OSCILLATOR

The internal oscillator provides a 4 MHz (nominal) system clock (see **Section 12.0 "Electrical Characteristics"** for information on variation over voltage and temperature).

In addition, a calibration instruction is programmed into the last address of memory, which contains the calibration value for the internal oscillator. This location is always uncode protected, regardless of the codeprotect settings. This value is programmed as a MOVLW xx instruction where xx is the calibration value and is placed at the Reset vector. This will load the W register with the calibration value upon Reset and the PC will then roll over to the users program at address 0x000. The user then has the option of writing the value to the OSCCAL Register (05h) or ignoring it.

OSCCAL, when written to with the calibration value, will "trim" the internal oscillator to remove process variation from the oscillator frequency.

| Note: | Erasing the device will also erase the pre- |  |  |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|--|--|
|       | programmed internal calibration value for   |  |  |  |  |  |  |  |
|       | the internal oscillator. The calibration    |  |  |  |  |  |  |  |
|       | value must be read prior to erasing the     |  |  |  |  |  |  |  |
|       | part so it can be reprogrammed correctly    |  |  |  |  |  |  |  |
|       | later.                                      |  |  |  |  |  |  |  |

#### 9.3 Reset

The device differentiates between various kinds of Reset:

- Power-on Reset (POR)
- MCLR Reset during normal operation
- MCLR Reset during Sleep
- · WDT time-out Reset during normal operation
- WDT time-out Reset during Sleep
- · Wake-up from Sleep on pin change
- · Wake-up from Sleep on comparator change

Some registers are not reset in any way, they are unknown on POR and unchanged in any other Reset. Most other registers are reset to "Reset state" on Power-on Reset (POR), MCLR, WDT or Wake-up on pin change Reset during normal operation. They are not affected by a WDT Reset during Sleep or MCLR Reset during Sleep, since these Resets are viewed as resumption of normal operation. The exceptions to this are TO, PD, GPWUF and CWUF bits. They are set or cleared differently in different Reset situations. These bits are used in software to determine the nature of Reset. See Table 9-1 for a full description of Reset states of all registers.

| Register              | Address | Power-on Reset           | MCLR Reset, WDT Time-out,<br>Wake-up On Pin Change, Wake on<br>Comparator Change |
|-----------------------|---------|--------------------------|----------------------------------------------------------------------------------|
| W                     | _       | qqqq qqqu <sup>(1)</sup> | qqqq qqqu(1)                                                                     |
| INDF                  | 00h     | XXXX XXXX                | uuuu uuuu                                                                        |
| TMR0                  | 01h     | XXXX XXXX                | uuuu uuuu                                                                        |
| PCL                   | 02h     | 1111 1111                | 1111 1111                                                                        |
| STATUS                | 03h     | 00-1 1xxx                | 9009 quuu <b>(2)</b>                                                             |
| STATUS <sup>(3)</sup> | 03h     | 00-1 1xxx                | qq0q quuu <b>(2)</b>                                                             |
| FSR                   | 04h     | 111x xxxx                | 111u uuuu                                                                        |
| OSCCAL                | 05h     | 1111 1110                | uuuu uuuu                                                                        |
| GPIO                  | 06h     | xxxx                     | uuuu                                                                             |
| CMCON <sup>(3)</sup>  | 07h     | 1111 1111                | uuuu uuuu                                                                        |
| OPTION                | _       | 1111 1111                | 1111 1111                                                                        |
| TRISGPIO              | —       | 1111                     | 1111                                                                             |

### TABLE 9-1: RESET CONDITIONS FOR REGISTERS – PIC10F200/202/204/206

**Legend:** u = unchanged, x = unknown, - = unimplemented bit, read as '0', q = value depends on condition.

Note 1: Bits <7:2> of W register contain oscillator calibration values due to MOVLW XX instruction at top of memory.

**2:** See Table 9-2 for Reset value for specific conditions.

3: PIC10F204/206 only.

| Mnemonic,<br>Operands |                                | Description                                        | Cycles           | 12-Bit Opcode Status | Status | Notes |          |         |
|-----------------------|--------------------------------|----------------------------------------------------|------------------|----------------------|--------|-------|----------|---------|
|                       |                                | Description                                        | Cycles           | MSb                  |        | LSb   | Affected | Notes   |
| ADDWF                 | f, d                           | Add W and f                                        | 1                | 0001                 | 11df   | ffff  | C, DC, Z | 1, 2, 4 |
| ANDWF                 | f, d                           | AND W with f                                       | 1                | 0001                 | 01df   | ffff  | Z        | 2, 4    |
| CLRF                  | f                              | Clear f                                            | 1                | 0000                 | 011f   | ffff  | Z        | 4       |
| CLRW                  | —                              | Clear W                                            | 1                | 0000                 | 0100   | 0000  | Z        |         |
| COMF                  | f, d                           | Complement f                                       | 1                | 0010                 | 01df   | ffff  | Z        |         |
| DECF                  | f, d                           | Decrement f                                        | 1                | 0000                 | 11df   | ffff  | Z        | 2, 4    |
| DECFSZ                | f, d                           | Decrement f, Skip if 0                             | 1 <sup>(2)</sup> | 0010                 | 11df   | ffff  | None     | 2, 4    |
| INCF                  | f, d                           | Increment f                                        | 1                | 0010                 | 10df   | ffff  | Z        | 2, 4    |
| INCFSZ                | f, d                           | Increment f, Skip if 0                             | 1 <sup>(2)</sup> | 0011                 | 11df   | ffff  | None     | 2, 4    |
| IORWF                 | f, d                           | Inclusive OR W with f                              | 1                | 0001                 | 00df   | ffff  | Z        | 2, 4    |
| MOVF                  | f, d                           | Move f                                             | 1                | 0010                 | 00df   | ffff  | Z        | 2, 4    |
| MOVWF                 | f                              | Move W to f                                        | 1                | 0000                 | 001f   | ffff  | None     | 1, 4    |
| NOP                   | _                              | No Operation                                       | 1                | 0000                 | 0000   | 0000  | None     |         |
| RLF                   | f, d                           | Rotate left f through Carry                        | 1                | 0011                 | 01df   | ffff  | С        | 2, 4    |
| RRF                   | f, d                           | Rotate right f through Carry                       | 1                | 0011                 | 00df   | ffff  | С        | 2, 4    |
| SUBWF                 | f, d                           | Subtract W from f                                  | 1                | 0000                 | 10df   | ffff  | C, DC, Z | 1, 2, 4 |
| SWAPF                 | f, d                           | Swap f                                             | 1                | 0011                 | 10df   | ffff  | None     | 2, 4    |
| XORWF                 | f, d                           | Exclusive OR W with f                              | 1                | 0001                 | 10df   | ffff  | Z        | 2, 4    |
|                       |                                | BIT-ORIENTED FILE REGISTE                          |                  | ATIONS               |        |       |          |         |
| BCF                   | f, b                           | Bit Clear f                                        | 1                | 0100                 | bbbf   | ffff  | None     | 2, 4    |
| BSF                   | f, b                           | Bit Set f                                          | 1                | 0101                 | bbbf   | ffff  | None     | 2, 4    |
| BTFSC                 | f, b                           | Bit Test f, Skip if Clear                          | 1 <sup>(2)</sup> | 0110                 | bbbf   | ffff  | None     |         |
| BTFSS                 | f, b                           | Bit Test f, Skip if Set                            | 1 <sup>(2)</sup> | 0111                 | bbbf   | ffff  | None     |         |
|                       | LITERAL AND CONTROL OPERATIONS |                                                    |                  |                      |        |       |          |         |
| ANDLW                 | k                              | AND literal with W                                 | 1                | 1110                 | kkkk   | kkkk  | Z        |         |
| CALL                  | k                              | Call Subroutine                                    | 2                | 1001                 | kkkk   | kkkk  | None     | 1       |
| CLRWDT                |                                | Clear Watchdog Timer                               | 1                | 0000                 | 0000   | 0100  | TO, PD   |         |
| GOTO                  | k                              | Unconditional branch                               | 2                | 101k                 | kkkk   | kkkk  | None     |         |
| IORLW                 | k                              | Inclusive OR literal with W                        | 1                | 1101                 | kkkk   | kkkk  | Z        |         |
| MOVLW                 | k                              | Move literal to W                                  | 1                | 1100                 | kkkk   | kkkk  | None     |         |
| OPTION                | _                              | Load OPTION register                               | 1                | 0000                 | 0000   | 0010  | None     |         |
| RETLW                 | k                              | Return, place Literal in W                         | 2                | 1000                 | kkkk   | kkkk  | None     |         |
| SLEEP                 | _                              | Go into Standby mode                               | 1                | 0000                 | 0000   | 0011  | TO, PD   |         |
| TRIS                  | f                              | Load TRIS register                                 | 1                | 0000                 | 0000   | 0fff  | None     | 3       |
| XORLW                 | k                              | Exclusive OR literal to W                          | 1                |                      | kkkk   |       | Z        | -       |
| Note 1                |                                | Lit of the program counter will be forced to a fai |                  | 1                    |        |       |          |         |

#### TABLE 10-2: INSTRUCTION SET SUMMARY

**Note 1:** The 9th bit of the program counter will be forced to a '0' by any instruction that writes to the PC except for GOTO. See Section 4.7 "Program Counter".

2: When an I/O register is modified as a function of itself (e.g. MOVF PORTB, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.

**3:** The instruction TRIS f, where f = 6, causes the contents of the W register to be written to the tri-state latches of PORTB. A '1' forces the pin to a high-impedance state and disables the output buffers.

**4:** If this instruction is executed on the TMR0 register (and where applicable, d = 1), the prescaler will be cleared (if assigned to TMR0).

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 '0',<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 2-cycle instruc-

 $0 \leq f \leq 31$ 

 $d \in [0,1]$ 

register 'f'.

tion.

None

DECFSZ

Operands:

Operation:

Description:

Status Affected:

Syntax:

| Syntax:                          | [label] INCF 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:                     | 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'.                                                |
| INCFSZ                           | Increment f, Skip if 0                                                                                                                                                                                                    |
| Syntax:                          | [ label ] INCFSZ f,d                                                                                                                                                                                                      |
| Operands:                        | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in [0,1] \end{array}$                                                                                                                                                            |
| Operation:                       | (f) + 1 $\rightarrow$ (dest), skip if result = 0                                                                                                                                                                          |
|                                  |                                                                                                                                                                                                                           |
| Status Affected:                 | None                                                                                                                                                                                                                      |
| Status Affected:<br>Description: | None<br>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'.<br>If the result is '0', then the next |

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

| GOTO             | Unconditional Branch                                                                                                                                                                     |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:          | [ <i>label</i> ] GOTO k                                                                                                                                                                  |  |  |
| Operands:        | $0 \leq k \leq 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 2-cycle<br>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 OR'ed with the 8-bit literal 'k'. The result is placed in the W register. |

| IORWF            | Inclusive OR W with f                                                                                                                                                       |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:          | [label] IORWF f,d                                                                                                                                                           |  |  |
| Operands:        | $\begin{array}{l} 0\leq f\leq 31\\ d\in \left[0,1\right] \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 \leq f \leq 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 \leq k \leq 255$                                                                            |
| Operation:       | $k \rightarrow (W)$                                                                            |
| Status Affected: | None                                                                                           |
| Description:     | The 8-bit literal 'k' is loaded into the W register. The "don't cares" will assembled as '0's. |

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

#### TABLE 12-1: COMPARATOR SPECIFICATIONS

#### Standard Operating Conditions (unless otherwise stated)

|  |  | Operating Temperature -40°C $\leq$ TA $\leq$ +125°C |
|--|--|-----------------------------------------------------|
|--|--|-----------------------------------------------------|

| Operating Temperature -40°C ≤ TA ≤ +125°C |         |                                           |         |      |       |          |       |                                                                         |
|-------------------------------------------|---------|-------------------------------------------|---------|------|-------|----------|-------|-------------------------------------------------------------------------|
| Param.<br>No.                             | Sym.    | Characteristics                           |         | Min. | Тур.† | Max.     | Units | Comments                                                                |
| D300                                      | Vos     | Input Offset Voltage                      |         | —    | ± 5.0 | ± 10     | mV    | (Vdd - 1.5)/2                                                           |
| D301                                      | Vсм     | Input Common Mode Voltage                 |         | 0    | —     | VDD-1.5* | V     |                                                                         |
| D302                                      | CMRR    | Common Mode Rejection Ratio               |         | 55*  | _     |          | dB    |                                                                         |
| D303*                                     | Trt     | Response Time                             | Falling | —    | 150   | 600      | ns    | (Note 1)                                                                |
|                                           |         |                                           | Rising  | —    | 200   | 1000     | ns    |                                                                         |
| D304*                                     | Тмc2coV | Comparator Mode Change to<br>Output Valid |         | _    | —     | 10*      | μS    |                                                                         |
| D305                                      | Vivrf   | Internal Reference Voltage                |         | 0.55 | 0.6   | 0.65     | V     | $2.0V \le VDD \le 5.5V$<br>-40°C $\le$ TA $\le \pm 125°C$<br>(extended) |

\* These parameters are characterized but not tested.

Data in 'Typ.' column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance † only and are not tested.

Note 1: Response time is measured with one comparator input at (VDD - 1.5)/2 - 100 mV to (VDD - 1.5)/2 + 20 mV.

#### TABLE 12-2: PULL-UP RESISTOR RANGES

| VDD (Volts) | Temperature (°C) | Min. | Тур. | Max. | Units |
|-------------|------------------|------|------|------|-------|
| GP0/GP1     |                  |      |      |      |       |
| 2.0         | -40              | 73K  | 105K | 186K | Ω     |
|             | 25               | 73K  | 113K | 187K | Ω     |
|             | 85               | 82K  | 123K | 190K | Ω     |
|             | 125              | 86K  | 132k | 190K | Ω     |
| 5.5         | -40              | 15K  | 21K  | 33K  | Ω     |
|             | 25               | 15K  | 22K  | 34K  | Ω     |
|             | 85               | 19K  | 26k  | 35K  | Ω     |
|             | 125              | 23K  | 29K  | 35K  | Ω     |
| GP3         |                  |      |      |      | •     |
| 2.0         | -40              | 63K  | 81K  | 96K  | Ω     |
|             | 25               | 77K  | 93K  | 116K | Ω     |
|             | 85               | 82K  | 96k  | 116K | Ω     |
|             | 125              | 86K  | 100K | 119K | Ω     |
| 5.5         | -40              | 16K  | 20k  | 22K  | Ω     |
|             | 25               | 16K  | 21K  | 23K  | Ω     |
|             | 85               | 24K  | 25k  | 28K  | Ω     |
|             | 125              | 26K  | 27K  | 29K  | Ω     |

### 12.4 Timing Parameter Symbology and Load Conditions – PIC10F200/202/204/206

The timing parameter symbols have been created following one of the following formats:

1. TppS2ppS

2. TppS

| 2. TppS     |                                          |        |                |  |  |  |
|-------------|------------------------------------------|--------|----------------|--|--|--|
| т           |                                          |        |                |  |  |  |
| F Frequency |                                          | T Time |                |  |  |  |
| Lower       | case subscripts (pp) and their meanings: |        |                |  |  |  |
| рр          |                                          |        |                |  |  |  |
| 2           | to                                       | mc     | MCLR           |  |  |  |
| ck          | CLKOUT                                   | osc    | Oscillator     |  |  |  |
| су          | Cycle time                               | tO     | ТОСКІ          |  |  |  |
| drt         | Device Reset Timer                       | wdt    | Watchdog Timer |  |  |  |
| io          | I/O port                                 | wdt    | Watchdog Timer |  |  |  |
| Upper       | case letters and their meanings:         |        |                |  |  |  |
| S           |                                          |        |                |  |  |  |
| F           | Fall                                     | Р      | Period         |  |  |  |
| Н           | High                                     | R      | Rise           |  |  |  |
| 1           | Invalid (high-impedance)                 | V      | Valid          |  |  |  |
| L           | Low                                      | Z      | High-impedance |  |  |  |

#### FIGURE 12-2: LOAD CONDITIONS – PIC10F200/202/204/206



| AC CHARACTERISTICS |      | $ \begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise specified)} \\ \mbox{Operating Temperature} & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ (industrial),} \\ & -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ (extended)} \\ \mbox{Operating Voltage VDD range is described in} \\ \mbox{Section 12.1 "DC Characteristics: PIC10F200/202/204/206} \\ \mbox{(Industrial)"} \end{array} $ |                                                     |              |              |              |            |                                                                                                                                                                                     |
|--------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--------------|--------------|--------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Param.<br>No.      | Sym. | Characteristic                                                                                                                                                                                                                                                                                                                                                                                                     | Freq.<br>Tolerance Min. Typ.† Max. Units Conditions |              |              |              | Conditions |                                                                                                                                                                                     |
| F10                | Fosc | Internal Calibrated<br>INTOSC Frequency <sup>(1,2)</sup>                                                                                                                                                                                                                                                                                                                                                           | ± 1%<br>± 2%                                        | 3.96<br>3.92 | 4.00<br>4.00 | 4.04<br>4.08 | MHz<br>MHz | VDD=3.5V @ 25°C<br>2.5V $\leq$ VDD $\leq$ 5.5V<br>0°C $\leq$ TA $\leq$ +85°C (industrial)                                                                                           |
|                    |      |                                                                                                                                                                                                                                                                                                                                                                                                                    | ± 5%                                                | 3.80         | 4.00         | 4.20         | MHz        | $\begin{array}{l} 2.0V \leq VDD \leq 5.5V \\ -40^{\circ}C \leq TA \leq +85^{\circ}C \text{ (industrial)} \\ -40^{\circ}C \leq TA \leq +125^{\circ}C \text{ (extended)} \end{array}$ |

#### TABLE 12-3: CALIBRATED INTERNAL RC FREQUENCIES - PIC10F200/202/204/206

\* These parameters are characterized but not tested.

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

Note 1: To ensure these oscillator frequency tolerances, VDD and VSS must be capacitively decoupled as close to the device as possible. 0.1  $\mu$ F and 0.01  $\mu$ F values in parallel are recommended.

2: Under stable VDD conditions.

#### FIGURE 12-3: RESET, WATCHDOG TIMER AND DEVICE RESET TIMER TIMING – PIC10F200/202/204/206





### FIGURE 13-2: TYPICAL IPD vs. VDD (SLEEP MODE, ALL PERIPHERALS DISABLED)







FIGURE 13-11: VOH vs. IOH OVER TEMPERATURE (VDD = 5.0V)



FIGURE 13-10: VOH vs. IOH OVER TEMPERATURE (VDD = 3.0V)

#### 8-Lead Plastic Dual Flat, No Lead Package (MC) – 2x3x0.9 mm Body [DFN]

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



|                        | Units    |          | MILLIMETERS |      |  |
|------------------------|----------|----------|-------------|------|--|
| Dimensio               | n Limits | MIN      | NOM         | MAX  |  |
| Number of Pins         | Ν        | 8        |             |      |  |
| Pitch                  | е        | 0.50 BSC |             |      |  |
| Overall Height         | Α        | 0.80     | 0.90        | 1.00 |  |
| Standoff               | A1       | 0.00     | 0.02        | 0.05 |  |
| Contact Thickness      | A3       | 0.20 REF |             |      |  |
| Overall Length         | D        | 2.00 BSC |             |      |  |
| Overall Width          | E        | 3.00 BSC |             |      |  |
| Exposed Pad Length     | D2       | 1.30     | -           | 1.55 |  |
| Exposed Pad Width      | E2       | 1.50     | -           | 1.75 |  |
| Contact Width          | b        | 0.20     | 0.25        | 0.30 |  |
| Contact Length         | L        | 0.30     | 0.40        | 0.50 |  |
| Contact-to-Exposed Pad | K        | 0.20     | _           | -    |  |

#### Notes:

- 1. Pin 1 visual index feature may vary, but must be located within the hatched area.
- 2. Package may have one or more exposed tie bars at ends.
- 3. Package is saw singulated.
- 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-123C

## **PRODUCT IDENTIFICATION SYSTEM**

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

| PART NO                  | [X] <sup>(1)</sup> - X /XX<br>T International Content<br>Tape and Reel Temperature Package<br>Option Range                                                       | XXX<br>Pattern | Examples:<br>a) PIC10F202T - E/OT<br>Tape and Reel<br>Extended temperature<br>SOT-23 package (Pb-free)                                                                                                                              |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device:                  | PIC10F200<br>PIC10F202<br>PIC10F204<br>PIC10F206<br>PIC10F200T (Tape & Reel)<br>PIC10F202T (Tape & Reel)<br>PIC10F204T (Tape & Reel)<br>PIC10F206T (Tape & Reel) |                | <ul> <li>b) PIC10F200 - I/P<br/>Industrial temperature,<br/>PDIP package (Pb-free)</li> <li>c) PIC10F204 - I/MC<br/>Industrial temperature<br/>DFN package (Pb-free)</li> </ul>                                                     |
| Tape and Reel<br>Option: | Blank = Standard packaging (tube or tray)<br>T = Tape and Reel <sup>(1)</sup>                                                                                    |                |                                                                                                                                                                                                                                     |
| Temperature<br>Range:    | I = $-40^{\circ}$ C to $+85^{\circ}$ C (Industrial)<br>E = $-40^{\circ}$ C to $+125^{\circ}$ C (Extended)                                                        |                | Note 1: Tape and Reel identifier only appears in the                                                                                                                                                                                |
| Package:                 | P = 300 mil PDIP (Pb-free)<br>OT = SOT-23, 6-LD (Pb-free)<br>MC = DFN, 8-LD 2x3 (Pb-free)                                                                        |                | catalog part number description. This<br>identifier is used for ordering purposes and is<br>not printed on the device package. Check<br>with your Microchip Sales Office for package<br>availability with the Tape and Reel option. |
| Pattern:                 | QTP, SQTP, Code or Special Requirements (blank otherwise)                                                                                                        |                |                                                                                                                                                                                                                                     |

#### Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.

## QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV = ISO/TS 16949=

#### Trademarks

The Microchip name and logo, the Microchip logo, dsPIC, FlashFlex, flexPWR, JukeBlox, KEELOQ, KEELOQ logo, Kleer, LANCheck, MediaLB, MOST, MOST logo, MPLAB, OptoLyzer, PIC, PICSTART, PIC<sup>32</sup> logo, RightTouch, SpyNIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

The Embedded Control Solutions Company and mTouch are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, ECAN, In-Circuit Serial Programming, ICSP, Inter-Chip Connectivity, KleerNet, KleerNet logo, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, RightTouch logo, REAL ICE, SQI, Serial Quad I/O, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

GestIC is a registered trademarks of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

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

© 2004-2014, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

ISBN: 978-1-63276-597-0

Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEEL0Q® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and mulfacture of development systems is ISO 9001:2000 certified.