# E·XFL



#### Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                      |
|----------------------------|-----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 4MHz                                                                        |
| Connectivity               | -                                                                           |
| Peripherals                | POR, WDT                                                                    |
| Number of I/O              | 5                                                                           |
| Program Memory Size        | 768B (512 x 12)                                                             |
| Program Memory Type        | ОТР                                                                         |
| EEPROM Size                | -                                                                           |
| RAM Size                   | 25 x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                                                   |
| Data Converters            | -                                                                           |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 8-VDFN Exposed Pad                                                          |
| Supplier Device Package    | 8-DFN-S (6x5)                                                               |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic12c508a-04i-mf |

Email: info@E-XFL.COM

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

#### 3.0 ARCHITECTURAL OVERVIEW

The high performance of the PIC12C5XX family can be attributed to a number of architectural features commonly found in RISC microprocessors. To begin with, the PIC12C5XX uses a Harvard architecture in which program and data are accessed on separate buses. This improves bandwidth over traditional von Neumann architecture where program and data are fetched on the same bus. Separating program and data memory further allows instructions to be sized differently than the 8-bit wide data word. Instruction opcodes are 12-bits wide making it possible to have all single word instructions. A 12-bit wide program memory access bus fetches a 12-bit instruction in a single cycle. A two-stage pipeline overlaps fetch and execution of instructions. Consequently, all instructions (33) execute in a single cycle (1µs @ 4MHz) except for program branches.

The table below lists program memory (EPROM), data memory (RAM), ROM memory, and non-volatile (EEPROM) for each device.

|             | Memory           |                |             |                |  |  |  |  |
|-------------|------------------|----------------|-------------|----------------|--|--|--|--|
| Device      | EPROM<br>Program | ROM<br>Program | RAM<br>Data | EEPROM<br>Data |  |  |  |  |
| PIC12C508   | 512 x 12         |                | 25          |                |  |  |  |  |
| PIC12C509   | 1024 x 12        |                | 41          |                |  |  |  |  |
| PIC12C508A  | 512 x 12         |                | 25          |                |  |  |  |  |
| PIC12C509A  | 1024 x 12        |                | 41          |                |  |  |  |  |
| PIC12CR509A |                  | 1024 x 12      | 41          |                |  |  |  |  |
| PIC12CE518  | 512 x 12         |                | 25 x 8      | 16 x 8         |  |  |  |  |
| PIC12CE519  | 1024 x 12        |                | 41 x 8      | 16 x 8         |  |  |  |  |

The PIC12C5XX can directly or indirectly address its register files and data memory. All special function registers including the program counter are mapped in the data memory. The PIC12C5XX has a highly orthogonal (symmetrical) instruction set that makes it possible to carry out any operation on any register using any addressing mode. This symmetrical nature and lack of 'special optimal situations' make programming with the PIC12C5XX simple yet efficient. In addition, the learning curve is reduced significantly.

The PIC12C5XX device contains an 8-bit ALU and working register. The ALU is a general purpose arithmetic unit. It performs arithmetic and Boolean functions between data in the working register and any register file.

The ALU is 8-bits wide and capable of addition, subtraction, shift and logical operations. Unless otherwise mentioned, arithmetic operations are two's complement in nature. In two-operand instructions, typically one operand is the W (working) register. The other operand is either a file register or an immediate constant. In single operand instructions, the operand is either the W register or a file register.

The W register is an 8-bit working register used for ALU operations. It is not an addressable register.

Depending on the instruction executed, the ALU may affect the values of the Carry (C), Digit Carry (DC), and Zero (Z) bits in the STATUS register. The C and DC bits operate as a borrow and digit borrow out bit, respectively, in subtraction. See the SUBWF and ADDWF instructions for examples.

A simplified block diagram is shown in Figure 3-1, with the corresponding device pins described in Table 3-1.

#### 4.4 OPTION Register

The OPTION register is a 8-bit wide, write-only register which contains various control bits to configure the Timer0/WDT prescaler and Timer0.

By executing the OPTION instruction, the contents of the W register will be transferred to the OPTION register. A RESET sets the OPTION<7:0> bits.

#### FIGURE 4-5: OPTION REGISTER

Note: If TRIS bit is set to '0', the wake-up on change and pull-up functions are disabled for that pin; i.e., note that TRIS overrides OPTION control of GPPU and GPWU.

**Note:** If the TOCS bit is set to '1', GP2 is forced to be an input even if TRIS GP2 = '0'.

| W-1      | W-1                                                  | W-1           | W-1         | W-1          | W-1         | W-1 | W-1  |                                                                                               |
|----------|------------------------------------------------------|---------------|-------------|--------------|-------------|-----|------|-----------------------------------------------------------------------------------------------|
| GPWU     | GPPU                                                 | TOCS          | T0SE        | PSA          | PS2         | PS1 | PS0  | W = Writable bit                                                                              |
| oit7     | 6                                                    | 5             | 4           | 3            | 2           | 1   | bit0 | U = Unimplemented bit<br>- n = Value at POR reset<br>Reference Table 4-1 for<br>other resets. |
| bit 7:   | <b>GPWU</b> : Ena<br>1 = Disable<br>0 = Enable       | d             | p on pin cl | hange (GP    | 0, GP1, GP3 | )   |      |                                                                                               |
| bit 6:   | <b>GPPU</b> : Ena<br>1 = Disable<br>0 = Enablec      | d .           | III-ups (GF | 90, GP1, G   | P3)         |     |      |                                                                                               |
| bit 5:   | <b>TOCS</b> : Time<br>1 = Transitio<br>0 = Transitio | on on TOCK    | l pin       |              | ock, Fosc/4 |     |      |                                                                                               |
| bit 4:   | TOSE: Time<br>1 = Increme<br>0 = Increme             | ent on high t | o low trans | sition on th |             |     |      |                                                                                               |
| bit 3:   | <b>PSA</b> : Presc<br>1 = Prescale<br>0 = Prescale   | er assigned   | to the WD   |              |             |     |      |                                                                                               |
| bit 2-0: | PS2:PS0: P                                           | Prescaler rat | e select bi | its          |             |     |      |                                                                                               |
|          | Bit Value                                            | Timer0 R      | ate WDT     | Rate         |             |     |      |                                                                                               |
|          | 000                                                  | 1:2<br>1:4    | 1:          | 2            |             |     |      |                                                                                               |
|          | 010<br>011                                           | 1:8           | 1:          |              |             |     |      |                                                                                               |
|          | 100                                                  | 1:32          |             | 0<br>16      |             |     |      |                                                                                               |
|          | 101                                                  | 1:64          |             | 32           |             |     |      |                                                                                               |
|          | 110                                                  | 1:128         |             | 64           |             |     |      |                                                                                               |
|          | 111                                                  | 1:256         | : 1.        | 128          |             |     |      |                                                                                               |

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

| ; | ;Initial GPIO Settings |       |   |      |         |     |        |  |  |  |
|---|------------------------|-------|---|------|---------|-----|--------|--|--|--|
| ; | ; GPIO<5:3> Inputs     |       |   |      |         |     |        |  |  |  |
| ; | ; 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.

# PIC12C5XX

NOTES:

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

#### 8.2 Oscillator Configurations

#### 8.2.1 OSCILLATOR TYPES

The PIC12C5XX can be operated in four different oscillator modes. The user can program two configuration bits (FOSC1:FOSC0) to select one of these four modes:

- LP: Low Power Crystal
- XT: Crystal/Resonator
- INTRC: Internal 4 MHz Oscillator
- EXTRC: External Resistor/Capacitor

### 8.2.2 CRYSTAL OSCILLATOR / CERAMIC RESONATORS

In XT or LP modes, a crystal or ceramic resonator is connected to the GP5/OSC1/CLKIN and GP4/OSC2 pins to establish oscillation (Figure 8-2). The PIC12C5XX oscillator design requires the use of a parallel cut crystal. Use of a series cut crystal may give a frequency out of the crystal manufacturers specifications. When in XT or LP modes, the device can have an external clock source drive the GP5/ OSC1/CLKIN pin (Figure 8-3).

#### FIGURE 8-2: CRYSTAL OPERATION (OR CERAMIC RESONATOR) (XT OR LP OSC CONFIGURATION)



#### FIGURE 8-3: EXTERNAL CLOCK INPUT OPERATION (XT OR LP OSC CONFIGURATION)



#### TABLE 8-1: CAPACITOR SELECTION FOR CERAMIC RESONATORS - PIC12C5XX

| Osc  | Resonator | Cap. Range | Cap. Range |
|------|-----------|------------|------------|
| Type | Freq      | C1         | C2         |
| XT   | 4.0 MHz   | 30 pF      | 30 pF      |

These values are for design guidance only. Since each resonator has its own characteristics, the user should consult the resonator manufacturer for appropriate values of external components.

#### TABLE 8-2: CAPACITOR SELECTION FOR CRYSTAL OSCILLATOR -PIC12C5XX

| Osc<br>Type | Resonator<br>Freq     | Cap.Range<br>C1 | Cap. Range<br>C2 |
|-------------|-----------------------|-----------------|------------------|
| LP          | 32 kHz <sup>(1)</sup> | 15 pF           | 15 pF            |
| XT          | 200 kHz               | 47-68 pF        | 47-68 pF         |
|             | 1 MHz                 | 15 pF           | 15 pF            |
|             | 4 MHz                 | 15 pF           | 15 pF            |

Note 1: For VDD > 4.5V, C1 = C2  $\approx$  30 pF is recommended.

These values are for design guidance only. Rs may be required to avoid overdriving crystals with low drive level specification. Since each crystal has its own characteristics, the user should consult the crystal manufacturer for appropriate values of external components.

#### 8.6.1 WDT PERIOD

The WDT has a nominal time-out period of 18 ms, (with no prescaler). If a longer time-out period is desired, a prescaler with a division ratio of up to 1:128 can be assigned to the WDT (under software control) by writing to the OPTION register. Thus, a time-out period of a nominal 2.3 seconds can be realized. These periods vary with temperature, VDD and part-to-part process variations (see DC specs).

Under worst case conditions (VDD = Min., Temperature = Max., max. WDT prescaler), it may take several seconds before a WDT time-out occurs.

#### 8.6.2 WDT PROGRAMMING CONSIDERATIONS

The CLRWDT instruction clears the WDT and the postscaler, if assigned to the WDT, and prevents it from timing out and generating a device RESET.

The SLEEP instruction resets the WDT and the postscaler, if assigned to the WDT. This gives the maximum SLEEP time before a WDT wake-up reset.



#### FIGURE 8-12: WATCHDOG TIMER BLOCK DIAGRAM

TABLE 8-6: SUMMARY OF REGISTERS ASSOCIATED WITH THE WATCHDOG TIMER

| Address | Name   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>Power-On<br>Reset | Value on<br>All Other<br>Resets |
|---------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------------------------------|---------------------------------|
| N/A     | OPTION | GPWU  | GPPU  | TOCS  | TOSE  | PSA   | PS2   | PS1   | PS0   | 1111 1111                     | 1111 1111                       |

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

# PIC12C5XX

| 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<br>avouted instruct making this a 2 curle |  |  |  |
| Example:           | BSF FLAG_REG, 7                                                                                                              |                  |                                                                                                                                                                           |  |  |  |
| Before Instruction |                                                                                                                              |                  | 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:

### PIC12C5XX

| OPTION                         | Load OP                                                           | TION Re | gister |  |  |
|--------------------------------|-------------------------------------------------------------------|---------|--------|--|--|
| Syntax:                        | [ label ]                                                         | OPTION  | l      |  |  |
| Operands:                      | None                                                              |         |        |  |  |
| Operation:                     | $(W)\toO$                                                         | PTION   |        |  |  |
| Status Affected:               | None                                                              |         |        |  |  |
| Encoding:                      | 0000                                                              | 0000    | 0010   |  |  |
| Description:                   | The content of the W register is loaded into the OPTION register. |         |        |  |  |
| Words:                         | 1                                                                 |         |        |  |  |
| Cycles:                        | 1                                                                 |         |        |  |  |
| Example                        | OPTION                                                            |         |        |  |  |
| Before Instruction<br>W = 0x07 |                                                                   |         |        |  |  |
| After Instruct<br>OPTION       |                                                                   |         |        |  |  |

| RETLW                 | Return with                                                            | Liter                                                                                                                                                                              | al in W                          |  |  |  |  |  |  |
|-----------------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--|--|--|--|--|--|
| Syntax:               | [label] RE                                                             | ETLW                                                                                                                                                                               | k                                |  |  |  |  |  |  |
| Operands:             | $0 \le k \le 255$                                                      |                                                                                                                                                                                    |                                  |  |  |  |  |  |  |
| Operation:            | $\begin{array}{l} k \rightarrow (W);\\ TOS \rightarrow PC \end{array}$ |                                                                                                                                                                                    |                                  |  |  |  |  |  |  |
| Status Affected:      | None                                                                   |                                                                                                                                                                                    |                                  |  |  |  |  |  |  |
| Encoding:             | 1000 kł                                                                | kk                                                                                                                                                                                 | kkkk                             |  |  |  |  |  |  |
| Description:          | bit literal 'k'. T<br>loaded from th                                   | The W register is loaded with the eight<br>bit literal 'k'. The program counter is<br>loaded from the top of the stack (the<br>return address). This is a two cycle<br>instruction |                                  |  |  |  |  |  |  |
| Words:                | 1                                                                      |                                                                                                                                                                                    |                                  |  |  |  |  |  |  |
| Cycles:               | 2                                                                      |                                                                                                                                                                                    |                                  |  |  |  |  |  |  |
| Example:              | CALL TABLE                                                             | ;tab<br>;val                                                                                                                                                                       | le offset<br>ue.<br>ow has table |  |  |  |  |  |  |
| TABLE                 | ADDWF PC<br>RETLW k1<br>RETLW k2                                       | ;Beg                                                                                                                                                                               | offset<br>in table<br>d of table |  |  |  |  |  |  |
| Before Instru<br>W =  | ox07                                                                   |                                                                                                                                                                                    |                                  |  |  |  |  |  |  |
| After Instruct<br>W = | tion<br>value of k8                                                    |                                                                                                                                                                                    |                                  |  |  |  |  |  |  |

| RLF                                                                                                                                                                            | Rotate Left f through Carry                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                                                                                                                                                        | [label] RLF f,d                                                                                                                                                                                                                                                                                                                                                                                                                |
| Operands:                                                                                                                                                                      | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                                                                                                                                                                                                                                                                               |
| Operation:                                                                                                                                                                     | See description below                                                                                                                                                                                                                                                                                                                                                                                                          |
| Status Affected:                                                                                                                                                               | С                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Encoding:                                                                                                                                                                      | 0011 01df ffff                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Description:                                                                                                                                                                   | The contents of register 'f' are rotated<br>one bit to the left through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is stored<br>back in register 'f'.                                                                                                                                                                                                                    |
| Words:                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Cycles:                                                                                                                                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Example:                                                                                                                                                                       | RLF REG1,0                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Before Instru                                                                                                                                                                  | iction                                                                                                                                                                                                                                                                                                                                                                                                                         |
| REG1<br>C                                                                                                                                                                      | = 1110 0110<br>= 0                                                                                                                                                                                                                                                                                                                                                                                                             |
| After Instruct                                                                                                                                                                 | tion                                                                                                                                                                                                                                                                                                                                                                                                                           |
| REG1                                                                                                                                                                           | = 1110 0110                                                                                                                                                                                                                                                                                                                                                                                                                    |
| W<br>C                                                                                                                                                                         | = 1100 1100<br>= 1                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                |
| RRF                                                                                                                                                                            | Rotate Right f through Carry                                                                                                                                                                                                                                                                                                                                                                                                   |
| RRF<br>Syntax:                                                                                                                                                                 | Rotate Right f through Carry<br>[ label ] RRF f,d                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Syntax:                                                                                                                                                                        | [ <i>label</i> ] RRF f,d<br>0 ≤ f ≤ 31                                                                                                                                                                                                                                                                                                                                                                                         |
| Syntax:<br>Operands:                                                                                                                                                           | $\begin{bmatrix} label \end{bmatrix} RRF f,d$<br>$0 \le f \le 31$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                                                                                             |
| Syntax:<br>Operands:<br>Operation:                                                                                                                                             | $ \begin{bmatrix} label \end{bmatrix} RRF f,d \\ 0 \le f \le 31 \\ d \in [0,1] $ See description below                                                                                                                                                                                                                                                                                                                         |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:                                                                                                                         | $ [label] RRF f,d  0 \le f \le 31  d \in [0,1]  See description below  C  0011 00df ffff  The contents of register 'f' are rotated  one bit to the right through the Carry  Flag. If 'd' is 0 the result is placed in the  W register. If 'd' is 1 the result is placed  back in register 'f'.$                                                                                                                                |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:                                                                                                            | $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                        |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:                                                                                                            | $ [label] RRF f,d  0 \le f \le 31  d \in [0,1]  See description below  C  0011 00df ffff  The contents of register 'f' are rotated  one bit to the right through the Carry  Flag. If 'd' is 0 the result is placed in the  W register. If 'd' is 1 the result is placed  back in register 'f'.$                                                                                                                                |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:                                                                       | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011  00df  ffff<br>The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'.<br>$c \ register 'f'$<br>1<br>1                                                                |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:                                                                                  | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'<br>T                                                                                              |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:                                                                       | $\begin{bmatrix} label \end{bmatrix} RRF f,d$<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>$\boxed{0011  00df  ffff}$<br>The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'.<br>$\boxed{C} \leftarrow register 'f'}$<br>1<br>1<br>RRF REG1,0 |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example:<br>Before Instru-<br>REG1                                 | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'.<br>C register 'f'<br>1<br>1<br>RRF REG1,0<br>interimed<br>= 1110 0110<br>= 0                     |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example:<br>Before Instruct<br>REG1<br>C<br>After Instruct<br>REG1 | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011 00df ffff<br>The contents of register 'f are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'<br>1<br>1<br>RRF REG1,0<br>intion<br>= 1110 0110<br>= 0<br>tion<br>= 1110 0110                     |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example:<br>Before Instruct<br>REG1<br>C<br>After Instruct         | [ <i>label</i> ] RRF f,d<br>$0 \le f \le 31$<br>$d \in [0,1]$<br>See description below<br>C<br>0011  00df  ffff<br>The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed<br>back in register 'f'<br>1<br>1<br>RRF REGI, 0<br>interval<br>1 100110<br>= 0<br>tion                                 |

#### 11.1 DC CHARACTERISTICS:

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

|             | DC Characteristics<br>Power Supply Pins       |       | 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) $-40^{\circ}C \le TA \le +125^{\circ}C$ (extended) |                    |     |       |                                                                                            |  |  |
|-------------|-----------------------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|-------|--------------------------------------------------------------------------------------------|--|--|
| Parm<br>No. | Characteristic                                | Sym   | Min                                                                                                                                                                                                                                      | Typ <sup>(1)</sup> | Max | Units | Conditions                                                                                 |  |  |
| D001        | Supply Voltage                                | Vdd   | 2.5                                                                                                                                                                                                                                      |                    | 5.5 | V     | Fosc = DC to 4 MHz (Commercial/<br>Industrial)                                             |  |  |
|             |                                               |       | 3.0                                                                                                                                                                                                                                      |                    | 5.5 | V     | 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.0V$ , 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 (5)                        |       |                                                                                                                                                                                                                                          |                    |     |       |                                                                                            |  |  |
| D020        |                                               | IPD   |                                                                                                                                                                                                                                          | 0.25               | 4   | μA    | VDD = 3.0V, Commercial WDT disabled                                                        |  |  |
| D021        |                                               |       |                                                                                                                                                                                                                                          | 0.25               | 5   | μA    | VDD = 3.0V, Industrial WDT disabled                                                        |  |  |
| D021B       |                                               |       |                                                                                                                                                                                                                                          | 2                  | 18  | μA    | VDD = 3.0V, Extended WDT disabled                                                          |  |  |
| D022        |                                               | ΔIWDT |                                                                                                                                                                                                                                          | 3.75               | 8   | μΑ    | VDD = 3.0V, Commercial                                                                     |  |  |
| 2022        |                                               |       |                                                                                                                                                                                                                                          | 3.75               | 9   | μΑ    | VDD = 3.0V, Commercial $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-4: TIMING REQUIREMENTS - PIC12C508/C509

| AC CharacteristicsStandard Operating Conditions (unless otherwise specified)<br>Operating Temperature $0^{\circ}C \le TA \le +70^{\circ}C$ (commercial)<br>$-40^{\circ}C \le TA \le +85^{\circ}C$ (industrial)<br>$-40^{\circ}C \le TA \le +125^{\circ}C$ (extended)<br>Operating Voltage VDD range is described in Section 11.1 |          |                                                                          |     |                    |      |       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------------------------|-----|--------------------|------|-------|
| Parameter<br>No.                                                                                                                                                                                                                                                                                                                 | Sym      | Characteristic                                                           | Min | Typ <sup>(1)</sup> | Max  | Units |
| 17                                                                                                                                                                                                                                                                                                                               | TosH2ioV | OSC1 <sup>↑</sup> (Q1 cycle) to Port out valid <sup>(3)</sup>            | _   | -                  | 100* | ns    |
| 18                                                                                                                                                                                                                                                                                                                               | TosH2iol | OSC1 <sup>↑</sup> (Q2 cycle) to Port input invalid<br>(I/O in hold time) | TBD | —                  | _    | ns    |
| 19                                                                                                                                                                                                                                                                                                                               | TioV2osH | Port input valid to OSC1↑<br>(I/O in setup time)                         | TBD | —                  | _    | ns    |
| 20                                                                                                                                                                                                                                                                                                                               | TioR     | Port output rise time <sup>(2, 3)</sup>                                  | _   | 10                 | 25** | ns    |
| 21                                                                                                                                                                                                                                                                                                                               | TioF     | Port output fall time <sup>(2, 3)</sup>                                  | _   | 10                 | 25** | ns    |

\* These parameters are characterized but not tested.

\*\* These parameters are design targets and are not tested. No characterization data available at this time.

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.

- 2: Measurements are taken in EXTRC mode.
- 3: See Figure 11-1 for loading conditions.

#### FIGURE 11-4: RESET, WATCHDOG TIMER, AND DEVICE RESET TIMER TIMING - PIC12C508/C509



#### TABLE 11-5: RESET, WATCHDOG TIMER, AND DEVICE RESET TIMER - PIC12C508/C509

| AC Charac        | teristics | $\begin{array}{l} \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 11.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<br>(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 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 11-6.

#### TABLE 11-6: DRT (DEVICE RESET TIMER PERIOD - PIC12C508/C509)

| Oscillator Configuration | POR Reset       | Subsequent Resets |  |  |  |
|--------------------------|-----------------|-------------------|--|--|--|
| IntRC & ExtRC            | 18 ms (typical) | 300 µs (typical)  |  |  |  |
| XT & LP                  | 18 ms (typical) | 18 ms (typical)   |  |  |  |

#### FIGURE 11-5: TIMER0 CLOCK TIMINGS - PIC12C508/C509



#### TABLE 11-7: TIMER0 CLOCK REQUIREMENTS - PIC12C508/C509

| Operating Temperat |      |                                       |                      |                              |                    |     |       |                                                                |  |
|--------------------|------|---------------------------------------|----------------------|------------------------------|--------------------|-----|-------|----------------------------------------------------------------|--|
| Parameter<br>No.   | Sym  | Characteristic                        |                      | Min                          | Тур <sup>(1)</sup> | Max | Units | Conditions                                                     |  |
| 40                 | Tt0H | T0CKI High Pulse Width - No Prescaler |                      | 0.5 TCY + 20*                | —                  |     | ns    |                                                                |  |
|                    |      |                                       | - With Prescaler     | 10*                          | —                  |     | ns    |                                                                |  |
| 41                 | Tt0L | T0CKI Low Pulse W                     | /idth - No Prescaler | 0.5 TCY + 20*                | —                  |     | ns    |                                                                |  |
|                    |      |                                       | - With Prescaler     | 10*                          | _                  |     | ns    |                                                                |  |
| 42                 | Tt0P | T0CKI Period                          |                      | 20 or <u>Tcy + 40</u> *<br>N | _                  | -   | ns    | Whichever is greater.<br>N = Prescale Value<br>(1, 2, 4,, 256) |  |

\* 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.

#### 12.0 DC AND AC CHARACTERISTICS - PIC12C508/PIC12C509

The graphs and tables provided in this section are for design guidance and are not tested. In some graphs or tables the data presented are outside specified operating range (e.g., outside specified VDD range). This is for information only and devices will operate properly only within the specified range.

The data presented in this section is a statistical summary of data collected on units from different lots over a period of time. "Typical" represents the mean of the distribution while "max" or "min" represents (mean +  $3\sigma$ ) and (mean -  $3\sigma$ ) respectively, where  $\sigma$  is standard deviation.











### TABLE 13-4: TIMING REQUIREMENTS - PIC12C508A, PIC12C509A, PIC12CE518, PIC12CE519, PIC12LC508A, PIC12LC509A, PIC12LCF509A, PIC12LCE518 and PIC12LCE519

| AC CharacteristicsStandard Operating Conditions (unless otherwise specified)<br>Operating Temperature $0^{\circ}C \le TA \le +70^{\circ}C$ (commercial)<br>$-40^{\circ}C \le TA \le +85^{\circ}C$ (industrial)<br>$-40^{\circ}C \le TA \le +125^{\circ}C$ (extended)<br>Operating Voltage VDD range is described in Section 13.1 |          |                                                                       |     |                    |      |       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------------------------|-----|--------------------|------|-------|
| Parameter<br>No.                                                                                                                                                                                                                                                                                                                 | Sym      | Characteristic                                                        | Min | Тур <sup>(1)</sup> | Max  | Units |
| 17                                                                                                                                                                                                                                                                                                                               | TosH2ioV | OSC1 <sup>↑</sup> (Q1 cycle) to Port out valid <sup>(3)</sup>         | —   | -                  | 100* | ns    |
| 18                                                                                                                                                                                                                                                                                                                               | TosH2iol | OSC1 <sup>↑</sup> (Q2 cycle) to Port input invalid (I/O in hold time) | TBD | _                  | —    | ns    |
| 19                                                                                                                                                                                                                                                                                                                               | TioV2osH | Port input valid to OSC1 <sup>↑</sup><br>(I/O in setup time)          | TBD | —                  | —    | ns    |
| 20                                                                                                                                                                                                                                                                                                                               | TioR     | Port output rise time <sup>(2, 3)</sup>                               | —   | 10                 | 25** | ns    |
| 21                                                                                                                                                                                                                                                                                                                               | TioF     | Port output fall time <sup>(2, 3)</sup>                               | —   | 10                 | 25** | ns    |

\* These parameters are characterized but not tested.

\*\* These parameters are design targets and are not tested. No characterization data available at this time.

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.

2: Measurements are taken in EXTRC mode.

3: See Figure 13-1 for loading conditions.



#### 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 Charact       | teristics |                                                  |       |                    |       |       |                        |  |
|------------------|-----------|--------------------------------------------------|-------|--------------------|-------|-------|------------------------|--|
| 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<br>(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 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.

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

# PIC12C5XX

NOTES:

#### PIC12C5XX Product Identification System



Please contact your local sales office for exact ordering procedures.

#### Sales and Support:

#### Data Sheets

Products supported by a preliminary Data Sheet may have an errata sheet describing minor operational differences and recommended workarounds. To determine if an errata sheet exists for a particular device, please contact one of the following:

- 1. Your local Microchip sales office
- 2. The Microchip Corporate Literature Center U.S. FAX: (602) 786-7277
- 3. The Microchip Worldwide Site (www.microchip.com)

Please specify which device, revision of silicon and Data Sheet (include Literature #) you are using.

#### **New Customer Notification System**

Register on our web site (www.microchip.com/cn) to receive the most current information on our products.