



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                      | 40MHz                                                                     |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                         |
| Peripherals                | Brown-out Detect/Reset, HLVD, POR, PWM, WDT                               |
| Number of I/O              | 54                                                                        |
| Program Memory Size        | 128KB (64K x 16)                                                          |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 1K x 8                                                                    |
| RAM Size                   | 3.8K x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 4.2V ~ 5.5V                                                               |
| Data Converters            | A/D 12x10b                                                                |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 64-TQFP                                                                   |
| Supplier Device Package    | 64-TQFP (10x10)                                                           |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f6722-i-pt |
|                            |                                                                           |

Email: info@E-XFL.COM

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

#### 3.5.4 EXIT WITHOUT AN OSCILLATOR START-UP DELAY

Certain exits from power-managed modes do not invoke the OST at all. There are two cases:

- PRI\_IDLE mode, where the primary clock source is not stopped and
- the primary clock source is not any of the LP, XT, HS or HSPLL modes.

In these instances, the primary clock source either does not require an oscillator start-up delay since it is already running (PRI\_IDLE), or normally does not require an oscillator start-up delay (RC, EC and INTIO Oscillator modes). However, a fixed delay of interval TCSD following the wake event is still required when leaving Sleep and Idle modes to allow the CPU to prepare for execution. Instruction execution resumes on the first clock cycle following this delay.

## TABLE 3-2:EXIT DELAY ON WAKE-UP BY RESET FROM SLEEP MODE OR ANY IDLE MODE<br/>(BY CLOCK SOURCES)

| Clock Source<br>before Wake-up | Clock Source<br>after Wake-up | Exit Delay                            | Clock Ready Status<br>Bit (OSCCON) |
|--------------------------------|-------------------------------|---------------------------------------|------------------------------------|
|                                | LP, XT, HS                    |                                       |                                    |
| Primary Device Clock           | HSPLL                         | Tcsd <sup>(1)</sup>                   | OSTS                               |
| (PRI_IDLE mode)                | EC, RC                        | 10.30 ( )                             |                                    |
|                                | INTOSC <sup>(2)</sup>         |                                       | IOFS                               |
|                                | LP, XT, HS                    | Tost <sup>(3)</sup>                   |                                    |
| T1OSC or INTRC                 | HSPLL                         | Tost + t <sub>rc</sub> <sup>(3)</sup> | OSTS                               |
|                                | EC, RC                        | TCSD <sup>(1)</sup>                   |                                    |
|                                | INTOSC <sup>(2)</sup>         | TIOBST <sup>(4)</sup>                 | IOFS                               |
|                                | LP, XT, HS                    | Tost <sup>(4)</sup>                   |                                    |
| INTOSC <sup>(2)</sup>          | HSPLL                         | Tost + t <sub>rc</sub> <sup>(3)</sup> | OSTS                               |
|                                | EC, RC                        | Tcsd <sup>(1)</sup>                   |                                    |
|                                | INTOSC <sup>(2)</sup>         | None                                  | IOFS                               |
|                                | LP, XT, HS                    | Tost <sup>(3)</sup>                   |                                    |
| None                           | HSPLL                         | Tost + t <sub>rc</sub> <sup>(3)</sup> | OSTS                               |
| (Sleep mode)                   | EC, RC                        | Tcsd <sup>(1)</sup>                   |                                    |
|                                | INTOSC <sup>(2)</sup>         | TIOBST <sup>(4)</sup>                 | IOFS                               |

Note 1: TCSD (parameter 38, Table 28-12) is a required delay when waking from Sleep and all Idle modes and runs concurrently with any other required delays (see Section 3.4 "Idle Modes").

2: Includes both the INTOSC 8 MHz source and postscaler derived frequencies. On Reset, INTOSC defaults to 1 MHz.

**3:** TOST is the Oscillator Start-up Timer (parameter 32, Table 28-12). t<sub>rc</sub> is the PLL Lock-out Timer (parameter F12, Table 28-7); it is also designated as TPLL.

4: Execution continues during TIOBST (parameter 39, Table 28-12), the INTOSC stabilization period.

| R/W-0                        | R/W-1 <sup>(1)</sup>                                                                               | U-0                                                                                                                                          | R/W-1                    | R-1               | R-1             | R/W-0 <sup>(2)</sup> | R/W-0      |  |  |  |
|------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-------------------|-----------------|----------------------|------------|--|--|--|
| IPEN                         | SBOREN                                                                                             | —                                                                                                                                            | RI                       | TO                | PD              | POR                  | BOR        |  |  |  |
| bit 7                        |                                                                                                    |                                                                                                                                              |                          |                   |                 |                      | bit        |  |  |  |
|                              |                                                                                                    |                                                                                                                                              |                          |                   |                 |                      |            |  |  |  |
| <b>Legend:</b><br>R = Readat | hle hit                                                                                            | W = Writable                                                                                                                                 | hit                      | II – I Inimpler   | nented bit, rea | ad as 'O'            |            |  |  |  |
| -n = Value a                 |                                                                                                    | '1' = Bit is se                                                                                                                              |                          | 0' = Bit is cle   |                 | x = Bit is unkn      | own        |  |  |  |
|                              |                                                                                                    |                                                                                                                                              |                          |                   |                 |                      | 0111       |  |  |  |
| bit 7                        | IPEN: Interru                                                                                      | pt Priority Ena                                                                                                                              | ble bit                  |                   |                 |                      |            |  |  |  |
|                              |                                                                                                    | iority levels or                                                                                                                             |                          |                   |                 |                      |            |  |  |  |
|                              |                                                                                                    |                                                                                                                                              |                          | IC16CXXX Co       | mpatibility mod | de)                  |            |  |  |  |
| bit 6                        |                                                                                                    | OR Software E                                                                                                                                | nable bit <sup>(1)</sup> |                   |                 |                      |            |  |  |  |
|                              | <u>If BOREN&lt;1:</u>                                                                              |                                                                                                                                              |                          |                   |                 |                      |            |  |  |  |
|                              |                                                                                                    | 1 = BOR is enabled<br>0 = BOR is disabled                                                                                                    |                          |                   |                 |                      |            |  |  |  |
|                              | If BOREN<1:                                                                                        | 0> = <u>00, 10 or</u>                                                                                                                        | <u>11:</u>               |                   |                 |                      |            |  |  |  |
|                              | Bit is disabled                                                                                    | d and read as '                                                                                                                              | 0'                       |                   |                 |                      |            |  |  |  |
| bit 5                        | Unimplemen                                                                                         | ted: Read as                                                                                                                                 | '0'                      |                   |                 |                      |            |  |  |  |
| bit 4                        |                                                                                                    | struction Flag                                                                                                                               |                          |                   |                 |                      |            |  |  |  |
|                              |                                                                                                    | 1 = The RESET instruction was not executed (set by firmware only)                                                                            |                          |                   |                 |                      |            |  |  |  |
|                              |                                                                                                    | <ul> <li>0 = The RESET instruction was executed causing a device Reset (must be set in software after<br/>Brown-out Reset occurs)</li> </ul> |                          |                   |                 |                      |            |  |  |  |
| bit 3                        |                                                                                                    |                                                                                                                                              |                          |                   |                 |                      |            |  |  |  |
|                              |                                                                                                    | <b>TO:</b> Watchdog Time-out Flag bit<br>1 = Set by power-up, CLRWDT instruction or SLEEP instruction                                        |                          |                   |                 |                      |            |  |  |  |
|                              |                                                                                                    | ime-out occurr                                                                                                                               |                          |                   |                 |                      |            |  |  |  |
| bit 2                        |                                                                                                    | own Detection                                                                                                                                | •                        |                   |                 |                      |            |  |  |  |
|                              |                                                                                                    | 1 = Set by power-up or by the CLRWDT instruction                                                                                             |                          |                   |                 |                      |            |  |  |  |
| <b>L</b> :L 4                | 0 = Set by execution of the SLEEP instruction <b>POR:</b> Power-on Reset Status bit <sup>(2)</sup> |                                                                                                                                              |                          |                   |                 |                      |            |  |  |  |
| bit 1                        |                                                                                                    |                                                                                                                                              |                          | (set by firmwar   |                 |                      |            |  |  |  |
|                              |                                                                                                    |                                                                                                                                              |                          |                   |                 | er-on Reset occur    | s)         |  |  |  |
| bit 0                        |                                                                                                    | out Reset Stat                                                                                                                               |                          |                   |                 |                      | ,          |  |  |  |
|                              | 1 = A Brown                                                                                        | 1 = A Brown-out Reset has not occurred (set by firmware only)                                                                                |                          |                   |                 |                      |            |  |  |  |
|                              | 0 = A Brown                                                                                        | -out Reset occ                                                                                                                               | urred (must b            | e set in softwar  | e after a Brow  | n-out Reset occu     | ırs)       |  |  |  |
| Note 1:                      | If SBOREN is ena                                                                                   | bled, its Reset                                                                                                                              | state is '1': ot         | herwise, it is '0 |                 |                      |            |  |  |  |
|                              | The actual Reset                                                                                   |                                                                                                                                              |                          |                   |                 | See the notes foll   | owing this |  |  |  |
| r                            | register and Secti                                                                                 | on 4.6 "Reset                                                                                                                                | State of Reg             | isters" for add   | itional informa | ition.               | -          |  |  |  |

#### REGISTER 4-1: RCON: RESET CONTROL REGISTER

**Note 1:** It is recommended that the POR bit be set after a Power-on Reset has been detected so that subsequent Power-on Resets may be detected.

2: Brown-out Reset is said to have occurred when BOR is '0' and POR is '1' (assuming that POR was set to '1' by software immediately after POR).

#### 5.1.3.2 Return Stack Pointer (STKPTR)

The STKPTR register (Register 5-1) contains the Stack Pointer value, the STKFUL (Stack Full) status bit and the STKUNF (Stack Underflow) status bits. The value of the Stack Pointer can be 0 through 31. The Stack Pointer increments before values are pushed onto the stack and decrements after values are popped off the stack. On Reset, the Stack Pointer value will be zero. The user may read and write the Stack Pointer value. This feature can be used by a Real-Time Operating System (RTOS) for return stack maintenance.

After the PC is pushed onto the stack 31 times (without popping any values off the stack), the STKFUL bit is set. The STKFUL bit is cleared by software or by a POR.

The action that takes place when the stack becomes full depends on the state of the STVREN (Stack Overflow Reset Enable) Configuration bit. (Refer to **Section 25.1 "Configuration Bits"** for a description of the device Configuration bits.) If STVREN is set (default), the 31st PUSH will push the (PC + 2) value onto the stack, set the STKFUL bit and reset the device. The STKFUL bit will remain set and the Stack Pointer will be set to zero.

If STVREN is cleared, the STKFUL bit will be set on the 31st PUSH and the Stack Pointer will increment to 31. Any additional pushes will not overwrite the 31st PUSH and STKPTR will remain at 31. When the stack has been popped enough times to unload the stack, the next POP will return a value of zero to the PC and set the STKUNF bit, while the Stack Pointer remains at zero. The STKUNF bit will remain set until cleared by software or until a POR occurs.

| Note: | Returning a value of zero to the PC on an<br>underflow has the effect of vectoring the<br>program to the Reset vector, where the<br>stack conditions can be verified and<br>appropriate actions can be taken. This is |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | not the same as a Reset, as the contents of the SFRs are not affected.                                                                                                                                                |

#### 5.1.3.3 PUSH and POP Instructions

Since the Top-of-Stack is readable and writable, the ability to push values onto the stack and pull values off the stack without disturbing normal program execution is a desirable feature. The PIC18 instruction set includes two instructions, PUSH and POP, that permit the TOS to be manipulated under software control. TOSU, TOSH and TOSL can be modified to place data or a return address on the stack.

The PUSH instruction places the current PC value onto the stack. This increments the Stack Pointer and loads the current PC value onto the stack.

The POP instruction discards the current TOS by decrementing the Stack Pointer. The previous value pushed onto the stack then becomes the TOS value.

### REGISTER 5-1: STKPTR: STACK POINTER REGISTER

| R/C-0                 | R/C-0                                                                                       | U-0                                                               | R/W-0                                                  | R/W-0            | R/W-0            | R/W-0           | R/W-0          |  |
|-----------------------|---------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--------------------------------------------------------|------------------|------------------|-----------------|----------------|--|
| STKFUL <sup>(1)</sup> | STKUNF <sup>(1)</sup>                                                                       | _                                                                 | SP4                                                    | SP3              | SP2              | SP1             | SP0            |  |
| bit 7                 |                                                                                             |                                                                   |                                                        |                  |                  |                 | bit (          |  |
|                       |                                                                                             |                                                                   |                                                        |                  |                  |                 |                |  |
| Legend:               |                                                                                             |                                                                   |                                                        |                  |                  |                 |                |  |
| R = Readable          | bit                                                                                         | W = Writable                                                      | bit                                                    | U = Unimpler     | nented bit, read | d as '0'        |                |  |
| -n = Value at I       | POR                                                                                         | '1' = Bit is set                                                  | t                                                      | '0' = Bit is cle | ared             | x = Bit is unkr | Bit is unknown |  |
| bit 7<br>bit 6        | 1 = Stack bec<br>0 = Stack has<br>STKUNF: Sta                                               | ck Full Flag bit<br>ame full or ove<br>not become funck Underflow | erflowed<br>ull or overflow<br>Flag bit <sup>(1)</sup> | ed               |                  |                 |                |  |
|                       | <ol> <li>1 = Stack underflow occurred</li> <li>0 = Stack underflow did not occur</li> </ol> |                                                                   |                                                        |                  |                  |                 |                |  |
| bit 5                 | Unimplemen                                                                                  | ted: Read as '                                                    | ʻ0'                                                    |                  |                  |                 |                |  |
| bit 4-0               | <b>SP&lt;4:0&gt;:</b> Sta                                                                   | ck Pointer Loc                                                    | ation bits                                             |                  |                  |                 |                |  |
|                       |                                                                                             |                                                                   |                                                        |                  |                  |                 |                |  |

#### 5.1.3.4 Stack Full and Underflow Resets

Device Resets on stack overflow and stack underflow conditions are enabled by setting the STVREN bit in Configuration Register 4L. When STVREN is set, a full or underflow will set the appropriate STKFUL or STKUNF bit and then cause a device Reset. When STVREN is cleared, a full or underflow condition will set the appropriate STKFUL or STKUNF bit, but not cause a device Reset. The STKFUL or STKUNF bits are cleared by the user software or a Power-on Reset.

#### 5.1.4 FAST REGISTER STACK

A fast register stack is provided for the STATUS, WREG and BSR registers, to provide a "fast return" option for interrupts. The stack for each register is only one level deep and is neither readable nor writable. It is loaded with the current value of the corresponding register when the processor vectors for an interrupt. All interrupt sources will push values into the Stack registers. The values in the registers are then loaded back into their associated registers if the RETFIE, FAST instruction is used to return from the interrupt.

If both low and high-priority interrupts are enabled, the stack registers cannot be used reliably to return from low-priority interrupts. If a high-priority interrupt occurs while servicing a low-priority interrupt, the Stack register values stored by the low-priority interrupt will be overwritten. In these cases, users must save the key registers in software during a low-priority interrupt.

If interrupt priority is not used, all interrupts may use the fast register stack for returns from interrupt. If no interrupts are used, the fast register stack can be used to restore the STATUS, WREG and BSR registers at the end of a subroutine call. To use the fast register stack for a subroutine call, a CALL label, FAST instruction must be executed to save the STATUS, WREG and BSR registers to the fast register stack. A RETURN, FAST instruction is then executed to restore these registers from the fast register stack.

Example 5-1 shows a source code example that uses the fast register stack during a subroutine call and return.

#### EXAMPLE 5-1: FAST REGISTER STACK CODE EXAMPLE

| CALL SUB1, | FAST | ;STATUS, WREG, BSR      |
|------------|------|-------------------------|
|            |      | ;SAVED IN FAST REGISTER |
|            |      | ; STACK                 |
| •          |      |                         |
| •          |      |                         |
|            |      |                         |
| SUB1 •     |      |                         |
| •          |      |                         |
| RETURN,    | FAST | ;RESTORE VALUES SAVED   |
|            |      | ;IN FAST REGISTER STACK |

#### 5.1.5 LOOK-UP TABLES IN PROGRAM MEMORY

There may be programming situations that require the creation of data structures, or look-up tables, in program memory. For PIC18 devices, look-up tables can be implemented in two ways:

- Computed GOTO
- Table Reads

#### 5.1.5.1 Computed GOTO

A computed GOTO is accomplished by adding an offset to the program counter. An example is shown in Example 5-2.

A look-up table can be formed with an ADDWF PCL instruction and a group of  ${\tt RETLW}\ {\tt nn}$  instructions. The W register is loaded with an offset into the table before executing a call to that table. The first instruction of the called routine is the ADDWF PCL instruction. The next instruction executed will be one of the RETLW nn instructions that returns the value 'nn' to the calling function.

The offset value (in WREG) specifies the number of bytes that the program counter should advance and should be multiples of 2 (LSb = 0).

In this method, only one data byte may be stored in each instruction location and room on the return address stack is required.

PCL" instruction does not The "ADDWF Note: update the PCLATH and PCLATU registers. A read operation on PCL must be performed to update PCLATH and PCLATU.

| EXAMPLE 5-2: |                                                  | COMPU                           | ITED GC | TO USING AN OFFSET VALUE                                                                                                                            |
|--------------|--------------------------------------------------|---------------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| MAIN:        | ORG<br>MOVLW<br>CALL                             | 0x0000<br>0x00<br>TABLE         |         |                                                                                                                                                     |
| <br>TABLE    | ORG<br>MOVF<br>RLNCF<br>ADDWF                    | 0x8000<br>PCL, F<br>W, W<br>PCL | ;       | A simple read of PCL will update PCLATH, PCLATU<br>Multiply by 2 to get correct offset in table<br>Add the modified offset to force jump into table |
|              | RETLW<br>RETLW<br>RETLW<br>RETLW<br>RETLW<br>END | `A'<br>`B'<br>`C'<br>`D'<br>`E' |         |                                                                                                                                                     |

### 

#### 7.5.1 16-BIT BYTE WRITE MODE

Figure 7-1 shows an example of 16-bit Byte Write mode for PIC18F8527/8622/8627/8722 devices. This mode is used for two separate 8-bit memories connected for 16-bit operation. This generally includes basic EPROM and Flash devices. It allows table writes to byte-wide external memories. During a TBLWT instruction cycle, the TABLAT data is presented on the upper and lower bytes of the AD<15:0> bus. The appropriate WRH or WRL control line is strobed on the LSb of the TBLPTR.





#### 7.7 Operation in Power-Managed Modes

In alternate power-managed Run modes, the external bus continues to operate normally. If a clock source with a lower speed is selected, bus operations will run at that speed. In these cases, excessive access times for the external memory may result if wait states have been enabled and added to external memory operations. If operations in a lower power Run mode are anticipated, users should provide in their applications for adjusting memory access times at the lower clock speeds. In Sleep and Idle modes, the microcontroller core does not need to access data; bus operations are suspended. The state of the external bus is frozen with the address/data pins and most of the control pins holding at the same state they were in when the mode was invoked. The only potential changes are the  $\overline{CE}$ ,  $\overline{LB}$ and  $\overline{UB}$  pins which are held at logic high.

| Name                    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2   | Bit 1                 | Bit 0  | Reset<br>Values<br>on page |
|-------------------------|-------|-------|-------|-------|-------|---------|-----------------------|--------|----------------------------|
| MEMCON <sup>(1)</sup>   | EBDIS | _     | WAIT1 | WAIT0 |       | —       | WM1                   | WM0    | 60                         |
| CONFIG3L <sup>(2)</sup> | WAIT  | BW    | ABW1  | ABW0  | _     | —       | PM1                   | PM0    | 302                        |
| CONFIG3H                | MCLRE |       |       | —     | _     | LPT1OSC | ECCPMX <sup>(2)</sup> | CCP2MX | 303                        |

#### TABLE 7-3: SUMMARY OF REGISTERS ASSOCIATED WITH POWER-MANAGED MODES

Legend: — = unimplemented, read as '0'. Shaded cells are not used by the External Memory Bus.

Note 1: This register is not implemented on 64-pin devices.

2: Unimplemented in PIC18F6527/6622/6627/6722 devices.

| R/W-0         | R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R/W-1           | R/W-1           | R/W-1            | R/W-1            | R/W-1           | R/W-1  |  |  |  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|------------------|------------------|-----------------|--------|--|--|--|
| SSP2IP        | BCL2IP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RC2IP           | TX2IP           | TMR4IP           | CCP5IP           | CCP4IP          | CCP3IP |  |  |  |
| bit 7         | ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | •               | ·               |                  |                  |                 | bit 0  |  |  |  |
|               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 |                 |                  |                  |                 |        |  |  |  |
| Legend:       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 | <b>F</b> .14    |                  |                  | -1 (0)          |        |  |  |  |
| R = Readabl   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | W = Writable    |                 |                  | mented bit, read |                 |        |  |  |  |
| -n = Value at | POR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | '1' = Bit is se | t               | '0' = Bit is cle | ared             | x = Bit is unkr | nown   |  |  |  |
| bit 7         | SSP2IP: MS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | SP2 Interrupt F | Priority hit    |                  |                  |                 |        |  |  |  |
| Sit 1         | 1 = High price                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | •               | nonty bit       |                  |                  |                 |        |  |  |  |
|               | 0 = Low prio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |                 |                  |                  |                 |        |  |  |  |
| bit 6         | BCL2IP: MS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | SP2 Bus Collis  | ion Interrupt F | Priority bit     |                  |                 |        |  |  |  |
|               | 1 = High priority                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                 |                 |                  |                  |                 |        |  |  |  |
|               | 0 = Low prio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | •               |                 |                  |                  |                 |        |  |  |  |
| bit 5         | RC2IP: EUSART2 Receive Interrupt Priority bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                 |                 |                  |                  |                 |        |  |  |  |
|               | 1 = High priority<br>0 = Low priority                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |                 |                  |                  |                 |        |  |  |  |
| bit 4         | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | •               | Interrunt Prio  | rity bit         |                  |                 |        |  |  |  |
|               | <b>TX2IP:</b> EUSART2 Transmit Interrupt Priority bit<br>1 = High priority                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |                 |                  |                  |                 |        |  |  |  |
|               | 0 = Low priority                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                 |                 |                  |                  |                 |        |  |  |  |
| bit 3         | TMR4IP: TM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R4 to PR4 Mat   | ch Interrupt P  | riority bit      |                  |                 |        |  |  |  |
|               | 1 = High pric                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | •               |                 |                  |                  |                 |        |  |  |  |
|               | 0 = Low prio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | •               |                 |                  |                  |                 |        |  |  |  |
| bit 2         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | P5 Interrupt Pr | iority bit      |                  |                  |                 |        |  |  |  |
|               | 1 = High pricts 0 = Low pricts 100 pricts | •               |                 |                  |                  |                 |        |  |  |  |
| bit 1         | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | •               | iority hit      |                  |                  |                 |        |  |  |  |
|               | <b>CCP4IP:</b> CCP4 Interrupt Priority bit<br>1 = High priority                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 |                 |                  |                  |                 |        |  |  |  |
|               | 0 = Low prio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |                 |                  |                  |                 |        |  |  |  |
| bit 0         | CCP3IP: EC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | CP3 Interrupt F | Priority bit    |                  |                  |                 |        |  |  |  |
|               | 1 = High pric                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                 |                 |                  |                  |                 |        |  |  |  |
|               | 0 = Low prio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | rity            |                 |                  |                  |                 |        |  |  |  |

#### REGISTER 10-12: IPR3: PERIPHERAL INTERRUPT PRIORITY REGISTER 3









#### 19.4.2 OPERATION

The MSSP module functions are enabled by setting MSSP Enable bit, SSPEN (SSPxCON1<5>).

The SSPxCON1 register allows control of the  $I^2C$  operation. Four mode selection bits (SSPxCON1<3:0>) allow one of the following  $I^2C$  modes to be selected:

- I<sup>2</sup>C Master mode, clock
- I<sup>2</sup>C Slave mode (7-bit address)
- I<sup>2</sup>C Slave mode (10-bit address)
- I<sup>2</sup>C Slave mode (7-bit address) with Start and Stop bit interrupts enabled
- I<sup>2</sup>C Slave mode (10-bit address) with Start and Stop bit interrupts enabled
- I<sup>2</sup>C Firmware Controlled Master mode, slave is Idle

Selection of any I<sup>2</sup>C mode with the SSPEN bit set forces the SCLx and SDAx pins to be open-drain, provided these pins are programmed as inputs by setting the appropriate TRISC or TRISD bits. To ensure proper operation of the module, pull-up resistors must be provided externally to the SCLx and SDAx pins.

#### 19.4.3 SLAVE MODE

In Slave mode, the SCLx and SDAx pins must be configured as inputs (TRISC<4:3> set). The MSSP module will override the input state with the output data when required (slave-transmitter).

The I<sup>2</sup>C Slave mode hardware will always generate an interrupt on an address match. Through the mode select bits, the user can also choose to interrupt on Start and Stop bits

When an address is matched, or the data transfer after an address match is received, the hardware automatically will generate the Acknowledge ( $\overrightarrow{ACK}$ ) pulse and load the SSPxBUF register with the received value currently in the SSPxSR register.

Any combination of the following conditions will cause the MSSP module not to give this ACK pulse:

- The Buffer Full bit, BF (SSPxSTAT<0>), was set before the transfer was received.
- The overflow bit, SSPOV (SSPxCON1<6>), was set before the transfer was received.

In this case, the SSPxSR register value is not loaded into the SSPxBUF, but bit SSPxIF is set. The BF bit is cleared by reading the SSPxBUF register, while bit SSPOV is cleared through software.

The SCLx clock input must have a minimum high and low for proper operation. The high and low times of the  $I^2C$  specification, as well as the requirement of the MSSP module, are shown in timing parameter 100 and parameter 101.

#### 19.4.3.1 Addressing

Once the MSSP module has been enabled, it waits for a Start condition to occur. Following the Start condition, the 8 bits are shifted into the SSPxSR register. All incoming bits are sampled with the rising edge of the clock (SCLx) line. The value of register SSPxSR<7:1> is compared to the value of the SSPxADD register. The address is compared on the falling edge of the eighth clock (SCLx) pulse. If the addresses match and the BF and SSPOV bits are clear, the following events occur:

- 1. The SSPxSR register value is loaded into the SSPxBUF register.
- 2. The Buffer Full bit, BF, is set.
- 3. An ACK pulse is generated.
- 4. The MSSP Interrupt Flag bit, SSPxIF, is set (and interrupt is generated, if enabled) on the falling edge of the ninth SCLx pulse.

In 10-Bit Addressing mode, two address bytes need to be received by the slave. The five Most Significant bits (MSbs) of the first address byte specify if this is a 10-bit address. Bit R/W (SSPxSTAT<2>) must specify a write so the slave device will receive the second address byte. For a 10-bit address, the first byte would equal '11110 A9 A8 0', where 'A9' and 'A8' are the two MSbs of the address. The sequence of events for 10-bit address is as follows, with steps 7 through 9 for the slave-transmitter:

- Receive first (high) byte of address (bits SSPxIF, BF and UA (SSPxSTAT<1>) are set on address match).
- Update the SSPxADD register with second (low) byte of address (clears bit UA and releases the SCLx line).
- 3. Read the SSPxBUF register (clears bit BF) and clear flag bit SSPxIF.
- 4. Receive second (low) byte of address (bits SSPxIF, BF and UA are set).
- 5. Update the SSPxADD register with the first (high) byte of address. If match releases SCLx line, this will clear bit UA.
- 6. Read the SSPxBUF register (clears bit BF) and clear flag bit SSPxIF.
- 7. Receive Repeated Start condition.
- 8. Receive first (high) byte of address (bits SSPxIF and BF are set).
- 9. Read the SSPxBUF register (clears bit BF) and clear flag bit SSPxIF.

#### 19.4.7 BAUD RATE

In I<sup>2</sup>C Master mode, the Baud Rate Generator (BRG) reload value is placed in the lower 7 bits of the SSPxADD register (Figure 19-17). When a write occurs to SSPxBUF, the Baud Rate Generator will automatically begin counting. The BRG counts down to '0' and stops until another reload has taken place. The BRG count is decremented twice per instruction cycle (TCY) on the Q2 and Q4 clocks. In I<sup>2</sup>C Master mode, the BRG is reloaded automatically.

Once the given operation is complete (i.e., transmission of the last data bit is followed by ACK), the internal clock will automatically stop counting and the SCLx pin will remain in its last state.

Table 19-3 demonstrates clock rates based on instruction cycles and the BRG value loaded into SSPxADD.

#### 19.4.7.1 Baud Rate and Module Interdependence

Because MSSP1 and MSSP2 are independent, they can operate simultaneously in I<sup>2</sup>C Master mode at different baud rates. This is done by using different BRG reload values for each module.

Because this mode derives its basic clock source from the system clock, any changes to the clock will affect both modules in the same proportion. It may be possible to change one or both baud rates back to a previous value by changing the BRG reload value.





#### TABLE 19-3: I<sup>2</sup>C<sup>™</sup> CLOCK RATE w/BRG

| Fosc   | Fcy    | Fcy*2  | BRG Value | FscL<br>(2 Rollovers of BRG) |
|--------|--------|--------|-----------|------------------------------|
| 40 MHz | 10 MHz | 20 MHz | 18h       | 400 kHz <sup>(1)</sup>       |
| 40 MHz | 10 MHz | 20 MHz | 1Fh       | 312.5 kHz                    |
| 40 MHz | 10 MHz | 20 MHz | 63h       | 100 kHz                      |
| 16 MHz | 4 MHz  | 8 MHz  | 09h       | 400 kHz <sup>(1)</sup>       |
| 16 MHz | 4 MHz  | 8 MHz  | 0Ch       | 308 kHz                      |
| 16 MHz | 4 MHz  | 8 MHz  | 27h       | 100 kHz                      |
| 4 MHz  | 1 MHz  | 2 MHz  | 02h       | 333 kHz <sup>(1)</sup>       |
| 4 MHz  | 1 MHz  | 2 MHz  | 09h       | 100 kHz                      |
| 4 MHz  | 1 MHz  | 2 MHz  | 00h       | 1 MHz <sup>(1)</sup>         |

**Note 1:** The I<sup>2</sup>C interface does not conform to the 400 kHz I<sup>2</sup>C specification (which applies to rates greater than 100 kHz) in all details, but may be used with care where higher rates are required by the application.

#### 20.1 Baud Rate Generator (BRG)

The BRG is a dedicated 8-bit or 16-bit generator that supports both the Asynchronous and Synchronous modes of the EUSART. By default, the BRG operates in 8-bit mode; setting the BRG16 bit (BAUDCONx<3>) selects 16-bit mode.

The SPBRGHx:SPBRGx register pair controls the period of a free running timer. In Asynchronous mode, bits BRGH (TXSTAx<2>) and BRG16 (BAUDCONx<3>) also control the baud rate. In Synchronous mode, BRGH is ignored. Table 20-1 shows the formula for computation of the baud rate for different EUSART modes which only apply in Master mode (internally generated clock).

Given the desired baud rate and Fosc, the nearest integer value for the SPBRGHx:SPBRGx registers can be calculated using the formulas in Table 20-1. From this, the error in baud rate can be determined. An example calculation is shown in Example 20-1. Typical baud rates and error values for the various Asynchronous modes are shown in Table 20-2. It may be advantageous to use the high baud rate (BRGH = 1) or the 16-bit BRG to reduce the baud rate error, or achieve a slow baud rate for a fast oscillator frequency.

Writing a new value to the SPBRGHx:SPBRGx registers causes the BRG timer to be reset (or cleared). This ensures the BRG does not wait for a timer overflow before outputting the new baud rate.

## 20.1.1 OPERATION IN POWER-MANAGED MODES

The device clock is used to generate the desired baud rate. When one of the power-managed modes is entered, the new clock source may be operating at a different frequency. This may require an adjustment to the value in the SPBRGx register pair.

#### 20.1.2 SAMPLING

The data on the RXx pin (either RC7/RX1/DT1 or RG2/ RX2/DT2) is sampled three times by a majority detect circuit to determine if a high or a low level is present at the RXx pin.

| C    | onfiguration B | lits | BRG/EUSART Mode     | Baud Rate Formula       |  |
|------|----------------|------|---------------------|-------------------------|--|
| SYNC | BRG16          | BRGH | BRG/EUSART Mode     | Bauu Kate Formula       |  |
| 0    | 0              | 0    | 8-bit/Asynchronous  | Fosc/[64 (n + 1)]       |  |
| 0    | 0              | 1    | 8-bit/Asynchronous  | $E_{0000}/[16 (n + 1)]$ |  |
| 0    | 1              | 0    | 16-bit/Asynchronous | Fosc/[16 (n + 1)]       |  |
| 0    | 1              | 1    | 16-bit/Asynchronous |                         |  |
| 1 0  |                | x    | 8-bit/Synchronous   | Fosc/[4 (n + 1)]        |  |
| 1    | 1              | x    | 16-bit/Synchronous  |                         |  |

#### TABLE 20-1: BAUD RATE FORMULAS

**Legend:** x = Don't care, n = value of SPBRGHx:SPBRGx register pair

#### EXAMPLE 20-1: CALCULATING BAUD RATE ERROR

| For a device with FOSC of 16 MHz, desired baud rate of 9600, Asynchronous mode, 8-bit BRG: |
|--------------------------------------------------------------------------------------------|
| Desired Baud Rate = Fosc/(64 ([SPBRGHx:SPBRGx] + 1))                                       |
| Solving for SPBRGHx:SPBRGx:                                                                |
| X = ((FOSC/Desired Baud Rate)/64) - 1                                                      |
| = ((1600000/9600)/64) - 1                                                                  |
| = [25.042] $=$ 25                                                                          |
| Calculated Baud Rate= 16000000/(64 (25 + 1))                                               |
| = 9615                                                                                     |
| Error = (Calculated Baud Rate – Desired Baud Rate)/Desired Baud Rate                       |
| = (9615 - 9600)/9600 = 0.16%                                                               |
|                                                                                            |

#### TABLE 20-2: REGISTERS ASSOCIATED WITH BAUD RATE GENERATOR

| Name                                                   | Bit 7   | Bit 6     | Bit 5       | Bit 4        | Bit 3  | Bit 2 | Bit 1 | Bit 0 | Reset<br>Values<br>on page |
|--------------------------------------------------------|---------|-----------|-------------|--------------|--------|-------|-------|-------|----------------------------|
| TXSTAx                                                 | CSRC    | TX9       | TXEN        | SYNC         | SENDB  | BRGH  | TRMT  | TX9D  | 59                         |
| RCSTAx                                                 | SPEN    | RX9       | SREN        | CREN         | ADDEN  | FERR  | OERR  | RX9D  | 59                         |
| BAUDCONx                                               | ABDOVF  | RCIDL     | _           | SCKP         | BRG16  | _     | WUE   | ABDEN | 61                         |
| SPBRGHx EUSARTx Baud Rate Generator Register High Byte |         |           |             |              |        |       |       |       | 59                         |
| SPBRGx                                                 | EUSARTx | Baud Rate | Generator I | Register Lov | w Byte |       |       |       | 59                         |

**Legend:** — = unimplemented, read as '0'. Shaded cells are not used by the BRG.

### 22.9 Analog Input Connection Considerations

A simplified circuit for an analog input is shown in Figure 22-4. Since the analog pins are connected to a digital output, they have reverse biased diodes to VDD and Vss. The analog input, therefore, must be between Vss and VDD. If the input voltage deviates from this

range by more than 0.6V in either direction, one of the diodes is forward biased and a latch-up condition may occur. A maximum source impedance of  $10 \text{ k}\Omega$  is recommended for the analog sources. Any external component connected to an analog input pin, such as a capacitor or a Zener diode, should have very little leakage current.





| TABLE 22-1: | REGISTERS ASSOCIATED WITH COMPARATOR MODULE |
|-------------|---------------------------------------------|
|-------------|---------------------------------------------|

| Name   | Bit 7    | Bit 6     | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Reset<br>Values<br>on page |
|--------|----------|-----------|--------|--------|--------|--------|--------|--------|----------------------------|
| CMCON  | C2OUT    | C10UT     | C2INV  | C1INV  | CIS    | CM2    | CM1    | CM0    | 59                         |
| CVRCON | CVREN    | CVROE     | CVRR   | CVRSS  | CVR3   | CVR2   | CVR1   | CVR0   | 59                         |
| INTCON | GIE/GIEH | PEIE/GIEL | TMR0IE | INT0IE | RBIE   | TMR0IF | INT0IF | RBIF   | 60                         |
| PIR2   | OSCFIF   | CMIF      | _      | EEIF   | BCL1IF | HLVDIF | TMR3IF | CCP2IF | 60                         |
| PIE2   | OSCFIE   | CMIE      | —      | EEIE   | BCL1IE | HLVDIE | TMR3IE | CCP2IE | 60                         |
| IPR2   | OSCFIP   | CMIP      | —      | EEIP   | BCL1IP | HLVDIP | TMR3IP | CCP2IP | 60                         |
| TRISF  | TRISF7   | TRISF6    | TRISF5 | TRISF4 | TRISF3 | TRISF2 | TRISF1 | TRISF0 | 60                         |

**Legend:** — = unimplemented, read as '0'. Shaded cells are unused by the comparator module.

#### REGISTER 25-1: CONFIG1H: CONFIGURATION REGISTER 1 HIGH (BYTE ADDRESS 300001h)

| R/P-0        | R/P-0                                                                                                                  | U-0                                                                                                           | U-0             | R/P-0            | R/P-1            | R/P-1           | R/P-1 |  |  |  |  |  |
|--------------|------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-----------------|------------------|------------------|-----------------|-------|--|--|--|--|--|
| IESO         | FCMEN                                                                                                                  | —                                                                                                             | _               | FOSC3            | FOSC2            | FOSC1           | FOSC0 |  |  |  |  |  |
| bit 7        |                                                                                                                        |                                                                                                               |                 |                  |                  |                 | bit C |  |  |  |  |  |
| Legend:      |                                                                                                                        |                                                                                                               |                 |                  |                  |                 |       |  |  |  |  |  |
| R = Readal   | ble bit                                                                                                                | W = Writable                                                                                                  | bit             | U = Unimpler     | mented bit, read | d as '0'        |       |  |  |  |  |  |
| -n = Value a | at POR                                                                                                                 | '1' = Bit is set                                                                                              |                 | '0' = Bit is cle |                  | x = Bit is unki | nown  |  |  |  |  |  |
|              |                                                                                                                        |                                                                                                               |                 |                  |                  |                 |       |  |  |  |  |  |
| bit 7        | IESO: Interna                                                                                                          | al/External Osc                                                                                               | illator Switcho | ver bit          |                  |                 |       |  |  |  |  |  |
|              | 1 = Two-Spe                                                                                                            | 1 = Two-Speed Start-up enabled                                                                                |                 |                  |                  |                 |       |  |  |  |  |  |
|              | 0 = Two-Spe                                                                                                            | ed Start-up disa                                                                                              | abled           |                  |                  |                 |       |  |  |  |  |  |
| bit 6        | FCMEN: Fail                                                                                                            | FCMEN: Fail-Safe Clock Monitor Enable bit                                                                     |                 |                  |                  |                 |       |  |  |  |  |  |
|              | 1 = Fail-Safe                                                                                                          | 1 = Fail-Safe Clock Monitor enabled                                                                           |                 |                  |                  |                 |       |  |  |  |  |  |
|              | 0 = Fail-Safe                                                                                                          | Clock Monitor                                                                                                 | disabled        |                  |                  |                 |       |  |  |  |  |  |
| bit 5-4      | Unimplemer                                                                                                             | nted: Read as '                                                                                               | 0'              |                  |                  |                 |       |  |  |  |  |  |
| bit 3-0      | FOSC<3:0>: Oscillator Selection bits                                                                                   |                                                                                                               |                 |                  |                  |                 |       |  |  |  |  |  |
|              | 11xx = External RC oscillator, CLKO function on RA6                                                                    |                                                                                                               |                 |                  |                  |                 |       |  |  |  |  |  |
|              |                                                                                                                        | 101x = External RC oscillator, CLKO function on RA6                                                           |                 |                  |                  |                 |       |  |  |  |  |  |
|              |                                                                                                                        | 1001 = Internal oscillator block, CLKO function on RA6, port function on RA7                                  |                 |                  |                  |                 |       |  |  |  |  |  |
|              | 1000 = Internal oscillator block, port function on RA6 and RA7                                                         |                                                                                                               |                 |                  |                  |                 |       |  |  |  |  |  |
|              | 0111 = External RC oscillator, port function on RA6<br>0110 = HS oscillator, PLL enabled (Clock Frequency = 4 x FOSC1) |                                                                                                               |                 |                  |                  |                 |       |  |  |  |  |  |
|              |                                                                                                                        | 0110 = HS oscillator, PLL enabled (Clock Frequency = 4 x POSCT)<br>0101 = EC oscillator, port function on RA6 |                 |                  |                  |                 |       |  |  |  |  |  |
|              |                                                                                                                        | 0100 = EC oscillator, CLKO function on RA6                                                                    |                 |                  |                  |                 |       |  |  |  |  |  |
|              |                                                                                                                        | rnal RC oscillat                                                                                              |                 |                  |                  |                 |       |  |  |  |  |  |
|              | 0010 = HS d                                                                                                            |                                                                                                               |                 |                  |                  |                 |       |  |  |  |  |  |
|              | 0001 = XT c                                                                                                            |                                                                                                               |                 |                  |                  |                 |       |  |  |  |  |  |
|              | 0000 = IPc                                                                                                             | 0000 = 1 P  oscillator                                                                                        |                 |                  |                  |                 |       |  |  |  |  |  |

0000 = LP oscillator

### 26.0 INSTRUCTION SET SUMMARY

The PIC18F8722 family of devices incorporates the standard set of 75 PIC18 core instructions, as well as an extended set of 8 new instructions for the optimization of code that is recursive or that utilizes a software stack. The extended set is discussed later in this section.

### 26.1 Standard Instruction Set

The standard PIC18 instruction set adds many enhancements to the previous PIC<sup>®</sup> MCU instruction sets, while maintaining an easy migration from these PIC MCU instruction sets. Most instructions are a single program memory word (16 bits), but there are four instructions that require two program memory locations.

Each single-word instruction is a 16-bit word divided into an opcode, which specifies the instruction type and one or more operands, which further specify the operation of the instruction.

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

- Byte-oriented operations
- Bit-oriented operations
- Literal operations
- Control operations

The PIC18 instruction set summary in Table 26-2 lists **byte-oriented**, **bit-oriented**, **literal** and **control** operations. Table 26-1 shows the opcode field descriptions.

Most byte-oriented instructions have three operands:

- 1. The file register (specified by 'f')
- 2. The destination of the result (specified by 'd')
- 3. The accessed memory (specified by 'a')

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

All bit-oriented instructions have three operands:

- 1. The file register (specified by 'f')
- 2. The bit in the file register (specified by 'b')
- 3. The accessed memory (specified by 'a')

The bit field designator 'b' selects the number of the bit affected by the operation, while the file register designator 'f' represents the number of the file in which the bit is located. The **literal** instructions may use some of the following operands:

- A literal value to be loaded into a file register (specified by 'k')
- The desired FSR register to load the literal value into (specified by 'f')
- No operand required (specified by '—')

The **control** instructions may use some of the following operands:

- A program memory address (specified by 'n')
- The mode of the CALL or RETURN instructions (specified by 's')
- The mode of the table read and table write instructions (specified by 'm')
- No operand required (specified by '—')

All instructions are a single word, except for four double-word instructions. These instructions were made double-word to contain the required information in 32 bits. In the second word, the 4 MSbs are 1's. If this second word is executed as an instruction (by itself), it will execute as a NOP.

All single-word instructions are executed in a single instruction cycle, unless a conditional test is true or the program counter is changed as a result of the instruction. In these cases, the execution takes two instruction cycles with the additional instruction cycle(s) executed as a NOP.

The double word instructions execute in two instruction cycles.

One instruction cycle consists of four oscillator periods. Thus, for an oscillator frequency of 4 MHz, the normal instruction execution time is 1  $\mu$ s. If a conditional test is true, or the program counter is changed as a result of an instruction, the instruction execution time is 2  $\mu$ s. Two-word branch instructions (if true) would take 3  $\mu$ s.

Figure 26-1 shows the general formats that the instructions can have. All examples use the convention 'nnh' to represent a hexadecimal number.

The Instruction Set Summary, shown in Table 26-2, lists the standard instructions recognized by the Microchip MPASM<sup>™</sup> Assembler.

Section 26.1.1 "Standard Instruction Set" provides a description of each instruction.

| SLEEP                   | Enter Sle                                   | ep Mode                                                         |               | SUBFWB                      | Subtract f fr                                                                                                        | om W with Bo                                                                                                                                                                                       | orrow                      |  |  |
|-------------------------|---------------------------------------------|-----------------------------------------------------------------|---------------|-----------------------------|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--|--|
| Syntax:                 | SLEEP                                       |                                                                 |               | Syntax:                     | SUBFWB f                                                                                                             | {,d {,a}}                                                                                                                                                                                          |                            |  |  |
| Operands:               | None                                        |                                                                 |               | Operands:                   | $0 \leq f \leq 255$                                                                                                  |                                                                                                                                                                                                    |                            |  |  |
| Operation:              | $00h \rightarrow WE$                        | DT,                                                             |               |                             | $d \in [0,1]$                                                                                                        |                                                                                                                                                                                                    |                            |  |  |
|                         | $0 \rightarrow WDT$<br>$1 \rightarrow TO$ , | postscaler,                                                     |               | Operation:                  | a ∈ [0,1]<br>(W) – (f) – ( <del>C</del>                                                                              | ·) doot                                                                                                                                                                                            |                            |  |  |
|                         | $0 \rightarrow PD$                          |                                                                 |               | Status Affected:            |                                                                                                                      |                                                                                                                                                                                                    |                            |  |  |
| Status Affected:        | TO, PD                                      |                                                                 |               | Encoding:                   | N, OV, C, DC                                                                                                         | f ffff                                                                                                                                                                                             |                            |  |  |
| Encoding:               | 0000                                        | 0000 000                                                        | 0 0011        | Description:                |                                                                                                                      | 01da fff                                                                                                                                                                                           |                            |  |  |
| Description:            | cleared. T<br>is set. The                   | r-Down status<br>he Time-out st<br>Watchdog Tir<br>are cleared. | atus bit (TO) | Description.                | (borrow) from<br>method). If 'c<br>W. If 'd' is '1'                                                                  | Subtract register 'f' and Carry flag<br>(borrow) from W (2's complement<br>method). If 'd' is '0', the result is stored in<br>W. If 'd' is '1', the result is stored in<br>register 'f' (default). |                            |  |  |
| Words:                  | with the os                                 | ssor is put into<br>scillator stoppe                            | •             |                             |                                                                                                                      | BSR is used to                                                                                                                                                                                     | is selected. If select the |  |  |
| vvoras:<br>Cycles:      | 1<br>1                                      |                                                                 |               |                             |                                                                                                                      | d the extended                                                                                                                                                                                     | d instruction              |  |  |
| Q Cycles.               | I                                           |                                                                 |               |                             | set is enabled, this instruction operates in<br>Indexed Literal Offset Addressing mode<br>whenever f ≤ 95 (5Fh). See |                                                                                                                                                                                                    |                            |  |  |
| Q Cycle Activity.<br>Q1 | Q2                                          | Q3                                                              | Q4            |                             |                                                                                                                      |                                                                                                                                                                                                    |                            |  |  |
| Decode                  | No                                          | Process                                                         | Go to         |                             | Section 26.2                                                                                                         | 2.3 "Byte-Orie                                                                                                                                                                                     | ented and                  |  |  |
|                         | operation                                   | Data                                                            | Sleep         |                             |                                                                                                                      | l Instructions<br>et Mode" for d                                                                                                                                                                   |                            |  |  |
| Example:                | SLEEP                                       |                                                                 |               | Words:                      | 1                                                                                                                    |                                                                                                                                                                                                    |                            |  |  |
| Before Instruc          |                                             |                                                                 |               | Cycles:                     | 1                                                                                                                    |                                                                                                                                                                                                    |                            |  |  |
| <u>TO</u> =             | ?                                           |                                                                 |               | Q Cycle Activity:           |                                                                                                                      |                                                                                                                                                                                                    |                            |  |  |
| PD =                    | ?                                           |                                                                 |               | Q1                          | Q2                                                                                                                   | Q3                                                                                                                                                                                                 | Q4                         |  |  |
| After Instructi<br>TO = | on<br>1†                                    |                                                                 |               | Decode                      | Read                                                                                                                 | Process                                                                                                                                                                                            | Write to                   |  |  |
| PD =                    | 0                                           |                                                                 |               |                             | register 'f'                                                                                                         | Data                                                                                                                                                                                               | destination                |  |  |
| † If WDT causes         | wake-up this h                              | oit is cleared                                                  |               | Example 1:<br>Before Instru | SUBFWB                                                                                                               | REG, 1, 0                                                                                                                                                                                          |                            |  |  |
| 1                       |                                             |                                                                 |               | REG                         | = 3                                                                                                                  |                                                                                                                                                                                                    |                            |  |  |
|                         |                                             |                                                                 |               | W<br>C                      | = 2<br>= 1                                                                                                           |                                                                                                                                                                                                    |                            |  |  |
|                         |                                             |                                                                 |               | After Instruct              |                                                                                                                      |                                                                                                                                                                                                    |                            |  |  |
|                         |                                             |                                                                 |               | REG<br>W                    | = FF<br>= 2                                                                                                          |                                                                                                                                                                                                    |                            |  |  |
|                         |                                             |                                                                 |               | C<br>Z                      | = 0<br>= 0                                                                                                           |                                                                                                                                                                                                    |                            |  |  |
|                         |                                             |                                                                 |               | Ň                           |                                                                                                                      | sult is negativ                                                                                                                                                                                    | e                          |  |  |
|                         |                                             |                                                                 |               | Example 2:                  | SUBFWB                                                                                                               | REG, 0, 0                                                                                                                                                                                          | )                          |  |  |
|                         |                                             |                                                                 |               | Before Instru<br>REG        | ction<br>= 2                                                                                                         |                                                                                                                                                                                                    |                            |  |  |
|                         |                                             |                                                                 |               | W                           | = 5                                                                                                                  |                                                                                                                                                                                                    |                            |  |  |
|                         |                                             |                                                                 |               | After Instruct              | = 1<br>ion                                                                                                           |                                                                                                                                                                                                    |                            |  |  |
|                         |                                             |                                                                 |               | REG                         | = 2                                                                                                                  |                                                                                                                                                                                                    |                            |  |  |
|                         |                                             |                                                                 |               | W<br>C                      | = 3<br>= 1                                                                                                           |                                                                                                                                                                                                    |                            |  |  |
|                         |                                             |                                                                 |               | Z<br>N                      | = 0<br>= 0 ; re                                                                                                      | sult is positive                                                                                                                                                                                   | •                          |  |  |
|                         |                                             |                                                                 |               | Evenuela 2:                 |                                                                                                                      |                                                                                                                                                                                                    |                            |  |  |

Example 3:

Before Instruction REG = W = C =

After Instruction

REG W C Z N SUBFWB REG, 1, 0

; result is zero

= 1 = 2 = 0

= 0 = 2 = 1 = 1 = 0

## 27.0 DEVELOPMENT SUPPORT

The PIC<sup>®</sup> microcontrollers are supported with a full range of hardware and software development tools:

- Integrated Development Environment
  - MPLAB<sup>®</sup> IDE Software
- Assemblers/Compilers/Linkers
  - MPASM<sup>™</sup> Assembler
  - MPLAB C18 and MPLAB C30 C Compilers
  - MPLINK<sup>™</sup> Object Linker/ MPLIB<sup>™</sup> Object Librarian
  - MPLAB ASM30 Assembler/Linker/Library
- Simulators
  - MPLAB SIM Software Simulator
- Emulators
  - MPLAB ICE 2000 In-Circuit Emulator
  - MPLAB REAL ICE™ In-Circuit Emulator
- In-Circuit Debugger
- MPLAB ICD 2
- Device Programmers
  - PICSTART<sup>®</sup> Plus Development Programmer
  - MPLAB PM3 Device Programmer
  - PICkit<sup>™</sup> 2 Development Programmer
- Low-Cost Demonstration and Development Boards and Evaluation Kits

### 27.1 MPLAB Integrated Development Environment Software

The MPLAB IDE software brings an ease of software development previously unseen in the 8/16-bit microcontroller market. The MPLAB IDE is a Windows<sup>®</sup> operating system-based application that contains:

- A single graphical interface to all debugging tools
  - Simulator
  - Programmer (sold separately)
  - Emulator (sold separately)
  - In-Circuit Debugger (sold separately)
- · A full-featured editor with color-coded context
- A multiple project manager
- Customizable data windows with direct edit of contents
- High-level source code debugging
- Visual device initializer for easy register initialization
- Mouse over variable inspection
- Drag and drop variables from source to watch windows
- Extensive on-line help
- Integration of select third party tools, such as HI-TECH Software C Compilers and IAR C Compilers

The MPLAB IDE allows you to:

- Edit your source files (either assembly or C)
- One touch assemble (or compile) and download to PIC MCU emulator and simulator tools (automatically updates all project information)
- Debug using:
  - Source files (assembly or C)
  - Mixed assembly and C
  - Machine code

MPLAB IDE supports multiple debugging tools in a single development paradigm, from the cost-effective simulators, through low-cost in-circuit debuggers, to full-featured emulators. This eliminates the learning curve when upgrading to tools with increased flexibility and power.

#### 28.2 DC Characteristics: Power-Down and Supply Current PIC18F6X27/6X22/8X27/8X22 (Industrial, Extended) PIC18LF6X27/6X22/8X27/8X22 (Industrial) (Continued)

| PIC18LF6X27/6X22/8X27/8X22<br>(Industrial)<br>PIC18F6X27/6X22/8X27/8X22<br>(Industrial, Extended) |                                     | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrialStandard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for extended |      |    |        |            |                                         |  |  |  |
|---------------------------------------------------------------------------------------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----|--------|------------|-----------------------------------------|--|--|--|
|                                                                                                   |                                     |                                                                                                                                                                                                                                                                                                                           |      |    |        |            |                                         |  |  |  |
|                                                                                                   | Supply Current (IDD) <sup>(2)</sup> |                                                                                                                                                                                                                                                                                                                           |      |    |        |            |                                         |  |  |  |
|                                                                                                   | All devices                         | 9.0                                                                                                                                                                                                                                                                                                                       | 13   | mA | -40°C  |            |                                         |  |  |  |
|                                                                                                   |                                     | 9.0                                                                                                                                                                                                                                                                                                                       | 13   | mA | +25°C  | VDD = 4.2V | Fosc = 4 MHz,<br>16 MHz internal        |  |  |  |
|                                                                                                   |                                     | 9.0                                                                                                                                                                                                                                                                                                                       | 13   | mA | +85°C  | VDD = 4.2V | (PRI RUN HS+PLL)                        |  |  |  |
|                                                                                                   | Extended devices only               | 9.6                                                                                                                                                                                                                                                                                                                       | 15   | mA | +125°C |            | (****_********************************* |  |  |  |
|                                                                                                   | All devices                         | 12                                                                                                                                                                                                                                                                                                                        | 15   | mA | -40°C  |            |                                         |  |  |  |
|                                                                                                   |                                     | 12                                                                                                                                                                                                                                                                                                                        | 15   | mA | +25°C  | VDD = 5.0V | Fosc = 4 MHz,<br>16 MHz internal        |  |  |  |
|                                                                                                   |                                     | 12                                                                                                                                                                                                                                                                                                                        | 15   | mA | +85°C  | VDD = 5.0V | (PRI RUN HS+PLL)                        |  |  |  |
|                                                                                                   | Extended devices only               | 12                                                                                                                                                                                                                                                                                                                        | 17   | mA | +125°C |            |                                         |  |  |  |
|                                                                                                   | All devices                         | 18                                                                                                                                                                                                                                                                                                                        | 23.5 | mA | -40°C  |            | Fosc = 10 MHz,                          |  |  |  |
|                                                                                                   |                                     | 19                                                                                                                                                                                                                                                                                                                        | 23.5 | mA | +25°C  | VDD = 4.2V | 40 MHz internal                         |  |  |  |
|                                                                                                   |                                     | 19                                                                                                                                                                                                                                                                                                                        | 23.5 | mA | +85°C  |            | (PRI_RUN HS+PLL)                        |  |  |  |
|                                                                                                   | All devices                         | 25                                                                                                                                                                                                                                                                                                                        | 29   | mA | -40°C  |            | Fosc = 10 MHz,                          |  |  |  |
|                                                                                                   |                                     | 25                                                                                                                                                                                                                                                                                                                        | 29   | mA | +25°C  | VDD = 5.0V | 40 MHz internal                         |  |  |  |
|                                                                                                   |                                     | 25                                                                                                                                                                                                                                                                                                                        | 29   | mA | +85°C  |            | (PRI_RUN HS+PLL)                        |  |  |  |

Legend: Shading of rows is to assist in readability of the table.

**Note 1:** The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part in Sleep mode, with all I/O pins in high-impedance state and tied to VDD or VSS and all features that add delta current disabled (such as WDT, Timer1 Oscillator, BOR, etc.).

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

The test conditions for all IDD measurements in active operation mode are:

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

MCLR = VDD; WDT enabled/disabled as specified.

**3:** When operation below -10°C is expected, use T1OSC High-Power mode, where LPT1OSC (CONFIG3H<2>) = 0. When operation will always be above -10°C, then the low-power Timer1 oscillator may be selected.

4: BOR and HLVD enable internal band gap reference. With both modules enabled, current consumption will be less than the sum of both specifications.



#### FIGURE 28-7: CLKO AND I/O TIMING

#### TABLE 28-9: CLKO AND I/O TIMING REQUIREMENTS

| Param<br>No. | Symbol   | Characteri                                     | Min              | Тур | Max | Units        | Conditions |            |
|--------------|----------|------------------------------------------------|------------------|-----|-----|--------------|------------|------------|
| 10           | TosH2cĸL | OSC1 $\uparrow$ to CLKO $\downarrow$           | —                | 75  | 200 | ns           | (Note 1)   |            |
| 11           | TosH2ckH | OSC1 ↑ to CLKO ↑                               |                  | —   | 75  | 200          | ns         | (Note 1)   |
| 12           | ТскR     | CLKO Rise Time                                 |                  | —   | 35  | 100          | ns         | (Note 1)   |
| 13           | ТскF     | CLKO Fall Time                                 |                  | —   | 35  | 100          | ns         | (Note 1)   |
| 14           | TckL2I0V | CLKO ↓ to Port Out Valid                       | 1                | —   |     | 0.5 Tcy + 20 | ns         | (Note 1)   |
| 15           | ТюV2скН  | Port In Valid before CLK                       | 0.25 Tcy + 25    |     | _   | ns           | (Note 1)   |            |
| 16           | TckH2iol | Port In Hold after CLKO                        | 0                | _   | —   | ns           | (Note 1)   |            |
| 17           | TosH2IoV | OSC1 1 (Q1 cycle) to Po                        | —                | 50  | 150 | ns           |            |            |
| 18           | TosH2iol | OSC1 ↑ (Q2 cycle) to                           | PIC18FXXXX       | 100 |     | _            | ns         |            |
| 18A          |          | Port Input Invalid<br>(I/O in hold time)       | PIC18LFXXXX      | 200 | —   | —            | ns         | VDD = 2.0V |
| 19           | TioV2osH | Port Input Valid to OSC1 1 (I/O in setup time) |                  | 0   | —   | —            | ns         |            |
| 20           | TIOR     | Port Output Rise Time                          | PIC18FXXXX       | —   | 10  | 25           | ns         |            |
| 20A          |          |                                                | PIC18LFXXXX      | —   | _   | 60           | ns         | VDD = 2.0V |
| 21           | TIOF     | Port Output Fall Time                          | PIC18FXXXX       | —   | 10  | 25           | ns         |            |
| 21A          |          |                                                | PIC18LFXXXX      | —   |     | 60           | ns         | VDD = 2.0V |
| 22†          | TINP     | INTx pin High or Low Tin                       | Тсү              |     | —   | ns           |            |            |
| 23†          | Trbp     | RB<7:4> Change INTx H                          | ligh or Low Time | Тсү |     | —            | ns         |            |

† These parameters are asynchronous events not related to any internal clock edges.

**Note 1:** Measurements are taken in RC mode, where CLKO output is 4 x Tosc.

## THE MICROCHIP WEB SITE

Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information:

- **Product Support** Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Micro-chip sales offices, distributors and factory representatives

# CUSTOMER CHANGE NOTIFICATION SERVICE

Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, access the Microchip web site at www.microchip.com, click on Customer Change Notification and follow the registration instructions.

## **CUSTOMER SUPPORT**

Users of Microchip products can receive assistance through several channels:

- Distributor or Representative
- Local Sales Office
- Field Application Engineer (FAE)
- Technical Support
- Development Systems Information Line

Customers should contact their distributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document.

Technical support is available through the web site at: http://support.microchip.com