



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              | 5                                                                          |
| Program Memory Size        | 768B (512 x 12)                                                            |
| Program Memory Type        | OTP                                                                        |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 25 x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 5.5V                                                                |
| Data Converters            | -                                                                          |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | 0°C ~ 70°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/pic12lc508a-04-p |

Email: info@E-XFL.COM

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

#### Pin Diagram - PIC12C508/509



# Pin Diagram - PIC12C508A/509A, PIC12CE518/519



#### Pin Diagram - PIC12CR509A



#### **Device Differences**

| Device      | Voltage<br>Range | Oscillator | Oscillator<br>Calibration <sup>2</sup><br>(Bits) | Process<br>Technology<br>(Microns) |
|-------------|------------------|------------|--------------------------------------------------|------------------------------------|
| PIC12C508A  | 3.0-5.5          | See Note 1 | 6                                                | 0.7                                |
| PIC12LC508A | 2.5-5.5          | See Note 1 | 6                                                | 0.7                                |
| PIC12C508   | 2.5-5.5          | See Note 1 | 4                                                | 0.9                                |
| PIC12C509A  | 3.0-5.5          | See Note 1 | 6                                                | 0.7                                |
| PIC12LC509A | 2.5-5.5          | See Note 1 | 6                                                | 0.7                                |
| PIC12C509   | 2.5-5.5          | See Note 1 | 4                                                | 0.9                                |
| PIC12CR509A | 2.5-5.5          | See Note 1 | 6                                                | 0.7                                |
| PIC12CE518  | 3.0-5.5          | -          | 6                                                | 0.7                                |
| PIC12LCE518 | 2.5-5.5          | -          | 6                                                | 0.7                                |
| PIC12CE519  | 3.0-5.5          | -          | 6                                                | 0.7                                |
| PIC12LCE519 | 2.5-5.5          | -          | 6                                                | 0.7                                |

**Note 1:** If you change from the PIC12C50X to the PIC12C50XA or to the PIC12CR50XA, please verify oscillator characteristics in your application.

Note 2: See Section 7.2.5 for OSCCAL implementation differences.

# 1.0 GENERAL DESCRIPTION

The PIC12C5XX from Microchip Technology is a family of low-cost, high performance, 8-bit, fully static, EEPROM/EPROM/ROM-based CMOS microcontrollers. It employs a RISC architecture with only 33 single word/single cycle instructions. All instructions are single cycle (1  $\mu$ s) except for program branches which take two cycles. The PIC12C5XX delivers performance an order of magnitude higher than its competitors in the same price category. The 12-bit wide instructions are highly symmetrical resulting in 2:1 code compression over other 8-bit microcontrollers in its class. The easy to use and easy to remember instruction set reduces development time significantly.

The PIC12C5XX products are equipped with special features that reduce system cost and power requirements. The Power-On Reset (POR) and Device Reset Timer (DRT) eliminate the need for external reset circuitry. There are four oscillator configurations to choose from, including INTRC internal oscillator mode and the power-saving LP (Low Power) oscillator mode. Power saving SLEEP mode, Watchdog Timer and code protection features also improve system cost, power and reliability.

The PIC12C5XX are available in the cost-effective One-Time-Programmable (OTP) versions which are suitable for production in any volume. The customer can take full advantage of Microchip's price leadership in OTP microcontrollers while benefiting from the OTP's flexibility.

The PIC12C5XX products are supported by a full-featured macro assembler, a software simulator, an in-circuit emulator, a 'C' compiler, fuzzy logic support tools, a low-cost development programmer, and a full featured programmer. All the tools are supported on IBM<sup>®</sup> PC and compatible machines.

### 1.1 Applications

The PIC12C5XX series fits perfectly in applications ranging from personal care appliances and security systems to low-power remote transmitters/receivers. The EPROM technology makes customizing application programs (transmitter codes, appliance settings, receiver frequencies. etc.) extremely fast and convenient, while the EEPROM data memory technology allows for the changing of calibration factors and security codes. The small footprint packages, for through hole or surface mounting, make this microcontroller series perfect for applications with space limitations. Low-cost, low-power, high performance, ease of use and I/O flexibility make the PIC12C5XX series very versatile even in areas where no microcontroller use has been considered before (e.g., timer functions, replacement of "glue" logic and PLD's in larger systems, coprocessor applications).

#### 4.2.2 SPECIAL FUNCTION REGISTERS

The Special Function Registers (SFRs) are registers used by the CPU and peripheral functions to control the operation of the device (Table 4-1).

The special registers can be classified into two sets. The special function registers associated with the "core" functions are described in this section. Those related to the operation of the peripheral features are described in the section for each peripheral feature.

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

|                    |                                                                                     |               |                                                                                                         |             |           |             |              |         |       | Value on<br>Power-On | Value on<br>All Other    |
|--------------------|-------------------------------------------------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------|-------------|-----------|-------------|--------------|---------|-------|----------------------|--------------------------|
| Address            | Name                                                                                | Bit 7         | Bit 6                                                                                                   | Bit 5       | Bit 4     | Bit 3       | Bit 2        | Bit 1   | Bit 0 | Reset                | Resets <sup>(2)</sup>    |
| N/A                | TRIS                                                                                | —             | I                                                                                                       |             |           |             |              |         |       | 11 1111              | 11 1111                  |
| N/A                | OPTION                                                                              |               | Contains control bits to configure Timer0, Timer0/WDT<br>rescaler, wake-up on change, and weak pull-ups |             |           |             |              |         |       |                      | 1111 1111                |
| 00h                | INDF                                                                                | Uses conte    | ents of FSR                                                                                             | R to addres | s data me | mory (not a | physical reg | jister) |       | xxxx xxxx            | uuuu uuuu                |
| 01h                | TMR0                                                                                | 8-bit real-ti | me clock/c                                                                                              | ounter      |           |             |              |         |       | xxxx xxxx            | uuuu uuuu                |
| 02h <sup>(1)</sup> | PCL                                                                                 | Low order     | B bits of PC                                                                                            | c           |           |             |              |         |       | 1111 1111            | 1111 1111                |
| 03h                | STATUS                                                                              | GPWUF         | -                                                                                                       | PA0         | TO        | PD          | Z            | DC      | С     | 0001 1xxx            | q00q quuu <sup>(3)</sup> |
| 04h                | FSR<br>(PIC12C508/<br>PIC12C508A/<br>PIC12C518)                                     | Indirect dat  | ndirect data memory address pointer                                                                     |             |           |             |              |         | 1     | 111x xxxx            | 111u uuuu                |
| 04h                | FSR<br>(PIC12C509/<br>PIC12C509A/<br>PIC12CR509A/<br>PIC12CE519)                    | Indirect dat  | Indirect data memory address pointer                                                                    |             |           |             |              |         |       | 110x xxxx            | 11uu uuuu                |
| 05h                | OSCCAL<br>(PIC12C508/<br>PIC12C509)                                                 | CAL3          | CAL2                                                                                                    | CAL1        | CAL0      | _           | _            | _       | _     | 0111                 | uuuu                     |
| 05h                | OSCCAL<br>(PIC12C508A/<br>PIC12C509A/<br>PIC12CE518/<br>PIC12CE519/<br>PIC12CR509A) | CAL5          | CAL4                                                                                                    | CAL3        | CAL2      | CAL1        | CAL0         |         | _     | 1000 00              | uuuu uu                  |
| 06h                | GPIO<br>(PIC12C508/<br>PIC12C509/<br>PIC12C508A/<br>PIC12C509A/<br>PIC12C509A)      | _             | _                                                                                                       | GP5         | GP4       | GP3         | GP2          | GP1     | GP0   | xx xxxx              | uu uuuu                  |
| 06h                | GPIO<br>(PIC12CE518/<br>PIC12CE519)                                                 | SCL           | SDA                                                                                                     | GP5         | GP4       | GP3         | GP2          | GP1     | GP0   | 11xx xxxx            | 11uu uuuu                |

Legend: Shaded boxes = unimplemented or unused, - = unimplemented, read as '0' (if applicable)

x = unknown, u = unchanged, q = see the tables in Section 8.7 for possible values.

Note 1: The upper byte of the Program Counter is not directly accessible. See Section 4.6 for an explanation of how to access these bits.

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

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

# 5.0 I/O PORT

As with any other register, the I/O register can be written and read under program control. However, read instructions (e.g., MOVF GPIO, W) always read the I/O pins independent of the pin's input/output modes. On RESET, all I/O ports are defined as input (inputs are at hi-impedance) since the I/O control registers are all set. See Section 7.0 for SCL and SDA description for PIC12CE5XX.

# 5.1 <u>GPIO</u>

GPIO is an 8-bit I/O register. Only the low order 6 bits are used (GP5:GP0). Bits 7 and 6 are unimplemented and read as '0's. Please note that GP3 is an input only pin. The configuration word can set several I/O's to alternate functions. When acting as alternate functions the pins will read as '0' during port read. Pins GP0, GP1, and GP3 can be configured with weak pull-ups and also with wake-up on change. The wake-up on change and weak pull-up functions are not pin selectable. If pin 4 is configured as MCLR, weak pullup is always on and wake-up on change for this pin is not enabled.

#### 5.2 TRIS Register

The output driver control register is loaded with the contents of the W register by executing the TRIS f instruction. A '1' from a TRIS register bit puts the corresponding output driver in a hi-impedance mode. A '0' puts the contents of the output data latch on the selected pins, enabling the output buffer. The exceptions are GP3 which is input only and GP2 which may be controlled by the option register, see Figure 4-5.

| Note: | A read of the ports reads the pins, not the output data latches. That is, if an output      |
|-------|---------------------------------------------------------------------------------------------|
|       | driver on a pin is enabled and driven high,                                                 |
|       | but the external system is holding it low, a read of the port will indicate that the pin is |
|       | low.                                                                                        |

The TRIS registers are "write-only" and are set (output drivers disabled) upon RESET.

# 5.3 I/O Interfacing

The equivalent circuit for an I/O port pin is shown in Figure 5-1. All port pins, except GP3 which is input only, may be used for both input and output operations. For input operations these ports are non-latching. Any input must be present until read by an input instruction (e.g., MOVF GPIO, W). The outputs are latched and remain unchanged until the output latch is rewritten. To use a port pin as output, the corresponding direction control bit in TRIS must be cleared (= 0). For use as an input, the corresponding TRIS bit must be set. Any I/O pin (except GP3) can be programmed individually as input or output.



## FIGURE 5-1: EQUIVALENT CIRCUIT FOR A SINGLE I/O PIN

| TABLE 5-1: S | UMMARY OF PORT | <b>REGISTERS</b> |
|--------------|----------------|------------------|
|--------------|----------------|------------------|

| Address | Name                                                                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>Power-On<br>Reset | Value on<br>All Other Resets |
|---------|---------------------------------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------------------------------|------------------------------|
| N/A     | TRIS                                                                            | —     | -     |       |       |       |       |       |       | 11 1111                       | 11 1111                      |
| N/A     | OPTION                                                                          | GPWU  | GPPU  | TOCS  | TOSE  | PSA   | PS2   | PS1   | PS0   | 1111 1111                     | 1111 1111                    |
| 03H     | STATUS                                                                          | GPWUF | -     | PAO   | TO    | PD    | Z     | DC    | С     | 0001 1xxx                     | q00q quuu <sup>(1)</sup>     |
| 06h     | GPIO<br>(PIC12C508/<br>PIC12C509/<br>PIC12C508A/<br>PIC12C509A/<br>PIC12CR509A) |       | _     | GP5   | GP4   | GP3   | GP2   | GP1   | GP0   | xx xxxx                       | uu uuuu                      |
| 06h     | GPIO<br>(PIC12CE518/<br>PIC12CE519)                                             | SCL   | SDA   | GP5   | GP4   | GP3   | GP2   | GP1   | GP0   | 11xx xxxx                     | 11uu uuuu                    |

Legend: Shaded cells not used by Port Registers, read as '0', — = unimplemented, read as '0', x = unknown, u = unchanged, g = see tables in Section 8.7 for possible values.

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

#### 5.4 I/O Programming Considerations

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

Some instructions operate internally as read followed by write operations. The BCF and BSF instructions, for example, read the entire port into the CPU, execute the bit operation and re-write the result. Caution must be used when these instructions are applied to a port where one or more pins are used as input/outputs. For example, a BSF operation on bit5 of GPIO will cause all eight bits of GPIO to be read into the CPU, bit5 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 bit0) and it is defined as an input at this time, the input signal present on the pin itself would be read into the CPU and rewritten to the data latch of this particular pin, overwriting the previous content. As long as the pin stays in the input mode, no problem occurs. However, if bit0 is switched into output mode later on, the content of the data latch may now be unknown.

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

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

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

| ; | Initia              | L GPIO  | Sett | ings |         |     |        |
|---|---------------------|---------|------|------|---------|-----|--------|
| ; | GPIO<5              | 5:3> In | puts | 3    |         |     |        |
| ; | ; GPIO<2:0> Outputs |         |      |      |         |     |        |
| ; |                     |         |      |      |         |     |        |
| ; |                     |         |      | GPIC | ) latch | GPI | ) pins |
| ; |                     |         |      |      |         |     |        |
|   | BCF                 | GPIO,   | 5    | ;01  | -ppp    | 11  | pppp   |
|   | BCF                 | GPIO,   | 4    | ;10  | -ppp    | 11  | pppp   |
|   | MOVLW               | 007h    |      | ;    |         |     |        |
|   | TRIS                | GPIO    |      | ;10  | -ppp    | 11  | pppp   |
|   |                     |         |      |      |         |     |        |

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

# 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, which causes that file to be read into the CPU, is executed. Otherwise, the previous state of that pin may be read into the CPU rather than the new state. When in doubt, it is better to separate these instructions with a NOP or another instruction not accessing this I/O port.

# 6.0 TIMER0 MODULE AND TMR0 REGISTER

The Timer0 module has the following features:

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

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

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

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

The prescaler may be used by either the Timer0 module or the Watchdog Timer, but not both. The prescaler assignment is controlled in software by the control bit PSA (OPTION<3>). Clearing the PSA bit will assign the prescaler to Timer0. The prescaler is not readable or writable. When the prescaler is assigned to the Timer0 module, prescale values of 1:2, 1:4,..., 1:256 are selectable. Section 6.2 details the operation of the prescaler.

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



#### FIGURE 6-1: TIMER0 BLOCK DIAGRAM

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

#### 6.1.1 EXTERNAL CLOCK SYNCHRONIZATION

When no prescaler is used, the external clock input is the same as the prescaler output. The synchronization of T0CKI 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 2Tosc (and a small RC delay of 20 ns) and low for at least 2Tosc (and a small RC delay of 20 ns). 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 4ToSC (and a small RC delay of 40 ns) 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 10 ns. Refer to parameters 40, 41 and 42 in the electrical specification of the desired device.

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

#### 6.1.3 OPTION REGISTER EFFECT ON GP2 TRIS

If the option register is set to read TIMER0 from the pin, the port is forced to an input regardless of the TRIS register setting.



#### FIGURE 6-4: TIMER0 TIMING WITH EXTERNAL CLOCK

# 7.0 EEPROM PERIPHERAL OPERATION

# This section applies to PIC12CE518 and PIC12CE519 only.

The PIC12CE518 and PIC12CE519 each have 16 bytes of EEPROM data memory. The EEPROM memory has an endurance of 1,000,000 erase/write cycles and a data retention of greater than 40 years. The EEPROM data memory supports a bi-directional 2-wire bus and data transmission protocol. These two-wires are serial data (SDA) and serial clock (SCL), that are mapped to bit6 and bit7, respectively, of the GPIO register (SFR 06h). Unlike the GP0-GP5 that are connected to the internal EEPROM peripheral. For most applications, all that is required is calls to the following functions:

; Byte\_Write: Byte write routine Inputs: EEPROM Address EEADDR : ; EEPROM Data EEDATA Outputs: Return 01 in W if OK, else ; return 00 in W ; ; Read\_Current: Read EEPROM at address currently held by EE device. Inputs: NONE ; Outputs: EEPROM Data EEDATA ; Return 01 in W if OK, else ; return 00 in W ; ; Read\_Random: Read EEPROM byte at supplied address Inputs: EEPROM Address : FFADDR ; Outputs: EEPROM Data EEDATA Return 01 in W if OK, ; else return 00 in W

The code for these functions is available on our website www.microchip.com. The code will be accessed by either including the source code FL51XINC.ASM or by linking FLASH5IX.ASM.

It is very important to check the return codes when using these calls, and retry the operation if unsuccessful. Unsuccessful return codes occur when the EE data memory is busy with the previous write, which can take up to 4 mS.

#### 7.0.1 SERIAL DATA

SDA is a bi-directional pin used to transfer addresses and data into and data out of the device.

For normal data transfer SDA is allowed to change only during SCL low. Changes during SCL high are reserved for indicating the START and STOP conditions.

The EEPROM interface is a 2-wire bus protocol consisting of data (SDA) and a clock (SCL). Although these lines are mapped into the GPIO register, they are not accessible as external pins; only to the internal EEPROM peripheral. SDA and SCL operation is also slightly different than GPO-GP5 as listed below. Namely, to avoid code overhead in modifying the TRIS register, both SDA and SCL are always outputs. To read data from the EEPROM peripheral requires outputting a '1' on SDA placing it in high-Z state, where only the internal 100K pull-up is active on the SDA line.

SDA:

Built-in 100K (typical) pull-up to VDD Open-drain (pull-down only) Always an output Outputs a '1' on reset

SCL: Full CMOS output Always an output Outputs a '1' on reset

The following example requires:

- · Code Space: 77 words
- RAM Space: 5 bytes (4 are overlayable)
- Stack Levels:1 (The call to the function itself. The functions do not call any lower level functions.)
- Timing:
  - WRITE\_BYTE takes 328 cycles
  - READ\_CURRENT takes 212 cycles
  - READ\_RANDOM takes 416 cycles.
- IO Pins: 0 (No external IO pins are used)

This code must reside in the lower half of a page. The code achieves it's small size without additional calls through the use of a sequencing table. The table is a list of procedures that must be called in order. The table uses an ADDWF PCL,F instruction, effectively a computed goto, to sequence to the next procedure. However the ADDWF PCL,F instruction yields an 8 bit address, forcing the code to reside in the first 256 addresses of a page.

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

| BSF              | Bit Set f                                                                                                                    | BTFSS                                       | Bit Test f, Skip if Set                                                                                                         |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:          | [label] BSF f,b                                                                                                              | Syntax:                                     | [label] BTFSS f,b                                                                                                               |  |  |  |
| Operands:        | $0 \le f \le 31$ $0 \le b \le 7$                                                                                             | Operands: $0 \le f \le 31$<br>$0 \le b < 7$ |                                                                                                                                 |  |  |  |
| Operation:       | $1 \rightarrow (f < b >)$                                                                                                    | Operation:                                  | skip if (f <b>) = 1</b>                                                                                                         |  |  |  |
| Status Affected: | None                                                                                                                         | Status Affected:                            | None                                                                                                                            |  |  |  |
| Encoding:        | 0101 bbbf ffff                                                                                                               | Encoding:                                   | 0111 bbbf ffff                                                                                                                  |  |  |  |
| Description:     | Bit 'b' in register 'f' is set.                                                                                              | Description:                                | If bit 'b' in register 'f' is '1' then the next                                                                                 |  |  |  |
| Words:           | 1                                                                                                                            |                                             | instruction is skipped.                                                                                                         |  |  |  |
| Cycles:          | 1                                                                                                                            |                                             | If bit 'b' is '1', then the next instruction<br>fetched during the current instruction<br>execution, is discarded and an NOP is |  |  |  |
| Example:         | BSF FLAG_REG, 7                                                                                                              |                                             |                                                                                                                                 |  |  |  |
| Before Instru    | uction                                                                                                                       |                                             | executed instead, making this a 2 cycle instruction.                                                                            |  |  |  |
| _                | EG = 0x0A                                                                                                                    | Words:                                      | 1                                                                                                                               |  |  |  |
| After Instruc    | tion<br>EG = 0x8A                                                                                                            | Cycles:                                     | 1(2)                                                                                                                            |  |  |  |
| FLAG_K           |                                                                                                                              | Example:                                    | HERE BTFSS FLAG,1<br>FALSE GOTO PROCESS_CODE                                                                                    |  |  |  |
| BTFSC            | Bit Test f, Skip if Clear                                                                                                    |                                             | TRUE •                                                                                                                          |  |  |  |
| Syntax:          | [ label ] BTFSC f,b                                                                                                          |                                             | •                                                                                                                               |  |  |  |
| Operands:        | $0 \le f \le 31$                                                                                                             | Before Instr                                | uction                                                                                                                          |  |  |  |
|                  | $0 \le b \le 7$                                                                                                              | PC                                          | = address (HERE)                                                                                                                |  |  |  |
| Operation:       | skip if $(f < b >) = 0$                                                                                                      | After Instruc                               |                                                                                                                                 |  |  |  |
| Status Affected: | None                                                                                                                         | If FLAG<br>PC                               | <1> = 0,<br>= address (FALSE);                                                                                                  |  |  |  |
| Encoding:        | 0110 bbbf ffff                                                                                                               | if FLAG<                                    | <1> = 1,                                                                                                                        |  |  |  |
| Description:     | If bit 'b' in register 'f' is 0 then the next instruction is skipped.                                                        | PC                                          | = address (TRUE)                                                                                                                |  |  |  |
|                  | If bit 'b' is 0 then the next instruction<br>fetched during the current instruction<br>execution is discarded, and an NOP is |                                             |                                                                                                                                 |  |  |  |

executed instead, making this a 2 cycle

BTFSC FLAG,1

address (HERE)

address (TRUE);

address(FALSE)

PROCESS\_CODE

GOTO

٠ •

0, =

1, =

instruction.

1

1(2)

HERE

TRUE

Before Instruction PC

After Instruction if FLAG<1>

if FLAG<1>

PC

PC

FALSE

=

=

=

Words:

Cycles:

Example:

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

### CLRF

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

Clear f

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

NOTES:

#### 11.1 DC CHARACTERISTICS:

#### PIC12C508/509 (Commercial, Industrial, Extended)

| DC Characteristics<br>Power Supply Pins |                                               |       |           | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |     |        |                                                                                                    |  |  |
|-----------------------------------------|-----------------------------------------------|-------|-----------|------------------------------------------------------|-----|--------|----------------------------------------------------------------------------------------------------|--|--|
| Parm<br>No.                             | Characteristic                                | Sym   | Min       | Typ <sup>(1)</sup>                                   | Max | Units  | Conditions                                                                                         |  |  |
| D001                                    | Supply Voltage                                | Vdd   | 2.5       |                                                      | 5.5 | V<br>V | Fosc = DC to 4 MHz (Commercial/<br>Industrial)                                                     |  |  |
|                                         |                                               |       | 3.0       |                                                      | 5.5 |        | FOSC = DC to 4 MHz (Extended)                                                                      |  |  |
| D002                                    | RAM Data Retention<br>Voltage <sup>(2)</sup>  | Vdr   |           | 1.5*                                                 |     | V      | Device in SLEEP mode                                                                               |  |  |
| D003                                    | VDD Start Voltage to<br>ensure Power-on Reset | VPOR  |           | Vss                                                  |     | V      | See section on Power-on Reset for details                                                          |  |  |
| D004                                    | VDD Rise Rate to ensure<br>Power-on Reset     | SVDD  | 0.05<br>* |                                                      |     | V/ms   | See section on Power-on Reset for details                                                          |  |  |
| D010                                    | Supply Current <sup>(3)</sup>                 | Idd   | _         | .78                                                  | 2.4 | mA     | XT and EXTRC options <sup>(4)</sup><br>Fosc = 4 MHz, VDD = $5.5V$                                  |  |  |
| D010C                                   |                                               |       | —         | 1.1                                                  | 2.4 | mA     | INTRC Option<br>Fosc = 4 MHz, VDD = 5.5V                                                           |  |  |
| D010A                                   |                                               |       | —         | 10                                                   | 27  | μA     | LP OPTION, Commercial Temperature<br>Fosc = $32 \text{ kHz}$ , VDD = $3.0 \text{V}$ , WDT disabled |  |  |
|                                         |                                               |       | —         | 14                                                   | 35  | μA     | LP OPTION, Industrial Temperature<br>Fosc = 32 kHz, VDD = 3.0V, WDT disabled                       |  |  |
|                                         |                                               |       | -         | 14                                                   | 35  | μA     | LP OPTION, Extended Temperature<br>Fosc = 32 kHz, VDD = 3.0V, WDT disabled                         |  |  |
|                                         | Power-Down Current <sup>(5)</sup>             |       |           |                                                      |     |        |                                                                                                    |  |  |
| D020                                    |                                               | IPD   |           | 0.25                                                 | 4   | μA     | VDD = 3.0V, Commercial WDT disabled                                                                |  |  |
| D021                                    |                                               |       |           | 0.25                                                 | 5   | μΑ     | VDD = 3.0V, Industrial WDT disabled                                                                |  |  |
| D021B                                   |                                               |       | —         | 2                                                    | 18  | μA     | VDD = 3.0V, Extended WDT disabled                                                                  |  |  |
| D022                                    |                                               | ΔIWDT | _         | 3.75                                                 | 8   | μA     | VDD = 3.0V, Commercial                                                                             |  |  |
|                                         |                                               |       |           | 3.75                                                 | 9   | μA     | VDD = 3.0V, Industrial                                                                             |  |  |
|                                         |                                               |       | —         | 3.75                                                 | 14  | μΑ     | VDD = 3.0V, Extended                                                                               |  |  |

\* These parameters are characterized but not tested.

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

- 2: This is the limit to which VDD can be lowered in SLEEP mode without losing RAM data.
- 3: The supply current is mainly a function of the operating voltage and frequency. Other factors such as bus loading, oscillator type, bus rate, internal code execution pattern, and temperature also have an impact on the current consumption.
  - a) The test conditions for all IDD measurements in active operation mode are:
  - OSC1 = external square wave, from rail-to-rail; all I/O pins tristated, pulled to  $V_{ss}$ , T0CKI = VDD, MCLR = VDD; WDT enabled/disabled as specified.
  - b) For standby current measurements, the conditions are the same, except that the device is in SLEEP mode.
- 4: Does not include current through Rext. The current through the resistor can be estimated by the formula: IR = VDD/2Rext (mA) with Rext in kOhm.
- 5: The power down current in SLEEP mode does not depend on the oscillator type. Power down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD or VSS.

# TABLE 11-3: CALIBRATED INTERNAL RC FREQUENCIES - PIC12C508/C509

| AC Chara         | cteristics | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |      |                    |      |       |            |  |  |  |
|------------------|------------|------------------------------------------------------|------|--------------------|------|-------|------------|--|--|--|
| Parameter<br>No. | Sym        | Characteristic                                       | Min* | Typ <sup>(1)</sup> | Max* | Units | Conditions |  |  |  |
|                  |            | Internal Calibrated RC Frequency                     | 3.58 | 4.00               | 4.32 | MHz   | VDD = 5.0V |  |  |  |
|                  |            | Internal Calibrated RC Frequency                     | 3.50 | —                  | 4.26 | MHz   | VDD = 2.5V |  |  |  |

\* These parameters are characterized but not tested.

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



### FIGURE 11-3: I/O TIMING - PIC12C508/C509

# 13.1 DC CHARACTERISTICS:

#### PIC12C508A/509A (Commercial, Industrial, Extended) PIC12CE518/519 (Commercial, Industrial, Extended) PIC12CR509A (Commercial, Industrial, Extended)

| DC Characteristics<br>Power Supply Pins |                                                                            |                |       | $\begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise specified)} \\ \mbox{Operating Temperature} & 0^{\circ}C \leq TA \leq +70^{\circ}C \mbox{ (commercial)} \\ -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ (industrial)} \\ -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ (extended)} \end{array}$ |     |       |                                                                              |  |  |  |  |
|-----------------------------------------|----------------------------------------------------------------------------|----------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|------------------------------------------------------------------------------|--|--|--|--|
| Parm<br>No.                             | Characteristic                                                             | Sym            | Min   | Typ <sup>(1)</sup>                                                                                                                                                                                                                                                                                                         | Max | Units | Conditions                                                                   |  |  |  |  |
| D001                                    | Supply Voltage                                                             | Vdd            | 3.0   |                                                                                                                                                                                                                                                                                                                            | 5.5 | V     | Fosc = DC to 4 MHz (Commercial/<br>Industrial, Extended)                     |  |  |  |  |
| D002                                    | RAM Data Retention<br>Voltage <sup>(2)</sup>                               | Vdr            |       | 1.5*                                                                                                                                                                                                                                                                                                                       |     | V     | Device in SLEEP mode                                                         |  |  |  |  |
| D003                                    | 3 VDD Start Voltage to ensure<br>Power-on Reset                            |                |       | Vss                                                                                                                                                                                                                                                                                                                        |     | V     | See section on Power-on Reset for details                                    |  |  |  |  |
| D004                                    | VDD Rise Rate to ensure<br>Power-on Reset                                  | SVDD           | 0.05* |                                                                                                                                                                                                                                                                                                                            |     | V/ms  | See section on Power-on Reset for details                                    |  |  |  |  |
| D010                                    | Supply Current <sup>(3)</sup>                                              | IDD            | —     | 0.8                                                                                                                                                                                                                                                                                                                        | 1.4 | mA    | XT and EXTRC options (Note 4)<br>Fosc = 4 MHz, VDD = 5.5V                    |  |  |  |  |
| D010C                                   |                                                                            |                | _     | 0.8                                                                                                                                                                                                                                                                                                                        | 1.4 | mA    | INTRC Option<br>Fosc = 4 MHz, VDD = 5.5V                                     |  |  |  |  |
| D010A                                   |                                                                            |                | -     | 19                                                                                                                                                                                                                                                                                                                         | 27  | μA    | LP OPTION, Commercial Temperature<br>Fosc = 32 kHz, VDD = 3.0V, WDT disabled |  |  |  |  |
|                                         |                                                                            |                | _     | 19                                                                                                                                                                                                                                                                                                                         | 35  | μA    | LP OPTION, Industrial Temperature<br>FOSC = 32 kHz, VDD = 3.0V, WDT disabled |  |  |  |  |
|                                         |                                                                            |                | _     | 30                                                                                                                                                                                                                                                                                                                         | 55  | μA    | LP OPTION, Extended Temperature<br>FOSC = 32 kHz, VDD = 3.0V, WDT disabled   |  |  |  |  |
| D020                                    | Power-Down Current <sup>(5)</sup>                                          | IPD            | —     | 0.25                                                                                                                                                                                                                                                                                                                       | 4   | μA    | VDD = 3.0V, Commercial WDT disabled                                          |  |  |  |  |
| D021                                    |                                                                            |                | —     | 0.25                                                                                                                                                                                                                                                                                                                       | 5   | μA    | VDD = 3.0V, Industrial WDT disabled                                          |  |  |  |  |
| D021B                                   |                                                                            |                | -     | 2                                                                                                                                                                                                                                                                                                                          | 12  | μA    | VDD = 3.0V, Extended WDT disabled                                            |  |  |  |  |
| D022                                    | Power-Down Current                                                         | $\Delta I$ WDT | —     | 2.2                                                                                                                                                                                                                                                                                                                        | 5   | μA    | VDD = 3.0V, Commercial                                                       |  |  |  |  |
|                                         |                                                                            |                | -     | 2.2                                                                                                                                                                                                                                                                                                                        | 6   | μA    | VDD = 3.0V, Industrial                                                       |  |  |  |  |
|                                         |                                                                            |                | -     | 4                                                                                                                                                                                                                                                                                                                          | 11  | μA    | VDD = 3.0V, Extended                                                         |  |  |  |  |
|                                         | Supply Current <sup>(3)</sup><br>During read/write to<br>EEPROM peripheral | ΔIEE           | -     | 0.1                                                                                                                                                                                                                                                                                                                        | 0.2 | mA    | FOSC = 4 MHz, Vdd = 5.5V,<br>SCL = 400kHz                                    |  |  |  |  |

\* These parameters are characterized but not tested.

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

2: This is the limit to which VDD can be lowered in SLEEP mode without losing RAM data.

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

- a) The test conditions for all IDD measurements in active operation mode are:
  - OSC1 = external square wave, from rail-to-rail; all I/O pins tristated, pulled to
  - Vss, T0CKI = VDD,  $\overline{MCLR}$  = VDD; WDT enabled/disabled as specified.
- b) For standby current measurements, the conditions are the same, except that the device is in SLEEP mode.
- 4: Does not include current through Rext. The current through the resistor can be estimated by the formula: IR = VDD/2Rext (mA) with Rext in kOhm.
- 5: The power down current in SLEEP mode does not depend on the oscillator type. Power down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD or VSS.

# 13.4 DC CHARACTERISTICS:

#### PIC12LC508A/509A (Commercial, Industrial) PIC12LC518/519 (Commercial, Industrial) PIC12LCR509A (Commercial, Industrial)

| DC CHARACTERISTICS |                                                                                                                       | Standard Operating Conditions (unless otherwise specified)           Operating temperature $0^{\circ}C \le TA \le +70^{\circ}C$ (commercial) $-40^{\circ}C \le TA \le +85^{\circ}C$ (industrial) |           |        |            |                               |                                                                    |  |  |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------|------------|-------------------------------|--------------------------------------------------------------------|--|--|--|
|                    |                                                                                                                       | Operat<br>Section                                                                                                                                                                                |           | VDD ra | ange as d  | d in DC spec Section 13.1 and |                                                                    |  |  |  |
| Param<br>No.       | Characteristic                                                                                                        | Sym                                                                                                                                                                                              | Min       | Тур†   | Max        | Units                         | Conditions                                                         |  |  |  |
|                    | Input Low Voltage                                                                                                     |                                                                                                                                                                                                  |           |        |            |                               |                                                                    |  |  |  |
|                    | I/O ports                                                                                                             | VIL                                                                                                                                                                                              |           |        |            |                               |                                                                    |  |  |  |
| D030               | with TTL buffer                                                                                                       |                                                                                                                                                                                                  | Vss       | -      | 0.8V       | V                             | For $4.5V \le VDD \le 5.5V$                                        |  |  |  |
|                    |                                                                                                                       |                                                                                                                                                                                                  | Vss       | -      | 0.15Vdd    | V                             | otherwise                                                          |  |  |  |
| D031               | with Schmitt Trigger buffer                                                                                           |                                                                                                                                                                                                  | Vss       | -      | 0.2Vdd     | V                             |                                                                    |  |  |  |
| D032               | MCLR, GP2/T0CKI (in EXTRC mode)                                                                                       |                                                                                                                                                                                                  | Vss       | -      | 0.2Vdd     | V                             |                                                                    |  |  |  |
| D033               | OSC1 (in EXTRC mode)                                                                                                  |                                                                                                                                                                                                  | Vss       | -      | 0.2Vdd     | V                             | Note 1                                                             |  |  |  |
| D033               | OSC1 (in XT and LP)                                                                                                   |                                                                                                                                                                                                  | Vss       | -      | 0.3Vdd     | V                             | Note 1                                                             |  |  |  |
|                    | Input High Voltage                                                                                                    | 1                                                                                                                                                                                                |           |        |            |                               |                                                                    |  |  |  |
|                    | I/O ports                                                                                                             | VIH                                                                                                                                                                                              |           | -      |            |                               |                                                                    |  |  |  |
| D040               | with TTL buffer                                                                                                       |                                                                                                                                                                                                  | 0.25Vdd + | -      | Vdd        | V                             | $4.5V \le VDD \le 5.5V$                                            |  |  |  |
|                    |                                                                                                                       |                                                                                                                                                                                                  | 0.8V      |        |            |                               |                                                                    |  |  |  |
| D040A              |                                                                                                                       |                                                                                                                                                                                                  | 2.0V      | -      | Vdd        | V                             | otherwise                                                          |  |  |  |
| D041               | with Schmitt Trigger buffer                                                                                           |                                                                                                                                                                                                  | 0.8Vdd    | -      | Vdd        | V                             | For entire VDD range                                               |  |  |  |
| D042               | MCLR, GP2/T0CKI                                                                                                       |                                                                                                                                                                                                  | 0.8Vdd    | -      | Vdd        | V                             |                                                                    |  |  |  |
| D042A              | OSC1 (XT and LP)                                                                                                      |                                                                                                                                                                                                  | 0.7Vdd    | -      | Vdd        | V                             | Note 1                                                             |  |  |  |
| D043               | OSC1 (in EXTRC mode)                                                                                                  |                                                                                                                                                                                                  | 0.9Vdd    | -      | Vdd        | V                             |                                                                    |  |  |  |
| D070               | GPIO weak pull-up current (Note 4)                                                                                    | IPUR                                                                                                                                                                                             | 30        | 250    | 400        | μA                            | VDD = 5V, VPIN = VSS                                               |  |  |  |
|                    | MCLR pull-up current                                                                                                  | -                                                                                                                                                                                                | -         | -      | 30         | μA                            | VDD = 5V, VPIN = VSS                                               |  |  |  |
|                    | Input Leakage Current (Notes 2, 3)                                                                                    |                                                                                                                                                                                                  |           |        |            | -                             |                                                                    |  |  |  |
| D060               | I/O ports                                                                                                             | lil                                                                                                                                                                                              | -         | -      | <u>+</u> 1 | μΑ                            | Vss $\leq$ VPIN $\leq$ VDD, Pin at hi-imped ance                   |  |  |  |
| D061               | тоскі                                                                                                                 |                                                                                                                                                                                                  | -         | -      | <u>+</u> 5 | μA                            | $Vss \leq VPIN \leq VDD$                                           |  |  |  |
| D063               | OSC1                                                                                                                  |                                                                                                                                                                                                  | -         | -      | <u>+</u> 5 | μA                            | Vss $\leq$ VPIN $\leq$ VDD, XT and LP osc configuration            |  |  |  |
|                    | Output Low Voltage                                                                                                    |                                                                                                                                                                                                  |           |        |            |                               |                                                                    |  |  |  |
| D080               | I/O ports                                                                                                             | Vol                                                                                                                                                                                              | -         | -      | 0.6        | V                             | IOL = 8.5 mA, VDD = 4.5V,<br>−40°C to +85°C                        |  |  |  |
| D080A              |                                                                                                                       |                                                                                                                                                                                                  | -         | -      | 0.6        | V                             | IOL = 7.0 mA, VDD = 4.5V,<br>−40°C to +125°C                       |  |  |  |
|                    | Output High Voltage                                                                                                   |                                                                                                                                                                                                  |           |        |            |                               |                                                                    |  |  |  |
| D090               | I/O ports (Note 3)                                                                                                    | Vон                                                                                                                                                                                              | Vdd - 0.7 | -      | -          | V                             | IOH = -3.0 mA, VDD = 4.5V,<br>−40°C to +85°C                       |  |  |  |
| D090A              |                                                                                                                       |                                                                                                                                                                                                  | Vdd - 0.7 | -      | -          | V                             | IOH = -2.5 mA, VDD = 4.5V,<br>-40°C to +125°C                      |  |  |  |
|                    | Capacitive Loading Specs on<br>Output Pins                                                                            |                                                                                                                                                                                                  |           |        |            |                               |                                                                    |  |  |  |
| D100               | OSC2 pin                                                                                                              | COSC<br>2                                                                                                                                                                                        | -         | -      | 15         | pF                            | In XT and LP modes when exter-<br>nal clock is used to drive OSC1. |  |  |  |
| D101               | All I/O pins                                                                                                          | Сю                                                                                                                                                                                               | -         | -      | 50         | pF                            |                                                                    |  |  |  |
| †                  | Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are no |                                                                                                                                                                                                  |           |        |            |                               |                                                                    |  |  |  |

† 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: In EXTRC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the PIC12C5XX be driven with external clock in RC mode.

2: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages.

3: Negative current is defined as coming out of the pin.

4: This spec. applies when GP3/MCLR is configured as MCLR. The leakage current of the MCLR circuit is higher than the standard I/O logic.



#### FIGURE 13-4: RESET, WATCHDOG TIMER, AND DEVICE RESET TIMER TIMING -PIC12C508A, PIC12C509A, PIC12CE518, PIC12CE519, PIC12LC508A, PIC12LC509A, PIC12LCR509A, PIC12LCE518 and PIC12LCE519

#### TABLE 13-5: RESET, WATCHDOG TIMER, AND DEVICE RESET TIMER - PIC12C508A, PIC12C509A, PIC12CE518, PIC12CE519, PIC12LC508A, PIC12LC509A, PIC12LCR509A, PIC12LCE518 and PIC12LCE519

| AC Characteristics |                                                    | $ \begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise specified)} \\ \mbox{Operating Temperature} & 0^{\circ}C \leq TA \leq +70^{\circ}C \mbox{ (commercial)} \\ & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ (industrial)} \\ & -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ (extended)} \\ \mbox{Operating Voltage VDD range is described in Section 13.1} \\ \end{array} $ |       |                    |       |       |                        |  |  |  |
|--------------------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------|-------|-------|------------------------|--|--|--|
| Parameter<br>No.   | Sym                                                | Characteristic                                                                                                                                                                                                                                                                                                                                                                                         | Min   | Typ <sup>(1)</sup> | Max   | Units | Conditions             |  |  |  |
| 30                 | TmcL                                               | MCLR Pulse Width (low)                                                                                                                                                                                                                                                                                                                                                                                 | 2000* | —                  |       | ns    | VDD = 5 V              |  |  |  |
| 31                 | Twdt Watchdog Timer Time-out Period (No Prescaler) |                                                                                                                                                                                                                                                                                                                                                                                                        | 9*    | 18*                | 30*   | ms    | VDD = 5 V (Commercial) |  |  |  |
| 32                 | TDRT                                               | Device Reset Timer Period <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                               | 9*    | 18*                | 30*   | ms    | VDD = 5 V (Commercial) |  |  |  |
| 34 Tioz I/O H      |                                                    | I/O Hi-impedance from MCLR Low                                                                                                                                                                                                                                                                                                                                                                         | —     | —                  | 2000* | ns    |                        |  |  |  |

\* These parameters are characterized but not tested.

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

Note 2: See Table 13-6.

NOTES:

# Package Type: K04-057 8-Lead Plastic Small Outline (SN) - Narrow, 150 mil





| Units                   |                |       | INCHES* |       | MILLIMETERS |      |      |  |
|-------------------------|----------------|-------|---------|-------|-------------|------|------|--|
| Dimension Limits        |                | MIN   | NOM     | MAX   | MIN         | NOM  | MAX  |  |
| Pitch                   | р              |       | 0.050   |       |             | 1.27 |      |  |
| Number of Pins          | n              |       | 8       |       |             | 8    |      |  |
| Overall Pack. Height    | A              | 0.054 | 0.061   | 0.069 | 1.37        | 1.56 | 1.75 |  |
| Shoulder Height         | A1             | 0.027 | 0.035   | 0.044 | 0.69        | 0.90 | 1.11 |  |
| Standoff                | A2             | 0.004 | 0.007   | 0.010 | 0.10        | 0.18 | 0.25 |  |
| Molded Package Length   | D‡             | 0.189 | 0.193   | 0.196 | 4.80        | 4.89 | 4.98 |  |
| Molded Package Width    | E‡             | 0.150 | 0.154   | 0.157 | 3.81        | 3.90 | 3.99 |  |
| Outside Dimension       | E1             | 0.229 | 0.237   | 0.244 | 5.82        | 6.01 | 6.20 |  |
| Chamfer Distance        | х              | 0.010 | 0.015   | 0.020 | 0.25        | 0.38 | 0.51 |  |
| Shoulder Radius         | R1             | 0.005 | 0.005   | 0.010 | 0.13        | 0.13 | 0.25 |  |
| Gull Wing Radius        | R2             | 0.005 | 0.005   | 0.010 | 0.13        | 0.13 | 0.25 |  |
| Foot Length             | L              | 0.011 | 0.016   | 0.021 | 0.28        | 0.41 | 0.53 |  |
| Foot Angle              | φ              | 0     | 4       | 8     | 0           | 4    | 8    |  |
| Radius Centerline       | L1             | 0.000 | 0.005   | 0.010 | 0.00        | 0.13 | 0.25 |  |
| Lead Thickness          | с              | 0.008 | 0.009   | 0.010 | 0.19        | 0.22 | 0.25 |  |
| Lower Lead Width        | B <sup>†</sup> | 0.014 | 0.017   | 0.020 | 0.36        | 0.43 | 0.51 |  |
| Mold Draft Angle Top    | α              | 0     | 12      | 15    | 0           | 12   | 15   |  |
| Mold Draft Angle Bottom | β              | 0     | 12      | 15    | 0           | 12   | 15   |  |

\* Controlling Parameter.

- <sup>†</sup> Dimension "B" does not include dam-bar protrusions. Dam-bar protrusions shall not exceed 0.003" (0.076 mm) per side or 0.006" (0.152 mm) more than dimension "B."
- <sup>‡</sup> Dimensions "D" and "E" do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.010" (0.254 mm) per side or 0.020" (0.508 mm) more than dimensions "D" or "E."

NOTES: