



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

| Details                    |                                                                            |
|----------------------------|----------------------------------------------------------------------------|
| Product Status             | Active                                                                     |
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 4MHz                                                                       |
| Connectivity               | -                                                                          |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 13                                                                         |
| Program Memory Size        | 1.75KB (1K x 14)                                                           |
| Program Memory Type        | OTP                                                                        |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 128 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 5.5V                                                                |
| Data Converters            | A/D 4x8b                                                                   |
| Oscillator Type            | External                                                                   |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 18-SOIC (0.295", 7.50mm Width)                                             |
| Supplier Device Package    | 18-SOIC                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lc712-04-so |
|                            |                                                                            |

Email: info@E-XFL.COM

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

#### 2.2.2.4 PIE1 Register

This register contains the individual enable bits for the peripheral interrupts.

Note: Bit PEIE (INTCON<6>) must be set to enable any peripheral interrupt.

### FIGURE 2-7: PIE1 REGISTER (ADDRESS 8Ch)

| U-0      | R/W-0                                                                                                                                     | U-0       | U-0        | R/W-0      | R/W-0  | R/W-0  | R/W-0  |                                                                                      |  |  |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------|------------|--------|--------|--------|--------------------------------------------------------------------------------------|--|--|
|          | ADIE                                                                                                                                      | —         |            | —          | CCP1IE | TMR2IE | TMR1IE | R = Readable bit                                                                     |  |  |
| bit7     |                                                                                                                                           |           |            |            |        |        | bit0   | W = Writable bit<br>U = Unimplemented bit,<br>read as '0'<br>-n = Value at POR Reset |  |  |
| bit 7:   | Unimpler                                                                                                                                  | nented: R | ead as '0  | ,          |        |        |        |                                                                                      |  |  |
| bit 6:   | •                                                                                                                                         |           |            |            |        |        |        |                                                                                      |  |  |
| bit 5-3: | Unimpler                                                                                                                                  | nented: R | ead as '0  | 1          |        |        |        |                                                                                      |  |  |
| bit 2:   | <b>CCP1IE</b> : 0<br>1 = Enabl<br>0 = Disab                                                                                               | es the CC | P1 interru | pt         |        |        |        |                                                                                      |  |  |
| bit 1:   | TMR2IE:<br>1 = Enabl<br>0 = Disab                                                                                                         | es the TM | R2 to PR   | 2 match in | •      |        |        |                                                                                      |  |  |
| bit 0:   | <b>TMR1IE</b> : TMR1 Overflow Interrupt Enable bit<br>1 = Enables the TMR1 overflow interrupt<br>0 = Disables the TMR1 overflow interrupt |           |            |            |        |        |        |                                                                                      |  |  |
|          |                                                                                                                                           |           |            |            |        |        |        |                                                                                      |  |  |

## 3.0 I/O PORTS

Some pins for these I/O ports are multiplexed with an alternate function for the peripheral features on the device. In general, when a peripheral is enabled, that pin may not be used as a general purpose I/O pin.

Additional information on I/O ports may be found in the PIC<sup>®</sup> Mid-Range Reference Manual, (DS33023).

### 3.1 PORTA and the TRISA Register

PORTA is a 5-bit wide bidirectional port. The corresponding data direction register is TRISA. Setting a TRISA bit (= 1) will make the corresponding PORTA pin an input, (i.e., put the corresponding output driver in a High-Impedance mode). Clearing a TRISA bit (= 0) will make the corresponding PORTA pin an output, (i.e., put the contents of the output latch on the selected pin).

Reading the PORTA register reads the status of the pins whereas writing to it will write to the port latch. All write operations are read-modify-write operations. Therefore, a write to a port implies that the port pins are read, the value is modified, and then written to the port data latch. Pin RA4 is multiplexed with the Timer0 module clock input to become the RA4/T0CKI pin. The RA4/T0CKI pin is a Schmitt Trigger input and an open drain output. All other RA port pins have TTL input levels and full CMOS output drivers.

PORTA pins, RA3:0, are multiplexed with analog inputs and analog VREF input. The operation of each pin is selected by clearing/setting the control bits in the ADCON1 register (A/D Control Register1).

| Note: | On a Power-on Reset, these pins are     |  |  |  |  |  |  |  |
|-------|-----------------------------------------|--|--|--|--|--|--|--|
|       | configured as analog inputs and read as |  |  |  |  |  |  |  |
|       | ʻ0'.                                    |  |  |  |  |  |  |  |

The TRISA register controls the direction of the RA pins, even when they are being used as analog inputs. The user must ensure the bits in the TRISA register are maintained set when using them as analog inputs.

#### EXAMPLE 3-1: INITIALIZING PORTA

| BCF   | STATUS, RPO | ;                       |
|-------|-------------|-------------------------|
| CLRF  | PORTA       | ; Initialize PORTA by   |
|       |             | ; clearing output       |
|       |             | ; data latches          |
| BSF   | STATUS, RPO | ; Select Bank 1         |
| MOVLW | OxEF        | ; Value used to         |
|       |             | ; initialize data       |
|       |             | ; direction             |
| MOVWF | TRISA       | ; Set RA<3:0> as inputs |
|       |             | ; RA<4> as outputs      |
| BCF   | STATUS, RPO | ; Return to Bank 0      |

#### 3.2 PORTB and the TRISB Register

PORTB is an 8-bit wide bidirectional port. The corresponding data direction register is TRISB. Setting a TRISB bit (= 1) will make the corresponding PORTB pin an input, (i.e., put the corresponding output driver in a High-Impedance mode). Clearing a TRISB bit (= 0) will make the corresponding PORTB pin an output, (i.e., put the contents of the output latch on the selected pin).

| BCF   | STATUS, RPO | i                       |
|-------|-------------|-------------------------|
| CLRF  | PORTB       | ; Initialize PORTB by   |
|       |             | ; clearing output       |
|       |             | ; data latches          |
| BSF   | STATUS, RPO | ; Select Bank 1         |
| MOVLW | 0xCF        | ; Value used to         |
|       |             | ; initialize data       |
|       |             | ; direction             |
| MOVWF | TRISB       | ; Set RB<3:0> as inputs |
|       |             | ; RB<5:4> as outputs    |
|       |             | ; RB<7:6> as inputs     |
|       |             |                         |

Each of the PORTB pins has a weak internal pull-up. A single control bit can turn on all the pull-ups. This is performed by clearing bit RBPU (OPTION\_REG<7>). The weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are disabled on a Power-on Reset.

#### FIGURE 3-3: BLOCK DIAGRAM OF RB0 PIN



NOTES:

#### 7.3.3 SET-UP FOR PWM OPERATION

The following steps should be taken when configuring the CCP module for PWM operation:

- 1. Set the PWM period by writing to the PR2 register.
- 2. Set the PWM duty cycle by writing to the CCPR1L register and CCP1CON<5:4> bits.
- 3. Make the CCP1 pin an output by clearing the TRISCCP<2> bit.
- 4. Set the TMR2 prescale value and enable Timer2 by writing to T2CON.
- 5. Configure the CCP1 module for PWM operation.

#### TABLE 7-3:EXAMPLE PWM FREQUENCIES AND RESOLUTIONS AT 20 MHz

| PWM Frequency              | 1.22 kHz | 4.88 kHz | 19.53 kHz | 78.12 kHz | 156.3 kHz | 208.3 kHz |
|----------------------------|----------|----------|-----------|-----------|-----------|-----------|
| Timer Prescaler (1, 4, 16) | 16       | 4        | 1         | 1         | 1         | 1         |
| PR2 Value                  | 0xFF     | 0xFF     | 0xFF      | 0x3F      | 0x1F      | 0x17      |
| Maximum Resolution (bits)  | 10       | 10       | 10        | 8         | 7         | 5.5       |

| Address | Name    | Bit 7     | Bit 6         | Bit 5         | Bit 4   | Bit 3   | Bit 2  | Bit 1   | Bit 0   | Value on<br>POR,<br>BOR | Value on<br>all other<br>Resets |
|---------|---------|-----------|---------------|---------------|---------|---------|--------|---------|---------|-------------------------|---------------------------------|
| 07h     | DATACCP | —         | _             |               |         |         | DCCP   |         | DT1CK   | xxxx xxxx               | xxxx xuxu                       |
| 0Bh,8Bh | INTCON  | GIE       | PEIE          | TOIE          | INTE    | RBIE    | T0IF   | INTF    | RBIF    | 0000 000x               | 0000 000u                       |
| 0Ch     | PIR1    | —         | ADIF          | _             | _       | _       | CCP1IF | TMR2IF  | TMR1IF  | -0000                   | -0000                           |
| 11h     | TMR2    | Timer2 Mc | dule's Regis  | ter           |         |         |        |         |         | 0000 0000               | 0000 0000                       |
| 12h     | T2CON   | —         | TOUTPS3       | TOUTPS2       | TOUTPS1 | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 | -000 0000               | -000 0000                       |
| 15h     | CCPR1L  | Capture/C | ompare/PWI    | V Register 1  | (LSB)   |         |        |         |         | xxxx xxxx               | uuuu uuuu                       |
| 16h     | CCPR1H  | Capture/C | ompare/PWI    | VI Register 1 | (MSB)   |         |        |         |         | xxxx xxxx               | uuuu uuuu                       |
| 17h     | CCP1CON | —         | _             | DC1B1         | DC1B0   | CCP1M3  | CCP1M2 | CCP1M1  | CCP1M0  | 00 0000                 | 00 0000                         |
| 87h     | TRISCCP | —         |               | _             | _       | _       | TCCP   | _       | TT1CK   | xxxx x1x1               | xxxx x1x1                       |
| 8Ch     | PIE1    | —         | ADIE          | _             | _       | _       | CCP1IE | TMR2IE  | TMR1IE  | -0000                   | -0000                           |
| 92h     | PR2     | Timer2 Mc | dule's Period | d Register    |         |         |        |         |         | 1111 1111               | 1111 1111                       |

#### TABLE 7-4: REGISTERS ASSOCIATED WITH PWM AND TIMER2

Legend: x = unknown, u = unchanged, — = unimplemented read as '0'. Shaded cells are not used by PWM and Timer2.

The ADRES register contains the result of the A/D conversion. When the A/D conversion is complete, the result is loaded into the ADRES register, the GO/DONE bit (ADCON0<2>) is cleared and the A/D Interrupt Flag bit ADIF is set. The block diagram of the A/D module is shown in Figure 8-3.

The value that is in the ADRES register is not modified for a Power-on Reset. The ADRES register will contain unknown data after a Power-on Reset.

After the A/D module has been configured as desired, the selected channel must be acquired before the conversion is started. The analog input channels must have their corresponding TRIS bits selected as an input. To determine acquisition time, see **Section 8.1 "A/D Acquisition Requirements"**. After this acquisition time has elapsed, the A/D conversion can be started. The following steps should be followed for doing an A/D conversion:

- 1. Configure the A/D module:
  - Configure analog pins/voltage reference/ and digital I/O (ADCON1)
  - Select A/D input channel (ADCON0)
  - Select A/D conversion clock (ADCON0)
  - Turn on A/D module (ADCON0)
- 2. Configure A/D interrupt (if desired):
  - Clear ADIF bit
  - Set ADIE bit
  - Set GIE bit
- 3. Wait the required acquisition time.
- 4. Start conversion:
  - Set GO/DONE bit (ADCON0)
- 5. Wait for A/D conversion to complete, by either:
  - Polling for the GO/DONE bit to be cleared

OR

- Waiting for the A/D interrupt
- Read A/D Result register (ADRES), clear bit ADIF if required.
- 7. For the next conversion, go to step 1 or step 2 as required. The A/D conversion time per bit is defined as TAD. A minimum wait of 2TAD is required before next acquisition starts.



#### FIGURE 8-3: A/D BLOCK DIAGRAM

#### 8.4 A/D Conversions

| Note: | The GO/DONE bit should NOT be set in        |
|-------|---------------------------------------------|
|       | the same instruction that turns on the A/D. |

### 8.5 Use of the CCP Trigger

An A/D conversion can be started by the "Special Event Trigger" of the CCP1 module. This requires that the CCP1M3:CCP1M0 bits (CCP1CON<3:0>) be programmed as 1011 and that the A/D module is enabled (ADON bit is set). When the trigger occurs, the GO/DONE bit will be set, starting the A/D conversion, and the Timer1 counter will be reset to zero. Timer1 is reset to automatically repeat the A/D acquisition period with minimal software overhead (moving the ADRES to the desired location). The appropriate analog input channel must be selected and the minimum acquisition done before the "Special Event Trigger" sets the GO/ DONE bit (starts a conversion).

If the A/D module is not enabled (ADON is cleared), then the "Special Event Trigger" will be ignored by the A/D module, but will still reset the Timer1 counter.

| Address | Name   | Bit 7    | Bit 6       | Bit 5 | Bit 4   | Bit 3                  | Bit 2         | Bit 1  | Bit 0  | Value on<br>POR,<br>BOR | Value on all other Resets |
|---------|--------|----------|-------------|-------|---------|------------------------|---------------|--------|--------|-------------------------|---------------------------|
| 05h     | PORTA  |          | _           | (1)   | RA4     | RA3                    | RA2           | RA1    | RA0    | xx xxxx                 | xu uuuu                   |
| 0Bh,8Bh | INTCON | GIE      | PEIE        | TOIE  | INTE    | RBIE                   | TOIF          | INTF   | RBIF   | 0000 000x               | 0000 000u                 |
| 0Ch     | PIR1   | _        | ADIF        | _     | —       | —                      | CCP1IF        | TMR2IF | TMR1IF | -0000                   | -0000                     |
| 1Eh     | ADRES  | A/D Resu | ult Registe | er    |         |                        |               |        |        | xxxx xxxx               | uuuu uuuu                 |
| 1Fh     | ADCON0 | ADCS1    | ADCS0       | CHS2  | CHS1    | CHS0                   | GO/DONE       | _      | ADON   | 0000 00-0               | 0000 00-0                 |
| 85h     | TRISA  | _        | _           | (1)   | PORTA I | Data Dire              | ction Registe | 1 1111 | 1 1111 |                         |                           |
| 8Ch     | PIE1   | _        | ADIE        | _     | —       | - CCP1IE TMR2IE TMR1IE |               |        |        | -0000                   | -0 0000                   |
| 9Fh     | ADCON1 |          | _           | _     | _       | _                      | PCFG2         | PCFG1  | PCFG0  | 000                     | 000                       |

TABLE 8-2: SUMMARY OF A/D REGISTERS

**Legend:** x = unknown, u = unchanged, — = unimplemented read as '0'. Shaded cells are not used for A/D conversion. **Note 1:** Reserved bits: Do Not Use.

DS41106C-page 50







**EXTERNAL BROWN-OUT PROTECTION CIRCUIT 2** 



$$\frac{R1}{R1 + R2} = 0$$

- 2: Internal Brown-out Reset should be disabled when using this circuit.
- 3: Resistors should be adjusted for the characteristics of the transistor.

#### **FIGURE 9-10:** EXTERNAL BROWN-OUT **PROTECTION CIRCUIT 3**



Microchip Technology's MCP809 microcontroller supervisor. The MCP8XX and MCP1XX families 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 accommodate 5V and 3V systems

#### 9.8 **Time-out Sequence**

On power-up the time-out sequence is as follows: First PWRT time-out is invoked after the POR time delay has expired. Then OST is activated. The total time-out will vary based on oscillator configuration and the status of the PWRT. For example, in RC mode with the PWRT disabled, there will be no time-out at all. Figure 9-11, Figure 9-12, and Figure 9-13 depict time-out sequences on power-up.

Since the time-outs occur from the POR pulse, if MCLR is kept low long enough, the time-outs will expire. Then bringing MCLR high will begin execution immediately (Figure 9-13). This is useful for testing purposes or to synchronize more than one PIC16CXXX device operating in parallel.

Table 9-5 shows the Reset conditions for some Special Function Registers, while Table 9-6 shows the Reset conditions for all the registers.

## 9.12 Watchdog Timer (WDT)

The Watchdog Timer is as a free running, on-chip, RC oscillator which does not require any external components. This RC oscillator is separate from the RC oscillator of the OSC1/CLKIN pin. That means that the WDT will run, even if the clock on the OSC1/CLKIN and OSC2/CLKOUT pins of the device have been stopped, for example, by execution of a SLEEP instruction.

During normal operation, a WDT Time-out generates a device Reset (Watchdog Timer Reset). If the device is in Sleep mode, a WDT Time-out causes the device to wake-up and continue with normal operation (Watchdog Timer Wake-up). The TO bit in the STATUS register will be cleared upon a Watchdog Timer Time-out.

The WDT can be permanently disabled by clearing Configuration bit WDTE (**Section 9.1 "Configuration Bits**").

WDT time-out period values may be found in the Electrical Specifications section under TwDT (parameter #31). Values for the WDT prescaler (actually a postscaler, but shared with the Timer0 prescaler) may be assigned using the OPTION\_REG register.

**Note:** The CLRWDT and SLEEP instructions clear the WDT and the postscaler, if assigned to the WDT, and prevent it from timing out and generating a device Reset condition.

**Note:** When a CLRWDT instruction is executed and the prescaler is assigned to the WDT, the prescaler count will be cleared, but the prescaler assignment is not changed.

#### FIGURE 9-15: WATCHDOG TIMER BLOCK DIAGRAM



#### FIGURE 9-16: SUMMARY OF WATCHDOG TIMER REGISTERS

| Address | Name         | Bits 13:8 | Bit 7 | Bit 6                | Bit 5 | Bit 4 | Bit 3                | Bit 2 | Bit 1 | Bit 0 |
|---------|--------------|-----------|-------|----------------------|-------|-------|----------------------|-------|-------|-------|
| 2007h   | Config. bits | (1)       |       | BODEN <sup>(1)</sup> | CP1   | CP0   | PWRTE <sup>(1)</sup> | WDTE  | FOSC1 | FOSC0 |
| 81h     | OPTION_REG   | N/A       | RBPU  | INTEDG               | TOCS  | T0SE  | PSA                  | PS2   | PS1   | PS0   |

**Legend:** Shaded cells are not used by the Watchdog Timer. **Note 1:** See Figure 9-1 for operation of these bits.

### 9.13 Power-down Mode (Sleep)

Power-Down mode is entered by executing a  $\ensuremath{\mathtt{SLEEP}}$  instruction.

If enabled, the Watchdog Timer will be cleared but keeps running, the PD bit (STATUS<3>) is cleared, the TO (STATUS<4>) bit is set, and the oscillator driver is turned off. The I/O ports maintain the status they had, before the SLEEP instruction was executed (driving high, low, or high-impedance).

For lowest current consumption in this mode, place all I/O pins at either VDD or VSS, ensure no external circuitry is drawing current from the I/O pin, powerdown the A/D and the disable external clocks. Pull all I/ O pins, that are high-impedance inputs, high or low externally to avoid switching currents caused by floating inputs. The TOCKI input should also be at VDD or VSS for lowest current consumption. The contribution from on-chip pull-ups on PORTB should be considered.

The  $\overline{\text{MCLR}}$  pin must be at a logic high level (VIHMC).

#### 9.13.1 WAKE-UP FROM SLEEP

The device can wake up from Sleep through one of the following events:

- 1. External Reset input on  $\overline{\text{MCLR}}$  pin.
- 2. Watchdog Timer Wake-up (if WDT was enabled).
- 3. Interrupt from INT pin, RB port change, or some peripheral interrupts.

External MCLR Reset will cause a device Reset. All other events are considered a continuation of program execution and cause a "wake-up". The TO and PD bits in the STATUS register can be used to determine the cause of device Reset. The PD bit, which is set on power-up, is cleared when SLEEP is invoked. The TO bit is cleared if a WDT Time-out occurred (and caused wake-up).

The following peripheral interrupts can wake the device from Sleep:

- 1. TMR1 interrupt. Timer1 must be operating as an asynchronous counter.
- 2. CCP Capture mode interrupt.
- 3. Special Event Trigger (Timer1 in Asynchronous mode using an external clock).

Other peripherals cannot generate interrupts, since during Sleep, no on-chip clocks are present.

When the SLEEP instruction is being executed, the next instruction (PC + 1) is pre-fetched. For the device to wake-up through an interrupt event, the corresponding interrupt enable bit must be set (enabled). Wake-up is regardless of the state of the GIE bit. If the GIE bit is clear (disabled), the device continues execution at the instruction after the SLEEP instruction. If the GIE bit is set (enabled), the device executes the instruction after the SLEEP instruction and then branches to the interrupt address (0004h). In cases where the execution of the instruction following SLEEP is not desirable, the user should have a NOP after the SLEEP instruction.

#### WAKE-UP USING INTERRUPTS 9.13.2

When global interrupts are disabled (GIE cleared) and any interrupt source has both its interrupt enable bit and interrupt flag bit set, one of the following will occur:

· If the interrupt occurs before the execution of a SLEEP instruction, the SLEEP instruction will complete as a NOP. Therefore, the WDT and WDT postscaler will not be cleared, the  $\overline{TO}$  bit will not be set and  $\overline{PD}$  bits will not be cleared.

• If the interrupt occurs during or after the execution of a SLEEP instruction, the device will immediately wake-up from Sleep. The SLEEP instruction will be completely executed before the wake-up. Therefore, the WDT and WDT postscaler will be cleared, the TO bit will be set and the  $\overline{PD}$  bit will be cleared.

Even if the flag bits were checked before executing a SLEEP instruction, it may be possible for flag bits to become set before the SLEEP instruction completes. To determine whether a SLEEP instruction executed, test the PD bit. If the PD bit is set, the SLEEP instruction was executed as a NOP.

To ensure that the WDT is cleared, a CLRWDT instruction should be executed before a **SLEEP** instruction.



4:

CLKOUT is not available in these osc modes, but shown here for timing reference.

#### 9.14 Program Verification/Code Protection

If the code protection bit(s) have not been programmed, the on-chip program memory can be read out for verification purposes.

| Note: | Microchip  | does   | not   | recommend | code |
|-------|------------|--------|-------|-----------|------|
|       | protecting | window | ved c | levices.  |      |

#### **ID** Locations 9.15

Four memory locations (2000h-2003h) are designated as ID locations where the user can store checksum or other code-identification numbers. These locations are not accessible during normal execution, but are readable and writable during Program/Verify. It is recommended that only the 4 Least Significant bits of the ID location are used.

For ROM devices, these values are submitted along with the ROM code.

### 11.11 PICSTART Plus Development Programmer

The PICSTART Plus Development Programmer is an easy-to-use, low-cost, prototype programmer. It connects to the PC via a COM (RS-232) port. MPLAB Integrated Development Environment software makes using the programmer simple and efficient. The PICSTART Plus Development Programmer supports most PIC devices in DIP packages up to 40 pins. Larger pin count devices, such as the PIC16C92X and PIC17C76X, may be supported with an adapter socket. The PICSTART Plus Development Programmer is CE compliant.

## 11.12 Demonstration, Development and Evaluation Boards

A wide variety of demonstration, development and evaluation boards for various PIC MCUs and dsPIC DSCs allows quick application development on fully functional systems. Most boards include prototyping areas for adding custom circuitry and provide application firmware and source code for examination and modification.

The boards support a variety of features, including LEDs, temperature sensors, switches, speakers, RS-232 interfaces, LCD displays, potentiometers and additional EEPROM memory.

The demonstration and development boards can be used in teaching environments, for prototyping custom circuits and for learning about various microcontroller applications.

In addition to the PICDEM<sup>™</sup> and dsPICDEM<sup>™</sup> demonstration/development board series of circuits, Microchip has a line of evaluation kits and demonstration software for analog filter design, KEELOQ<sup>®</sup> security ICs, CAN, IrDA<sup>®</sup>, PowerSmart<sup>®</sup> battery management, SEEVAL<sup>®</sup> evaluation system, Sigma-Delta ADC, flow rate sensing, plus many more.

Check the Microchip web page (www.microchip.com) and the latest *"Product Selector Guide"* (DS00148) for the complete list of demonstration, development and evaluation kits.

# 12.0 ELECTRICAL CHARACTERISTICS

#### Absolute Maximum Ratings (†)

| Ambient temperature under bias                                          | 55°C to +125°C                                          |
|-------------------------------------------------------------------------|---------------------------------------------------------|
| Ambient temperature under bias<br>Storage temperature                   | 65°C to +150°C                                          |
| Voltage on any pin with respect to Vss (except VDD, MCLR, and RA4)      | 0.3V to (VDD + 0.3V)                                    |
| Voltage on VDD with respect to Vss                                      | 0.3V to +7.5V                                           |
| Voltage on MCLR with respect to Vss (Note 2)                            | 0V to +13.25V                                           |
| Voltage on RA4 with respect to Vss                                      | 0V to +8.5V                                             |
| Total power dissipation (Note 1) (PDIP and SOIC)                        | 1.0W                                                    |
| Total power dissipation (Note 1) (SSOP)                                 |                                                         |
| Maximum current out of Vss pin                                          | 300 mA                                                  |
| Maximum current into VDD pin                                            |                                                         |
| Input clamp current, Iк (VI < 0 or VI > VDD)                            | ±20 mA                                                  |
| Output clamp current, Ioк (Vo < 0 or Vo > VDD)                          | ±20 mA                                                  |
| Maximum output current sunk by any I/O pin                              |                                                         |
| Maximum output current sourced by any I/O pin                           | 25 mA                                                   |
| Maximum current sunk by PORTA and PORTB (combined)                      | 200 mA                                                  |
| Maximum current sourced by PORTA and PORTB (combined)                   | 200 mA                                                  |
| Note 4. Deven discipation is calculated as follows: Ddis (IDD (IDD (IDD | $\lambda(a, y) = \{a, y\} = \sum \{\lambda(a, y) = x\}$ |

- **Note 1:** Power dissipation is calculated as follows:  $Pdis = VDD \times \{IDD \sum IOH\} + \sum \{(VDD-VOH) \times IOH\} + \sum (VOI \times IOL)$ **2:** Voltage spikes below Vss at the MCLR/VPP pin, inducing currents greater than 80 mA, may cause latch-up.
  - Thus, a series resistor of 50-100 $\Omega$  should be used when applying a "low" level to the MCLR/VPP pin rather than pulling this pin directly to Vss.

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





#### FIGURE 12-2: PIC16LC712/716 VOLTAGE-FREQUENCY GRAPH, 0°C < TA < +70°C



### 12.3 DC Characteristics: PIC16C712/716-04 (Commercial, Industrial, Extended) PIC16C712716-20 (Commercial, Industrial, Extended) PIC16LC712/716-04 (Commercial, Industrial)

| Standard Operating Conditions (unless otherwise stated) |                                  |                                       |                                                              |                                                                |                |                                       |                                                        |  |  |  |
|---------------------------------------------------------|----------------------------------|---------------------------------------|--------------------------------------------------------------|----------------------------------------------------------------|----------------|---------------------------------------|--------------------------------------------------------|--|--|--|
|                                                         |                                  | Operating                             |                                                              | rature                                                         | ≥ O°C<br>2°0 ≤ | $TA \leq +70^{\circ}C$ for commercial |                                                        |  |  |  |
|                                                         |                                  |                                       |                                                              |                                                                | -4(            | ≥ O°C                                 | $TA \leq +125^{\circ}C$ for extended                   |  |  |  |
| DC CHA                                                  | RACTE                            | RISTICS                               | Operating                                                    | voltage                                                        | e VDD rang     | e as de                               | escribed in DC spec Section 12.1                       |  |  |  |
|                                                         |                                  |                                       |                                                              | "DC Characteristics: PIC16C712/716-04 (Commercial, Industrial, |                |                                       |                                                        |  |  |  |
|                                                         |                                  |                                       | Extended) PIC16C712/716-20 (Commercial, Industrial,          |                                                                |                |                                       |                                                        |  |  |  |
|                                                         |                                  |                                       | Extended)" and Section 12.2 "DC Characteristics: PIC16LC712/ |                                                                |                |                                       |                                                        |  |  |  |
| _                                                       | 716-04 (Commercial, Industrial)" |                                       |                                                              |                                                                |                |                                       |                                                        |  |  |  |
| Param                                                   | Sym.                             | Characteristic                        | Min.                                                         | Тур†                                                           | Max.           | Units                                 | Conditions                                             |  |  |  |
| No.                                                     |                                  |                                       |                                                              |                                                                |                |                                       |                                                        |  |  |  |
|                                                         |                                  | Input Low Voltage                     |                                                              |                                                                |                |                                       |                                                        |  |  |  |
|                                                         | VIL                              | I/O ports                             |                                                              |                                                                |                |                                       |                                                        |  |  |  |
| D030                                                    |                                  | with TTL buffer                       | Vss                                                          | —                                                              | 0.8V           | V                                     | $4.5V \leq VDD \leq 5.5V$                              |  |  |  |
| D030A                                                   |                                  |                                       | Vss                                                          | —                                                              | 0.15Vdd        | V                                     | otherwise                                              |  |  |  |
| D031                                                    |                                  | with Schmitt Trigger buffer           | Vss                                                          | —                                                              | 0.2VDD         | V                                     |                                                        |  |  |  |
| D032                                                    |                                  | MCLR, OSC1 (in RC mode)               | Vss                                                          | —                                                              | 0.2Vdd         | V                                     |                                                        |  |  |  |
| D033                                                    |                                  | OSC1 (in XT, HS and LP modes)         | Vss                                                          | _                                                              | 0.3Vdd         | V                                     | (Note 1)                                               |  |  |  |
|                                                         |                                  | Input High Voltage                    |                                                              |                                                                |                |                                       |                                                        |  |  |  |
|                                                         | Vін                              | I/O ports                             |                                                              | —                                                              |                |                                       |                                                        |  |  |  |
| D040                                                    |                                  | with TTL buffer                       | 2.0                                                          | —                                                              | Vdd            | V                                     | $4.5V \leq V\text{dd} \leq 5.5V$                       |  |  |  |
| D040A                                                   |                                  |                                       | 0.25Vdd                                                      | —                                                              | Vdd            | V                                     | otherwise                                              |  |  |  |
|                                                         |                                  |                                       | + 0.8V                                                       |                                                                |                |                                       |                                                        |  |  |  |
| D041                                                    |                                  | with Schmitt Trigger buffer           | 0.8Vdd                                                       | _                                                              | Vdd            | V                                     | For entire VDD range                                   |  |  |  |
| D042                                                    |                                  | MCLR                                  | 0.8Vdd                                                       | —                                                              | Vdd            | V                                     |                                                        |  |  |  |
| D042A                                                   |                                  | OSC1 (XT, HS and LP modes)            | 0.7Vdd                                                       | —                                                              | Vdd            | V                                     | (Note 1)                                               |  |  |  |
| D043                                                    |                                  | OSC1 (in RC mode)                     | 0.9Vdd                                                       | —                                                              | Vdd            | V                                     |                                                        |  |  |  |
|                                                         |                                  | Input Leakage Current<br>(Notes 2, 3) |                                                              |                                                                |                |                                       |                                                        |  |  |  |
| D060                                                    | lı∟                              | I/O ports                             | -                                                            | —                                                              | ±1             | μA                                    | $Vss \leq VPIN \leq VDD$ ,                             |  |  |  |
| DOC1                                                    |                                  |                                       |                                                              |                                                                | LE.            | ۸                                     | Pin at high-impedance<br>Vss $\leq$ VPIN $\leq$ VDD    |  |  |  |
| D061                                                    |                                  | MCLR, RA4/T0CKI                       |                                                              | _                                                              | ±5             | μA                                    |                                                        |  |  |  |
| D063                                                    |                                  | OSC1                                  |                                                              | _                                                              | ±5             | μA                                    | Vss $\leq$ VPIN $\leq$ VDD,<br>XT, HS and LP osc modes |  |  |  |
| D070                                                    | IPURB                            | PORTB weak pull-up current            | 50                                                           | 250                                                            | 400            | μA                                    | VDD = 5V, VPIN = VSS                                   |  |  |  |
| 5010                                                    | IFURB                            | FOR TO weak pull-up cultent           | 50                                                           | 200                                                            | 400            | μΑ                                    | $v_{DD} = 5v, v_{PIN} = v_{55}$                        |  |  |  |

These parameters are characterized but not tested.

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

**Note 1:** In RC Oscillator mode, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the PIC MCU be driven with external clock in RC mode.

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

3: Negative current is defined as current sourced by the pin.

#### 12.4.2 TIMING CONDITIONS

The temperature and voltages specified in Table 12-1 apply to all timing specifications, unless otherwise noted. Figure 12-3 specifies the load conditions for the timing specifications.

#### TABLE 12-1: TEMPERATURE AND VOLTAGE SPECIFICATIONS – AC

| Standard Operating Conditions (unless otherwise stated) |                                                                                       |            |                  |          |                |  |  |  |
|---------------------------------------------------------|---------------------------------------------------------------------------------------|------------|------------------|----------|----------------|--|--|--|
|                                                         | Operating temperature                                                                 | 0°C        | $\leq$ Ta $\leq$ | +70°C    | for commercial |  |  |  |
|                                                         |                                                                                       | -40°C      | $\leq$ Ta $\leq$ | +85°C    | for industrial |  |  |  |
|                                                         |                                                                                       | -40°C      | $\leq$ Ta $\leq$ | +125°C   | for extended   |  |  |  |
| AC CHARACTERISTICS                                      | Operating voltage VDD range as described in DC spec Section 12.1 "DC Characteristics: |            |                  |          |                |  |  |  |
|                                                         | PIC16C712/716-04 (Commercial, Industrial, Extended) PIC16C712/716-20 (Commercial,     |            |                  |          |                |  |  |  |
|                                                         | Industrial, Extended)" and Section 12.2 "DC Characteristics: PIC16LC712/716-04 (Com-  |            |                  |          |                |  |  |  |
|                                                         | mercial, Industrial)".                                                                |            |                  |          |                |  |  |  |
|                                                         | LC parts operate for comm                                                             | nercial/in | dustrial t       | emp's on | ly.            |  |  |  |

#### FIGURE 12-3: LOAD CONDITIONS FOR DEVICE TIMING SPECIFICATIONS



#### 13.2 Package Details

The following sections give the technical details of the packages.

### 18-Lead Plastic Dual In-line (P) – 300 mil (PDIP)



Notes: Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" (0.254mm) per side.

.008

.045

.014

.310

5

5

.012

.058

.018

.370

10

10

.015

.070

.022

.430

15

15

0.20

1.14

0.36

7.87

5

5

0.29

1.46

0.46

9.40

10

10

0.38

1.78

0.56

10.92

15

15

С

B1

В

eВ

α

β

δ

JEDEC Equivalent: MS-001

Drawing No. C04-007

Lead Thickness

Upper Lead Width

Lower Lead Width

**Overall Row Spacing** 

Mold Draft Angle Top

Mold Draft Angle Bottom

\* Controlling Parameter § Significant Characteristic

## 18-Lead Ceramic Dual In-line with Window (JW) - 300 mil (CERDIP)

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



|                            | Units    | INCHES* |      |      | MILLIMETERS |       |       |  |
|----------------------------|----------|---------|------|------|-------------|-------|-------|--|
| Dimensio                   | n Limits | MIN     | NOM  | MAX  | MIN         | NOM   | MAX   |  |
| Number of Pins             | n        |         | 18   |      |             | 18    |       |  |
| Pitch                      | р        |         | .100 |      |             | 2.54  |       |  |
| Top to Seating Plane       | Α        | .170    | .183 | .195 | 4.32        | 4.64  | 4.95  |  |
| Ceramic Package Height     | A2       | .155    | .160 | .165 | 3.94        | 4.06  | 4.19  |  |
| Standoff                   | A1       | .015    | .023 | .030 | 0.38        | 0.57  | 0.76  |  |
| Shoulder to Shoulder Width | E        | .300    | .313 | .325 | 7.62        | 7.94  | 8.26  |  |
| Ceramic Pkg. Width         | E1       | .285    | .290 | .295 | 7.24        | 7.37  | 7.49  |  |
| Overall Length             | D        | .880    | .900 | .920 | 22.35       | 22.86 | 23.37 |  |
| Tip to Seating Plane       | L        | .125    | .138 | .150 | 3.18        | 3.49  | 3.81  |  |
| Lead Thickness             | С        | .008    | .010 | .012 | 0.20        | 0.25  | 0.30  |  |
| Upper Lead Width           | B1       | .050    | .055 | .060 | 1.27        | 1.40  | 1.52  |  |
| Lower Lead Width           | В        | .016    | .019 | .021 | 0.41        | 0.47  | 0.53  |  |
| Overall Row Spacing §      | eB       | .345    | .385 | .425 | 8.76        | 9.78  | 10.80 |  |
| Window Width               | W1       | .130    | .140 | .150 | 3.30        | 3.56  | 3.81  |  |
| Window Length              | W2       | .190    | .200 | .210 | 4.83        | 5.08  | 5.33  |  |

\* Controlling Parameter
§ Significant Characteristic
JEDEC Equivalent: MO-036
Drawing No. C04-010

NOTES:

| Interrupt Sources 51, 6                  | 51 |
|------------------------------------------|----|
| A/D Conversion Complete 4                | 7  |
| Block Diagram6                           | 51 |
| Capture Complete (CCP)4                  | 0  |
| Compare Complete (CCP) 4                 | 1  |
| Interrupt-on-Change (RB7:RB4) 2          |    |
| RB0/INT Pin, External 6                  | 52 |
| TMR0 Overflow 30, 6                      | 52 |
| TMR1 Overflow 31, 3                      |    |
| TMR2 to PR2 Match                        | 37 |
| TMR2 to PR2 Match (PWM) 36, 4            | 2  |
| Interrupts, Context Saving During        |    |
| Interrupts, Enable Bits                  |    |
| A/D Converter Enable (ADIE Bit) 1        | 6  |
| CCP1 Enable (CCP1IE Bit) 16, 4           | 0  |
| Global Interrupt Enable (GIE Bit) 15, 6  |    |
| Interrupt-on-Change (RB7:RB4) Enable     |    |
| (RBIE Bit) 15, 6                         | 52 |
| Peripheral Interrupt Enable (PEIE Bit) 1 |    |
| RB0/INT Enable (INTE Bit) 1              | 5  |
| TMR0 Overflow Enable (T0IE Bit) 1        | 5  |
| TMR1 Overflow Enable (TMR1IE Bit)1       | 6  |
| TMR2 to PR2 Match Enable (TMR2IE Bit) 1  |    |
| Interrupts, Flag Bits                    |    |
| A/D Converter Flag (ADIF Bit) 17, 4      | 7  |
| CCP1 Flag (CCP1IF Bit) 17, 40, 4         | 1  |
| Interrupt-on-Change (RB7:RB4) Flag       |    |
| (RBIF Bit) 15, 24, 6                     | 52 |
| RB0/INT Flag (INTF Bit) 1                | 5  |
| TMR0 Overflow Flag (T0IF Bit) 15, 6      | 52 |
| TMR1 Overflow Flag (TMR1IF Bit) 1        |    |
| TMR2 to PR2 Match Flag (TMR2IF Bit) 1    | 7  |

### Μ

## 0

| OPCODE Field Descriptions    | 67         |
|------------------------------|------------|
| OPTION_REG Register          | 12, 14     |
| INTEDG Bit                   | 14         |
| PS2:PS0 Bits                 | 14, 29     |
| PSA Bit                      | 14, 29     |
| RBPU Bit                     | 14         |
| T0CS Bit                     | 14, 29     |
| T0SE Bit                     | 14, 29     |
| Oscillator Configuration     | 51, 53     |
| HS                           |            |
| LP                           | 53, 58     |
| RC                           | 53, 54, 58 |
| Selection (FOSC1:FOSC0 Bits) | 52         |
|                              |            |

| XT 53                                                                                                     |          |                      |
|-----------------------------------------------------------------------------------------------------------|----------|----------------------|
| Oscillator, Timer1 31                                                                                     | ۱,       | 34                   |
| Oscillator, WDT                                                                                           |          | 63                   |
| D                                                                                                         |          |                      |
| Р                                                                                                         |          |                      |
| Packaging                                                                                                 |          | 89                   |
| Details                                                                                                   |          | 90                   |
| Paging, Program Memory                                                                                    | Э.       | 19                   |
| PCON Register 18                                                                                          |          |                      |
| BOR Bit                                                                                                   |          | 18                   |
| POR Bit                                                                                                   |          | 18                   |
| PICSTART Plus Development Programmer                                                                      |          | 72                   |
|                                                                                                           |          |                      |
| PIE1 Register                                                                                             |          | 16                   |
| ADIE Bit                                                                                                  |          | -                    |
| CCP1IE Bit                                                                                                |          | 16                   |
| TMR1IE Bit                                                                                                |          | 16                   |
| TMR2IE Bit                                                                                                | •        | 16                   |
| Pin F <u>unctio</u> ns                                                                                    |          |                      |
| MCLR/VPP                                                                                                  |          | . 6                  |
| RA0/AN0                                                                                                   |          | . 6                  |
| RA1/AN1                                                                                                   |          | . 6                  |
| RA2/AN2                                                                                                   |          | . 6                  |
| RA3/AN3/Vref                                                                                              |          |                      |
| RA4/T0CKI                                                                                                 |          | -                    |
| RB0/INT                                                                                                   |          | -                    |
|                                                                                                           |          |                      |
| RB1                                                                                                       |          |                      |
| RB2                                                                                                       |          |                      |
| RB3                                                                                                       |          |                      |
| RB4                                                                                                       |          |                      |
| RB5                                                                                                       | •••      | . 7                  |
| RB6                                                                                                       |          | . 7                  |
| RB7                                                                                                       |          | . 7                  |
| Vdd                                                                                                       |          | . 7                  |
| Vss                                                                                                       |          | . 7                  |
| Pinout Descriptions                                                                                       |          |                      |
| PIC16C712/716 Pinout Description                                                                          |          | 6                    |
| PIR1 Register                                                                                             |          |                      |
| ADIF Bit                                                                                                  |          | 17                   |
|                                                                                                           |          |                      |
| CCP1IF Bit                                                                                                |          | 17                   |
| TMR1IF Bit                                                                                                |          | 17                   |
| TMR2IF Bit                                                                                                |          |                      |
| Pointer, FSR                                                                                              | •        | 20                   |
| POR. See Power-on Reset                                                                                   |          |                      |
| PORTA                                                                                                     |          |                      |
| Initialization                                                                                            |          | 21                   |
| PORTA Register 1'                                                                                         | ١.       | 21                   |
| RA3:RA0 Port Pins                                                                                         |          |                      |
| RA4/T0CKI Pin                                                                                             |          | 22                   |
| TRISA Register                                                                                            |          |                      |
| PORTB                                                                                                     | -,       | 21                   |
| Block Diagram of RB1/T1OSO/T1CKI Pin                                                                      |          | 24                   |
|                                                                                                           |          |                      |
| Block Diagram of RB2/T10SI Pin                                                                            | •        | 20                   |
| Block Diagram of RB3/CCP1 Pin                                                                             |          |                      |
| Initialization                                                                                            |          |                      |
| PORTB Register 12                                                                                         |          |                      |
| Pull-up Enable (RBPU Bit)                                                                                 |          | 14                   |
| RB0/INT Edge Select (INTEDG Bit)                                                                          |          | 14                   |
| RB0/INT Pin, External                                                                                     |          | 62                   |
| RB3:RB0 Port Pins                                                                                         |          |                      |
| RB7:RB4 Interrupt-on-Change                                                                               |          |                      |
|                                                                                                           |          |                      |
|                                                                                                           |          | 62                   |
| RB7:RB4 Interrupt-on-Change Enable (RBIE Bit) 15                                                          |          | 62                   |
| RB7:RB4 Interrupt-on-Change Enable (RBIE Bit) 15<br>RB7:RB4 Interrupt-on-Change Flag                      | 5,       | 62<br>62             |
| RB7:RB4 Interrupt-on-Change Enable (RBIE Bit) 15<br>RB7:RB4 Interrupt-on-Change Flag<br>(RBIF Bit) 15, 24 | 5,<br>1, | 62<br>62<br>62       |
| RB7:RB4 Interrupt-on-Change Enable (RBIE Bit) 15<br>RB7:RB4 Interrupt-on-Change Flag                      | 5,<br>1, | 62<br>62<br>62<br>26 |