



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | PIC                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 25MHz                                                                     |
| Connectivity               | UART/USART                                                                |
| Peripherals                | Brown-out Detect/Reset, LVD, POR, PWM, WDT                                |
| Number of I/O              | 16                                                                        |
| Program Memory Size        | 8KB (4K x 16)                                                             |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 256 x 8                                                                   |
| RAM Size                   | 256 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 4.2V ~ 5.5V                                                               |
| Data Converters            | A/D 7x10b                                                                 |
| Oscillator Type            | Internal                                                                  |
| 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/pic18f1320-e-ss |
|                            |                                                                           |

Email: info@E-XFL.COM

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

|                                                                                   | Pin Number         |                        |           |                           | D                                |                                                                                                                                                                                                   |  |  |
|-----------------------------------------------------------------------------------|--------------------|------------------------|-----------|---------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Pin Name                                                                          | PDIP/<br>SOIC      | SSOP QFN               |           | Pin<br>Type               | Buffer<br>Type                   | Description                                                                                                                                                                                       |  |  |
|                                                                                   | _                  |                        | _         |                           |                                  | PORTB is a bidirectional I/O port. PORTB can be softwa<br>programmed for internal weak pull-ups on all inputs.                                                                                    |  |  |
| RB0/AN4/INT0<br>RB0<br>AN4<br>INT0                                                | 8                  | 9                      | 9         | I/O<br>I<br>I             | TTL<br>Analog<br>ST              | Digital I/O.<br>Analog input 4.<br>External interrupt 0.                                                                                                                                          |  |  |
| RB1/AN5/TX/CK/INT1<br>RB1<br>AN5<br>TX<br>CK<br>INT1                              | 9                  | 10                     | 10        | I/O<br>I<br>0<br>I/O<br>I | TTL<br>Analog<br>—<br>ST<br>ST   | Digital I/O.<br>Analog input 5.<br>EUSART asynchronous transmit.<br>EUSART synchronous clock (see related RX/DT).<br>External interrupt 1.                                                        |  |  |
| RB2/P1B/INT2<br>RB2<br>P1B<br>INT2                                                | 17                 | 19                     | 23        | I/O<br>O<br>I             | TTL<br>—<br>ST                   | Digital I/O.<br>Enhanced CCP1/PWM output.<br>External interrupt 2.                                                                                                                                |  |  |
| RB3/CCP1/P1A<br>RB3<br>CCP1<br>P1A                                                | 18                 | 20                     | 24        | I/O<br>I/O<br>O           | TTL<br>ST                        | Digital I/O.<br>Capture 1 input/Compare 1 output/PWM 1 output.<br>Enhanced CCP1/PWM output.                                                                                                       |  |  |
| RB4/AN6/RX/DT/KBI0<br>RB4<br>AN6<br>RX<br>DT<br>KBI0                              | 10                 | 11                     | 12        | I/O<br>I<br>I<br>I/O<br>I | TTL<br>Analog<br>ST<br>ST<br>TTL | Digital I/O.<br>Analog input 6.<br>EUSART asynchronous receive.<br>EUSART synchronous data (see related TX/CK).<br>Interrupt-on-change pin.                                                       |  |  |
| RB5/PGM/KBI1<br>RB5<br>PGM<br>KBI1                                                | 11                 | 12                     | 13        | I/O<br>I/O<br>I           | TTL<br>ST<br>TTL                 | Digital I/O.<br>Low-Voltage ICSP™ Programming enable pin.<br>Interrupt-on-change pin.                                                                                                             |  |  |
| RB6/PGC/T10S0/<br>T13CKI/P1C/KBI2<br>RB6<br>PGC<br>T10S0<br>T13CKI<br>P1C<br>KBI2 | 12                 | 13                     | 15        | I/O<br>I/O<br>I<br>O<br>I | TTL<br>ST<br>—<br>ST<br>—<br>TTL | Digital I/O.<br>In-Circuit Debugger and ICSP programming clock pin.<br>Timer1 oscillator output.<br>Timer1/Timer3 external clock output.<br>Enhanced CCP1/PWM output.<br>Interrupt-on-change pin. |  |  |
| RB7/PGD/T1OSI/<br>P1D/KBI3<br>RB7<br>PGD<br>T1OSI<br>P1D<br>KBI3                  | 13                 | 14                     | 16        | I/O<br>I/O<br>I<br>O<br>I | TTL<br>ST<br>CMOS<br>—<br>TTL    | Digital I/O.<br>In-Circuit Debugger and ICSP programming data pin.<br>Timer1 oscillator input.<br>Enhanced CCP1/PWM output.<br>Interrupt-on-change pin.                                           |  |  |
| Vss                                                                               | 5                  | 5, 6                   | 3, 5      | Ρ                         | —                                | Ground reference for logic and I/O pins.                                                                                                                                                          |  |  |
| Vdd                                                                               | 14                 | 15, 16                 | 17, 19    | Р                         |                                  | Positive supply for logic and I/O pins.                                                                                                                                                           |  |  |
| NC                                                                                | —                  | —                      | 18        | —                         | —                                | No connect.                                                                                                                                                                                       |  |  |
| ST = Sc                                                                           | hmitt Tri<br>Itput | atible inp<br>gger inp | ut with ( |                           | evels                            | CMOS = CMOS compatible input or output<br>I = Input<br>P = Power                                                                                                                                  |  |  |

O = Output OD = Open-drain (no P diode to VDD)

### 2.7.2 OSCILLATOR TRANSITIONS

The PIC18F1220/1320 devices contain circuitry to prevent clocking "glitches" when switching between clock sources. A short pause in the system clock occurs during the clock switch. The length of this pause is between eight and nine clock periods of the new clock source. This ensures that the new clock source is stable and that its pulse width will not be less than the shortest pulse width of the two clock sources.

Clock transitions are discussed in greater detail in **Section 3.1.2 "Entering Power Managed Modes"**.

## 2.8 Effects of Power Managed Modes on the Various Clock Sources

When the device executes a SLEEP instruction, the system is switched to one of the power managed modes, depending on the state of the IDLEN and SCS1:SCS0 bits of the OSCCON register. See **Section 3.0 "Power Managed Modes"** for details.

When PRI\_IDLE mode is selected, the designated primary oscillator continues to run without interruption. For all other power managed modes, the oscillator using the OSC1 pin is disabled. The OSC1 pin (and OSC2 pin, if used by the oscillator) will stop oscillating.

In Secondary Clock modes (SEC\_RUN and SEC\_I-DLE), the Timer1 oscillator is operating and providing the system clock. The Timer1 oscillator may also run in all power managed modes if required to clock Timer1 or Timer3.

In Internal Oscillator modes (RC\_RUN and RC\_IDLE), the internal oscillator block provides the system clock source. The INTRC output can be used directly to provide the system clock and may be enabled to support various special features, regardless of the power managed mode (see Section 19.2 "Watchdog Timer (WDT)" through Section 19.4 "Fail-Safe Clock Monitor"). The INTOSC output at 8 MHz may be used directly to clock the system, or may be divided down first. The INTOSC output is disabled if the system clock is provided directly from the INTRC output. If the Sleep mode is selected, all clock sources are stopped. Since all the transistor switching currents have been stopped, Sleep mode achieves the lowest current consumption of the device (only leakage currents).

Enabling any on-chip feature that will operate during Sleep will increase the current consumed during Sleep. The INTRC is required to support WDT operation. The Timer1 oscillator may be operating to support a realtime clock. Other features may be operating that do not require a system clock source (i.e., INTn pins, A/D conversions and others).

## 2.9 Power-up Delays

Power-up delays are controlled by two timers, so that no external Reset circuitry is required for most applications. The delays ensure that the device is kept in Reset until the device power supply is stable under normal circumstances and the primary clock is operating and stable. For additional information on power-up delays, see Sections 4.1 through 4.5.

The first timer is the Power-up Timer (PWRT), which provides a fixed delay on power-up (parameter 33, Table 22-8) if enabled in Configuration Register 2L. The second timer is the Oscillator Start-up Timer (OST), intended to keep the chip in Reset until the crystal oscillator is stable (LP, XT and HS modes). The OST does this by counting 1024 oscillator cycles before allowing the oscillator to clock the device.

When the HSPLL Oscillator mode is selected, the device is kept in Reset for an additional 2 ms following the HS mode OST delay, so the PLL can lock to the incoming clock frequency.

There is a delay of 5 to 10  $\mu s$  following POR while the controller becomes ready to execute instructions. This delay runs concurrently with any other delays. This may be the only delay that occurs when any of the EC, RC or INTIO modes are used as the primary clock source.

| Oscillator Mode | OSC1 Pin                                              | OSC2 Pin                                              |
|-----------------|-------------------------------------------------------|-------------------------------------------------------|
| RC, INTIO1      | Floating, external resistor should pull high          | At logic low (clock/4 output)                         |
| RCIO, INTIO2    | Floating, external resistor should pull high          | Configured as PORTA, bit 6                            |
| ECIO            | Floating, pulled by external clock                    | Configured as PORTA, bit 6                            |
| EC              | Floating, pulled by external clock                    | At logic low (clock/4 output)                         |
| LP, XT and HS   | Feedback inverter disabled at quiescent voltage level | Feedback inverter disabled at quiescent voltage level |

 TABLE 2-3:
 OSC1 AND OSC2 PIN STATES IN SLEEP MODE

**Note:** See Table 4-1 in **Section 4.0** "**Reset**" for time-outs due to Sleep and MCLR Reset.

#### 3.3.1 PRI\_IDLE MODE

This mode is unique among the three Low-Power Idle modes, in that it does not disable the primary system clock. For timing sensitive applications, this allows for the fastest resumption of device operation with its more accurate primary clock source, since the clock source does not have to "warm up" or transition from another oscillator.

PRI\_IDLE mode is entered by setting the IDLEN bit, clearing the SCS bits and executing a SLEEP instruction. Although the CPU is disabled, the peripherals continue to be clocked from the primary clock source specified in Configuration Register 1H. The OSTS bit remains set in PRI\_IDLE mode (see Figure 3-3).

When a wake event occurs, the CPU is clocked from the primary clock source. A delay of approximately 10  $\mu$ s is required between the wake event and code execution starts. This is required to allow the CPU to become ready to execute instructions. After the wakeup, the OSTS bit remains set. The IDLEN and SCS bits are not affected by the wake-up (see Figure 3-4).





#### FIGURE 3-4: TRANSITION TIMING FOR WAKE FROM PRI\_IDLE MODE



## 3.4 Run Modes

If the IDLEN bit is clear when a SLEEP instruction is executed, the CPU and peripherals are both clocked from the source selected using the SCS1:SCS0 bits. While these operating modes may not afford the power conservation of Idle or Sleep modes, they do allow the device to continue executing instructions by using a lower frequency clock source. RC\_RUN mode also offers the possibility of executing code at a frequency greater than the primary clock.

Wake-up from a power managed Run mode can be triggered by an interrupt, or any Reset, to return to fullpower operation. As the CPU is executing code in Run modes, several additional exits from Run modes are possible. They include exit to Sleep mode, exit to a corresponding Idle mode and exit by executing a RESET instruction. While the device is in any of the power managed Run modes, a WDT time-out will result in a WDT Reset.

#### 3.4.1 PRI\_RUN MODE

The PRI\_RUN mode is the normal full-power execution mode. If the SLEEP instruction is never executed, the microcontroller operates in this mode (a SLEEP instruction is executed to enter all other power managed modes). All other power managed modes exit to PRI\_RUN mode when an interrupt or WDT time-out occur.

There is no entry to PRI\_RUN mode. The OSTS bit is set. The IOFS bit may be set if the internal oscillator block is the primary clock source (see **Section 2.7.1** "Oscillator Control Register").

#### 3.4.2 SEC\_RUN MODE

The SEC\_RUN mode is the compatible mode to the "clock switching" feature offered in other PIC18 devices. In this mode, the CPU and peripherals are clocked from the Timer1 oscillator. This gives users the option of lower power consumption while still using a high accuracy clock source.

SEC\_RUN mode is entered by clearing the IDLEN bit, setting SCS1:SCS0 = 01 and executing a SLEEP instruction. The system clock source is switched to the Timer1 oscillator (see Figure 3-9), the primary oscillator is shut down, the T1RUN bit (T1CON<6>) is set and the OSTS bit is cleared.

Note: The Timer1 oscillator should already be running prior to entering SEC\_RUN mode. If the T1OSCEN bit is not set when the SLEEP instruction is executed, the SLEEP instruction will be ignored and entry to SEC\_RUN mode will not occur. If the Timer1 oscillator is enabled, but not yet running, system clocks will be delayed until the oscillator has started; in such situations, initial oscillator operation is far from stable and unpredictable operation may result.

When a wake event occurs, the peripherals and CPU continue to be clocked from the Timer1 oscillator while the primary clock is started. When the primary clock becomes ready, a clock switchback to the primary clock occurs (see Figure 3-6). When the clock switch is complete, the T1RUN bit is cleared, the OSTS bit is set and the primary clock is providing the system clock. The IDLEN and SCS bits are not affected by the wake-up. The Timer1 oscillator continues to run.

Firmware can force an exit from SEC\_RUN mode. By clearing the T1OSCEN bit (T1CON<3>), an exit from SEC\_RUN back to normal full-power operation is triggered. The Timer1 oscillator will continue to run and provide the system clock, even though the T1OSCEN bit is cleared. The primary clock is started. When the primary clock becomes ready, a clock switchback to the primary clock occurs (see Figure 3-6). When the clock switch is cleared, the Timer1 oscillator is disabled, the T1RUN bit is cleared, the OSTS bit is set and the primary clock is providing the system clock. The IDLEN and SCS bits are not affected by the wake-up.

#### FIGURE 3-9: TIMING TRANSITION FOR ENTRY TO SEC\_RUN MODE



### 3.4.4 EXIT TO IDLE MODE

An exit from a power managed Run mode to its corresponding Idle mode is executed by setting the IDLEN bit and executing a SLEEP instruction. The CPU is halted at the beginning of the instruction following the SLEEP instruction. There are no changes to any of the clock source status bits (OSTS, IOFS or T1RUN). While the CPU is halted, the peripherals continue to be clocked from the previously selected clock source.

### 3.4.5 EXIT TO SLEEP MODE

An exit from a power managed Run mode to Sleep mode is executed by clearing the IDLEN and SCS1:SCS0 bits and executing a SLEEP instruction. The code is no different than the method used to invoke Sleep mode from the normal operating (full-power) mode.

The primary clock and internal oscillator block are disabled. The INTRC will continue to operate if the WDT is enabled. The Timer1 oscillator will continue to run, if enabled in the T1CON register (Register 12-1). All clock source Status bits are cleared (OSTS, IOFS and T1RUN).

#### 3.5 Wake from Power Managed Modes

An exit from any of the power managed modes is triggered by an interrupt, a Reset or a WDT time-out. This section discusses the triggers that cause exits from power managed modes. The clocking subsystem actions are discussed in each of the power managed modes (see Sections 3.2 through 3.4).

| Note: | If application code is timing sensitive, it |
|-------|---------------------------------------------|
|       | should wait for the OSTS bit to become      |
|       | set before continuing. Use the interval     |
|       | during the low-power exit sequence          |
|       | (before OSTS is set) to perform timing      |
|       | insensitive "housekeeping" tasks.           |

Device behavior during Low-Power mode exits is summarized in Table 3-3.

#### 3.5.1 EXIT BY INTERRUPT

Any of the available interrupt sources can cause the device to exit a power managed mode and resume fullpower operation. To enable this functionality, an interrupt source must be enabled by setting its enable bit in one of the INTCON or PIE registers. The exit sequence is initiated when the corresponding interrupt flag bit is set. On all exits from Low-Power mode by interrupt, code execution branches to the interrupt vector if the GIE/GIEH bit (INTCON<7>) is set. Otherwise, code execution continues or resumes without branching (see Section 9.0 "Interrupts").

#### 3.6.1 EXAMPLE – EUSART

An adjustment may be indicated when the EUSART begins to generate framing errors, or receives data with errors while in Asynchronous mode. Framing errors indicate that the system clock frequency is too high – try decrementing the value in the OSCTUNE register to reduce the system clock frequency. Errors in data may suggest that the system clock speed is too low – increment OSCTUNE.

#### 3.6.2 EXAMPLE – TIMERS

This technique compares system clock speed to some reference clock. Two timers may be used; one timer is clocked by the peripheral clock, while the other is clocked by a fixed reference source, such as the Timer1 oscillator.

Both timers are cleared, but the timer clocked by the reference generates interrupts. When an interrupt occurs, the internally clocked timer is read and both timers are cleared. If the internally clocked timer value is greater than expected, then the internal oscillator block is running too fast – decrement OSCTUNE.

## 3.6.3 EXAMPLE – CCP IN CAPTURE MODE

A CCP module can use free running Timer1 (or Timer3), clocked by the internal oscillator block and an external event with a known period (i.e., AC power frequency). The time of the first event is captured in the CCPRxH:CCPRxL registers and is recorded for use later. When the second event causes a capture, the time of the first event is subtracted from the time of the second event. Since the period of the external event is known, the time difference between events can be calculated.

If the measured time is much greater than the calculated time, the internal oscillator block is running too fast – decrement OSCTUNE. If the measured time is much less than the calculated time, the internal oscillator block is running too slow-increment OSCTUNE.

| R/W-x            | R/W-x                                                                                                                                                                          | U-0                                                                                                                                                                                                                   | R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R/W-x                | R/W-0            | R/S-0            | R/S-0          |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------------|------------------|----------------|--|--|--|
| EEPGD            | CFGS                                                                                                                                                                           | _                                                                                                                                                                                                                     | FREE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | WRERR <sup>(1)</sup> | WREN             | WR               | RD             |  |  |  |
| bit 7            |                                                                                                                                                                                |                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | · ·                  |                  |                  | bit C          |  |  |  |
|                  |                                                                                                                                                                                |                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
| Legend:          |                                                                                                                                                                                |                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
| R = Readable     | e bit                                                                                                                                                                          | W = Writable                                                                                                                                                                                                          | bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | U = Unimplem         | nented bit, read | l as '0'         |                |  |  |  |
| S = Bit can or   | nly be set                                                                                                                                                                     | x = Bit is unk                                                                                                                                                                                                        | x = Bit is unknown -n/n = Value at POR and BOR/Value at all other structures of the second |                      |                  |                  |                |  |  |  |
| '1' = Bit is set |                                                                                                                                                                                | '0' = Bit is cle                                                                                                                                                                                                      | eared                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | HC = Bit is cle      | ared by hardw    | are              |                |  |  |  |
| bit 7            | EEPGD: Fla                                                                                                                                                                     | sh Program or                                                                                                                                                                                                         | Data EEPRO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | M Memory Selec       | ct bit           |                  |                |  |  |  |
|                  |                                                                                                                                                                                | program Flash                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ,                    |                  |                  |                |  |  |  |
|                  |                                                                                                                                                                                | data EEPROM                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
| bit 6            | CFGS: Flas                                                                                                                                                                     | h Program/Data                                                                                                                                                                                                        | a EEPROM or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Configuration S      | elect bit        |                  |                |  |  |  |
|                  |                                                                                                                                                                                | 1 = Accesses Configuration, User ID and Device ID Registers                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
|                  |                                                                                                                                                                                | -                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PROM Memory          |                  |                  |                |  |  |  |
| bit 5            | •                                                                                                                                                                              | nted: Read as                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
| bit 4            |                                                                                                                                                                                | Row Erase Enable bit                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
|                  | <ul> <li>1 = Erase the program memory row addressed by TBLPTR on the next WR command<br/>(cleared by completion of erase operation – TBLPTR&lt;5:0&gt; are ignored)</li> </ul> |                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
|                  | 0 = Perform write only                                                                                                                                                         |                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
| bit 3            | WRERR: EE                                                                                                                                                                      | EPROM Error F                                                                                                                                                                                                         | lag bit <sup>(1)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      |                  |                  |                |  |  |  |
|                  |                                                                                                                                                                                | 1 = A write operation was prematurely terminated (any Reset during self-timed programming)                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
|                  | 0 = The writ                                                                                                                                                                   | e operation completed normally                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
| bit 2            | WREN: Prog                                                                                                                                                                     | gram/Erase Ena                                                                                                                                                                                                        | able bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                      |                  |                  |                |  |  |  |
|                  | <ul> <li>1 = Allows program/erase cycles</li> <li>0 = Inhibits programming/erasing of program Flash and data EEPROM</li> </ul>                                                 |                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
| 1.1.4            |                                                                                                                                                                                |                                                                                                                                                                                                                       | rasing of prog                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ram Flash and c      | ata EEPROM       |                  |                |  |  |  |
| bit 1            |                                                                                                                                                                                | WR: Write Control bit                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
|                  |                                                                                                                                                                                | <ul> <li>Initiates a data EEPROM erase/write cycle or a program memory erase cycle or write cycle.</li> <li>(The operation is self-timed and the bit is cleared by hardware once write is complete. The WR</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
|                  |                                                                                                                                                                                | only be set (not                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
|                  |                                                                                                                                                                                | cle completed                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
| bit 0            | RD: Read C                                                                                                                                                                     | RD: Read Control bit                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
|                  |                                                                                                                                                                                | a memory read                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |
|                  |                                                                                                                                                                                | akes one cycle<br>e. RD bit canno                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ed in hardware.      | The RD bit car   | n only be set (r | not cleared) i |  |  |  |
|                  | 0 = Read co                                                                                                                                                                    |                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | LL: GD – 1.)         |                  |                  |                |  |  |  |
| Note 1: W        | hen a WRERR                                                                                                                                                                    | occurs the EE                                                                                                                                                                                                         | PGD and CE(                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 25 hits are not c    | laarad This all  | 0.005            |                |  |  |  |
|                  |                                                                                                                                                                                |                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |                  |                  |                |  |  |  |

## REGISTER 6-1: EECON1: EEPROM CONTROL 1 REGISTER

### 6.4 Erasing Flash Program Memory

The minimum erase block size is 32 words or 64 bytes under firmware control. Only through the use of an external programmer, or through ICSP control, can larger blocks of program memory be bulk erased. Word erase in Flash memory is not supported.

When initiating an erase sequence from the microcontroller itself, a block of 64 bytes of program memory is erased. The Most Significant 16 bits of the TBLPTR<21:6> point to the block being erased. TBLPTR<5:0> are ignored.

The EECON1 register commands the erase operation. The EEPGD bit must be set to point to the Flash program memory. The CFGS bit must be clear to access program Flash and data EEPROM memory. The WREN bit must be set to enable write operations. The FREE bit is set to select an erase operation. The WR bit is set as part of the required instruction sequence (as shown in Example 6-2) and starts the actual erase operation. It is not necessary to load the TABLAT register with any data as it is ignored.

For protection, the write initiate sequence using EECON2 must be used.

A long write is necessary for erasing the internal Flash. Instruction execution is halted while in a long write cycle. The long write will be terminated by the internal programming timer.

#### 6.4.1 FLASH PROGRAM MEMORY ERASE SEQUENCE

The sequence of events for erasing a block of internal program memory location is:

- 1. Load Table Pointer with address of row being erased.
- 2. Set the EECON1 register for the erase operation:
  •set EEPGD bit to point to program memory;
  •clear the CFGS bit to access program memory;
  •set WREN bit to enable writes;

•set FREE bit to enable the erase.

- 3. Disable interrupts.
- 4. Write 55h to EECON2.
- 5. Write AAh to EECON2.
- 6. Set the WR bit. This will begin the row erase cycle.
- 7. The CPU will stall for duration of the erase (about 2 ms using internal timer).
- 8. Execute a NOP.
- 9. Re-enable interrupts.

#### EXAMPLE 6-2: ERASING A FLASH PROGRAM MEMORY ROW

| ERASE ROW | MOVLW<br>MOVWF<br>MOVLW<br>MOVWF<br>MOVLW<br>MOVWF | CODE_ADDR_UPPER<br>TBLPTRU<br>CODE_ADDR_HIGH<br>TBLPTRH<br>CODE_ADDR_LOW<br>TBLPTRL | ; load TBLPTR with the base<br>; address of the memory block |
|-----------|----------------------------------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------|
| EKASE_KOW | BSF                                                | EECON1, EEPGD                                                                       | ; point to FLASH program memory                              |
|           | BSF                                                | EECON1, WREN                                                                        | ; enable write to memory                                     |
|           | BSF                                                | EECON1, FREE                                                                        | ; enable Row Erase operation                                 |
|           | BCF                                                | INTCON, GIE                                                                         | ; disable interrupts                                         |
|           | MOVLW                                              | 55h                                                                                 |                                                              |
|           | MOVWF                                              | EECON2                                                                              | ; write 55H                                                  |
| Required  | MOVLW                                              | AAh                                                                                 |                                                              |
| Sequence  | MOVWF                                              | EECON2                                                                              | ; write AAH                                                  |
|           | BSF                                                | EECON1, WR                                                                          | ; start erase (CPU stall)                                    |
|           | NOP                                                |                                                                                     |                                                              |
|           | BSF                                                | INTCON, GIE                                                                         | ; re-enable interrupts                                       |
|           |                                                    |                                                                                     |                                                              |

#### 7.7 Operation During Code-Protect

Data EEPROM memory has its own code-protect bits in Configuration Words. External read and write operations are disabled if either of these mechanisms are enabled.

The microcontroller itself can both read and write to the internal data EEPROM, regardless of the state of the code-protect Configuration bit. Refer to Section 19.0 "Special Features of the CPU" for additional information.

#### 7.8 Using the Data EEPROM

The data EEPROM is a high endurance, byte addressable array that has been optimized for the storage of frequently changing information (e.g., program variables or other data that are updated often). Frequently changing values will typically be updated more often than specification D124. If this is not the case, an array refresh must be performed. For this reason, variables that change infrequently (such as constants, IDs, calibration, etc.) should be stored in Flash program memory.

A simple data EEPROM refresh routine is shown in Example 7-3.

**Note:** If data EEPROM is only used to store constants and/or data that changes rarely, an array refresh is likely not required. See specification D124.

|      | LL I=0. |               |                              |
|------|---------|---------------|------------------------------|
|      | CLRF    | EEADR         | ; Start at address 0         |
|      | BCF     | EECON1, CFGS  | ; Set for memory             |
|      | BCF     | EECON1, EEPGD | ; Set for Data EEPROM        |
|      | BCF     | INTCON, GIE   | ; Disable interrupts         |
|      | BSF     | EECON1, WREN  | ; Enable writes              |
| Loop |         |               | ; Loop to refresh array      |
|      | BSF     | EECON1, RD    | ; Read current address       |
|      | MOVLW   | 55h           | ;                            |
|      | MOVWF   | EECON2        | ; Write 55h                  |
|      | MOVLW   | AAh           | ;                            |
|      | MOVWF   | EECON2        | ; Write AAh                  |
|      | BSF     | EECON1, WR    | ; Set WR bit to begin write  |
|      | BTFSC   | EECON1, WR    | ; Wait for write to complete |
|      | BRA     | \$-2          |                              |
|      | INCFSZ  | EEADR, F      | ; Increment address          |
|      | BRA     | Loop          | ; Not zero, do it again      |
|      | BCF     | EECON1, WREN  | ; Disable writes             |
|      | BSF     | INTCON, GIE   |                              |
|      |         |               |                              |

#### EXAMPLE 7-3: DATA EEPROM REFRESH ROUTINE

| Name   | Bit 7                                               | Bit 6                   | Bit 5  | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0 | Value on:<br>POR, BOR | Value on<br>all other<br>Resets |
|--------|-----------------------------------------------------|-------------------------|--------|-------|-------|--------|--------|-------|-----------------------|---------------------------------|
| INTCON | GIE/GIEH                                            | PEIE/GIEL               | TMR0IE | INTE  | RBIE  | TMR0IF | INTF   | RBIF  | 0000 000x             | 0000 000u                       |
| EEADR  | EEPROM A                                            | EEPROM Address Register |        |       |       |        |        |       |                       | 0000 0000                       |
| EEDATA | EEPROM Data Register                                |                         |        |       |       |        |        |       | 0000 0000             | 0000 0000                       |
| EECON2 | EEPROM Control Register 2 (not a physical register) |                         |        |       |       |        |        |       | _                     | _                               |
| EECON1 | EEPGD                                               | CFGS                    | _      | FREE  | WRERR | WREN   | WR     | RD    | xx-0 x000             | uu-0 u000                       |
| IPR2   | OSCFIP                                              | _                       | _      | EEIP  | —     | LVDIP  | TMR3IP | —     | 11 -11-               | 11 -11-                         |
| PIR2   | OSCFIF                                              | _                       | —      | EEIF  | _     | LVDIF  | TMR3IF | _     | 00 -00-               | 00 -00-                         |
| PIE2   | OSCFIE                                              | _                       | —      | EEIE  | _     | LVDIE  | TMR3IE | _     | 00 -00-               | 00 -00-                         |

Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used during Flash/EEPROM access.

© 2002-2015 Microchip Technology Inc.

| R/W-0/0          | U-0                                                                                                                                                               | U-0                                   | R/W-0/0        | U-0              | R/W-0/0          | R/W-0/0           | U-0        |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|----------------|------------------|------------------|-------------------|------------|--|
| OSCFIF           | —                                                                                                                                                                 | —                                     | EEIF           | —                | LVDIF            | TMR3IF            | _          |  |
| bit 7            |                                                                                                                                                                   |                                       |                | •                |                  |                   | bit (      |  |
| Legend:          |                                                                                                                                                                   |                                       |                |                  |                  |                   |            |  |
| R = Readable     | bit                                                                                                                                                               | W = Writable                          | bit            | U = Unimpler     | nented bit, read | as '0'            |            |  |
| u = Bit is unch  | anged                                                                                                                                                             | x = Bit is unkr                       | nown           | -n/n = Value a   | at POR and BO    | R/Value at all ot | her Resets |  |
| '1' = Bit is set |                                                                                                                                                                   | '0' = Bit is clea                     | ared           |                  |                  |                   |            |  |
| bit 7            |                                                                                                                                                                   | illator Fail Inter                    |                |                  |                  |                   |            |  |
|                  | ,                                                                                                                                                                 | oscillator failed,<br>clock operating | clock input h  | as changed to    | INTOSC (must l   | be cleared in so  | oftware)   |  |
| bit 6-5          | Unimplemen                                                                                                                                                        | ted: Read as '                        | 0'             |                  |                  |                   |            |  |
| bit 4            | EEIF: Data EEPROM/Flash Write Operation Interrupt Flag bit                                                                                                        |                                       |                |                  |                  |                   |            |  |
|                  | <ul> <li>1 = The write operation is complete (must be cleared in software)</li> <li>0 = The write operation is not complete or has not been started</li> </ul>    |                                       |                |                  |                  |                   |            |  |
| bit 3            | Unimplemen                                                                                                                                                        | ted: Read as '                        | 0'             |                  |                  |                   |            |  |
| bit 2            | LVDIF: Low-\                                                                                                                                                      | /oltage Detect                        | Interrupt Flag | bit              |                  |                   |            |  |
|                  | <ul> <li>1 = A low-voltage condition occurred (must be cleared in software)</li> <li>0 = The device voltage is above the Low-Voltage Detect trip point</li> </ul> |                                       |                |                  |                  |                   |            |  |
| bit 1            | TMR3IF: TMF                                                                                                                                                       | R3 Overflow Int                       | errupt Flag bi | t                |                  |                   |            |  |
|                  |                                                                                                                                                                   | gister overflowe<br>gister did not o  |                | leared in softwa | are)             |                   |            |  |
| bit 0            | Unimplemen                                                                                                                                                        | ted: Read as '                        | 0'             |                  |                  |                   |            |  |
|                  |                                                                                                                                                                   |                                       |                |                  |                  |                   |            |  |

## REGISTER 9-5: PIR2: PERIPHERAL INTERRUPT REQUEST REGISTER 2

## FIGURE 10-11: BLOCK DIAGRAM OF RB4/AN6/RX/DT/KBI0 PIN



# 12.7 Using Timer1 as a Real-Time Clock

Adding an external LP oscillator to Timer1 (such as the one described in **Section 12.2 "Timer1 Oscillator**", above), gives users the option to include RTC functionality to their applications. This is accomplished with an inexpensive watch crystal to provide an accurate time base and several lines of application code to calculate the time. When operating in Sleep mode and using a battery or supercapacitor as a power source, it can completely eliminate the need for a separate RTC device and battery backup.

The application code routine, RTCisr, shown in Example 12-1, demonstrates a simple method to increment a counter at one-second intervals using an Interrupt Service Routine. Incrementing the TMR1 register pair to overflow, triggers the interrupt and calls the routine, which increments the seconds counter by one; additional counters for minutes and hours are incremented as the previous counter overflow.

Since the register pair is 16 bits wide, counting up to overflow the register directly from a 32.768 kHz clock would take two seconds. To force the overflow at the required one-second intervals, it is necessary to preload it; the simplest method is to set the MSb of TMR1H with a BSF instruction. Note that the TMR1L register is never preloaded or altered; doing so may introduce cumulative error over many cycles.

For this method to be accurate, Timer1 must operate in Asynchronous mode and the Timer1 overflow interrupt must be enabled (PIE1<0> = 1), as shown in the routine, RTCinit. The Timer1 oscillator must also be enabled and running at all times.

| EXAMPLE 12-1: | IMPLEMENTING A REAL-TIME CLOCK USING A TIMER1 INTERRUPT SERVICE |
|---------------|-----------------------------------------------------------------|
|               |                                                                 |

| RTCinit |        |              |   |                                             |
|---------|--------|--------------|---|---------------------------------------------|
|         | MOVLW  | 0x80         | ; | Preload TMR1 register pair                  |
|         | MOVWF  | TMR1H        | ; | for 1 second overflow                       |
|         | CLRF   | TMR1L        |   |                                             |
|         | MOVLW  | b'00001111'  | ; | Configure for external clock,               |
|         | MOVWF  | TIOSC        | ; | Asynchronous operation, external oscillator |
|         | CLRF   | secs         | ; | Initialize timekeeping registers            |
|         | CLRF   | mins         | ; |                                             |
|         | MOVLW  | .12          |   |                                             |
|         | MOVWF  | hours        |   |                                             |
|         | BSF    | PIE1, TMR1IE | ; | Enable Timerl interrupt                     |
|         | RETURN |              |   |                                             |
| RTCisr  |        |              |   |                                             |
|         | BSF    | TMR1H, 7     | ; | Preload for 1 sec overflow                  |
|         | BCF    | PIR1, TMR1IF | ; | Clear interrupt flag                        |
|         | INCF   | secs, F      | ; | Increment seconds                           |
|         | MOVLW  | .59          | ; | 60 seconds elapsed?                         |
|         | CPFSGT | secs         |   |                                             |
|         | RETURN |              | ; | No, done                                    |
|         | CLRF   | secs         | ; | Clear seconds                               |
|         | INCF   | mins, F      | ; | Increment minutes                           |
|         | MOVLW  | .59          | ; | 60 minutes elapsed?                         |
|         | CPFSGT | mins         |   |                                             |
|         | RETURN |              |   | No, done                                    |
|         | CLRF   | mins         | ; | clear minutes                               |
|         | INCF   | hours, F     |   | Increment hours                             |
|         | MOVLW  | .23          | ; | 24 hours elapsed?                           |
|         | CPFSGT | hours        |   |                                             |
|         | RETURN |              |   | No, done                                    |
|         | MOVLW  | .01          | ; | Reset hours to 1                            |
|         | MOVWF  | hours        |   |                                             |
|         | RETURN |              | ; | Done                                        |
|         |        |              |   |                                             |

| Name    | Bit 7                                   | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0            |           |              |           |        |         |         | Value on<br>POR, BOF | Value on<br>all other<br>Resets |
|---------|-----------------------------------------|------------------------------------------------------------|-----------|--------------|-----------|--------|---------|---------|----------------------|---------------------------------|
| INTCON  | GIE/GIEH                                | GIE/GIEH PEIE/GIEL TMROIE INTOIE RBIE TMROIF INTOIF RBIF 0 |           |              |           |        |         |         |                      |                                 |
| RCON    | IPEN                                    | -                                                          | 01 11q    | q 0q qquu    |           |        |         |         |                      |                                 |
| PIR1    | _                                       | - ADIF RCIF TXIF - CCP1IF TMR2IF TMR1IF                    |           |              |           |        |         |         |                      |                                 |
| PIE1    |                                         | ADIE                                                       | RCIE      | TXIE         |           | CCP1IE | TMR2IE  | TMR1IE  | -000 -00             | 0 -000 -000                     |
| IPR1    | - ADIP RCIP TXIP - CCP1IP TMR2IP TMR1IP |                                                            |           |              |           |        |         |         |                      | L -111 -111                     |
| TMR2    | Timer2 Mo                               |                                                            | 0000 000  | 0000 0000    |           |        |         |         |                      |                                 |
| PR2     | Timer2 Mo                               | dule Period I                                              | Register  |              |           |        |         |         | 1111 111             | l 1111 1111                     |
| T2CON   | _                                       | TOUTPS3                                                    | TOUTPS2   | TOUTPS1      | TOUTPS0   | TMR2ON | T2CKPS1 | T2CKPS0 | -000 000             | 0 -000 0000                     |
| TRISB   | PORTB Da                                | ta Direction                                               | Register  |              |           |        |         |         | 1111 111             | l 1111 1111                     |
| CCPR1H  | Enhanced                                | Capture/Con                                                | npare/PWM | Register 1 H | ligh Byte |        |         |         | XXXX XXX             | k uuuu uuuu                     |
| CCPR1L  | Enhanced                                | Capture/Con                                                | npare/PWM | Register 1 L | ow Byte   |        |         |         | XXXX XXX             | k uuuu uuuu                     |
| CCP1CON | P1M1                                    | P1M0                                                       | DC1B1     | DC1B0        | CCP1M3    | CCP1M2 | CCP1M1  | CCP1M0  | 0000 000             | 0000 0000                       |
| ECCPAS  | ECCPASE                                 | ECCPAS2                                                    | ECCPAS1   | ECCPAS0      | PSSAC1    | PSSAC0 | PSSBD1  | PSSBD0  | 0000 000             | 0000 0000                       |
| PWM1CON | PRSEN                                   | PDC6                                                       | PDC5      | PDC4         | PDC3      | PDC2   | PDC1    | PDC0    | 0000 000             | ) uuuu uuuu                     |
| OSCCON  | IDLEN                                   | IRCF2                                                      | IRCF1     | IRCF0        | OSTS      | IOFS   | SCS1    | SCS0    | 0000 qq0             | 000p qq00                       |

|  | TABLE 15-5: | REGISTERS ASSOCIATED WITH ENHANCED PWM AND TIMER2 |
|--|-------------|---------------------------------------------------|
|--|-------------|---------------------------------------------------|

 $\label{eq:loss} \begin{array}{ll} \mbox{Legend:} & x = \mbox{unknown}, \mbox{u} = \mbox{unchanged}, \mbox{-} = \mbox{unimplemented}, \mbox{read as '0'}. \\ & \mbox{Shaded cells are not used by the ECCP module in Enhanced PWM mode}. \end{array}$ 

#### 16.3.4 AUTO-WAKE-UP ON SYNC BREAK CHARACTER

During Sleep mode, all clocks to the EUSART are suspended. Because of this, the Baud Rate Generator is inactive and a proper byte reception cannot be performed. The auto-wake-up feature allows the controller to wake-up due to activity on the RX/DT line while the EUSART is operating in Asynchronous mode.

The auto-wake-up feature is enabled by setting the WUE bit (BAUDCTL<1>). Once set, the typical receive sequence on RX/DT is disabled and the EUSART remains in an Idle state, monitoring for a wake-up event independent of the CPU mode. A wake-up event consists of a high-to-low transition on the RX/DT line. (This coincides with the start of a Sync Break or a Wake-up Signal character for the LIN protocol.)

Following a wake-up event, the module generates an RCIF interrupt. The interrupt is generated synchronously to the Q clocks in normal operating modes (Figure 16-7) and asynchronously if the device is in Sleep mode (Figure 16-8). The interrupt condition is cleared by reading the RCREG register.

The WUE bit is automatically cleared once a low-to-high transition is observed on the RX line, following the wakeup event. At this point, the EUSART module is in Idle mode and returns to normal operation. This signals to the user that the Sync Break event is over.

## 16.3.4.1 Special Considerations Using Auto-Wake-up

Since auto-wake-up functions by sensing rising edge transitions on RX/DT, information with any state changes before the Stop bit may signal a false end-of-character

and cause data or framing errors. To work properly, therefore, the initial character in the transmission must be all '0's. This can be 00h (8 bytes) for standard RS-232 devices, or 000h (12 bits) for LIN bus.

Oscillator start-up time must also be considered, especially in applications using oscillators with longer start-up intervals (i.e., LP, XT or HS/PLL mode). The Sync Break (or Wake-up Signal) character must be of sufficient length and be followed by a sufficient period, to allow enough time for the selected oscillator to start and provide proper initialization of the EUSART.

## 16.3.4.2 Special Considerations Using the WUE Bit

The timing of WUE and RCIF events may cause some confusion when it comes to determining the validity of received data. As noted, setting the WUE bit places the EUSART in an Idle mode. The wake-up event causes a receive interrupt by setting the RCIF bit. The WUE bit is cleared after this when a rising edge is seen on RX/ DT. The interrupt condition is then cleared by reading the RCREG register. Ordinarily, the data in RCREG will be dummy data and should be discarded.

The fact that the WUE bit has been cleared (or is still set) and the RCIF flag is set should not be used as an indicator of the integrity of the data in RCREG. Users should consider implementing a parallel method in firmware to verify received data integrity.

To assure that no actual data is lost, check the RCIDL bit to verify that a receive operation is not in process. If a receive operation is not occurring, the WUE bit may then be set just prior to entering the Sleep mode.

#### FIGURE 16-7: AUTO-WAKE-UP BIT (WUE) TIMINGS DURING NORMAL OPERATION

| 0801          | YAAAA       | puntha | INNUNIA.                               | 13.1 | NAMA.                                   | i Su   | A.A.A.   | puntu                                  | NANANA                  | 191         | NA U      | 1.2 N.E            |                | ununun      | 920   |
|---------------|-------------|--------|----------------------------------------|------|-----------------------------------------|--------|----------|----------------------------------------|-------------------------|-------------|-----------|--------------------|----------------|-------------|-------|
|               | 1 88.386 by | ¥286°  |                                        |      |                                         | ÷.     | 2        | e<br>e                                 |                         |             |           |                    |                | dip bey bes | idan. |
| - 890 RE (287 | ł           |        | 3                                      |      | • • • • • • • • • • • • • • • • • • • • | 4      | ······   | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |                         | · · · · · · |           | ····· }            | [              |             |       |
|               |             | 1      | 2<br>2                                 |      |                                         | 5<br>7 | 5<br>5   | :<br>:                                 |                         |             |           | 1                  | 1              |             |       |
| XBY Lass -    | *           | ·····  | · · · · · · · · · · · · · · · · · · ·  | 3    | UMAAAA                                  | ÛUQ.   | ziiiiina |                                        |                         | Alth        | aaaaaaa   | We -               |                |             |       |
| ci ci ce      |             |        |                                        | 5 5  |                                         | 2      | 1. N     | 5                                      | •<br>•••••••••••••••••• |             |           | ۰ د<br>میں بی در د |                | - :<br>     |       |
| RCE           |             | ·      | ······································ | ÷    |                                         |        |          | 9<br>1                                 | Acres 6                 |             | Same.     | an it              | ROREG          | German in   |       |
|               | ·           |        |                                        |      |                                         | 1      |          | ,                                      | nansearena soa          |             | water ees | toor set           | A Church an Al |             |       |

#### FIGURE 16-8: AUTO-WAKE-UP BIT (WUE) TIMINGS DURING SLEEP



#### 16.5.2 EUSART SYNCHRONOUS SLAVE RECEPTION

The operation of the Synchronous Master and Slave modes is identical, except in the case of Sleep, or any Idle mode and bit SREN, which is a "don't care" in Slave mode.

If receive is enabled by setting the CREN bit prior to entering Sleep or any Idle mode, then a word may be received while in this low-power mode. Once the word is received, the RSR register will transfer the data to the RCREG register; if the RCIE enable bit is set, the interrupt generated will wake the chip from low-power mode. If the global interrupt is enabled, the program will branch to the interrupt vector. To set up a Synchronous Slave Reception:

- Enable the synchronous master serial port by setting bits SYNC and SPEN and clearing bit CSRC.
- 2. If interrupts are desired, set enable bit RCIE.
- 3. If 9-bit reception is desired, set bit RX9.
- 4. To enable reception, set enable bit CREN.
- 5. Flag bit, RCIF, will be set when reception is complete. An interrupt will be generated if enable bit, RCIE, was set.
- Read the RCSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception.
- 7. Read the 8-bit received data by reading the RCREG register.
- 8. If any error occurred, clear the error by clearing bit CREN.
- If using interrupts, ensure that the GIE and PEIE bits in the INTCON register (INTCON<7:6>) are set.

#### TABLE 16-10: REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE RECEPTION

| Name    | Bit 7       | Bit 6         | Bit 5        | Bit 4     | Bit 3 | Bit 2  | Bit 1  | Bit 0  | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|---------|-------------|---------------|--------------|-----------|-------|--------|--------|--------|----------------------|---------------------------------|
| INTCON  | GIE/GIEH    | PEIE/GIEL     | TMR0IE       | INT0IE    | RBIE  | TMR0IF | INT0IF | RBIF   | 0000 000x            | 0000 000u                       |
| PIR1    | _           | ADIF          | RCIF         | TXIF      | —     | CCP1IF | TMR2IF | TMR1IF | -000 -000            | -000 -000                       |
| PIE1    | _           | ADIE          | RCIE         | TXIE      | —     | CCP1IE | TMR2IE | TMR1IE | -000 -000            | -000 -000                       |
| IPR1    | _           | ADIP          | RCIP         | TXIP      | —     | CCP1IP | TMR2IP | TMR1IP | -111 -111            | -111 -111                       |
| RCSTA   | SPEN        | RX9           | SREN         | CREN      | ADDEN | FERR   | OERR   | RX9D   | 0000 000x            | 0000 000x                       |
| RCREG   | EUSART Re   |               | 0000 0000    | 0000 0000 |       |        |        |        |                      |                                 |
| TXSTA   | CSRC        | TX9           | TXEN         | SYNC      | SENDB | BRGH   | TRMT   | TX9D   | 0000 0010            | 0000 0010                       |
| BAUDCTL | _           | RCIDL         | _            | SCKP      | BRG16 | —      | WUE    | ABDEN  | -1-1 0-00            | -1-1 0-00                       |
| SPBRGH  | Baud Rate G | Senerator Reg | ister High E | Byte      |       |        |        |        | 0000 0000            | 0000 0000                       |
| SPBRG   | Baud Rate G | Generator Reg | ister Low B  | yte       |       |        |        |        | 0000 0000            | 0000 0000                       |
|         |             |               |              |           |       |        |        |        |                      |                                 |

Legend: x = unknown, - = unimplemented, read as '0'. Shaded cells are not used for synchronous slave reception.

| R/W-0/0          | U-0                                                                                                                               | R/W-0/0                                            | R/W-0/0       | R/W-0/0        | R/W-0/0                                            | R/W-0/0 | R/W-0/0 |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|---------------|----------------|----------------------------------------------------|---------|---------|--|--|--|--|
| ADFM             | _                                                                                                                                 | ACQT2                                              | ACQT1         | ACQT0          | ADCS2                                              | ADCS1   | ADCS0   |  |  |  |  |
| bit 7            |                                                                                                                                   |                                                    |               |                |                                                    |         | bit     |  |  |  |  |
| Legend:          |                                                                                                                                   |                                                    |               |                |                                                    |         |         |  |  |  |  |
| -                | .:.                                                                                                                               |                                                    | L. 14         |                |                                                    |         |         |  |  |  |  |
| R = Readable b   |                                                                                                                                   | W = Writable                                       |               |                | nented bit, read                                   |         |         |  |  |  |  |
| u = Bit is uncha | inged                                                                                                                             | x = Bit is unki                                    |               | -n/n = Value a | -n/n = Value at POR and BOR/Value at all other Res |         |         |  |  |  |  |
| 1' = Bit is set  |                                                                                                                                   | '0' = Bit is cle                                   | ared          |                |                                                    |         |         |  |  |  |  |
| bit 7            | ADFM: A/D                                                                                                                         | Result Format S                                    | Select bit    |                |                                                    |         |         |  |  |  |  |
|                  | 1 = Right jus<br>0 = Left justi                                                                                                   |                                                    |               |                |                                                    |         |         |  |  |  |  |
| bit 6            | Unimplemented: Read as '0'                                                                                                        |                                                    |               |                |                                                    |         |         |  |  |  |  |
| bit 5-3          | ACQT<2:0><br>000 = 0 TAD<br>001 = 2 TAD<br>010 = 4 TAD<br>011 = 6 TAD<br>100 = 8 TAD<br>101 = 12 TA<br>110 = 16 TA<br>111 = 20 TA | D                                                  | n Time Select | bits           |                                                    |         |         |  |  |  |  |
| bit 2-0          | ADCS<2:0>: A/D Conversion Clock Select bits                                                                                       |                                                    |               |                |                                                    |         |         |  |  |  |  |
|                  | 000 = FOSC/<br>001 = FOSC/<br>010 = FOSC/<br>011 = FRC (<br>100 = FOSC/<br>101 = FOSC/<br>110 = FOSC/<br>111 = FRC (              | /8<br>/32<br>clock derived fro<br>/4<br>/16<br>/64 |               |                |                                                    |         |         |  |  |  |  |

## REGISTER 17-3: ADCON2: A/D CONTROL REGISTER 2

clock starts. This allows the  ${\tt SLEEP}$  instruction to be executed before starting a conversion.

#### 19.5.1 PROGRAM MEMORY CODE PROTECTION

The program memory may be read to, or written from, any location using the table read and table write instructions. The device ID may be read with table reads. The Configuration registers may be read and written with the table read and table write instructions.

In normal execution mode, the CPn bits have no direct effect. CPn bits inhibit external reads and writes. A block of user memory may be protected from table writes if the WRTn Configuration bit is '0'. The EBTRn bits control table reads. For a block of user memory with the EBTRn bit set to '0', a table read instruction that executes from within that block is allowed to read. A table read instruction that executes from a location outside of that block is not allowed to read and will result in reading '0's. Figures 19-6 through 19-8 illustrate table write and table read protection. Note: Code protection bits may only be written to a '0' from a '1' state. It is not possible to write a '1' to a bit in the '0' state. Code protection bits are only set to '1' by a full Chip Erase or Block Erase function. The full Chip Erase and Block Erase functions can only be initiated via ICSP or an external programmer.



### FIGURE 19-6: TABLE WRITE (WRTn) DISALLOWED: PIC18F1320

## 21.0 DEVELOPMENT SUPPORT

The PIC<sup>®</sup> microcontrollers (MCU) and dsPIC<sup>®</sup> digital signal controllers (DSC) are supported with a full range of software and hardware development tools:

- Integrated Development Environment
- MPLAB<sup>®</sup> X IDE Software
   Compilers/Assemblers/Linkers
  - MPLAB XC Compiler
  - MPASM<sup>™</sup> Assembler
  - MPLINK<sup>™</sup> Object Linker/ MPLIB<sup>™</sup> Object Librarian
  - MPLAB Assembler/Linker/Librarian for Various Device Families
- Simulators
  - MPLAB X SIM Software Simulator
- Emulators
  - MPLAB REAL ICE™ In-Circuit Emulator
- In-Circuit Debuggers/Programmers
  - MPLAB ICD 3
  - PICkit™ 3
- Device Programmers
  - MPLAB PM3 Device Programmer
- Low-Cost Demonstration/Development Boards, Evaluation Kits and Starter Kits
- Third-party development tools

## 21.1 MPLAB X Integrated Development Environment Software

The MPLAB X IDE is a single, unified graphical user interface for Microchip and third-party software, and hardware development tool that runs on Windows<sup>®</sup>, Linux and Mac OS<sup>®</sup> X. Based on the NetBeans IDE, MPLAB X IDE is an entirely new IDE with a host of free software components and plug-ins for high-performance application development and debugging. Moving between tools and upgrading from software simulators to hardware debugging and programming tools is simple with the seamless user interface.

With complete project management, visual call graphs, a configurable watch window and a feature-rich editor that includes code completion and context menus, MPLAB X IDE is flexible and friendly enough for new users. With the ability to support multiple tools on multiple projects with simultaneous debugging, MPLAB X IDE is also suitable for the needs of experienced users.

Feature-Rich Editor:

- Color syntax highlighting
- Smart code completion makes suggestions and provides hints as you type
- Automatic code formatting based on user-defined rules
- Live parsing

User-Friendly, Customizable Interface:

- Fully customizable interface: toolbars, toolbar buttons, windows, window placement, etc.
- Call graph window
- Project-Based Workspaces:
- Multiple projects
- Multiple tools
- Multiple configurations
- · Simultaneous debugging sessions
- File History and Bug Tracking:
- Local file history feature
- Built-in support for Bugzilla issue tracker

## 22.3 DC Characteristics: PIC18F1220/1320 (Industrial) PIC18LF1220/1320 (Industrial) (Continued)

| DC CHA              | RACTER | RISTICS                                    | $\begin{array}{l} \mbox{Standard Operating Conditions (unless otherwise stated)} \\ \mbox{Operating temperature } -40^{\circ}C \leq Ta \leq +85^{\circ}C \mbox{ for industrial} \\ -40^{\circ}C \leq Ta \leq +125^{\circ}C \mbox{ for extended} \end{array}$ |      |       |                                                                        |  |  |  |
|---------------------|--------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|------------------------------------------------------------------------|--|--|--|
| Param<br>No.        | Symbol | Characteristic                             | Min.                                                                                                                                                                                                                                                         | Max. | Units | Conditions                                                             |  |  |  |
|                     | Vol    | Output Low Voltage                         |                                                                                                                                                                                                                                                              |      |       |                                                                        |  |  |  |
| D080                |        | I/O ports                                  | _                                                                                                                                                                                                                                                            | 0.6  | V     | IOL = 8.5 mA, VDD = 4.5V,<br>-40°C to +85°C                            |  |  |  |
| D083                |        | OSC2/CLKO<br>(RC mode)                     | _                                                                                                                                                                                                                                                            | 0.6  | V     | IOL = 1.6 mA, VDD = 4.5V,<br>-40°C to +85°C                            |  |  |  |
|                     | Vон    | Output High Voltage <sup>(3)</sup>         |                                                                                                                                                                                                                                                              |      |       |                                                                        |  |  |  |
| D090                |        | I/O ports                                  | Vdd - 0.7                                                                                                                                                                                                                                                    | —    | V     | IOH = -3.0 mA, VDD = 4.5V,<br>-40°C to +85°C                           |  |  |  |
| D092                |        | OSC2/CLKO<br>(RC mode)                     | Vdd - 0.7                                                                                                                                                                                                                                                    | —    | V     | IOH = -1.3 mA, VDD = 4.5V,<br>-40°C to +85°C                           |  |  |  |
| D150                | Vod    | Open-Drain High Voltage                    | —                                                                                                                                                                                                                                                            | 8.5  | V     | RA4 pin                                                                |  |  |  |
|                     |        | Capacitive Loading Specs<br>on Output Pins |                                                                                                                                                                                                                                                              |      |       |                                                                        |  |  |  |
| D100 <sup>(4)</sup> | Cosc2  | OSC2 pin                                   | _                                                                                                                                                                                                                                                            | 15   | pF    | In XT, HS and LP modes<br>when external clock is<br>used to drive OSC1 |  |  |  |
| D101                | Сю     | All I/O pins and OSC2<br>(in RC mode)      | _                                                                                                                                                                                                                                                            | 50   | pF    | To meet the AC timing specifications                                   |  |  |  |
| D102                | Св     | SCL, SDA                                   | —                                                                                                                                                                                                                                                            | 400  | pF    | In I <sup>2</sup> C mode                                               |  |  |  |

**Note 1:** In RC oscillator configuration, the OSC1/CLKI pin is a Schmitt Trigger input. It is not recommended that the PIC<sup>®</sup> device be driven with an external clock while in RC mode.

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

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

4: Parameter is characterized but not tested.





