# E·XFL



Welcome to E-XFL.COM

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

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

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

#### Details

| Betails                    |                                                                              |
|----------------------------|------------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                     |
| 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        | 1.75KB (1K x 14)                                                             |
| Program Memory Type        | OTP                                                                          |
| EEPROM Size                | 128 x 8                                                                      |
| RAM Size                   | 96 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             | 20-SSOP (0.209", 5.30mm Width)                                               |
| Supplier Device Package    | 20-SSOP                                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lce624-04e-ss |

Email: info@E-XFL.COM

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

#### 3.1 Clocking Scheme/Instruction Cycle

The clock input (OSC1/CLKIN pin) is internally divided by four to generate four non-overlapping quadrature clocks namely Q1, Q2, Q3 and Q4. Internally, the program counter (PC) is incremented every Q1, the instruction is fetched from the program memory and latched into the instruction register in Q4. The instruction is decoded and executed during the following Q1 through Q4. The clocks and instruction execution flow is shown in Figure 3-2.

#### 3.2 Instruction Flow/Pipelining

An "Instruction Cycle" consists of four Q cycles (Q1, Q2, Q3 and Q4). The instruction fetch and execute are pipelined such that fetch takes one instruction cycle, while decode and execute takes another instruction cycle. However, due to the pipelining, each instruction effectively executes in one cycle. If an instruction causes the program counter to change (i.e., GOTO) then two cycles are required to complete the instruction (Example 3-1).

A fetch cycle begins with the program counter (PC) incrementing in Q1.

In the execution cycle, the fetched instruction is latched into the "Instruction Register (IR)" in cycle Q1. This instruction is then decoded and executed during the Q2, Q3, and Q4 cycles. Data memory is read during Q2 (operand read) and written during Q4 (destination write).



#### FIGURE 3-2: CLOCK/INSTRUCTION CYCLE





All instructions are single cycle, except for any program branches. These take two cycles since the fetch instruction is "flushed" from the pipeline, while the new instruction is being fetched and then executed.

#### FIGURE 4-4: DATA MEMORY MAP FOR THE PIC16CE623/624

| 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                                                                                       |                                | EEINTF              | 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<br>Purpose<br>Register |                     |                 |  |  |
|                                                                                           |                                |                     |                 |  |  |
|                                                                                           |                                |                     | EFh             |  |  |
|                                                                                           |                                | Accesses            | F0h             |  |  |
| 7Fh                                                                                       |                                | 70h-7Fh             | FFh             |  |  |
| / [1]                                                                                     | Bank 0                         | Bank 1              |                 |  |  |
| Unimplemented data memory locations, read as '0'. <b>Note 1:</b> Not a physical register. |                                |                     |                 |  |  |

#### FIGURE 4-5: DATA MEMORY MAP FOR THE PIC16CE625

| File                                    |                     |                     | File       |  |  |
|-----------------------------------------|---------------------|---------------------|------------|--|--|
| Address                                 | ;                   |                     | 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                                     |                     | EEINTF              | 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             | AUII       |  |  |
|                                         | Purpose<br>Register | Purpose<br>Register |            |  |  |
|                                         | negistei            | negister            | BFh        |  |  |
|                                         |                     |                     | C0h        |  |  |
|                                         |                     |                     |            |  |  |
|                                         |                     | _                   | F0h        |  |  |
|                                         |                     | Accesses            |            |  |  |
| 751                                     |                     | 70h-7Fh             | FFh        |  |  |
| 7Fh I                                   | Bank 0              | Bank 1              | J FFN      |  |  |
| <b>—</b>                                |                     |                     |            |  |  |
|                                         | plemented data me   |                     | ad as '0'. |  |  |
| <b>Note 1:</b> Not a physical register. |                     |                     |            |  |  |

#### 4.4 Indirect Addressing, INDF and FSR Registers

The INDF register is not a physical register. Addressing the INDF register will cause indirect addressing.

Indirect addressing is possible by using the INDF register. Any instruction using the INDF register actually accesses data pointed to by the File Select Register (FSR). Reading INDF itself indirectly will produce 00h. Writing to the INDF register indirectly results in a no-operation (although status bits may be affected). An effective 9-bit address is obtained by concatenating the 8-bit FSR register and the IRP bit (STATUS<7>), as shown in Figure 4-7. However, IRP is not used in the PIC16CE62X. A simple program to clear RAM location 20h-2Fh using indirect addressing is shown in Example 4-1.

| EXAMPL    | E 4-1: | INDIRECT ADDRESSING |                      |  |  |  |
|-----------|--------|---------------------|----------------------|--|--|--|
|           | movlw  | 0x20                | ;initialize pointer  |  |  |  |
|           | movwf  | FSR                 | ;to RAM              |  |  |  |
| NEXT      | clrf   | INDF                | clear INDF register; |  |  |  |
|           | incf   | FSR                 | ;inc pointer         |  |  |  |
|           | btfss  | FSR,4               | ;all done?           |  |  |  |
|           | goto   | NEXT                | ;no clear next       |  |  |  |
|           |        |                     | ;yes continue        |  |  |  |
| CONTINUE: |        |                     |                      |  |  |  |

### FIGURE 4-7: DIRECT/INDIRECT ADDRESSING PIC16CE62X



### 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  $\overline{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 (i.e., 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>).





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.





#### 5.3 <u>I/O Programming Considerations</u>

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

Any instruction which writes, operates internally as a read followed by a write operation. The BCF and BSF instructions, for example, read the register into the CPU, execute the bit operation and write the result back to the register. Caution must be used when these instructions are applied to a port with both inputs and outputs defined. For example, a BSF operation on bit5 of PORTB will cause all eight bits of PORTB to be read into the CPU. Then the BSF operation takes place on bit5 and PORTB is written to the output latches. If another bit of PORTB is used as a bidirectional I/O pin (i.e., bit0) and it is defined as an input at this time, the input signal present on the pin itself would be read into the CPU and re-written to the data latch of this particular pin, overwriting the previous content. As long as the pin stays in the input mode, no problem occurs. However, if bit0 is switched into output mode later on, the content of the data latch may now be unknown.

Reading the port register, reads the values of the port pins. Writing to the port register writes the value to the port latch. When using read modify write instructions (i.e., BCF, BSF, etc.) on a port, the value of the port pins is read, the desired operation is done to this value, and this value is then written to the port latch.

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

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

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

; Initial PORT settings: PORTB<7:4> Inputs ; PORTB<3:0> Outputs ; ; PORTB<7:6> have external pull-up and are not ; connected to other circuitry ; PORT latch PORT pins ; ; BCF PORTB. 7 ; 01pp pppp 11pp pppp BCF PORTB, 6 ; 10pp pppp 11pp pppp BSF STATUS, RPO ; BCF TRISB, 7 ; 10pp pppp 11pp pppp BCF TRISB, 6 ; 10pp pppp 10pp pppp ; ; Note that the user may have expected the pin

; values to be 00pp pppp. The 2nd BCF caused ; RB7 to be latched as the pin value (High).

#### 5.3.2 SUCCESSIVE OPERATIONS ON I/O PORTS

The actual write to an I/O port happens at the end of an instruction cycle, whereas for reading, the data must be valid at the beginning of the instruction cycle (Figure 5-7). Therefore, care must be exercised if a write followed by a read operation is carried out on the same I/O port. The sequence of instructions should allow the pin voltage to stabilize (load dependent) before the next instruction causes that file to be read into the CPU. Otherwise, the previous state of that pin may be read into the CPU rather than the new state. When in doubt, it is better to separate these instructions with an NOP or another instruction not accessing this I/O port.



#### FIGURE 5-7: SUCCESSIVE I/O OPERATION

#### 7.2 Using Timer0 with External Clock

When an external clock input is used for Timer0, it must meet certain requirements. The external clock requirement is due to internal phase clock (Tosc) synchronization. Also, there is a delay in the actual incrementing of Timer0 after synchronization.

#### 7.2.1 EXTERNAL CLOCK SYNCHRONIZATION

When no prescaler is used, the external clock input is the same as the prescaler output. The synchronization of T0CKI with the internal phase clocks is accomplished by sampling the prescaler output on the Q2 and Q4 cycles of the internal phase clocks (Figure 7-5). Therefore, it is necessary for T0CKI to be high for at least 2Tosc (and a small RC delay of 20 ns) and low for at least 2Tosc (and a small RC delay of 20 ns). Refer to the electrical specification of the desired device. When a prescaler is used, the external clock input is divided by the asynchronous ripple-counter type prescaler so that the prescaler output is symmetrical. For the external clock to meet the sampling requirement, the ripple-counter must be taken into account. Therefore, it is necessary for TOCKI to have a period of at least 4TOSC (and a small RC delay of 40 ns) divided by the prescaler value. The only requirement on TOCKI high and low time is that they do not violate the minimum pulse width requirement of 10 ns. Refer to parameters 40, 41 and 42 in the electrical specification of the desired device.

#### 7.2.2 TIMER0 INCREMENT DELAY

Since the prescaler output is synchronized with the internal clocks, there is a small delay from the time the external clock edge occurs to the time the TMR0 is actually incremented. Figure 7-5 shows the delay from the external clock edge to the timer incrementing.



#### FIGURE 7-5: TIMER0 TIMING WITH EXTERNAL CLOCK

| Name   | Bit 7                                    | Bit 6                                                   | Bit 5                                                       | Bit 4                                                            | Bit 3                                                                        | Bit 2                                                                                     | Bit 1                                                                                                 | Bit 0                                                                                                             | Value on:<br>POR                                                                                                              | Value on<br>All Other<br>Resets                                                                                                                                                                                                                                                                                                                                                                               |
|--------|------------------------------------------|---------------------------------------------------------|-------------------------------------------------------------|------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMCON  | C2OUT                                    | C1OUT                                                   |                                                             | _                                                                | CIS                                                                          | CM2                                                                                       | CM1                                                                                                   | CM0                                                                                                               | 00 0000                                                                                                                       | 00 0000                                                                                                                                                                                                                                                                                                                                                                                                       |
| VRCON  | VREN                                     | VROE                                                    | VRR                                                         | —                                                                | VR3                                                                          | VR2                                                                                       | VR1                                                                                                   | VR0                                                                                                               | 000- 0000                                                                                                                     | 000- 0000                                                                                                                                                                                                                                                                                                                                                                                                     |
| INTCON | GIE                                      | PEIE                                                    | TOIE                                                        | INTE                                                             | RBIE                                                                         | T0IF                                                                                      | INTF                                                                                                  | RBIF                                                                                                              | 0000 000x                                                                                                                     | 0000 000u                                                                                                                                                                                                                                                                                                                                                                                                     |
| PIR1   | _                                        | CMIF                                                    |                                                             | _                                                                | _                                                                            |                                                                                           | _                                                                                                     | _                                                                                                                 | -0                                                                                                                            | -0                                                                                                                                                                                                                                                                                                                                                                                                            |
| PIE1   | —                                        | CMIE                                                    | —                                                           | —                                                                | —                                                                            | —                                                                                         | —                                                                                                     | —                                                                                                                 | -0                                                                                                                            | -0                                                                                                                                                                                                                                                                                                                                                                                                            |
| TRISA  | —                                        | —                                                       | _                                                           | TRISA4                                                           | TRISA3                                                                       | TRISA2                                                                                    | TRISA1                                                                                                | TRISA0                                                                                                            | 1 1111                                                                                                                        | 1 1111                                                                                                                                                                                                                                                                                                                                                                                                        |
|        | CMCON<br>VRCON<br>INTCON<br>PIR1<br>PIE1 | CMCON C2OUT<br>VRCON VREN<br>INTCON GIE<br>PIR1<br>PIE1 | CMCONC2OUTC1OUTVRCONVRENVROEINTCONGIEPEIEPIR1—CMIFPIE1—CMIE | CMCONC2OUTC1OUTVRCONVRENVROEVRRINTCONGIEPEIETOIEPIR1CMIFPIE1CMIE | CMCONC2OUTC1OUT—VRCONVRENVROEVRR—INTCONGIEPEIETOIEINTEPIR1—CMIF——PIE1I—CMIEI | CMCONC2OUTC1OUT——CISVRCONVRENVROEVRR—VR3INTCONGIEPEIET0IEINTERBIEPIR1—CMIF———PIE1—CMIE——— | CMCONC2OUTC1OUT——CISCM2VRCONVRENVROEVRR—VR3VR2INTCONGIEPEIETOIEINTERBIETOIFPIR1—CMIF————PIE1—CMIE———— | CMCONC2OUTC1OUT——CISCM2CM1VRCONVRENVROEVRR—VR3VR2VR1INTCONGIEPEIET0IEINTERBIET0IFINTFPIR1—CMIF—————PIE1—CMIE————— | CMCONC2OUTC1OUT——CISCM2CM1CM0VRCONVRENVROEVRR—VR3VR2VR1VR0INTCONGIEPEIETOIEINTERBIETOIFINTFRBIFPIR1—CMIF——————PIE1—CMIE—————— | Name   Bit 7   Bit 6   Bit 5   Bit 4   Bit 3   Bit 2   Bit 1   Bit 0   POR     CMCON   C2OUT   C1OUT   —   —   CIS   CM2   CM1   CM0   00 0000     VRCON   VREN   VROE   VRR   —   VR3   VR2   VR1   VR0   000- 0000     INTCON   GIE   PEIE   TOIE   INTE   RBIE   TOIF   INTF   RBIF   0000 000x     PIR1   —   CMIE   —   —   —   —   —   -   -0   -0     PIE1   —   CMIE   —   —   —   —   —   -   -0   - |

TABLE 8-1: REGISTERS ASSOCIATED WITH COMPARATOR MODULE

Legend: - = Unimplemented, read as "0", x = Unknown, u = unchanged

#### 10.3 <u>Reset</u>

The PIC16CE62X differentiates between various kinds of reset:

- a) Power-on reset (POR)
- b) MCLR reset during normal operation
- c) MCLR reset during SLEEP
- d) WDT reset (normal operation)
- e) WDT wake-up (SLEEP)
- f) Brown-out Reset (BOD)

Some registers are not affected in any reset condition. Their status is unknown on POR and unchanged in any other reset. Most other registers are reset to a "reset state" on Power-on reset, MCLR reset, WDT reset and MCLR reset during SLEEP. They are not affected by a WDT wake-up, since this is viewed as the resumption of normal operation. TO and PD bits are set or cleared differently in different reset situations as indicated in Table 10-4. These bits are used in software to determine the nature of the reset. See Table 10-6 for a full description of reset states of all registers.

A simplified block diagram of the on-chip reset circuit is shown in Figure 10-6.

The  $\overline{\text{MCLR}}$  reset path has a noise filter to detect and ignore small pulses. See Table 13-5 for pulse width specification.



### FIGURE 10-6: SIMPLIFIED BLOCK DIAGRAM OF ON-CHIP RESET CIRCUIT

#### 10.6 Context Saving During Interrupts

During an interrupt, only the return PC value is saved on the stack. Typically, users may wish to save key registers during an interrupt (i.e. W register and STATUS register). This will have to be implemented in software.

Example 10-1 stores and restores the STATUS and W registers. The user register, W\_TEMP, must be defined in both banks and must be defined at the same offset from the bank base address (i.e., W\_TEMP is defined at 0x70 in Bank 0 and it must also be defined at 0xF0 in Bank 1). The user register, STATUS\_TEMP, must be defined in Bank 0. The Example 10-1:

- Stores the W register
- Stores the STATUS register in Bank 0
- Executes the ISR code
- Restores the STATUS (and bank select bit register)
- · Restores the W register

#### EXAMPLE 10-1: SAVING THE STATUS AND W REGISTERS IN RAM

| MOVWF | W_TEMP        | ;copy W to temp register,<br>;could be in either bank                  |
|-------|---------------|------------------------------------------------------------------------|
| SWAPF | STATUS,W      | ;swap status to be saved into ${\tt W}$                                |
| BCF   | STATUS, RPO   | ;change to bank 0 regardless<br>;of current bank                       |
| MOVWF | STATUS_TEMP   | ;save status to bank 0<br>;register                                    |
| :     |               |                                                                        |
| :     | (ISR)         |                                                                        |
| :     |               |                                                                        |
| SWAPF | STATUS_TEMP,W | ;swap STATUS_TEMP register<br>;into W, sets bank to original<br>;state |
| MOVWF | STATUS        | ;move W into STATUS register                                           |
| SWAPF | W_TEMP,F      | ;swap W_TEMP                                                           |
| SWAPF | W_TEMP,W      | ;swap W_TEMP into W                                                    |

### 10.7 <u>Watchdog Timer (WDT)</u>

The Watchdog Timer is a free running on-chip RC oscillator which does not require any external components. This RC oscillator is separate from the RC oscillator of the CLKIN pin. That means that the WDT will run, even if the clock on the OSC1 and OSC2 pins of the device have been stopped, for example, by execution of a SLEEP instruction. During normal operation, a WDT time-out generates a device RESET. If the device is in SLEEP mode, a WDT time-out causes the device to wake-up and continue with normal operation. The WDT can be permanently disabled by programming the configuration bit WDTE as clear (Section 10.1).

#### 10.7.1 WDT PERIOD

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

The CLRWDT and SLEEP instructions clear the WDT and the postscaler, if assigned to the WDT, and prevent it from timing out and generating a device RESET.

The  $\overline{\text{TO}}$  bit in the STATUS register will be cleared upon a Watchdog Timer time-out.

#### 10.7.2 WDT PROGRAMMING CONSIDERATIONS

It should also be taken in account that under worst case conditions (VDD = Min., Temperature = Max., max. WDT prescaler), it may take several seconds before a WDT time-out occurs.

#### 10.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  $\overline{PD}$  bit in the STATUS register is cleared, the  $\overline{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 |  |  |  |  |  |  |
|-------|-------------------------------------------|--|--|--|--|--|--|
|       | by a WDT time-out does not drive MCLR     |  |  |  |  |  |  |
|       | pin low.                                  |  |  |  |  |  |  |

#### 10.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  $\overline{TO}$  and  $\overline{PD}$  bits in the STATUS register can be used to determine the cause of device reset.  $\overline{PD}$ bit, which is set on power-up is cleared when SLEEP is invoked.  $\overline{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 correspond-  |  |  |  |  |  |
|       | ing 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   Q3   Q4                      | Q1 Q2 Q3 Q4                           | Q1 Q2 Q3 Q4 |
|---------------------------------------------|--------------|--------------|----------------------------------------|---------------------------------------|-------------|
|                                             |              |              | $\mathcal{A} \cup \cup \cup \cup \cup$ | $/ \cup \cup \cup \cup$               |             |
| CLKOUT(4)                                   | -\           | /            | <u>\</u> /                             | \/                                    |             |
| INT pin                                     |              |              | ,<br>,<br>,                            | ı<br>ı<br>ı                           |             |
| INTF flag<br>(INTCON<1>)                    |              |              | Interrupt Latency                      | · · · · · · · · · · · · · · · · · · · |             |
|                                             |              |              | 1                                      | 1 · · · ·                             |             |
| GIE bit<br>(INTCON<7>)                      | Processor in | <br> <br>    |                                        | I                                     |             |
|                                             | SLEEP        |              |                                        |                                       |             |
| INSTRUCTION FLOW                            |              |              |                                        |                                       |             |
| PC X PC X PC+1                              | PC+2         | PC+2         | X PC + 2                               | X 0004h                               | X 0005h     |
| Instruction { Inst(PC) = SLEEP Inst(PC + 1) | 1            | Inst(PC + 2) | 1<br>1<br>1                            | Inst(0004h)                           | Inst(0005h) |
| Instruction Inst(PC - 1) SLEEP              | 1            | Inst(PC + 1) | Dummy cycle                            | Dummy cycle                           | Inst(0004h) |
|                                             |              |              |                                        |                                       |             |

#### FIGURE 10-19: WAKE-UP FROM SLEEP THROUGH INTERRUPT

**Note 1:** XT, HS or LP oscillator mode assumed.

2: TOST = 1024TOSC (drawing not to scale) This delay does not occur for RC osc mode.

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.

# 11.0 INSTRUCTION SET SUMMARY

Each PIC16CE62X instruction is a 14-bit word divided into an OPCODE which specifies the instruction type and one or more operands which further specify the operation of the instruction. The PIC16CE62X instruction set summary in Table 11-2 lists **byte-oriented**, **bit-oriented**, and **literal and control** operations. Table 11-1 shows the opcode field descriptions.

For **byte-oriented** instructions, 'f' represents a file register designator and 'd' represents a destination designator. The file register designator specifies which file register is to be used by the instruction.

The destination designator specifies where the result of the operation is to be placed. If 'd' is zero, the result is placed in the W register. If 'd' is one, the result is placed in the file register specified in the instruction.

For **bit-oriented** instructions, 'b' represents a bit field designator which selects the number of the bit affected by the operation, while 'f' represents the number of the file in which the bit is located.

For **literal and control** operations, 'k' represents an eight or eleven bit constant or literal value.

# TABLE 11-1: OPCODE FIELD DESCRIPTIONS

| Field         | Description                                                                                                                                                                    |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| f             | Register file address (0x00 to 0x7F)                                                                                                                                           |
| W             | Working register (accumulator)                                                                                                                                                 |
| b             | Bit address within an 8-bit file register                                                                                                                                      |
| k             | Literal field, constant data or label                                                                                                                                          |
| x             | Don't care location (= 0 or 1)<br>The assembler will generate code with $x = 0$ . It is the<br>recommended form of use for compatibility with all<br>Microchip software tools. |
| d             | Destination select; d = 0: store result in W,<br>d = 1: store result in file register f.<br>Default is d = 1                                                                   |
| label         | Label name                                                                                                                                                                     |
| TOS           | Top of Stack                                                                                                                                                                   |
| PC            | Program Counter                                                                                                                                                                |
| PCLATH        | Program Counter High Latch                                                                                                                                                     |
| GIE           | Global Interrupt Enable bit                                                                                                                                                    |
| WDT           | Watchdog Timer/Counter                                                                                                                                                         |
| TO            | Time-out bit                                                                                                                                                                   |
| PD            | Power-down bit                                                                                                                                                                 |
| dest          | Destination either the W register or the specified register file location                                                                                                      |
| []            | Options                                                                                                                                                                        |
| ()            | Contents                                                                                                                                                                       |
| $\rightarrow$ | Assigned to                                                                                                                                                                    |
| <>            | Register bit field                                                                                                                                                             |
| ∈             | In the set of                                                                                                                                                                  |
| italics       | User defined term (font is courier)                                                                                                                                            |

The instruction set is highly orthogonal and is grouped into three basic categories:

- Byte-oriented operations
- Bit-oriented operations
- Literal and control operations

All instructions are executed within one single instruction cycle, unless a conditional test is true or the program counter is changed as a result of an instruction. In this case, the execution takes two instruction cycles with the second cycle executed as a NOP. One instruction cycle consists of four oscillator periods. Thus, for an oscillator frequency of 4 MHz, the normal instruction execution time is 1  $\mu$ s. If a conditional test is true or the program counter is changed as a result of an instruction, the instruction execution time is 2  $\mu$ s.

Table 11-1 lists the instructions recognized by the MPASM assembler.

Figure 11-1 shows the three general formats that the instructions can have.

| Note: |                                                      |  |  | compatibility |  |  |  |  |
|-------|------------------------------------------------------|--|--|---------------|--|--|--|--|
|       | future PIC <sup>®</sup> MCU products, do not use the |  |  |               |  |  |  |  |
|       | OPTION and TRIS instructions.                        |  |  |               |  |  |  |  |

All examples use the following format to represent a hexadecimal number:

0xhh

where h signifies a hexadecimal digit.

# FIGURE 11-1: GENERAL FORMAT FOR INSTRUCTIONS



<sup>13 11 10</sup> OPCODE k (literal)

k = 11-bit immediate value

| NOP              | No Oper      | ation |      |      |  |
|------------------|--------------|-------|------|------|--|
| Syntax:          | [ label ]    | NOP   |      |      |  |
| Operands:        | None         |       |      |      |  |
| Operation:       | No operation |       |      |      |  |
| Status Affected: | None         |       |      |      |  |
| Encoding:        | 0 0          | 0000  | 0xx0 | 0000 |  |
| Description:     | No operati   | ion.  |      |      |  |
| Words:           | 1            |       |      |      |  |
| Cycles:          | 1            |       |      |      |  |
| Example          | NOP          |       |      |      |  |

| RETFIE           | Return from Int                                                                                                                                                                                                   | terrupt   |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--|--|--|
| Syntax:          | [label] RETF                                                                                                                                                                                                      | IE        |  |  |  |
| Operands:        | None                                                                                                                                                                                                              |           |  |  |  |
| Operation:       | $\begin{array}{l} TOS \to PC, \\ 1 \to GIE \end{array}$                                                                                                                                                           |           |  |  |  |
| Status Affected: | None                                                                                                                                                                                                              |           |  |  |  |
| Encoding:        | 00 0000                                                                                                                                                                                                           | 0000 1001 |  |  |  |
| Description:     | Return from Interrupt. Stack is POPed<br>and Top of Stack (TOS) is loaded in<br>the PC. Interrupts are enabled by<br>setting Global Interrupt Enable bit,<br>GIE (INTCON<7>). This is a two-cycle<br>instruction. |           |  |  |  |
| Words:           | 1                                                                                                                                                                                                                 |           |  |  |  |
| Cycles:          | 2                                                                                                                                                                                                                 |           |  |  |  |
| Example          | RETFIE                                                                                                                                                                                                            |           |  |  |  |
|                  | After Interrupt<br>PC =<br>GIE =                                                                                                                                                                                  | TOS<br>1  |  |  |  |

| OPTION                                       | Load Option Register                                                                                                                                                                                                                                       |  |  |  |  |
|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:                                      | [label] OPTION                                                                                                                                                                                                                                             |  |  |  |  |
| Operands:                                    | None                                                                                                                                                                                                                                                       |  |  |  |  |
| Operation:                                   | $(W) \rightarrow OPTION$                                                                                                                                                                                                                                   |  |  |  |  |
| Status Affected:                             | None                                                                                                                                                                                                                                                       |  |  |  |  |
| Encoding:                                    | 00 0000 0110 0010                                                                                                                                                                                                                                          |  |  |  |  |
| Description:<br>Words:<br>Cycles:<br>Example | The contents of the W register are<br>loaded in the OPTION register. This<br>instruction is supported for code<br>compatibility with PIC16C5X products.<br>Since OPTION is a readable/writable<br>register, the user can directly<br>address it.<br>1<br>1 |  |  |  |  |
|                                              | To maintain upward compatibility<br>with future PIC <sup>®</sup> MCU products, do<br>not use this instruction.                                                                                                                                             |  |  |  |  |

| RETLW            | Return with Literal in W                                                                                                                                                            |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] RETLW k                                                                                                                                                            |
| Operands:        | $0 \le k \le 255$                                                                                                                                                                   |
| Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow$ PC                                                                                                                                        |
| Status Affected: | None                                                                                                                                                                                |
| Encoding:        | 11 01xx kkkk kkkk                                                                                                                                                                   |
| Description:     | The W register is loaded with the eight<br>bit literal 'k'. The program counter is<br>loaded from the top of the stack (the<br>return address). This is a two-cycle<br>instruction. |
| Words:           | 1                                                                                                                                                                                   |
| Cycles:          | 2                                                                                                                                                                                   |
| Example          | CALL TABLE ;W contains table<br>;offset value<br>;W now has table<br>value                                                                                                          |
| TABLE            | ADDWF PC ;W = offset<br>RETLW k1 ;Begin table<br>RETLW k2 ;                                                                                                                         |
|                  | RETLW kn ; End of table                                                                                                                                                             |
|                  | Before Instruction<br>W = 0x07                                                                                                                                                      |
|                  | After Instruction<br>W = value of k8                                                                                                                                                |

# PIC16CE62X

| RETURN             | Return from Subroutine                                                                                          | RRF              | Rotate Right f through Carry                                                                                                                                                   |  |  |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:            | [label] RETURN                                                                                                  | Syntax:          | [ <i>label</i> ] RRF f,d                                                                                                                                                       |  |  |  |
| Operands:          | None                                                                                                            | Operands:        | $0 \le f \le 127$                                                                                                                                                              |  |  |  |
| Operation:         | $TOS \rightarrow PC$                                                                                            |                  | $d \in [0,1]$                                                                                                                                                                  |  |  |  |
| Status Affected:   | None                                                                                                            | Operation:       | See description below                                                                                                                                                          |  |  |  |
| Encoding:          | 00 0000 0000 1000                                                                                               | Status Affected: | С                                                                                                                                                                              |  |  |  |
| Description:       | Return from subroutine. The stack is                                                                            | Encoding:        | 00 1100 dfff ffff                                                                                                                                                              |  |  |  |
|                    | POPed and the top of the stack (TOS)<br>is loaded into the program counter.<br>This is a two cycle instruction. | Description:     | The contents of register 'f' are rotated<br>one bit to the right through the Carry<br>Flag. If 'd' is 0, the result is placed in<br>the W register. If 'd' is 1, the result is |  |  |  |
| Words:             | 1                                                                                                               |                  | placed back in register 'f'.                                                                                                                                                   |  |  |  |
| Cycles:<br>Example | 2<br>RETURN                                                                                                     |                  | C Register f                                                                                                                                                                   |  |  |  |
|                    | After Interrupt                                                                                                 | Words:           | 1                                                                                                                                                                              |  |  |  |
|                    | PC = TOS                                                                                                        | Cycles:          | 1                                                                                                                                                                              |  |  |  |
|                    |                                                                                                                 | Example          | RRF REG1,0                                                                                                                                                                     |  |  |  |
|                    |                                                                                                                 |                  | Before Instruction REG1 = 1110 0110   C = 0 0   After Instruction REG1 = 1110 0110   W = 0111 0011   C = 0 0                                                                   |  |  |  |

| RLF              | Rotate Left f t                                                   | hrough Carry                                                                                                                |         |
|------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|---------|
| Syntax:          | [label] RLF                                                       | f,d                                                                                                                         |         |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in  [0,1] \end{array}$ |                                                                                                                             |         |
| Operation:       | See description                                                   | n below                                                                                                                     |         |
| Status Affected: | С                                                                 |                                                                                                                             |         |
| Encoding:        | 00 110                                                            | 1 dfff ff                                                                                                                   | ff      |
| Description:     | one bit to the left<br>Flag. If 'd' is 0, th                      | register 'f' are rota<br>t through the Carry<br>ne result is placed<br>f 'd' is 1, the result<br>egister 'f'.<br>Register f | /<br>in |
| Words:           | 1                                                                 |                                                                                                                             |         |
| Cycles:          | 1                                                                 |                                                                                                                             |         |
|                  |                                                                   |                                                                                                                             |         |
| Example          | RLF                                                               | REG1,0                                                                                                                      |         |

# SLEEP

| 02221            |                                                                                                                                                                                                                                                                          |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] SLEEP                                                                                                                                                                                                                                                          |
| Operands:        | None                                                                                                                                                                                                                                                                     |
| Operation:       | $\begin{array}{l} 00h \rightarrow WDT, \\ 0 \rightarrow WDT \ prescaler, \\ 1 \rightarrow \overline{TO}, \\ 0 \rightarrow \overline{PD} \end{array}$                                                                                                                     |
| Status Affected: | TO, PD                                                                                                                                                                                                                                                                   |
| Encoding:        | 00 0000 0110 0011                                                                                                                                                                                                                                                        |
| Description:     | The power-down status bit, $\overline{PD}$ is<br>cleared. Time-out status bit, $\overline{TO}$ is<br>set. Watchdog Timer and its<br>prescaler are cleared.<br>The processor is put into SLEEP<br>mode with the oscillator stopped.<br>See Section 10.8 for more details. |
| Words:           | 1                                                                                                                                                                                                                                                                        |
| Cycles:          | 1                                                                                                                                                                                                                                                                        |
| Example:         | SLEEP                                                                                                                                                                                                                                                                    |





**2:** The maximum rated speed of the part limits the permissible combinations of voltage and frequency. Please reference the Product Identification System section for the maximum rated speed of the parts.





# PIC16CE62X



#### 13.3 DC CHARACTERISTICS:

#### PIC16CE62X-04 (Commercial, Industrial, Extended) PIC16CE62X-20 (Commercial, Industrial, Extended) PIC16LCE62X (Commercial, Industrial)

|                    |       |                                                                 | Standard Opera                                          | ating (       | Conditions (u | unles                    | s otherwise stated)                             |  |  |
|--------------------|-------|-----------------------------------------------------------------|---------------------------------------------------------|---------------|---------------|--------------------------|-------------------------------------------------|--|--|
|                    |       |                                                                 |                                                         |               |               |                          | +85°C for industrial and                        |  |  |
| DC CHARACTERISTICS |       |                                                                 | $0^{\circ}C \le TA \le +70^{\circ}C$ for commercial and |               |               |                          |                                                 |  |  |
|                    |       |                                                                 |                                                         |               |               |                          | +125°C for extended                             |  |  |
|                    |       |                                                                 | Operating voltag                                        | o range as de | scrib         | ed in DC spec Table 13-1 |                                                 |  |  |
| Parm               | Sym   | Characteristic                                                  | Min                                                     | Typ†          | Max           | Unit                     | Conditions                                      |  |  |
| No.                |       |                                                                 |                                                         |               |               |                          |                                                 |  |  |
|                    | Vi∟   | Input Low Voltage                                               |                                                         |               |               |                          |                                                 |  |  |
|                    |       | I/O ports                                                       |                                                         |               |               |                          |                                                 |  |  |
| D030               |       | with TTL buffer                                                 | Vss                                                     | _             | 0.8V          | v                        | VDD = 4.5V to 5.5V, Otherwise                   |  |  |
|                    |       |                                                                 |                                                         |               | 0.15VDD       |                          |                                                 |  |  |
| D031               |       | with Schmitt Trigger input                                      | Vss                                                     |               | 0.2VDD        | V                        |                                                 |  |  |
| D032               |       | MCLR, RA4/T0CKI,OSC1 (in RC                                     | Vss                                                     | -             | 0.2VDD        | V                        | Note1                                           |  |  |
|                    |       | mode)                                                           |                                                         |               |               |                          |                                                 |  |  |
| D033               |       | OSC1 (in XT and HS)                                             | Vss                                                     | -             | 0.3Vdd        | V                        |                                                 |  |  |
|                    |       | OSC1 (in LP)                                                    | Vss                                                     | -             | 0.6VDD - 1.0  | V                        |                                                 |  |  |
|                    | VIH   | Input High Voltage                                              |                                                         |               |               |                          |                                                 |  |  |
|                    |       | I/O ports                                                       |                                                         |               |               |                          |                                                 |  |  |
| D040               |       | with TTL buffer                                                 | 2.0V                                                    | -             | VDD           | V                        | VDD = 4.5V to 5.5V, Otherwise                   |  |  |
| <b>D</b> 044       |       |                                                                 | .25VDD + 0.8V                                           |               | VDD           |                          |                                                 |  |  |
| D041               |       | with Schmitt Trigger input                                      | 0.8VDD                                                  |               | VDD           |                          |                                                 |  |  |
| D042               |       | MCLR RA4/T0CKI                                                  | 0.8VDD                                                  | -             | VDD           | V                        |                                                 |  |  |
| D043<br>D043A      |       | OSC1 (XT, HS and LP)                                            | 0.7Vdd<br>0.9Vdd                                        | -             | Vdd           | V                        | Note1                                           |  |  |
| D043A              | IPURB | OSC1 (in RC mode)<br>PORTB weak pull-up current                 | 50                                                      | 200           | 400           | μA                       | VDD = 5.0V, VPIN = VSS                          |  |  |
| 0070               | IPUND | Input Leakage Current                                           | 50                                                      | 200           | 400           | μΑ                       | VDD = 5.0V, VPIN = V35                          |  |  |
|                    | lı∟   | (Notes 2, 3)                                                    |                                                         |               |               |                          |                                                 |  |  |
|                    |       | I/O ports (Except PORTA)                                        |                                                         |               | ±1.0          | μА                       | VSS $\leq$ VPIN $\leq$ VDD, pin at hi-impedance |  |  |
| D060               |       | PORTA                                                           | _                                                       | _             | ±0.5          | μA                       |                                                 |  |  |
| D061               |       | RA4/T0CKI                                                       | _                                                       | _             | ±1.0          | μA                       |                                                 |  |  |
| D063               |       | OSC1, MCLR                                                      | _                                                       | _             | ±5.0          | μA                       |                                                 |  |  |
|                    |       |                                                                 |                                                         |               |               | · ·                      | configuration                                   |  |  |
|                    | Vol   | Output Low Voltage                                              |                                                         |               |               |                          |                                                 |  |  |
| D080               |       | I/O ports                                                       | _                                                       | _             | 0.6           | v                        | IOL=8.5 mA, VDD=4.5V, -40° to +85°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° to +85°C             |  |  |
|                    |       |                                                                 | -                                                       | -             | 0.6           | V                        | IOL=1.2 mA, VDD=4.5V, +125°C                    |  |  |
|                    | Voh   | Output High Voltage (Note 3)                                    |                                                         | 1             |               | 1                        |                                                 |  |  |
| D090               |       | I/O ports (Except RA4)                                          | VDD-0.7                                                 | -             | _             | v                        | IOH=-3.0 mA, VDD=4.5V, -40° to +85°C            |  |  |
|                    |       |                                                                 | VDD-0.7                                                 | -             | -             | v                        | IOH=-2.5 mA, VDD=4.5V, +125°С                   |  |  |
| D092               |       | OSC2/CLKOUT (RC only)                                           | VDD-0.7                                                 | -             | -             | v                        | IOH=-1.3 mA, VDD=4.5V, -40° to +85°C            |  |  |
|                    |       |                                                                 | VDD-0.7                                                 | -             | -             | v                        | IOH=-1.0 mA, VDD=4.5V, +125°С                   |  |  |
| *D150              | Vod   | Open-Drain High Voltage                                         |                                                         |               | 8.5           | V                        | RA4 pin                                         |  |  |
|                    |       | Capacitive Loading Specs on                                     |                                                         |               |               |                          |                                                 |  |  |
|                    |       | Output Pins                                                     |                                                         |               |               |                          |                                                 |  |  |
| D100               |       | OSC2 pin                                                        |                                                         |               | 15            | pF                       | In XT, HS and LP modes when external            |  |  |
|                    | 2     |                                                                 |                                                         |               |               |                          | clock used to drive OSC1.                       |  |  |
| D101               | Cio   | All I/O pins/OSC2 (in RC mode)<br>These parameters are characte |                                                         |               | 50            | pF                       |                                                 |  |  |

These parameters are characterized but not tested.

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

**Note 1:** In RC oscillator configuration, the OSC1 pin is a Schmitt Trigger input. It is not recommended that the PIC16CE62X 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.

### FIGURE 13-6: CLKOUT AND I/O TIMING



| Parameter # | Sym      | Characteristic                                                        | Min          | Тур† | Мах | Units |
|-------------|----------|-----------------------------------------------------------------------|--------------|------|-----|-------|
| 10*         | TosH2ckL | OSC1↑ to CLKOUT↓ <sup>(1)</sup>                                       | —            | 75   | 200 | ns    |
| 11*         | TosH2ckH | OSC1 <sup>↑</sup> to CLKOUT <sup>↑</sup> <sup>(1)</sup>               | _            | 75   | 200 | ns    |
| 12*         | TckR     | CLKOUT rise time <sup>(1)</sup>                                       | _            | 35   | 100 | ns    |
| 13*         | TckF     | CLKOUT fall time <sup>(1)</sup>                                       | _            | 35   | 100 | ns    |
| 14*         | TckL2ioV | CLKOUT ↓ to Port out valid <sup>(1)</sup>                             | _            | —    | 20  | ns    |
| 15*         | TioV2ckH | Port in valid before CLKOUT $\uparrow$ <sup>(1)</sup>                 | Tosc +200 ns | —    |     | ns    |
| 16*         | TckH2iol | Port in hold after CLKOUT $\uparrow$ <sup>(1)</sup>                   | 0            | —    |     | ns    |
| 17*         | TosH2ioV | OSC1↑ (Q1 cycle) to Port out valid                                    | —            | 50   | 150 | ns    |
| 18*         | TosH2iol | OSC1 <sup>↑</sup> (Q2 cycle) to Port input invalid (I/O in hold time) | 100          | -    | _   | ns    |
| 19*         | TioV2osH | Port input valid to OSC1 <sup>↑</sup> (I/O in setup time)             | 0            | —    |     | ns    |
| 20*         | TioR     | Port output rise time                                                 | —            | 10   | 40  | ns    |
| 21*         | TioF     | Port output fall time                                                 | —            | 10   | 40  | ns    |
| 22*         | Tinp     | RB0/INT pin high or low time                                          | 25           | —    | —   | ns    |
| 23          | Trbp     | RB<7:4> change interrupt high or low time                             | Тсү          | —    | _   | ns    |

|  | TABLE 13-4: | <b>CLKOUT AND I/O TIMING REQUIREMENTS</b> |
|--|-------------|-------------------------------------------|
|--|-------------|-------------------------------------------|

\* These parameters are characterized but not tested

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

Note 1: Measurements are taken in RC Mode where CLKOUT output is 4 x Tosc.

## 14.0 PACKAGING INFORMATION

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

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



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

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

# PIC16XXXXX FAMILY

## READER RESPONSE

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

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

| TO:<br>RE: | ······································                                                     | Total Pages Sent                   |  |  |  |  |  |
|------------|--------------------------------------------------------------------------------------------|------------------------------------|--|--|--|--|--|
|            | n: Name                                                                                    |                                    |  |  |  |  |  |
| FIU        |                                                                                            |                                    |  |  |  |  |  |
|            | Company<br>Address                                                                         |                                    |  |  |  |  |  |
|            | City / State / ZIP / Country                                                               |                                    |  |  |  |  |  |
|            | Telephone: ()                                                                              | FAX: ()                            |  |  |  |  |  |
| Арр        | lication (optional):                                                                       |                                    |  |  |  |  |  |
| Wo         | uld you like a reply?YN                                                                    |                                    |  |  |  |  |  |
|            | ice: PIC16xxxxxx family                                                                    | Literature Number: DS40182D        |  |  |  |  |  |
| Que        | estions:                                                                                   |                                    |  |  |  |  |  |
| 1.         | What are the best features of this document?                                               |                                    |  |  |  |  |  |
| _          |                                                                                            |                                    |  |  |  |  |  |
| 2.         | How does this document meet your hardware and s                                            | oftware development needs?         |  |  |  |  |  |
|            |                                                                                            |                                    |  |  |  |  |  |
| 3.         | 3. Do you find the organization of this document easy to follow? If not, why?              |                                    |  |  |  |  |  |
|            |                                                                                            |                                    |  |  |  |  |  |
| 4.         | What additions to the document do you think would                                          | enhance the structure and subject? |  |  |  |  |  |
|            |                                                                                            |                                    |  |  |  |  |  |
| 5.         | . What deletions from the document could be made without affecting the overall usefulness? |                                    |  |  |  |  |  |
|            |                                                                                            |                                    |  |  |  |  |  |
| 6.         | Is there any incorrect or misleading information (what                                     | at and where)?                     |  |  |  |  |  |
|            |                                                                                            |                                    |  |  |  |  |  |
| 7.         | How would you improve this document?                                                       |                                    |  |  |  |  |  |
|            |                                                                                            |                                    |  |  |  |  |  |

# Worldwide Sales and Service

#### AMERICAS

Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: http://www.microchip.com/ support Web Address: www.microchip.com

Atlanta Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455

Boston Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

Chicago Itasca, IL Tel: 630-285-0071 Fax: 630-285-0075

**Cleveland** Independence, OH Tel: 216-447-0464 Fax: 216-447-0643

**Dallas** Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

Detroit Farmington Hills, MI Tel: 248-538-2250 Fax: 248-538-2260

Indianapolis Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453

Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608

Santa Clara Santa Clara, CA Tel: 408-961-6444 Fax: 408-961-6445

Toronto Mississauga, Ontario, Canada Tel: 905-673-0699 Fax: 905-673-6509

#### ASIA/PACIFIC

Asia Pacific Office Suites 3707-14, 37th Floor Tower 6, The Gateway Harbour City, Kowloon Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431 Australia - Sydney Tel: 61-2-9868-6733

Fax: 61-2-9868-6755 China - Beijing

Tel: 86-10-8569-7000 Fax: 86-10-8528-2104

**China - Chengdu** Tel: 86-28-8665-5511 Fax: 86-28-8665-7889

China - Chongqing Tel: 86-23-8980-9588 Fax: 86-23-8980-9500

**China - Hangzhou** Tel: 86-571-2819-3187 Fax: 86-571-2819-3189

**China - Hong Kong SAR** Tel: 852-2943-5100 Fax: 852-2401-3431

**China - Nanjing** Tel: 86-25-8473-2460 Fax: 86-25-8473-2470

**China - Qingdao** Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

**China - Shanghai** Tel: 86-21-5407-5533 Fax: 86-21-5407-5066

**China - Shenyang** Tel: 86-24-2334-2829 Fax: 86-24-2334-2393

**China - Shenzhen** Tel: 86-755-8864-2200 Fax: 86-755-8203-1760

**China - Wuhan** Tel: 86-27-5980-5300 Fax: 86-27-5980-5118

**China - Xian** Tel: 86-29-8833-7252 Fax: 86-29-8833-7256

**China - Xiamen** Tel: 86-592-2388138 Fax: 86-592-2388130

**China - Zhuhai** Tel: 86-756-3210040 Fax: 86-756-3210049

#### ASIA/PACIFIC

India - Bangalore Tel: 91-80-3090-4444 Fax: 91-80-3090-4123

**India - New Delhi** Tel: 91-11-4160-8631 Fax: 91-11-4160-8632

India - Pune Tel: 91-20-2566-1512 Fax: 91-20-2566-1513

**Japan - Osaka** Tel: 81-6-6152-7160 Fax: 81-6-6152-9310

**Japan - Tokyo** Tel: 81-3-6880- 3770 Fax: 81-3-6880-3771

**Korea - Daegu** Tel: 82-53-744-4301 Fax: 82-53-744-4302

Korea - Seoul Tel: 82-2-554-7200 Fax: 82-2-558-5932 or 82-2-558-5934

Malaysia - Kuala Lumpur Tel: 60-3-6201-9857 Fax: 60-3-6201-9859

**Malaysia - Penang** Tel: 60-4-227-8870 Fax: 60-4-227-4068

Philippines - Manila Tel: 63-2-634-9065 Fax: 63-2-634-9069

**Singapore** Tel: 65-6334-8870 Fax: 65-6334-8850

**Taiwan - Hsin Chu** Tel: 886-3-5778-366 Fax: 886-3-5770-955

Taiwan - Kaohsiung Tel: 886-7-213-7828 Fax: 886-7-330-9305

**Taiwan - Taipei** Tel: 886-2-2508-8600 Fax: 886-2-2508-0102

**Thailand - Bangkok** Tel: 66-2-694-1351 Fax: 66-2-694-1350

#### EUROPE

Austria - Wels Tel: 43-7242-2244-39 Fax: 43-7242-2244-393 Denmark - Copenhagen Tel: 45-4450-2828

Fax: 45-4485-2829 France - Paris Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

**Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

**Italy - Milan** Tel: 39-0331-742611 Fax: 39-0331-466781

Netherlands - Drunen Tel: 31-416-690399 Fax: 31-416-690340

**Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

**UK - Wokingham** Tel: 44-118-921-5869 Fax: 44-118-921-5820