

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

E·XF

| Details                    |                                                                              |
|----------------------------|------------------------------------------------------------------------------|
| Product Status             | Active                                                                       |
| Core Processor             | PIC                                                                          |
| Core Size                  | 8-Bit                                                                        |
| Speed                      | 4MHz                                                                         |
| Connectivity               | -                                                                            |
| Peripherals                | Brown-out Detect/Reset, POR, WDT                                             |
| Number of I/O              | 13                                                                           |
| Program Memory Size        | 3.5KB (2K x 14)                                                              |
| Program Memory Type        | OTP                                                                          |
| EEPROM Size                | -                                                                            |
| RAM Size                   | 128 x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 5.5V                                                                  |
| Data Converters            | ·                                                                            |
| Oscillator Type            | External                                                                     |
| Operating Temperature      | -40°C ~ 125°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/pic16lc622a-04e-so |

Email: info@E-XFL.COM

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

NOTES:

# FIGURE 4-6: DATA MEMORY MAP FOR THE PIC16C620A/CR620A/621A

|                 | 11010002                       |                     | - 17 (          |
|-----------------|--------------------------------|---------------------|-----------------|
| File<br>Address | 3                              |                     | File<br>Address |
| 00h             | INDF <sup>(1)</sup>            | INDF <sup>(1)</sup> | 80h             |
| 01h             | TMR0                           | OPTION              | 81h             |
| 02h             | PCL                            | PCL                 | 82h             |
| 03h             | STATUS                         | STATUS              | 83h             |
| 04h             | FSR                            | FSR                 | 84h             |
| 05h             | PORTA                          | TRISA               | 85h             |
| 06h             | PORTB                          | TRISB               | 86h             |
| 07h             |                                |                     | 87h             |
| 08h             |                                |                     | 88h             |
| 09h             |                                |                     | 89h             |
| 0Ah             | PCLATH                         | PCLATH              | 8Ah             |
| 0Bh             | INTCON                         | INTCON              | 8Bh             |
| 0Ch             | PIR1                           | PIE1                | 8Ch             |
| 0Dh             |                                |                     | 8Dh             |
| 0Eh             |                                | PCON                | 8Eh             |
| 0Fh             |                                |                     | 8Fh             |
| 10h             |                                |                     | 90h             |
| 11h             |                                |                     | 91h             |
| 12h             |                                |                     | 92h             |
| 13h             |                                |                     | 93h             |
| 14h             |                                |                     | 94h             |
| 15h             |                                |                     | 95h             |
| 16h             |                                |                     | 96h             |
| 17h             |                                |                     | 97h             |
| 18h             |                                |                     | 98h             |
| 19h             |                                |                     | 99h             |
| 1Ah             |                                |                     | 9Ah             |
| 1Bh             |                                |                     | 9Bh             |
| 1Ch             |                                |                     | 9Ch             |
| 1Dh             |                                |                     | 9Dh             |
| 1Eh             |                                |                     | 9Eh             |
| 1Fh             | CMCON                          | VRCON               | 9Fh             |
| 20h             | General<br>Purpose<br>Register |                     | A0h             |
| 6Fh             |                                |                     |                 |
| 70h             | General                        |                     | F0h             |
|                 | Purpose<br>Register            | Accesses<br>70h-7Fh |                 |
| 7Fh             | Bank 0                         | Bank 1              | 」 FFh           |
| Unimp           | lemented data mer              | mory locations, rea | ad as '0'.      |
| Note 1:         | Not a physical re              | gister.             |                 |
|                 |                                |                     |                 |

#### FIGURE 4-7: DATA MEMORY MAP FOR THE PIC16C622A

|                 |                     | C10C022A            |                 |
|-----------------|---------------------|---------------------|-----------------|
| File<br>Address | 3                   |                     | File<br>Address |
| 00h             | INDF <sup>(1)</sup> | INDF <sup>(1)</sup> | 80h             |
| 01h             | TMR0                | OPTION              | 81h             |
| 02h             | PCL                 | PCL                 | 82h             |
| 03h             | STATUS              | STATUS              | 83h             |
| 04h             | FSR                 | FSR                 | 84h             |
| 05h             | PORTA               | TRISA               | 85h             |
| 06h             | PORTB               | TRISB               | 86h             |
| 07h             |                     |                     | 87h             |
| 08h             |                     |                     | 88h             |
| 09h             |                     |                     | 89h             |
| 0Ah             | PCLATH              | PCLATH              | 8Ah             |
| 0Bh             | INTCON              | INTCON              | 8Bh             |
| 0Ch             | PIR1                | PIE1                | 8Ch             |
| 0Dh             |                     |                     | 8Dh             |
| 0Eh             |                     | PCON                | 8Eh             |
| 0Fh             |                     |                     | 8Fh             |
| 10h             |                     |                     | 90h             |
| 11h             |                     |                     | 91h             |
| 12h             |                     |                     | 92h             |
| 13h             |                     |                     | 93h             |
| 14h             |                     |                     | 94h             |
| 15h             |                     |                     | 95h             |
| 16h             |                     |                     | 96h             |
| 17h             |                     |                     | 97h             |
| 18h             |                     |                     | 98h             |
| 19h             |                     |                     | 99h             |
| 1Ah             |                     |                     | 9Ah             |
| 1Bh             |                     |                     | 9Bh             |
| 1Ch             |                     |                     | 9Ch             |
| 1Dh             |                     |                     | 9Dh             |
| 1Eh             |                     |                     | 9Eh             |
| 1Fh             | CMCON               | VRCON               | 9Fh             |
| 20h             |                     |                     | A0h             |
|                 | General             | General             | Aon             |
|                 | Purpose<br>Register | Purpose<br>Register |                 |
|                 | rtegister           | rtegister           | BFh             |
|                 |                     |                     | C0h             |
| 0.51            |                     |                     |                 |
| 6Fh             | 0                   |                     | F0h             |
| 70h             | General<br>Purpose  | Accesses            |                 |
| 754             | Register            | 70h-7Fh             | FFh             |
| 7Fh             | Bank 0              | Bank 1              | → FF11          |
|                 |                     |                     |                 |
| Unimp           | plemented data me   | mory locations, re  | ad as '0'.      |
| Note 1:         | Not a physical re   | egister.            |                 |

#### **OPTION Register** 4.2.2.2

The OPTION register is a readable and writable register, which contains various control bits to configure the TMR0/WDT prescaler, the external RB0/INT interrupt, TMR0 and the weak pull-ups on PORTB.

| Note: | To achieve a 1:1 prescaler assignment for |
|-------|-------------------------------------------|
|       | TMR0, assign the prescaler to the WDT     |
|       | (PSA = 1).                                |

|         | R/W-1                                                             | R/W-1                                                                                             | R/W-1                         | R/W-1                        | R/W-1 | R/W-1 | R/W-1 | R/W-1 |  |  |  |  |  |
|---------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|-------------------------------|------------------------------|-------|-------|-------|-------|--|--|--|--|--|
|         | RBPU                                                              | INTEDG                                                                                            | TOCS                          | TOSE                         | PSA   | PS2   | PS1   | PS0   |  |  |  |  |  |
|         | bit 7                                                             |                                                                                                   |                               |                              |       | •     |       | bit 0 |  |  |  |  |  |
| bit 7   | RBPU: PO                                                          | RBPU: PORTB Pull-up Enable bit                                                                    |                               |                              |       |       |       |       |  |  |  |  |  |
|         |                                                                   | 1 = PORTB pull-ups are disabled<br>0 = PORTB pull-ups are enabled by individual port latch values |                               |                              |       |       |       |       |  |  |  |  |  |
| bit 6   | INTEDG: Interrupt Edge Select bit                                 |                                                                                                   |                               |                              |       |       |       |       |  |  |  |  |  |
|         |                                                                   | 1 = Interrupt on rising edge of RB0/INT pin<br>0 = Interrupt on falling edge of RB0/INT pin       |                               |                              |       |       |       |       |  |  |  |  |  |
| bit 5   | TOCS: TMI                                                         | R0 Clock Sc                                                                                       | ource Select                  | bit                          |       |       |       |       |  |  |  |  |  |
|         |                                                                   | 1 = Transition on RA4/T0CKI pin<br>0 = Internal instruction cycle clock (CLKOUT)                  |                               |                              |       |       |       |       |  |  |  |  |  |
| bit 4   | TOSE: TM                                                          | R0 Source E                                                                                       | Edge Select                   | bit                          |       |       |       |       |  |  |  |  |  |
|         |                                                                   |                                                                                                   |                               | ition on RA4<br>ition on RA4 |       |       |       |       |  |  |  |  |  |
| bit 3   | PSA: Pres                                                         | caler Assigr                                                                                      | iment bit                     |                              | -     |       |       |       |  |  |  |  |  |
|         |                                                                   |                                                                                                   | ned to the W<br>ned to the Ti | DT<br>mer0 module            | Э     |       |       |       |  |  |  |  |  |
| bit 2-0 | <b>PS&lt;2:0&gt;</b> : [                                          | Prescaler Ra                                                                                      | ate Select bi                 | ts                           |       |       |       |       |  |  |  |  |  |
|         | E                                                                 | Bit Value T                                                                                       | MR0 Rate                      | WDT Rate                     |       |       |       |       |  |  |  |  |  |
|         | 000         1:2         1:1           001         1:4         1:2 |                                                                                                   |                               |                              |       |       |       |       |  |  |  |  |  |
|         |                                                                   | 010<br>011                                                                                        | 1 : 8<br>1 : 16               | 1:4<br>1:8                   |       |       |       |       |  |  |  |  |  |
|         |                                                                   | 100                                                                                               | 1:32                          | 1:16                         |       |       |       |       |  |  |  |  |  |
|         |                                                                   | 101                                                                                               | 1:64                          | 1:32                         |       |       |       |       |  |  |  |  |  |
|         |                                                                   | 110                                                                                               | 1:128                         | 1:64                         |       |       |       |       |  |  |  |  |  |
|         |                                                                   | 111                                                                                               | 1:256                         | 1 : 128                      |       |       |       |       |  |  |  |  |  |

| Legend:            |                  |                      |                    |
|--------------------|------------------|----------------------|--------------------|
| R = Readable bit   | W = Writable bit | U = Unimplemented    | bit, read as '0'   |
| - n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown |

## 4.3 PCL and PCLATH

The program counter (PC) is 13-bits wide. The low byte comes from the PCL register, which is a readable and writable register. The high byte (PC<12:8>) is not directly readable or writable and comes from PCLATH. On any RESET, the PC is cleared. Figure 4-8 shows the two situations for the loading of the PC. The upper example in the figure shows how the PC is loaded on a write to PCL (PCLATH<4:0>  $\rightarrow$  PCH). The lower example in the figure shows how the PC is loaded during a CALL or GOTO instruction (PCLATH<4:3>  $\rightarrow$  PCH).

#### FIGURE 4-8: LOADING OF PC IN DIFFERENT SITUATIONS



## 4.3.1 COMPUTED GOTO

A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). When doing a table read using a computed GOTO method, care should be exercised if the table location crosses a PCL memory boundary (each 256 byte block). Refer to the application note, *"Implementing a Table Read"* (AN556).

## 4.3.2 STACK

The PIC16C62X family has an 8-level deep x 13-bit wide hardware stack (Figure 4-2 and Figure 4-3). The stack space is not part of either program or data space and the stack pointer is not readable or writable. The PC is PUSHed onto the stack when a CALL instruction is executed or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE instruction execution. PCLATH is not affected by a PUSH or POP operation.

The stack operates as a circular buffer. This means that after the stack has been PUSHed eight times, the ninth push overwrites the value that was stored from the first push. The tenth push overwrites the second push (and so on).

- Note 1: There are no STATUS bits to indicate stack overflow or stack underflow conditions.
  - 2: There are no instructions/mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, RETURN, RETLW and RETFIE instructions, or the vectoring to an interrupt address.

### 5.2 PORTB and TRISB Registers

PORTB is an 8-bit wide, bi-directional port. The corresponding data direction register is TRISB. A '1' in the TRISB register puts the corresponding output driver in a High Impedance mode. A '0' in the TRISB register puts the contents of the output latch on the selected pin(s).

Reading PORTB 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. So a write to a port implies that the port pins are first read, then this value is modified and written to the port data latch.

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

Four of PORTB's pins, RB<7:4>, have an interrupt on change feature. Only pins configured as inputs can cause this interrupt to occur (e.g., any RB<7:4> pin configured as an output is excluded from the interrupt on change comparison). The input pins (of RB<7:4>) are compared with the old value latched on the last read of PORTB. The "mismatch" outputs of RB<7:4> are OR'ed together to generate the RBIF interrupt (flag latched in INTCON<0>).

#### FIGURE 5-5: BLOCK DIAGRAM OF RB<7:4> PINS



This interrupt can wake the device from SLEEP. The user, in the interrupt service routine, can clear the interrupt in the following manner:

- a) Any read or write of PORTB. This will end the mismatch condition.
- b) Clear flag bit RBIF.

A mismatch condition will continue to set flag bit RBIF. Reading PORTB will end the mismatch condition and allow flag bit RBIF to be cleared.

This interrupt on mismatch feature, together with software configurable pull-ups on these four pins allow easy interface to a key pad and make it possible for wake-up on key-depression. (See AN552, "Implementing Wake-Up on Key Strokes.)

| Note: | If a change on the I/O pin should occur       |  |  |  |  |  |  |
|-------|-----------------------------------------------|--|--|--|--|--|--|
|       | when the read operation is being executed     |  |  |  |  |  |  |
|       | (start of the Q2 cycle), then the RBIF inter- |  |  |  |  |  |  |
|       | rupt flag may not get set.                    |  |  |  |  |  |  |

The interrupt-on-change feature is recommended for wake-up on key depression operation and operations where PORTB is only used for the interrupt on change feature. Polling of PORTB is not recommended while using the interrupt-on-change feature.





## 6.0 TIMER0 MODULE

The Timer0 module timer/counter has the following features:

- 8-bit timer/counter
- Readable and writable
- 8-bit software programmable prescaler
- · Internal or external clock select
- · Interrupt on overflow from FFh to 00h
- · Edge select for external clock

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

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

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

The prescaler is shared between the Timer0 module and the Watchdog Timer. The prescaler assignment is controlled in software by the control bit PSA (OPTION<3>). Clearing the PSA bit will assign the prescaler to Timer0. The prescaler is not readable or writable. When the prescaler is assigned to the Timer0 module, prescale value of 1:2, 1:4, ..., 1:256 are selectable. Section 6.3 details the operation of the prescaler.

### 6.1 TIMER0 Interrupt

Timer0 interrupt is generated when the TMR0 register timer/counter overflows from FFh to 00h. This overflow sets the T0IF bit. The interrupt can be masked by clearing the T0IE bit (INTCON<5>). The T0IF bit (INTCON<2>) must be cleared in software by the Timer0 module interrupt service routine before reenabling this interrupt. The Timer0 interrupt cannot wake the processor from SLEEP, since the timer is shut off during SLEEP. See Figure 6-4 for Timer0 interrupt timing.



#### FIGURE 6-2: TIMER0 (TMR0) TIMING: INTERNAL CLOCK/NO PRESCALER

| (Program<br>Counter) | ( PC-1      | ) PC        | ( <u>PC+1</u> )        | PC+2                   | <u>PC+3</u> χ          | PC+4                   | PC+5 χ                     | PC+6                     |
|----------------------|-------------|-------------|------------------------|------------------------|------------------------|------------------------|----------------------------|--------------------------|
| Instruction<br>Fetch |             | MOVWF TMR   | 0MOVF TMR0,V           | MOVF TMR0,W            | MOVF TMR0,W            | MOVF TMR0,W            | MOVF TMR0,W                | 1                        |
|                      | i.          | 1           |                        |                        | i                      |                        | i                          |                          |
| TMR0                 | то х        | T0+1 )(     | T0+2 X                 | 1                      | NT0                    |                        | NT0+1 \                    | NT0+2 )                  |
| Instruction          | 1<br>1<br>1 | 1<br>1<br>1 | <b></b>                | <b>≜</b>               | <b>≜</b>               | <b>†</b>               | <b>†</b>                   | <b>≜</b>                 |
| Executed             | 1           | 1           | Write TMR0<br>executed | Read TMR0<br>reads NT0 | Read TMR0<br>reads NT0 | Read TMR0<br>reads NT0 | Read TMR0<br>reads NT0 + 1 | Read TMR0<br>reads NT0 + |

#### 6.3.1 SWITCHING PRESCALER ASSIGNMENT

The prescaler assignment is fully under software control (i.e., it can be changed "on-the-fly" during program execution). To avoid an unintended device RESET, the following instruction sequence (Example 6-1) must be executed when changing the prescaler assignment from Timer0 to WDT.)

#### EXAMPLE 6-1: CHANGING PRESCALER (TIMER0→WDT)

|          |              | ,                                             |
|----------|--------------|-----------------------------------------------|
| 1.BCF    | STATUS, RPO  | ;Skip if already in<br>;Bank 0                |
| 2.CLRWDT |              | ;Clear WDT                                    |
| 3.CLRF   | TMR0         | ;Clear TMR0 & Prescaler                       |
| 4.BSF    | STATUS, RPO  | ;Bank 1                                       |
| 5.MOVLW  | '00101111'b; | ;These 3 lines (5, 6, 7)                      |
| 6.MOVWF  | OPTION       | ;are required only if<br>;desired PS<2:0> are |
| 7.CLRWDT |              | ;000 or 001                                   |
| 8.MOVLW  | '00101xxx'b  | ;Set Postscaler to                            |
| 9.MOVWF  | OPTION       | ;desired WDT rate                             |
| 10.BCF   | STATUS, RPO  | ;Return to Bank 0                             |
|          |              |                                               |

To change prescaler from the WDT to the TMR0 module, use the sequence shown in Example 6-2. This precaution must be taken even if the WDT is disabled.

## EXAMPLE 6-2:

#### CHANGING PRESCALER (WDT→TIMER0)

|        | •           | ,                                        |
|--------|-------------|------------------------------------------|
| CLRWDT |             | ;Clear WDT and                           |
|        |             | ;prescaler                               |
| BSF    | STATUS, RPO |                                          |
| MOVLW  | b'xxxx0xxx' | ;Select TMR0, new<br>;prescale value and |
|        |             | ;clock source                            |
| MOVWF  | OPTION REG  |                                          |
| BCF    | STATUS, RPO |                                          |

#### TABLE 6-1: REGISTERS ASSOCIATED WITH TIMER0

| Address |        |          |                                        |      |        |        |        | Value on<br>POR | Value on<br>All Other<br>RESETS |           |           |
|---------|--------|----------|----------------------------------------|------|--------|--------|--------|-----------------|---------------------------------|-----------|-----------|
| 01h     | TMR0   | Timer0 r | imer0 module register                  |      |        |        |        |                 |                                 | XXXX XXXX | uuuu uuuu |
| 0Bh/8Bh | INTCON | GIE      | GIE PEIE TOIE INTE RBIE TOIF INTE RBIF |      |        |        |        |                 |                                 | 0000 000x | 0000 000u |
| 81h     | OPTION | RBPU     | INTEDG                                 | TOCS | TOSE   | PSA    | PS2    | PS1             | PS0                             | 1111 1111 | 1111 1111 |
| 85h     | TRISA  | _        |                                        | _    | TRISA4 | TRISA3 | TRISA2 | TRISA1          | TRISA0                          | 1 1111    | 1 1111    |

Legend: — = Unimplemented locations, read as '0', u = unchanged, x = unknown

**Note:** Shaded bits are not used by TMR0 module.

### 9.4 Power-on Reset (POR), Power-up Timer (PWRT), Oscillator Start-up Timer (OST) and Brown-out Reset (BOR)

#### 9.4.1 POWER-ON RESET (POR)

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 POR, just tie the MCLR pin through a resistor to VDD. This will eliminate external RC components usually needed to create Power-on Reset. A maximum rise time for VDD is required. See Electrical Specifications for details.

The POR circuit does not produce an internal RESET when VDD declines.

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

For additional information, refer to Application Note AN607, "Power-up Trouble Shooting".

#### 9.4.2 POWER-UP TIMER (PWRT)

The Power-up Timer provides a fixed 72 ms (nominal) time-out on power-up only, from POR or Brown-out Reset. The Power-up Timer operates on an internal RC oscillator. The chip is kept in RESET as long as PWRT is active. The PWRT delay allows the VDD to rise to an acceptable level. A configuration bit, PWRTE can disable (if set) or enable (if cleared or programmed) the Power-up Timer. The Power-up Timer should always be enabled when Brown-out Reset is enabled.

The Power-up Time delay will vary from chip-to-chip and due to VDD, temperature and process variation. See DC parameters for details.

#### 9.4.3 OSCILLATOR START-UP TIMER (OST)

The Oscillator Start-Up Timer (OST) provides a 1024 oscillator cycle (from OSC1 input) delay after the PWRT delay is over. This ensures that the crystal oscillator or resonator has started and stabilized.

The OST time-out is invoked only for XT, LP and HS modes and only on Power-on Reset or wake-up from SLEEP.

#### 9.4.4 BROWN-OUT RESET (BOR)

The PIC16C62X members have on-chip Brown-out Reset circuitry. A configuration bit, BODEN, can disable (if clear/programmed) or enable (if set) the Brown-out Reset circuitry. If VDD falls below 4.0V refer to VBOR parameter D005 (VBOR) for greater than parameter (TBOR) in Table 12-5. The brown-out situation will RESET the chip. A RESET won't occur if VDD falls below 4.0V for less than parameter (TBOR).

On any RESET (Power-on, Brown-out, Watchdog, etc.) the chip will remain in RESET until VDD rises above BVDD. The Power-up Timer will now be invoked and will keep the chip in RESET an additional 72 ms.

If VDD drops below BVDD while the Power-up Timer is running, the chip will go back into a Brown-out Reset and the Power-up Timer will be re-initialized. Once VDD rises above BVDD, the Power-Up Timer will execute a 72 ms RESET. The Power-up Timer should always be enabled when Brown-out Reset is enabled. Figure 9-7 shows typical Brown-out situations.



#### FIGURE 9-7: BROWN-OUT SITUATIONS

# PIC16C62X

#### **FIGURE 9-11: EXTERNAL POWER-ON RESET CIRCUIT (FOR** SLOW VDD POWER-UP) Vdd Vdd D R R1 MCLR PIC16C62X С Note 1: External Power-on Reset circuit is required only if VDD power-up slope is too slow. The diode D helps discharge the capacitor quickly when VDD powers down. **2:** < 40 k $\Omega$ is recommended to make sure that voltage drop across R does not violate the device's electrical specification. **3:** R1 = $100\Omega$ to 1 k $\Omega$ will limit any current flowing into MCLR from external capacitor C in the event of MCLR/VPP pin

breakdown due to Electrostatic Discharge (ESD) or Electrical Overstress (EOS).

#### FIGURE 9-12: EXTERNAL BROWN-OUT PROTECTION CIRCUIT 1



- Note 1: This circuit will activate RESET when VDD goes below (Vz + 0.7V) where Vz = Zener voltage.
  - **2:** Internal Brown-out Reset circuitry should be disabled when using this circuit.

#### FIGURE 9-13: EXTERNAL BROWN-OUT PROTECTION CIRCUIT 2



**3:** Resistors should be adjusted for the characteristics of the transistor.

#### FIGURE 9-14: EXTERNAL BROWN-OUT PROTECTION CIRCUIT 3



This brown-out protection circuit employs 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.5.1 RB0/INT INTERRUPT

External interrupt on RB0/INT pin is edge triggered, either rising if INTEDG bit (OPTION<6>) is set, or falling, if INTEDG bit is clear. When a valid edge appears on the RB0/INT pin, the INTF bit (INTCON<1>) is set. This interrupt can be disabled by clearing the INTE control bit (INTCON<4>). The INTF bit must be cleared in software in the interrupt service routine before reenabling this interrupt. The RB0/INT interrupt can wake-up the processor from SLEEP, if the INTE bit was set prior to going into SLEEP. The status of the GIE bit decides whether or not the processor branches to the interrupt vector following wake-up. See Section 9.8 for details on SLEEP and Figure 9-18 for timing of wakeup from SLEEP through RB0/INT interrupt.

#### 9.5.2 TMR0 INTERRUPT

An overflow (FFh  $\rightarrow$  00h) in the TMR0 register will set the T0IF (INTCON<2>) bit. The interrupt can be enabled/disabled by setting/clearing T0IE (INTCON<5>) bit. For operation of the Timer0 module, see Section 6.0.

#### 9.5.3 PORTB INTERRUPT

An input change on PORTB <7:4> sets the RBIF (INTCON<0>) bit. The interrupt can be enabled/disabled by setting/clearing the RBIE (INTCON<4>) bit. For operation of PORTB (Section 5.2).

| Note: | If a change on the I/O pin should occur   |
|-------|-------------------------------------------|
|       | when the read operation is being executed |
|       | (start of the Q2 cycle), then the RBIF    |
|       | interrupt flag may not get set.           |

#### 9.5.4 COMPARATOR INTERRUPT

See Section 7.6 for complete description of comparator interrupts.



#### FIGURE 9-16: INT PIN INTERRUPT TIMING

### 9.8 Power-Down Mode (SLEEP)

The Power-down mode is entered by executing a SLEEP instruction.

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

For lowest current consumption in this mode, all I/O pins should be either at VDD or VSs with no external circuitry drawing current from the I/O pin and the comparators and VREF should be disabled. I/O pins that are hi-impedance inputs should be pulled 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 MCLR pin must be at a logic high level (VIHMC).

| Note: | It should be noted that a RESET generated<br>by a WDT time-out does not drive MCLR |  |  |  |  |
|-------|------------------------------------------------------------------------------------|--|--|--|--|
|       | pin low.                                                                           |  |  |  |  |
|       |                                                                                    |  |  |  |  |

#### 9.8.1 WAKE-UP FROM SLEEP

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

- 1. External RESET input on MCLR pin
- 2. Watchdog Timer Wake-up (if WDT was enabled)
- 3. Interrupt from RB0/INT pin, RB Port change, or the Peripheral Interrupt (Comparator).

The first event will cause a device RESET. The two latter events are considered a continuation of program execution. The TO and PD bits in the STATUS register can be used to determine the cause of device RESET. PD bit, which is set on power-up, is cleared when SLEEP is invoked. TO bit is cleared if WDT wake-up occurred.

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 after the SLEEP instruction after the 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 an NOP after the SLEEP instruction.

**Note:** If the global interrupts are disabled (GIE is cleared), but any interrupt source has both its interrupt enable bit and the corresponding interrupt flag bits set, the device will immediately wake-up from SLEEP. The SLEEP instruction is completely executed.

The WDT is cleared when the device wakes up from SLEEP, regardless of the source of wake-up.

| Q1 Q2 Q                  | 3 Q4 Q1 Q2 Q3 Q4 Q | Q1                    | Q1 Q2 Q3 Q4      | Q1 Q2 Q3 Q4 | Q1 Q2 Q3 Q4 0    | Q1 Q2 Q3 Q4 |
|--------------------------|--------------------|-----------------------|------------------|-------------|------------------|-------------|
| OSC1 /\_/\               |                    | AAAAA                 |                  |             |                  |             |
| CLKOUT(4)                |                    | Tost(2)               | <u> </u>         |             | \ <u>`</u>       |             |
| INT pin                  | 1 I                |                       | 1<br>1           |             | 1                |             |
| NTF flag                 |                    |                       | Interrupt Latend | SV.         |                  |             |
| INTCON<1>)               |                    | <del>≉</del>          | (Note 2)         | ,           |                  |             |
| GIE bit<br>INTCON<7>)    |                    | Processor in<br>SLEEP | 1                |             |                  |             |
| INSTRUCTION FLOW         |                    |                       | 1<br>1<br>1      |             | 1                |             |
| PC X PC                  | <u>Υ PC+1 Χ</u>    | PC+2                  | X PC+2           | PC + 2      | <u>χ 0004h χ</u> | 0005h       |
| Instruction { Inst(PC) = | SLEEP Inst(PC + 1) |                       | Inst(PC + 2)     |             | Inst(0004h)      | Inst(0005h) |
| Instruction Inst(PC      | - 1) SLEEP         |                       | Inst(PC + 1)     | Dummy cycle | Dummy cycle      | Inst(0004h) |

#### FIGURE 9-18: WAKE-UP FROM SLEEP THROUGH INTERRUPT

**3:** GIE = '1' assumed. In this case, after wake-up, the processor jumps to the interrupt routine. If GIE = '0', execution will continue in-line.

4: CLKOUT is not available in these Osc modes, but shown here for timing reference.

## **10.1** Instruction Descriptions

| ADDLW            | Add Literal and W                                                                                                          |  |  |  |  |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ADDLW k                                                                                                   |  |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                                                          |  |  |  |  |  |
| Operation:       | $(W) + k \to (W)$                                                                                                          |  |  |  |  |  |
| Status Affected: | C, DC, Z                                                                                                                   |  |  |  |  |  |
| Encoding:        | 11 111x kkkk kkkk                                                                                                          |  |  |  |  |  |
| Description:     | The contents of the W register are<br>added to the eight bit literal 'k' and<br>the result is placed in the W<br>register. |  |  |  |  |  |
| Words:           | 1                                                                                                                          |  |  |  |  |  |
| Cycles:          | 1                                                                                                                          |  |  |  |  |  |
| Example          | ADDLW 0x15                                                                                                                 |  |  |  |  |  |
|                  | Before Instruction<br>W = 0x10<br>After Instruction<br>W = 0x25                                                            |  |  |  |  |  |

| ANDLW            | AND Literal with W                                                                                                     |  |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ANDLW k                                                                                               |  |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                                                      |  |  |  |  |  |
| Operation:       | (W) .AND. (k) $\rightarrow$ (W)                                                                                        |  |  |  |  |  |
| Status Affected: | Z                                                                                                                      |  |  |  |  |  |
| Encoding:        | 11 1001 kkkk kkkk                                                                                                      |  |  |  |  |  |
| Description:     | The contents of W register are<br>AND'ed with the eight bit literal 'k'.<br>The result is placed in the W<br>register. |  |  |  |  |  |
| Words:           | 1                                                                                                                      |  |  |  |  |  |
| Cycles:          | 1                                                                                                                      |  |  |  |  |  |
| Example          | ANDLW 0x5F                                                                                                             |  |  |  |  |  |
|                  | Before Instruction<br>W = 0xA3<br>After Instruction<br>W = 0x03                                                        |  |  |  |  |  |
| ANDWF            | AND W with f                                                                                                           |  |  |  |  |  |

| ADDWF            | Add W and f                                                                                                                                                                    |  |  |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ADDWF f,d                                                                                                                                                     |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0\leq f\leq 127\\ d\in[0,1] \end{array}$                                                                                                                     |  |  |  |  |  |
| Operation:       | (W) + (f) $\rightarrow$ (dest)                                                                                                                                                 |  |  |  |  |  |
| Status Affected: | C, DC, Z                                                                                                                                                                       |  |  |  |  |  |
| Encoding:        | 00 0111 dfff ffff                                                                                                                                                              |  |  |  |  |  |
| Description:     | Add the contents of the W register<br>with register 'f'. If 'd' is 0, the result<br>is stored in the W register. If 'd' is<br>1, the result is stored back in<br>register 'f'. |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                              |  |  |  |  |  |
| Cycles:          | 1                                                                                                                                                                              |  |  |  |  |  |
| Example          | ADDWF FSR, <b>O</b>                                                                                                                                                            |  |  |  |  |  |
|                  | Before Instruction<br>W = 0x17<br>FSR = 0xC2<br>After Instruction<br>W = 0xD9<br>FSR = 0xC2                                                                                    |  |  |  |  |  |

| ANDWF            | AND W with f                                                                                                                                                |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ANDWF f,d                                                                                                                                  |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in  [0,1] \end{array}$                                                                                           |  |  |  |  |  |
| Operation:       | (W) .AND. (f) $\rightarrow$ (dest)                                                                                                                          |  |  |  |  |  |
| Status Affected: | Z                                                                                                                                                           |  |  |  |  |  |
| Encoding:        | 00 0101 dfff ffff                                                                                                                                           |  |  |  |  |  |
| Description:     | AND the W register with register<br>'f'. If 'd' is 0, the result is stored in<br>the W register. If 'd' is 1, the result<br>is stored back in register 'f'. |  |  |  |  |  |
| Words:           | 1                                                                                                                                                           |  |  |  |  |  |
| Cycles:          | 1                                                                                                                                                           |  |  |  |  |  |
| Example          | ANDWF FSR, <b>1</b>                                                                                                                                         |  |  |  |  |  |
|                  | Before Instruction<br>W = 0x17<br>FSR = 0xC2<br>After Instruction<br>W = 0x17<br>FSR = 0x02                                                                 |  |  |  |  |  |

| SWAPF            | Swap Ni                                                                                                                                                                    | bbles in  | f          |                   |  |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------|-------------------|--|--|
| Syntax:          | [label]                                                                                                                                                                    | SWAPF     | f,d        |                   |  |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                         |           |            |                   |  |  |
| Operation:       | (f<3:0>) -<br>(f<7:4>) -                                                                                                                                                   |           | <i>,</i> . |                   |  |  |
| Status Affected: | None                                                                                                                                                                       |           |            |                   |  |  |
| Encoding:        | 00                                                                                                                                                                         | 1110      | dfff       | ffff              |  |  |
| Description:     | The upper and lower nibbles of<br>register 'f' are exchanged. If 'd' is<br>0, the result is placed in W<br>register. If 'd' is 1, the result is<br>placed in register 'f'. |           |            | d. If 'd' is<br>W |  |  |
| Words:           | 1                                                                                                                                                                          |           |            |                   |  |  |
| Cycles:          | 1                                                                                                                                                                          |           |            |                   |  |  |
| Example          | SWAPF REG, 0                                                                                                                                                               |           |            |                   |  |  |
|                  | Before Instruction                                                                                                                                                         |           |            |                   |  |  |
|                  |                                                                                                                                                                            | REG1      | = (        | DxA5              |  |  |
|                  | After Inst                                                                                                                                                                 | ruction   |            |                   |  |  |
|                  |                                                                                                                                                                            | REG1<br>W |            | 0xA5<br>0x5A      |  |  |

| TRIS             | Load TRIS Register                                                                                                                                                                 |  |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] TRIS f                                                                                                                                                            |  |  |  |  |  |
| Operands:        | $5 \leq f \leq 7$                                                                                                                                                                  |  |  |  |  |  |
| Operation:       | $(W) \rightarrow TRIS$ register f;                                                                                                                                                 |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                                               |  |  |  |  |  |
| Encoding:        | 00 0000 0110 Offf                                                                                                                                                                  |  |  |  |  |  |
| Description:     | The instruction is supported for<br>code compatibility with the<br>PIC16C5X products. Since TRIS<br>registers are readable and<br>writable, the user can directly<br>address them. |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                                  |  |  |  |  |  |
| Cycles:          | 1                                                                                                                                                                                  |  |  |  |  |  |
| Example          |                                                                                                                                                                                    |  |  |  |  |  |
|                  | To maintain upward compatibil-<br>ity with future PICmicro <sup>®</sup> prod-<br>ucts, do not use this<br>instruction.                                                             |  |  |  |  |  |

| XORLW                                                                                         | Exclusive OR Literal with W                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:                                                                                       | [ <i>label</i> XORLW k<br>]                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| Operands:                                                                                     | $0 \le k \le 255$                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| Operation:                                                                                    | (W) .XOR. $k \rightarrow (W)$                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| Status Affected:                                                                              | Z                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| Encoding:                                                                                     | 11 1010 kkkk kkkk                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| Description:                                                                                  | The contents of the W register<br>are XOR'ed with the eight bit<br>literal 'k'. The result is placed in<br>the W register.                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| Words:                                                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| Cycles:                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| Example:                                                                                      | XORLW 0xAF                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                                                                                               | Before Instruction                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                                                                                               | W = 0xB5                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|                                                                                               | After Instruction                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|                                                                                               | W = 0x1A                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| XORWF                                                                                         | Exclusive OR W with f                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| Syntax:                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|                                                                                               | [ <i>label</i> ] XORWF f,d                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| Operands:                                                                                     | $ \begin{array}{l} \left[ \begin{array}{c} \textit{label} \end{array} \right]  \text{XORWF}  f,d \\ 0 \leq f \leq 127 \\ d \in [0,1] \end{array} $                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| -                                                                                             | $0 \le f \le 127$                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| Operands:                                                                                     | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| Operands:<br>Operation:                                                                       | $0 \le f \le 127$<br>$d \in [0,1]$<br>(W) .XOR. (f) $\rightarrow$ (dest)                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:                                                   | $0 \le f \le 127$<br>$d \in [0,1]$<br>(W) .XOR. (f) $\rightarrow$ (dest)<br>Z                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:                                      | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \\ (W) . XOR. (f) \rightarrow (dest) \\ \hline Z \\ \hline 00 & 0110 & dfff & ffff \\ \hline Exclusive OR the contents of the \\ W register with register 'f'. If 'd' is \\ 0, the result is stored in the W \\ register. If 'd' is 1, the result is \\ \end{array}$                                                                                                       |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                      | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \\ (W) .XOR. (f) \rightarrow (dest) \\ \hline Z \\ \hline 00 & 0110 & dfff & ffff \\ \hline Exclusive OR the contents of the \\ W register with 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'. \end{array}$                                                                           |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:            | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \\ (W) . XOR. (f) \rightarrow (dest) \\ \hline Z \\ \hline \hline 00 & 0110 & dfff & ffff \\ \hline Exclusive OR the contents of the \\ W register with 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'. \\ 1 \end{array}$                                                              |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles: | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \\ (W) . XOR. (f) \rightarrow (dest) \\ \hline Z \\ \hline \hline 00 & 0110 & dfff & ffff \\ \hline Exclusive OR the contents of the \\ W register with 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'. \\ 1 \\ 1 \end{array}$                                                            |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles: | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \\ (W) . XOR. (f) \rightarrow (dest) \\ \hline Z \\ \hline 00 & 0110 & dfff & ffff \\ \hline Exclusive OR the contents of the \\ W register with 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'. \\ 1 \\ 1 \\ XORWF & REG & 1 \\ \end{array}$                                          |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles: | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \\ (W) .XOR. (f) \rightarrow (dest) \\ Z \\ \hline 00 & 0110 & dfff & ffff \\ \hline Exclusive OR the contents of the \\ W register with 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'. \\ 1 \\ 1 \\ XORWF & REG & 1 \\ \hline Before Instruction \\ \hline REG & = 0xAF \\ \end{array}$ |  |  |  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles: | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |

# PIC16C62X

NOTES:

## 12.0 ELECTRICAL SPECIFICATIONS

#### Absolute Maximum Ratings †

| Ambient Temperature under bias                                                                                 | 40° to +125°C                  |
|----------------------------------------------------------------------------------------------------------------|--------------------------------|
| Storage Temperature                                                                                            | 65° to +150°C                  |
| Voltage on any pin with respect to Vss (except VDD and MCLR)                                                   | 0.6V to VDD +0.6V              |
| Voltage on VDD with respect to Vss                                                                             | 0 to +7.5V                     |
| Voltage on MCLR with respect to Vss (Note 2)                                                                   | 0 to +14V                      |
| Voltage on RA4 with respect to Vss                                                                             |                                |
| Total power Dissipation (Note 1)                                                                               | 1.0W                           |
| Maximum Current out of Vss pin                                                                                 | 300 mA                         |
| Maximum Current into VDD pin                                                                                   | 250 mA                         |
| Input Clamp Current, Iк (Vi <0 or Vi> VDD)                                                                     | ±20 mA                         |
| Output Clamp Current, Iок (Vo <0 or Vo>VoD)                                                                    | ±20 mA                         |
| Maximum Output Current sunk by any I/O pin                                                                     | 25 mA                          |
| Maximum Output Current sourced by any I/O pin                                                                  | 25 mA                          |
| Maximum Current sunk by PORTA and PORTB                                                                        | 200 mA                         |
| Maximum Current sourced by PORTA and PORTB                                                                     | 200 mA                         |
| <b>Note 1:</b> Power dissipation is calculated as follows: PDIS = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD-VOH) | x IOH} + $\Sigma$ (VOI x IOL). |

2: Voltage spikes below Vss at the MCLR pin, inducing currents greater than 80 mA, may cause latchup. Thus, a series resistor of 50-100Ω should be used when applying a "low" level to the MCLR 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.

#### 12.1 DC Characteristics: PIC16C62X-04 (Commercial, Industrial, Extended) PIC16C62X-20 (Commercial, Industrial, Extended) PIC16LC62X-04 (Commercial, Industrial, Extended) (CONT.)

|                                                                   |                                                                   |                                                                                                                                                                                                                                                                        | Stand                                                                                                               | dard O                             | perati                                            | ng Con                                                                                                                                                                                                                                                                    | ditions (unless otherwise stated)                                                                                          |
|-------------------------------------------------------------------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|------------------------------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| PIC16C62X                                                         |                                                                   | Opera                                                                                                                                                                                                                                                                  | ating te                                                                                                            | empera                             |                                                   | $\begin{array}{ll} 0^{\circ}C & \leq TA \leq +85^{\circ}C \text{ for industrial and} \\ 0^{\circ}C & \leq TA \leq +70^{\circ}C \text{ for commercial and} \\ 0^{\circ}C & \leq TA \leq +125^{\circ}C \text{ for extended} \end{array}$                                    |                                                                                                                            |
| PIC16L                                                            |                                                                   |                                                                                                                                                                                                                                                                        | $-40^{\circ}C  \leq TA \leq +125^{\circ}C \text{ for extended}$ Operating voltage VDD range is the PIC16C62X range. |                                    |                                                   | $\begin{array}{lll} 0^{\circ}C &\leq TA \leq +85^{\circ}C \text{ for industrial and} \\ 0^{\circ}C &\leq TA \leq +70^{\circ}C \text{ for commercial and} \\ 0^{\circ}C &\leq TA \leq +125^{\circ}C \text{ for extended} \\ \text{ge is the PIC16C62X range.} \end{array}$ |                                                                                                                            |
| Param<br>. No.                                                    | Sym                                                               | Characteristic                                                                                                                                                                                                                                                         | Min                                                                                                                 | Тур†                               | Мах                                               | Units                                                                                                                                                                                                                                                                     | Conditions                                                                                                                 |
| D022<br>D022A<br>D023<br>D023A<br>D022A<br>D022A<br>D022A<br>D023 | ΔIWDT<br>ΔIBOR<br>ΔICOM<br>P<br>ΔIVREF<br>ΔIWDT<br>ΔIBOR<br>ΔICOM | WDT Current <sup>(5)</sup><br>Brown-out Reset Current <sup>(5)</sup><br>Comparator Current for each<br>Comparator <sup>(5)</sup><br>VREF Current <sup>(5)</sup><br>WDT Current <sup>(5)</sup><br>Brown-out Reset Current <sup>(5)</sup><br>Comparator Current for each |                                                                                                                     | 6.0<br>350<br>—<br>6.0<br>350<br>— | 20<br>25<br>425<br>100<br>300<br>15<br>425<br>100 | μΑ<br>μΑ<br>μΑ<br>μΑ<br>μΑ<br>μΑ<br>μΑ                                                                                                                                                                                                                                    | VDD=4.0V $(125°C)$ $BOD enabled, VDD = 5.0V$ $VDD = 4.0V$ $VDD = 4.0V$ $VDD = 3.0V$ $BOD enabled, VDD = 5.0V$ $VDD = 3.0V$ |
| D023A                                                             | P<br>∆IVREF                                                       | Comparator <sup>(5)</sup><br>VREF Current <sup>(5)</sup>                                                                                                                                                                                                               | —                                                                                                                   | —                                  | 300                                               | μA                                                                                                                                                                                                                                                                        | VDD = 3.0V                                                                                                                 |
| 1A                                                                | Fosc                                                              | LP Oscillator Operating Frequency<br>RC Oscillator Operating Frequency<br>XT Oscillator Operating Frequency<br>HS Oscillator Operating Frequency                                                                                                                       | 0<br>0<br>0<br>0                                                                                                    | <br> <br>                          | 200<br>4<br>4<br>20                               | kHz<br>MHz<br>MHz<br>MHz                                                                                                                                                                                                                                                  | All temperatures<br>All temperatures<br>All temperatures<br>All temperatures                                               |
| 1A                                                                | Fosc                                                              | LP Oscillator Operating Frequency<br>RC Oscillator Operating Frequency<br>XT Oscillator Operating Frequency<br>HS Oscillator Operating Frequency                                                                                                                       | 0<br>0<br>0<br>0                                                                                                    |                                    | 200<br>4<br>4<br>20                               | kHz<br>MHz<br>MHz<br>MHz                                                                                                                                                                                                                                                  | All temperatures<br>All temperatures<br>All temperatures<br>All temperatures                                               |

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: This is the limit to which VDD can be lowered without losing RAM data.

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

The test conditions for all IDD measurements in Active Operation mode are:

OSC1 = external square wave, from rail to rail; all I/O pins tri-stated, pulled to VDD,

MCLR = VDD; WDT enabled/disabled as specified.

**3:** The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD or VSS.

4: For RC osc configuration, current through REXT is not included. The current through the resistor can be estimated by the formula: Ir = VDD/2REXT (mA) with REXT in kΩ.

5: The  $\Delta$  current is the additional current consumed when this peripheral is enabled. This current should be added to the base IDD or IPD measurement.

#### 12.2 DC Characteristics: PIC16C62XA-04 (Commercial, Industrial, Extended) PIC16C62XA-20 (Commercial, Industrial, Extended) PIC16LC62XA-04 (Commercial, Industrial, Extended)

| PIC16C62XA<br>PIC16LC62XA |      |                                               | Opera<br>Stand | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |      |       |                                              |  |  |  |
|---------------------------|------|-----------------------------------------------|----------------|------------------------------------------------------|------|-------|----------------------------------------------|--|--|--|
| Param.<br>No.             | Sym  | Characteristic                                | Min            | Тур†                                                 | Мах  | Units | Conditions                                   |  |  |  |
| D001                      | Vdd  | Supply Voltage                                | 3.0            | _                                                    | 5.5  | V     | See Figures 12-1, 12-2, 12-3, 12-4, and 12-5 |  |  |  |
| D001                      | Vdd  | Supply Voltage                                | 2.5            | _                                                    | 5.5  | V     | See Figures 12-1, 12-2, 12-3, 12-4, and 12-5 |  |  |  |
| D002                      | Vdr  | RAM Data Retention<br>Voltage <sup>(1)</sup>  | _              | 1.5*                                                 |      | V     | Device in SLEEP mode                         |  |  |  |
| D002                      | Vdr  | RAM Data Retention Voltage <sup>(1)</sup>     |                | 1.5*                                                 |      | V     | Device in SLEEP mode                         |  |  |  |
| D003                      | VPOR | VDD start voltage to<br>ensure Power-on Reset |                | Vss                                                  | _    | V     | See section on Power-on Reset for details    |  |  |  |
| D003                      | VPOR | VDD start voltage to<br>ensure Power-on Reset |                | Vss                                                  | —    | V     | See section on Power-on Reset for details    |  |  |  |
| D004                      | SVDD | VDD rise rate to ensure<br>Power-on Reset     | 0.05*          | —                                                    | —    | V/ms  | See section on Power-on Reset for details    |  |  |  |
| D004                      | SVDD | VDD rise rate to ensure<br>Power-on Reset     | 0.05*          | —                                                    | —    | V/ms  | See section on Power-on Reset for details    |  |  |  |
| D005                      | VBOR | Brown-out Detect Voltage                      | 3.7            | 4.0                                                  | 4.35 | V     | BOREN configuration bit is cleared           |  |  |  |
| D005                      | VBOR | Brown-out Detect Voltage                      | 3.7            | 4.0                                                  | 4.35 | V     | BOREN configuration bit is cleared           |  |  |  |

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: This is the limit to which VDD can be lowered without losing RAM data.

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

The test conditions for all IDD measurements in Active Operation mode are:

OSC1 = external square wave, from rail to rail; all I/O pins tri-stated, pulled to VDD, MCLR = VDD; WDT enabled/disabled as specified.

3: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD or Vss.

4: For RC osc configuration, current through REXT is not included. The current through the resistor can be estimated by the formula: Ir = VDD/2REXT (mA) with REXT in kΩ.

5: The  $\Delta$  current is the additional current consumed when this peripheral is enabled. This current should be added to the base IDD or IPD measurement.

**6:** Commercial temperature range only.

### 12.3 DC CHARACTERISTICS: PIC16CR62XA-04 (Commercial, Industrial, Extended) PIC16CR62XA-20 (Commercial, Industrial, Extended) PIC16LCR62XA-04 (Commercial, Industrial, Extended)

| PIC16CR62XA-04<br>PIC16CR62XA-20 |      |                                               | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |                                                      |            |          |                                                                                                                   |  |  |  |
|----------------------------------|------|-----------------------------------------------|------------------------------------------------------|------------------------------------------------------|------------|----------|-------------------------------------------------------------------------------------------------------------------|--|--|--|
| PIC16LCR62XA-04                  |      |                                               |                                                      | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |            |          |                                                                                                                   |  |  |  |
| Param.<br>No.                    | Sym  | Characteristic                                | Min                                                  | Тур†                                                 | Мах        | Units    | Conditions                                                                                                        |  |  |  |
| D001                             | Vdd  | Supply Voltage                                | 3.0                                                  | —                                                    | 5.5        | V        | See Figures 12-7, 12-8, 12-9                                                                                      |  |  |  |
| D001                             | Vdd  | Supply Voltage                                | 2.5                                                  | _                                                    | 5.5        | V        | See Figures 12-7, 12-8, 12-9                                                                                      |  |  |  |
| D002                             | Vdr  | RAM Data Retention<br>Voltage <sup>(1)</sup>  |                                                      | 1.5*                                                 |            | V        | Device in SLEEP mode                                                                                              |  |  |  |
| D002                             | Vdr  | RAM Data Retention<br>Voltage <sup>(1)</sup>  | _                                                    | 1.5*                                                 | —          | V        | Device in SLEEP mode                                                                                              |  |  |  |
| D003                             | VPOR | VDD start voltage to<br>ensure Power-on Reset |                                                      | Vss                                                  | _          | V        | See section on Power-on Reset for details                                                                         |  |  |  |
| D003                             | VPOR | VDD start voltage to<br>ensure Power-on Reset | —                                                    | Vss                                                  | —          | V        | See section on Power-on Reset for details                                                                         |  |  |  |
| D004                             | SVDD | VDD rise rate to ensure<br>Power-on Reset     | 0.05*                                                | —                                                    | —          | V/ms     | See section on Power-on Reset for details                                                                         |  |  |  |
| D004                             | SVDD | VDD rise rate to ensure<br>Power-on Reset     | 0.05*                                                | —                                                    | —          | V/ms     | See section on Power-on Reset for details                                                                         |  |  |  |
| D005                             | VBOR | Brown-out Detect Voltage                      | 3.7                                                  | 4.0                                                  | 4.35       | V        | BOREN configuration bit is cleared                                                                                |  |  |  |
| D005                             | VBOR | Brown-out Detect Voltage                      | 3.7                                                  | 4.0                                                  | 4.35       | V        | BOREN configuration bit is cleared                                                                                |  |  |  |
| D010                             | Idd  | Supply Current <sup>(2)</sup>                 | _                                                    | 1.2<br>500                                           | 1.7<br>900 | mA<br>μA | Fosc = 4 MHz, VDD = 5.5V, WDT disabled, XT mode,<br>(Note 4)*<br>Fosc = 4 MHz, VDD = 3.0V, WDT disabled, XT mode, |  |  |  |
|                                  |      |                                               | _                                                    | 1.0                                                  | 2.0        | mA       | (Note 4)<br>Fosc = 10 MHz, VDD = 3.0V, WDT disabled, HS mode,<br>(Note 6)                                         |  |  |  |
|                                  |      |                                               | —                                                    | 4.0                                                  | 7.0        | mA       | Fosc = 20 MHz, VDD = 5.5V, WDT disabled*, HS                                                                      |  |  |  |
|                                  |      |                                               | —                                                    | 3.0                                                  | 6.0        | mA       | mode                                                                                                              |  |  |  |
|                                  |      |                                               |                                                      | 35                                                   | 70         | μA       | Fosc = 20 MHz, VDD = 4.5V, WDT disabled, HS mode<br>Fosc = 32 kHz, VDD = 3.0V, WDT disabled, LP mode              |  |  |  |
| D010                             | IDD  | Supply Current <sup>(2)</sup>                 | —                                                    | 1.2                                                  | 1.7        | mA       | Fosc = 4.0 MHz, VDD = 5.5V, WDT disabled, XT<br>mode, ( <b>Note 4</b> )*                                          |  |  |  |
|                                  |      |                                               | _                                                    | 400                                                  | 800        | μA       | Fosc = 4.0 MHz, VDD = 2.5V, WDT disabled, XT mode (Note 4)                                                        |  |  |  |
|                                  |      |                                               | —                                                    | 35                                                   | 70         | μA       | Fosc = 32 kHz, VDD = 2.5V, WDT disabled, LP mode                                                                  |  |  |  |

#### 12.4 DC Characteristics: PIC16C62X/C62XA/CR62XA (Commercial, Industrial, Extended) PIC16LC62X/LC62XA/LCR62XA (Commercial, Industrial, Extended) (CONT.)

| PIC16C62X/C62XA/CR62XA |                                                       |                                                                     | $\begin{array}{l lllllllllllllllllllllllllllllllllll$ |      |            |       |                                                             |  |
|------------------------|-------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------|------|------------|-------|-------------------------------------------------------------|--|
| PIC16L0                | $\begin{array}{l lllllllllllllllllllllllllllllllllll$ |                                                                     |                                                       |      |            |       |                                                             |  |
| Param.<br>No.          | Sym                                                   | Characteristic                                                      | Min                                                   | Тур† | Мах        | Units | Conditions                                                  |  |
|                        | Vih                                                   | Input High Voltage                                                  |                                                       |      |            |       |                                                             |  |
| D040                   |                                                       | with TTL buffer                                                     | 2.0V<br>0.25 VDD<br>+ 0.8V                            | _    | Vdd<br>Vdd | V     | VDD = 4.5V to 5.5V<br>otherwise                             |  |
| D041                   |                                                       | with Schmitt Trigger input                                          | 0.8 Vdd                                               | _    | VDD        |       |                                                             |  |
| D042                   |                                                       | MCLR RA4/T0CKI                                                      | 0.8 VDD                                               | _    | Vdd        | V     |                                                             |  |
| D043<br>D043A          |                                                       | OSC1 (XT, HS and LP)<br>OSC1 (in RC mode)                           | 0.7 Vdd<br>0.9 Vdd                                    | -    | Vdd        | V     | (Note 1)                                                    |  |
| D070                   | IPURB                                                 | PORTB weak pull-up current                                          | 50                                                    | 200  | 400        | μA    | VDD = 5.0V, VPIN = VSS                                      |  |
| D070                   | IPURB                                                 | PORTB weak pull-up current                                          | 50                                                    | 200  | 400        | μA    | VDD = 5.0V, VPIN = VSS                                      |  |
|                        | lı∟                                                   | Input Leakage Current <sup>(2, 3)</sup><br>I/O ports (Except PORTA) |                                                       |      | ±1.0       | μA    | Vss ≤ VPIN ≤ VDD, pin at hi-impedance                       |  |
| D060                   |                                                       | PORTA                                                               | _                                                     | _    | ±0.5       | μΑ    | $Vss \leq VPIN \leq VDD$ , pin at hi-impedance              |  |
| D061                   |                                                       | RA4/T0CKI                                                           | _                                                     | _    | ±1.0       | μΑ    | $Vss \leq VPIN \leq VDD$                                    |  |
| D063                   |                                                       | OSC1, MCLR                                                          | _                                                     | _    | ±5.0       | μA    | Vss $\leq$ VPIN $\leq$ VDD, XT, HS and LP osc configuration |  |
|                        | lı∟                                                   | Input Leakage Current <sup>(2, 3)</sup>                             |                                                       |      |            |       |                                                             |  |
|                        |                                                       | I/O ports (Except PORTA)                                            |                                                       |      | ±1.0       | μA    | Vss $\leq$ VPIN $\leq$ VDD, pin at hi-impedance             |  |
| D060                   |                                                       | PORTA                                                               | -                                                     | —    | ±0.5       | μA    | $Vss \le VPIN \le VDD$ , pin at hi-impedance                |  |
| D061                   |                                                       | RA4/T0CKI                                                           | -                                                     | —    | ±1.0       | μA    | $Vss \leq V \text{PIN} \leq V \text{DD}$                    |  |
| D063                   |                                                       | OSC1, MCLR                                                          | —                                                     | —    | ±5.0       | μΑ    | Vss $\leq$ VPIN $\leq$ VDD, XT, HS and LP osc configuration |  |
|                        | Vol                                                   | Output Low Voltage                                                  |                                                       |      |            |       |                                                             |  |
| D080                   |                                                       | I/O ports                                                           | —                                                     | —    | 0.6        | V     | IOL = 8.5 mA, VDD = 4.5V, $-40^{\circ}$ to $+85^{\circ}$ C  |  |
|                        |                                                       |                                                                     | —                                                     | -    | 0.6        | V     | IOL = 7.0 mA, VDD = 4.5V, +125°C                            |  |
| D083                   |                                                       | OSC2/CLKOUT (RC only)                                               | —                                                     | -    | 0.6        | V     | IOL = 1.6 mA, VDD = 4.5V, $-40^{\circ}$ to $+85^{\circ}$ C  |  |
|                        |                                                       |                                                                     | —                                                     | —    | 0.6        | V     | IOL = 1.2 mA, VDD = 4.5V, +125°C                            |  |

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

Note 1: In RC oscillator configuration, the OSC1 pin is a Schmitt Trigger input. It is not recommended that the PIC16C62X(A) be driven with external clock in RC mode.

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

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

## 12.8 Timing Parameter Symbology

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

1. TppS2ppS

2. TppS

| 2. Tpp3                               |                                               |     |              |  |  |  |  |
|---------------------------------------|-----------------------------------------------|-----|--------------|--|--|--|--|
| т                                     |                                               |     |              |  |  |  |  |
| F                                     | Frequency                                     | Т   | Time         |  |  |  |  |
| Lowerca                               | Lowercase subscripts (pp) and their meanings: |     |              |  |  |  |  |
| рр                                    |                                               |     |              |  |  |  |  |
| ck                                    | CLKOUT                                        | osc | OSC1         |  |  |  |  |
| io                                    | I/O port                                      | t0  | TOCKI        |  |  |  |  |
| mc                                    | MCLR                                          |     |              |  |  |  |  |
| Uppercase letters and their meanings: |                                               |     |              |  |  |  |  |
| S                                     |                                               |     |              |  |  |  |  |
| F                                     | Fall                                          | Р   | Period       |  |  |  |  |
| н                                     | High                                          | R   | Rise         |  |  |  |  |
| I                                     | Invalid (Hi-impedance)                        | V   | Valid        |  |  |  |  |
| L                                     | Low                                           | Z   | Hi-Impedance |  |  |  |  |

#### FIGURE 12-11: LOAD CONDITIONS

