

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) | 3V ~ 5.5V                                                                   |
| Data Converters            | -                                                                           |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 8-SOIC (0.209", 5.30mm Width)                                               |
| Supplier Device Package    | 8-SOIJ                                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic12c508a-04e-sm |

Email: info@E-XFL.COM

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

| Name           | DIP<br>Pin # | SOIC<br>Pin # | l/O/P<br>Type | Buffer<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|--------------|---------------|---------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GP0            | 7            | 7             | I/O           | TTL/ST         | Bi-directional I/O port/ serial programming data. Can<br>be software programmed for internal weak pull-up and<br>wake-up from SLEEP on pin change. This buffer is a<br>Schmitt Trigger input when used in serial programming<br>mode.                                                                                                                                                                                                               |
| GP1            | 6            | 6             | I/O           | TTL/ST         | Bi-directional I/O port/ serial programming clock. Can<br>be software programmed for internal weak pull-up and<br>wake-up from SLEEP on pin change. This buffer is a<br>Schmitt Trigger input when used in serial programming<br>mode.                                                                                                                                                                                                              |
| GP2/T0CKI      | 5            | 5             | I/O           | ST             | Bi-directional I/O port. Can be configured as T0CKI.                                                                                                                                                                                                                                                                                                                                                                                                |
| GP3/MCLR/Vpp   | 4            | 4             | Ι             | TTL/ST         | Input port/master clear (reset) input/programming volt-<br>age input. When configured as MCLR, this pin is an<br>active low reset to the device. Voltage on MCLR/VPP<br>must not exceed VDD during normal device operation<br>or the device will enter programming mode. Can be<br>software programmed for internal weak pull-up and<br>wake-up from SLEEP on pin change. Weak pull-up<br>always on if configured as MCLR. ST when in MCLR<br>mode. |
| GP4/OSC2       | 3            | 3             | I/O           | TTL            | Bi-directional I/O port/oscillator crystal output. Con-<br>nections to crystal or resonator in crystal oscillator<br>mode (XT and LP modes only, GPIO in other modes).                                                                                                                                                                                                                                                                              |
| GP5/OSC1/CLKIN | 2            | 2             | I/O           | TTL/ST         | Bidirectional IO port/oscillator crystal input/external<br>clock source input (GPIO in Internal RC mode only,<br>OSC1 in all other oscillator modes). TTL input when<br>GPIO, ST input in external RC oscillator mode.                                                                                                                                                                                                                              |
| Vdd            | 1            | 1             | Р             | _              | Positive supply for logic and I/O pins                                                                                                                                                                                                                                                                                                                                                                                                              |
| Vss            | 8            | 8             | Р             | _              | Ground reference for logic and I/O pins                                                                                                                                                                                                                                                                                                                                                                                                             |

Legend: I = input, O = output, I/O = input/output, P = power, — = not used, TTL = TTL input, ST = Schmitt Trigger input

#### 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 co<br>prescaler, v |              |             |           | Timer0/WD1<br>pull-ups | Г            |         |       | 1111 1111            | 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                | a memory     | address p   | pointer   | L                      | L            | 1       | 1     | 111x xxxx            | 111u uuuu                |
| 04h                | FSR<br>(PIC12C509/<br>PIC12C509A/<br>PIC12CR509A/<br>PIC12CE519)                    | Indirect dat                | a memory     | address p   | oointer   |                        |              |         |       | 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>PIC12CC509A)     | _                           | _            | 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.

## 4.6 Program Counter

As a program instruction is executed, the Program Counter (PC) will contain the address of the next program instruction to be executed. The PC value is increased by one every instruction cycle, unless an instruction changes the PC.

For a GOTO instruction, bits 8:0 of the PC are provided by the GOTO instruction word. The PC Latch (PCL) is mapped to PC<7:0>. Bit 5 of the STATUS register provides page information to bit 9 of the PC (Figure 4-8).

For a CALL instruction, or any instruction where the PCL is the destination, bits 7:0 of the PC again are provided by the instruction word. However, PC<8> does not come from the instruction word, but is always cleared (Figure 4-8).

Instructions where the PCL is the destination, or Modify PCL instructions, include <code>MOVWF PC</code>, <code>ADDWF PC</code>, and <code>BSF PC</code>, <code>5</code>.



# FIGURE 4-8: LOADING OF PC BRANCH INSTRUCTIONS -PIC12C5XX



#### 4.6.1 EFFECTS OF RESET

The Program Counter is set upon a RESET, which means that the PC addresses the last location in the last page i.e., the oscillator calibration instruction. After executing MOVLW XX, the PC will roll over to location 00h, and begin executing user code.

The STATUS register page preselect bits are cleared upon a RESET, which means that page 0 is pre-selected.

Therefore, upon a RESET, a GOTO instruction will automatically cause the program to jump to page 0 until the value of the page bits is altered.

# 4.7 Stack

PIC12C5XX devices have a 12-bit wide L.I.F.O. hardware push/pop stack.

A CALL instruction will *push* the current value of stack 1 into stack 2 and then push the current program counter value, incremented by one, into stack level 1. If more than two sequential CALL's are executed, only the most recent two return addresses are stored.

A RETLW instruction will *pop* the contents of stack level 1 into the program counter and then copy stack level 2 contents into level 1. If more than two sequential RETLW's are executed, the stack will be filled with the address previously stored in level 2. Note that the W register will be loaded with the literal value specified in the instruction. This is particularly useful for the implementation of data look-up tables within the program memory.

Upon any reset, the contents of the stack remain unchanged, however the program counter (PCL) will also be reset to 0.

- Note 1: There are no STATUS bits to indicate stack overflows or stack underflow conditions.
- Note 2: There are no instructions mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL and RETLW instructions.



# FIGURE 6-2: TIMER0 TIMING: INTERNAL CLOCK/NO PRESCALE

# FIGURE 6-3: TIMER0 TIMING: INTERNAL CLOCK/PRESCALE 1:2



# TABLE 6-1: REGISTERS ASSOCIATED WITH TIMER0

| 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 |
|---------|--------|----------|------------|-----------|----------|-------|-------|-------|-------|-------------------------------|---------------------------------|
| 01h     | TMR0   | Timer0 - | 8-bit real | -time clo | ck/count | er    |       |       |       | xxxx xxxx                     | uuuu uuuu                       |
| N/A     | OPTION | GPWU     | GPPU       | T0CS      | T0SE     | PSA   | PS2   | PS1   | PS0   | 1111 1111                     | 1111 1111                       |
| N/A     | TRIS   | —        |            | GP5       | GP4      | GP3   | GP2   | GP1   | GP0   | 11 1111                       | 11 1111                         |

Legend: Shaded cells not used by Timer0, - = unimplemented, x = unknown, u = unchanged,

# FIGURE 7-3: DATA TRANSFER SEQUENCE ON THE SERIAL BUS





# 7.2 Device Addressing

After generating a START condition, the bus master transmits a control byte consisting of a slave address and a Read/Write bit that indicates what type of operation is to be performed. The slave address consists of a 4-bit device code (1010) followed by three don't care bits.

The last bit of the control byte determines the operation to be performed. When set to a one a read operation is selected, and when set to a zero a write operation is selected. (Figure 7-5). The bus is monitored for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.

#### FIGURE 7-5: CONTROL BYTE FORMAT



# 7.5 READ OPERATIONS

Read operations are initiated in the same way as write operations with the exception that the  $R/\overline{W}$  bit of the slave address is set to one. There are three basic types of read operations: current address read, random read, and sequential read.

#### 7.5.1 CURRENT ADDRESS READ

It contains an address counter that maintains the address of the last word accessed, internally incremented by one. Therefore, if the previous read access was to address n, the next current address read operation would access data from address n + 1. Upon receipt of the slave address with the R/W bit set to one, the device issues an acknowledge and transmits the eight bit data word. The master will not acknowledge the transfer but does generate a stop condition and the device discontinues transmission (Figure 7-8).

#### 7.5.2 RANDOM READ

Random read operations allow the master to access any memory location in a random manner. To perform this type of read operation, first the word address must be set. This is done by sending the word address to the device as part of a write operation. After the word address is sent, the master generates a start condition following the acknowledge. This terminates the write operation, but not before the internal address pointer is set. Then the master issues the control byte again but with the  $R/\overline{W}$  bit set to a one. It will then issue an acknowledge and transmits the eight bit data word. The master will not acknowledge the transfer but does generate a stop condition and the device discontinues transmission (Figure 7-9). After this command, the internal address counter will point to the address location following the one that was just read.

#### 7.5.3 SEQUENTIAL READ

Sequential reads are initiated in the same way as a random read except that after the device transmits the first data byte, the master issues an acknowledge as opposed to a stop condition in a random read. This directs the device to transmit the next sequentially addressed 8-bit word (Figure 7-10).

To provide sequential reads, it contains an internal address pointer which is incremented by one at the completion of each read operation. This address pointer allows the entire memory contents to be serially read during one operation.



#### FIGURE 7-9: RANDOM READ



# FIGURE 7-10: SEQUENTIAL READ



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

TABLE 8-3: RESET CONDITIONS FOR REGISTERS

| Register                                                                    | Address | Power-on Reset | MCLR Reset<br>WDT time-out<br>Wake-up on Pin Change |
|-----------------------------------------------------------------------------|---------|----------------|-----------------------------------------------------|
| W (PIC12C508/509)                                                           | _       | qqqq xxxx (1)  | qqqq uuuu (1)                                       |
| W (PIC12C508A/509A/<br>PIC12CE518/519/<br>PIC12CE509A)                      | _       | qqqq qqxx (1)  | qqqq qquu (1)                                       |
| INDF                                                                        | 00h     | xxxx xxxx      | uuuu uuuu                                           |
| TMR0                                                                        | 01h     | xxxx xxxx      | uuuu uuuu                                           |
| PC                                                                          | 02h     | 1111 1111      | 1111 1111                                           |
| STATUS                                                                      | 03h     | 0001 1xxx      | q00q quuu (2,3)                                     |
| FSR (PIC12C508/<br>PIC12C508A/<br>PIC12CE518)                               | 04h     | 111x xxxx      | 111u uuuu                                           |
| FSR (PIC12C509/<br>PIC12C509A/<br>PIC12CE519/<br>PIC12CR509A)               | 04h     | 110x xxxx      | 11uu uuuu                                           |
| OSCCAL<br>(PIC12C508/509)                                                   | 05h     | 0111           | uuuu                                                |
| OSCCAL<br>(PIC12C508A/509A/<br>PIC12CE518/512/<br>PIC12CR509A)              | 05h     | 1000 00        | uuuu uu                                             |
| GPIO<br>(PIC12C508/PIC12C509/<br>PIC12C508A/<br>PIC12C509A/<br>PIC12CR509A) | 06h     | xx xxxx        | uu uuuu                                             |
| GPIO<br>(PIC12CE518/                                                        | 06h     | 11             | 11                                                  |
| PIC12CE519)<br>OPTION                                                       |         | 11xx xxxx      | 11uu uuuu                                           |
| TRIS                                                                        | —       | 1111 1111      | 1111 1111                                           |
| IKIS                                                                        |         | 11 1111        | 11 1111                                             |

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

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

Note 2: See Table 8-7 for reset value for specific conditions

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

# TABLE 8-4: RESET CONDITION FOR SPECIAL REGISTERS

|                                    | STATUS Addr: 03h | PCL Addr: 02h |
|------------------------------------|------------------|---------------|
| Power on reset                     | 0001 1xxx        | 1111 1111     |
| MCLR reset during normal operation | 000u uuuu        | 1111 1111     |
| MCLR reset during SLEEP            | 0001 0uuu        | 1111 1111     |
| WDT reset during SLEEP             | 0000 Ouuu        | 1111 1111     |
| WDT reset normal operation         | 0000 uuuu        | 1111 1111     |
| Wake-up from SLEEP on pin change   | 1001 Ouuu        | 1111 1111     |

Legend: u = unchanged, x = unknown, - = unimplemented bit, read as '0'.

#### 8.3.1 MCLR ENABLE

This configuration bit when unprogrammed (left in the '1' state) enables the external  $\overline{MCLR}$  function. When programmed, the  $\overline{MCLR}$  function is tied to the internal VDD, and the pin is assigned to be a GPIO. See Figure 8-7. When pin GP3/ $\overline{MCLR}$ /VPP is configured as  $\overline{MCLR}$ , the internal pull-up is always on.

# FIGURE 8-7: MCLR SELECT



## 8.4 Power-On Reset (POR)

The PIC12C5XX family incorporates on-chip Power-On Reset (POR) circuitry which provides an internal chip reset for most power-up situations.

The on-chip POR circuit holds the chip in reset until VDD has reached a high enough level for proper operation. To take advantage of the internal POR, program the GP3/MCLR/VPP pin as MCLR and tie through a resistor to VDD or program the pin as GP3. An internal weak pull-up resistor is implemented using a transistor. Refer to Table 11-1 for the pull-up resistor ranges. This will eliminate external RC components usually needed to create a Power-on Reset. A maximum rise time for VDD is specified. See Electrical Specifications for details.

When the device starts normal operation (exits the reset condition), device operating parameters (voltage, frequency, temperature, ...) must be met to ensure operation. If these conditions are not met, the device must be held in reset until the operating parameters are met.

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

The Power-On Reset circuit and the Device Reset Timer (Section 8.5) circuit are closely related. On power-up, the reset latch is set and the DRT is reset. The DRT timer begins counting once it detects MCLR to be high. After the time-out period, which is typically 18 ms, it will reset the reset latch and thus end the onchip reset signal.

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

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

| Note: | When the device starts normal operation (exits the reset condition), device operating |
|-------|---------------------------------------------------------------------------------------|
|       | parameters (voltage, frequency, tempera-                                              |
|       | ture, etc.) must be meet to ensure opera-                                             |
|       | tion. If these conditions are not met, the                                            |
|       | device must be held in reset until the oper-                                          |
|       | ating conditions are met.                                                             |

For additional information refer to Application Notes "Power-Up Considerations" - AN522 and "Power-up Trouble Shooting" - AN607.

# FIGURE 8-11: TIME-OUT SEQUENCE ON POWER-UP (MCLR TIED TO VDD): SLOW VDD RISE TIME



#### 8.5 Device Reset Timer (DRT)

In the PIC12C5XX, DRT runs from RESET and varies based on oscillator selection (see Table 8-5.)

The DRT operates on an internal RC oscillator. The processor is kept in RESET as long as the DRT is active. The DRT delay allows VDD to rise above VDD min., and for the oscillator to stabilize.

Oscillator circuits based on crystals or ceramic resonators require a certain time after power-up to establish a stable oscillation. The on-chip DRT keeps the device in a RESET condition for approximately 18 ms after MCLR has reached a logic high (VIHMCLR) level. Thus, programming GP3/MCLR/VPP as MCLR and using an external RC network connected to the MCLR input is not required in most cases, allowing for savings in cost-sensitive and/or space restricted applications, as well as allowing the use of the GP3/MCLR/VPP pin as a general purpose input.

The Device Reset time delay will vary from chip to chip due to VDD, temperature, and process variation. See AC parameters for details.

The DRT will also be triggered upon a Watchdog Timer time-out. This is particularly important for applications using the WDT to wake from SLEEP mode automatically.

## 8.6 Watchdog Timer (WDT)

The Watchdog Timer (WDT) is a free running on-chip RC oscillator which does not require any external components. This RC oscillator is separate from the external RC oscillator of the GP5/OSC1/CLKIN pin and the internal 4 MHz oscillator. That means that the WDT will run even if the main processor clock has been stopped, for example, by execution of a SLEEP instruction. During normal operation or SLEEP, a WDT reset or wake-up reset generates a device RESET.

The  $\overline{TO}$  bit (STATUS<4>) will be cleared upon a Watchdog Timer reset.

The WDT can be permanently disabled by programming the configuration bit WDTE as a '0' (Section 8.1). Refer to the PIC12C5XX Programming Specifications to determine how to access the configuration word.

TABLE 8-5: DRT (DEVICE RESET TIMER PERIOD)

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

#### 8.7 <u>Time-Out Sequence, Power Down,</u> and Wake-up from SLEEP Status Bits (TO/PD/GPWUF)

The  $\overline{\text{TO}}$ ,  $\overline{\text{PD}}$ , and GPWUF bits in the STATUS register can be tested to determine if a RESET condition has been caused by a power-up condition, a  $\overline{\text{MCLR}}$  or Watchdog Timer (WDT) reset.

| TABLE 8-7: | TO/PD/GPWUF STATUS |
|------------|--------------------|
|            | AFTER RESET        |

| GPWUF | то | PD | RESET caused by                     |
|-------|----|----|-------------------------------------|
| 0     | 0  | 0  | WDT wake-up from<br>SLEEP           |
| 0     | 0  | u  | WDT time-out (not from<br>SLEEP)    |
| 0     | 1  | 0  | MCLR wake-up from<br>SLEEP          |
| 0     | 1  | 1  | Power-up                            |
| 0     | u  | u  | MCLR not during SLEEP               |
| 1     | 1  | 0  | Wake-up from SLEEP on<br>pin change |

Legend: u = unchanged

Note 1: The TO, PD, and GPWUF bits maintain their status (u) until a reset occurs. A lowpulse on the MCLR input does not change the TO, PD, and GPWUF status bits.

# 8.8 Reset on Brown-Out

A brown-out is a condition where device power (VDD) dips below its minimum value, but not to zero, and then recovers. The device should be reset in the event of a brown-out.

To reset PIC12C5XX devices when a brown-out occurs, external brown-out protection circuits may be built, as shown in Figure 8-13 , Figure 8-14 and Figure 8-15

#### FIGURE 8-13: BROWN-OUT PROTECTION CIRCUIT 1



# FIGURE 8-14: BROWN-OUT PROTECTION CIRCUIT 2



This brown-out circuit is less expensive, although less accurate. Transistor Q1 turns off when VDD is below a certain level such that:

$$V_{DD} \bullet \frac{R1}{R1 + R2} = 0.7V$$

\*Refer to Figure 8-7 and Table 11-1 for internal weak pull-up on MCLR.

# FIGURE 8-15: BROWN-OUT PROTECTION CIRCUIT 3



This brown-out protection circuit employs Microchip Technology's MCP809 microcontroller supervisor. The MCP8XX and MCP1XX family of supervisors provide push-pull and open collector outputs with both high and low active reset pins. There are 7 different trip point selections to accomodate 5V and 3V systems.

| TABLE 9-2: | INSTRUCTION SET SUMMARY |
|------------|-------------------------|
|------------|-------------------------|

| Mnemonic, |         |                              |        | 12-Bit Opcode |      |      | Status    |       |
|-----------|---------|------------------------------|--------|---------------|------|------|-----------|-------|
| Operan    |         | Description                  | Cycles | MSb           |      | LSb  | Affected  | Notes |
| ADDWF     | f,d     | Add W and f                  | 1      | 0001          | 11df | ffff | C,DC,Z    | 1,2,4 |
| ANDWF     | f,d     | AND W with f                 | 1      | 0001          | 01df | ffff | Z         | 2,4   |
| CLRF      | f       | Clear f                      | 1      | 0000          | 011f | ffff | Z         | 4     |
| CLRW      | -       | Clear W                      | 1      | 0000          | 0100 | 0000 | Z         |       |
| COMF      | f, d    | Complement f                 | 1      | 0010          | 01df | ffff | Z         |       |
| DECF      | f, d    | Decrement f                  | 1      | 0000          | 11df | ffff | Z         | 2,4   |
| DECFSZ    | f, d    | Decrement f, Skip if 0       | 1(2)   | 0010          | 11df | ffff | None      | 2,4   |
| INCF      | f, d    | Increment f                  | 1      | 0010          | 10df | ffff | Z         | 2,4   |
| INCFSZ    | f, d    | Increment f, Skip if 0       | 1(2)   | 0011          | 11df | ffff | None      | 2,4   |
| IORWF     | f, d    | Inclusive OR W with f        | 1      | 0001          | 00df | ffff | Z         | 2,4   |
| MOVF      | f, d    | Move f                       | 1      | 0010          | 00df | ffff | Z         | 2,4   |
| MOVWF     | f       | Move W to f                  | 1      | 0000          | 001f | ffff | None      | 1,4   |
| NOP       | -       | No Operation                 | 1      | 0000          | 0000 | 0000 | None      |       |
| RLF       | f, d    | Rotate left f through Carry  | 1      | 0011          | 01df | ffff | С         | 2,4   |
| RRF       | f, d    | Rotate right f through Carry | 1      | 0011          | 00df | ffff | С         | 2,4   |
| SUBWF     | f, d    | Subtract W from f            | 1      | 0000          | 10df | ffff | C,DC,Z    | 1,2,4 |
| SWAPF     | f, d    | Swap f                       | 1      | 0011          | 10df | ffff | None      | 2,4   |
| XORWF     | f, d    | Exclusive OR W with f        | 1      | 0001          | 10df | ffff | Z         | 2,4   |
| BIT-ORIEN | TED FIL | E REGISTER OPERATIONS        |        |               |      |      |           |       |
| BCF       | f, b    | Bit Clear f                  | 1      | 0100          | bbbf | ffff | None      | 2,4   |
| BSF       | f, b    | Bit Set f                    | 1      | 0101          | bbbf | ffff | None      | 2,4   |
| BTFSC     | f, b    | Bit Test f, Skip if Clear    | 1 (2)  | 0110          | bbbf | ffff | None      |       |
| BTFSS     | f, b    | Bit Test f, Skip if Set      | 1 (2)  | 0111          | bbbf | ffff | None      |       |
| LITERAL A | ND CON  | NTROL OPERATIONS             |        |               |      |      |           |       |
| ANDLW     | k       | AND literal with W           | 1      | 1110          | kkkk | kkkk | Z         |       |
| CALL      | k       | Call subroutine              | 2      | 1001          | kkkk | kkkk | None      | 1     |
| CLRWDT    | k       | Clear Watchdog Timer         | 1      | 0000          | 0000 | 0100 | TO, PD    |       |
| GOTO      | k       | Unconditional branch         | 2      | 101k          | kkkk | kkkk | None      |       |
| IORLW     | k       | Inclusive OR Literal with W  | 1      | 1101          | kkkk | kkkk | Z         |       |
| MOVLW     | k       | Move Literal to W            | 1      | 1100          | kkkk | kkkk | None      |       |
| OPTION    | -       | Load OPTION register         | 1      | 0000          | 0000 | 0010 | 0010 None |       |
| RETLW     | k       | Return, place Literal in W   | 2      | 1000          | kkkk | kkkk | None      |       |
| SLEEP     | -       | Go into standby mode         | 1      | 0000          | 0000 | 0011 | TO, PD    |       |
| TRIS      | f       | Load TRIS register           | 1      | 0000          | 0000 | Offf | None      | 3     |
| XORLW     | k       | Exclusive OR Literal to W    | 1      | 1111          | kkkk | kkkk | Z         |       |

Note 1: The 9th bit of the program counter will be forced to a '0' by any instruction that writes to the PC except for GOTO. (Section 4.6)

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

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

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

# PIC12C5XX

| ADDWF                                                           | Add W and f                                                                                                                                                       |  |  |  |  |  |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:                                                         | [label] ADDWF f,d                                                                                                                                                 |  |  |  |  |  |
| Operands:                                                       | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$                                                                                                  |  |  |  |  |  |
| Operation:                                                      | $(W) + (f) \to (dest)$                                                                                                                                            |  |  |  |  |  |
| Status Affected:                                                | C, DC, Z                                                                                                                                                          |  |  |  |  |  |
| Encoding:                                                       | 0001 11df ffff                                                                                                                                                    |  |  |  |  |  |
| Description:                                                    | Add the contents of the W register and register 'f'. If 'd' is 0 the result is stored in the W register. If 'd' is '1' the result is stored back in register 'f'. |  |  |  |  |  |
| Words:                                                          | 1                                                                                                                                                                 |  |  |  |  |  |
| Cycles:                                                         | 1                                                                                                                                                                 |  |  |  |  |  |
| Example:                                                        | ADDWF FSR, 0                                                                                                                                                      |  |  |  |  |  |
| Before Instru<br>W =<br>FSR =<br>After Instruct<br>W =<br>FSR = | 0x17<br>0xC2<br>ion<br>0xD9                                                                                                                                       |  |  |  |  |  |

| ANDWF                          | AND W                                                            | with f                     |                                |                    |
|--------------------------------|------------------------------------------------------------------|----------------------------|--------------------------------|--------------------|
| Syntax:                        | [label] A                                                        | NDWF                       | f,d                            |                    |
| Operands:                      | $\begin{array}{l} 0 \leq f \leq 31 \\ d \in \ [0,1] \end{array}$ |                            |                                |                    |
| Operation:                     | (W) .AND                                                         | 0. (f) $\rightarrow$ (d    | est)                           |                    |
| Status Affected:               | Z                                                                |                            |                                |                    |
| Encoding:                      | 0001                                                             | 01df                       | ffff                           |                    |
| Description:                   | The conter<br>AND'ed wit<br>result is sto<br>'1' the resu        | th register<br>pred in the | 'f'. If 'd' is 0<br>W register | the<br>. If 'd' is |
| Words:                         | 1                                                                |                            |                                |                    |
| Cycles:                        | 1                                                                |                            |                                |                    |
| Example:                       | ANDWF 1                                                          | FSR,                       | 1                              |                    |
| Before Instru<br>W =<br>FSR =  | 0x17                                                             |                            |                                |                    |
| After Instruct<br>W =<br>FSR = | 0x17                                                             |                            |                                |                    |

| ANDLW                 | And liter       | ral with V               | v                                           |          |  |  |  |
|-----------------------|-----------------|--------------------------|---------------------------------------------|----------|--|--|--|
| Syntax:               | [label]         | [ <i>label</i> ] ANDLW k |                                             |          |  |  |  |
| Operands:             | $0 \le k \le 2$ | 55                       |                                             |          |  |  |  |
| Operation:            | (W).AND         | . (k) $\rightarrow$ (V   | V)                                          |          |  |  |  |
| Status Affected:      | Z               |                          |                                             |          |  |  |  |
| Encoding:             | 1110            | kkkk                     | kkkk                                        |          |  |  |  |
| Description:          | AND'ed w        | ith the eigl             | W register<br>ht-bit literal<br>e W registe | 'k'. The |  |  |  |
| Words:                | 1               |                          |                                             |          |  |  |  |
| Cycles:               | 1               |                          |                                             |          |  |  |  |
| Example:              | ANDLW           | 0x5F                     |                                             |          |  |  |  |
| Before Instru<br>W =  | oxA3            |                          |                                             |          |  |  |  |
| After Instruct<br>W = | tion<br>0x03    |                          |                                             |          |  |  |  |

| BCF                     | Bit Clear                                                          | Bit Clear f   |          |  |  |  |
|-------------------------|--------------------------------------------------------------------|---------------|----------|--|--|--|
| Syntax:                 | [label] BCF f,b                                                    |               |          |  |  |  |
| Operands:               | $\begin{array}{l} 0 \leq f \leq 31 \\ 0 \leq b \leq 7 \end{array}$ |               |          |  |  |  |
| Operation:              | $0 \rightarrow (f < b;$                                            | >)            |          |  |  |  |
| Status Affected:        | None                                                               |               |          |  |  |  |
| Encoding:               | 0100                                                               | bbbf          | ffff     |  |  |  |
| Description:            | Bit 'b' in re                                                      | gister 'f' is | cleared. |  |  |  |
| Words:                  | 1                                                                  |               |          |  |  |  |
| Cycles:                 | 1                                                                  |               |          |  |  |  |
| Example:                | BCF                                                                | FLAG_REC      | 3, 7     |  |  |  |
| Before Instru<br>FLAG_R | iction<br>EG = 0xC7                                                | 7             |          |  |  |  |
| After Instruc<br>FLAG_R | tion<br>EG = 0x47                                                  |               |          |  |  |  |
|                         |                                                                    |               |          |  |  |  |

#### 10.10 <u>MPLAB Integrated Development</u> <u>Environment Software</u>

The MPLAB IDE Software brings an ease of software development previously unseen in the 8-bit microcontroller market. MPLAB is a windows based application which contains:

- A full featured editor
- Three operating modes
  - editor
  - emulator
  - simulator
- A project manager
- Customizable tool bar and key mapping
- A status bar with project information
- · Extensive on-line help

MPLAB allows you to:

- Edit your source files (either assembly or 'C')
- One touch assemble (or compile) and download to PICmicro<sup>®</sup> tools (automatically updates all project information)
- Debug using:
- source files
- absolute listing file

The ability to use MPLAB with Microchip's simulator allows a consistent platform and the ability to easily switch from the low cost simulator to the full featured emulator with minimal retraining due to development tools.

# 10.11 Assembler (MPASM)

The MPASM Universal Macro Assembler is a PChosted symbolic assembler. It supports all microcontroller series including the PIC12C5XX, PIC14000, PIC16C5X, PIC16CXXX, and PIC17CXX families.

MPASM offers full featured Macro capabilities, conditional assembly, and several source and listing formats. It generates various object code formats to support Microchip's development tools as well as third party programmers.

MPASM allows full symbolic debugging from MPLAB-ICE, Microchip's Universal Emulator System.

MPASM has the following features to assist in developing software for specific use applications.

- Provides translation of Assembler source code to object code for all Microchip microcontrollers.
- Macro assembly capability.
- Produces all the files (Object, Listing, Symbol, and special) required for symbolic debug with Microchip's emulator systems.
- Supports Hex (default), Decimal and Octal source and listing formats.

MPASM provides a rich directive language to support programming of the PICmicro<sup>®</sup>. Directives are helpful in making the development of your assemble source code shorter and more maintainable.

# 10.12 Software Simulator (MPLAB-SIM)

The MPLAB-SIM Software Simulator allows code development in a PC host environment. It allows the user to simulate the PICmicro<sup>®</sup> series microcontrollers on an instruction level. On any given instruction, the user may examine or modify any of the data areas or provide external stimulus to any of the pins. The input/ output radix can be set by the user and the execution can be performed in; single step, execute until break, or in a trace mode.

MPLAB-SIM fully supports symbolic debugging using MPLAB-C17 and MPASM. The Software Simulator offers the low cost flexibility to develop and debug code outside of the laboratory environment making it an excellent multi-project software development tool.

## 10.13 MPLAB-C17 Compiler

The MPLAB-C17 Code Development System is a complete ANSI 'C' compiler and integrated development environment for Microchip's PIC17CXXX family of microcontrollers. The compiler provides powerful integration capabilities and ease of use not found with other compilers.

For easier source level debugging, the compiler provides symbol information that is compatible with the MPLAB IDE memory display.

#### 10.14 <u>Fuzzy Logic Development System</u> (fuzzyTECH-MP)

*fuzzy*TECH-MP fuzzy logic development tool is available in two versions - a low cost introductory version, MP Explorer, for designers to gain a comprehensive working knowledge of fuzzy logic system design; and a full-featured version, *fuzzy*TECH-MP, Edition for implementing more complex systems.

Both versions include Microchip's *fuzzy*LAB<sup>™</sup> demonstration board for hands-on experience with fuzzy logic systems implementation.

# 10.15 <u>SEEVAL® Evaluation and</u> <u>Programming System</u>

The SEEVAL SEEPROM Designer's Kit supports all Microchip 2-wire and 3-wire Serial EEPROMs. The kit includes everything necessary to read, write, erase or program special features of any Microchip SEEPROM product including Smart Serials<sup>™</sup> and secure serials. The Total Endurance<sup>™</sup> Disk is included to aid in trade-off analysis and reliability calculations. The total kit can significantly reduce time-to-market and result in an optimized system.

# 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-8: EEPROM MEMORY BUS TIMING REQUIREMENTS - PIC12CE5XX ONLY.

| AC Characteristics                                                                   | $ \begin{array}{l} \mbox{Standard Operating Conditions (unless otherwise specified)} \\ \mbox{Operating Temperature} & 0^{\circ}C \leq TA \leq +70^{\circ}C, \ Vcc = 3.0V \ to \ 5.5V \ (commercial) \\ & -40^{\circ}C \leq TA \leq +85^{\circ}C, \ Vcc = 3.0V \ to \ 5.5V \ (industrial) \\ & -40^{\circ}C \leq TA \leq +125^{\circ}C, \ Vcc = 4.5V \ to \ 5.5V \ (extended) \\ \mbox{Operating Voltage VDD range is described in Section 13.1} \end{array} $ |                      |                     |        |                                                                                                                                     |  |  |
|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|---------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Parameter                                                                            | Symbol                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Min                  | Max                 | Units  | Conditions                                                                                                                          |  |  |
| Clock frequency                                                                      | FCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <br>                 | 100<br>100<br>400   | kHz    | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V                                                          |  |  |
| Clock high time                                                                      | Тнідн                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 4000<br>4000<br>600  |                     | ns     | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V                                                          |  |  |
| Clock low time                                                                       | TLOW                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 4700<br>4700<br>1300 |                     | ns     | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V                                                          |  |  |
| SDA and SCL rise time<br>(Note 1)                                                    | TR                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      | 1000<br>1000<br>300 | ns     | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V                                                          |  |  |
| SDA and SCL fall time                                                                | TF                                                                                                                                                                                                                                                                                                                                                                                                                                                             | —                    | 300                 | ns     | (Note 1)                                                                                                                            |  |  |
| START condition hold time                                                            | THD:STA                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 4000<br>4000<br>600  |                     | ns     | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V                                                          |  |  |
| START condition setup time                                                           | TSU:STA                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 4700<br>4700<br>600  |                     | ns     | $\begin{array}{l} 4.5V \leq Vcc \leq 5.5V \mbox{ (E Temp range)} \\ 3.0V \leq Vcc \leq 4.5V \\ 4.5V \leq Vcc \leq 5.5V \end{array}$ |  |  |
| Data input hold time                                                                 | THD:DAT                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0                    |                     | ns     | (Note 2)                                                                                                                            |  |  |
| Data input setup time                                                                | TSU:DAT                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 250<br>250<br>100    |                     | ns     | $\begin{array}{l} 4.5V \leq Vcc \leq 5.5V \mbox{ (E Temp range)} \\ 3.0V \leq Vcc \leq 4.5V \\ 4.5V \leq Vcc \leq 5.5V \end{array}$ |  |  |
| STOP condition setup time                                                            | Tsu:sto                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 4000<br>4000<br>600  |                     | ns     | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V                                                          |  |  |
| Output valid from clock<br>(Note 2)                                                  | ΤΑΑ                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                      | 3500<br>3500<br>900 | ns     | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V                                                          |  |  |
| Bus free time: Time the bus must<br>be free before a new transmis-<br>sion can start | TBUF                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 4700<br>4700<br>1300 |                     | ns     | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V                                                          |  |  |
| Output fall time from VIH<br>minimum to VIL maximum                                  | Tof                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 20+0.1<br>CB         | 250                 | ns     | (Note 1), CB ≤ 100 pF                                                                                                               |  |  |
| Input filter spike suppression (SDA and SCL pins)                                    | TSP                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                      | 50                  | ns     | (Notes 1, 3)                                                                                                                        |  |  |
| Write cycle time                                                                     | Twc                                                                                                                                                                                                                                                                                                                                                                                                                                                            | —                    | 4                   | ms     |                                                                                                                                     |  |  |
| Endurance                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1M                   | _                   | cycles | 25°C, Vcc = 5.0V, Block Mode (Note 4)                                                                                               |  |  |

Note 1: Not 100% tested. CB = total capacitance of one bus line in pF.

2: As a transmitter, the device must provide an internal minimum delay time to bridge the undefined region (minimum 300 ns) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.

**3:** The combined TSP and VHYS specifications are due to new Schmitt trigger inputs which provide improved noise spike suppression. This eliminates the need for a TI specification for standard operation.

4: This parameter is not tested but guaranteed by characterization. For endurance estimates in a specific application, please consult the Total Endurance Model which can be obtained on Microchip's website.

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

Е w D 2 n 1 U t А A1 ı. A2 с B1р eВ В

| Package Type: | K04-084 8-Lead Ceramic Side Brazed Dual In-line with Window (JW) – 300 mil |
|---------------|----------------------------------------------------------------------------|
|---------------|----------------------------------------------------------------------------|

| Units                        |    |       | INCHES* |       |       | MILLIMETERS |       |  |  |
|------------------------------|----|-------|---------|-------|-------|-------------|-------|--|--|
| Dimension Limits             |    | MIN   | NOM     | MAX   | MIN   | NOM         | MAX   |  |  |
| PCB Row Spacing              |    |       | 0.300   |       |       | 7.62        |       |  |  |
| Number of Pins               | n  |       | 8       |       |       | 8           |       |  |  |
| Pitch                        | р  | 0.098 | 0.100   | 0.102 | 2.49  | 2.54        | 2.59  |  |  |
| Lower Lead Width             | В  | 0.016 | 0.018   | 0.020 | 0.41  | 0.46        | 0.51  |  |  |
| Upper Lead Width             | B1 | 0.050 | 0.055   | 0.060 | 1.27  | 1.40        | 1.52  |  |  |
| Lead Thickness               | С  | 0.008 | 0.010   | 0.012 | 0.20  | 0.25        | 0.30  |  |  |
| Top to Seating Plane         | А  | 0.145 | 0.165   | 0.185 | 3.68  | 4.19        | 4.70  |  |  |
| Top of Body to Seating Plane | A1 | 0.103 | 0.123   | 0.143 | 2.62  | 3.12        | 3.63  |  |  |
| Base to Seating Plane        | A2 | 0.025 | 0.035   | 0.045 | 0.64  | 0.89        | 1.14  |  |  |
| Tip to Seating Plane         | L  | 0.130 | 0.140   | 0.150 | 3.30  | 3.56        | 3.81  |  |  |
| Package Length               | D  | 0.510 | 0.520   | 0.530 | 12.95 | 13.21       | 13.46 |  |  |
| Package Width                | E  | 0.280 | 0.290   | 0.300 | 7.11  | 7.37        | 7.62  |  |  |
| Overall Row Spacing          | eB | 0.310 | 0.338   | 0.365 | 7.87  | 8.57        | 9.27  |  |  |
| Window Diameter              | W  | 0.161 | 0.166   | 0.171 | 4.09  | 4.22        | 4.34  |  |  |
| Lid Length                   | Т  | 0.440 | 0.450   | 0.460 | 11.18 | 11.43       | 11.68 |  |  |
| Lid Width                    | U  | 0.260 | 0.270   | 0.280 | 6.60  | 6.86        | 7.11  |  |  |

\* Controlling Parameter.

# **READER RESPONSE**

It is our intention to provide you with the best documentation possible to ensure successful use of your Microchip product. If you wish to provide your comments on organization, clarity, subject matter, and ways in which our documentation can better serve you, please FAX your comments to the Technical Publications Manager at (602) 786-7578.

Please list the following information, and use this outline to provide us with your comments about this Data Sheet.

| To:  | Technical Publications Manager Total Pages Sent                                            |
|------|--------------------------------------------------------------------------------------------|
| RE:  | Reader Response                                                                            |
| Fron | n: Name                                                                                    |
|      | Company                                                                                    |
|      | Address                                                                                    |
|      | City / State / ZIP / Country                                                               |
|      | Telephone: () FAX: ()                                                                      |
|      | lication (optional):                                                                       |
| Wou  | Id you like a reply?YN                                                                     |
| Devi | ce: PIC12C5XX Literature Number: DS40139E                                                  |
| Que  | stions:                                                                                    |
| 1.   | What are the best features of this document?                                               |
|      |                                                                                            |
|      |                                                                                            |
| 2.   | How does this document meet your hardware and software development needs?                  |
|      |                                                                                            |
| 3    | Do you find the organization of this data sheet easy to follow? If not, why?               |
| 0.   |                                                                                            |
|      |                                                                                            |
| 4.   | What additions to the data sheet do you think would enhance the structure and subject?     |
| -    |                                                                                            |
| 5    | What deletions from the data sheet could be made without affecting the overall usefulness? |
| 5.   |                                                                                            |
| -    |                                                                                            |
| 6.   | Is there any incorrect or misleading information (what and where)?                         |
| -    |                                                                                            |
|      |                                                                                            |
| 7.   | How would you improve this document?                                                       |
| -    |                                                                                            |
| 8.   | How would you improve our software, systems, and silicon products?                         |
|      |                                                                                            |

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