

#### Welcome to E-XFL.COM

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

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

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

#### Details

E·XFI

| Product Status             | Active                                                                      |
|----------------------------|-----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 64MHz                                                                       |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                   |
| Peripherals                | Brown-out Detect/Reset, LVD, POR, PWM, WDT                                  |
| Number of I/O              | 36                                                                          |
| Program Memory Size        | 64KB (32K x 16)                                                             |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | 1K x 8                                                                      |
| RAM Size                   | 3.6K x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                 |
| Data Converters            | A/D 35x10b; D/A 1x5b                                                        |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 44-TQFP                                                                     |
| Supplier Device Package    | 44-TQFP (10x10)                                                             |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf46k40-i-pt |

Email: info@E-XFL.COM

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

## TABLE 1: 28-PIN ALLOCATION TABLE (PIC18(L)F26K40) (CONTINUED)

|                    |                          |               |                  | · ·       | . ,            | ,                                                                  | •                            | ,                                |     |           |                                                                                              |     |                                              |         |                 |
|--------------------|--------------------------|---------------|------------------|-----------|----------------|--------------------------------------------------------------------|------------------------------|----------------------------------|-----|-----------|----------------------------------------------------------------------------------------------|-----|----------------------------------------------|---------|-----------------|
| 1/O <sup>(2)</sup> | 28-Pin SPDIP, SOIC, SSOP | 28-Pin (U)QFN | A/D              | Reference | Comparator     | Timers                                                             | ССР                          | CWG                              | ZCD | Interrupt | EUSART                                                                                       | NSU | MSSP                                         | Pull-up | Basic           |
| RC0                | 11                       | 8             | ANC0             | _         | _              | T1CKI <sup>(1)</sup><br>T3CKI <sup>(1)</sup><br>T3G <sup>(1)</sup> | -                            | _                                | -   | IOCC0     | _                                                                                            |     | —                                            | Y       | SOSCO           |
| RC1                | 12                       | 9             | ANC1             | —         | _              | —                                                                  | CCP2 <sup>(1)</sup>          | —                                | _   | IOCC1     | —                                                                                            | _   | —                                            | Y       | SOSCIN<br>SOSCI |
| RC2                | 13                       | 10            | ANC2             | _         | _              | T5CKI <sup>(1)</sup>                                               | CCP1 <sup>(1)</sup>          | _                                | _   | IOCC2     | _                                                                                            | _   | _                                            | Y       | _               |
| RC3                | 14                       | 11            | ANC3             | —         | _              | T2AIN <sup>(1)</sup>                                               | -                            | —                                | —   | IOCC3     | —                                                                                            | _   | SCK1 <sup>(1)</sup><br>SCL1 <sup>(3,4)</sup> | Y       | _               |
| RC4                | 15                       | 12            | ANC4             | —         | _              | —                                                                  | -                            | —                                | —   | IOCC4     | —                                                                                            | —   | SDI1 <sup>(1)</sup><br>SDA1 <sup>(3,4)</sup> | Y       | —               |
| RC5                | 16                       | 13            | ANC5             | _         | _              | T4AIN <sup>(1)</sup>                                               | _                            | _                                | _   | IOCC5     | _                                                                                            | _   | _                                            | Y       | _               |
| RC6                | 17                       | 14            | ANC6             | _         | _              | _                                                                  | _                            | _                                | _   | IOCC6     | CK1 <sup>(1)</sup>                                                                           | _   |                                              | Y       | _               |
| RC7                | 18                       | 15            | ANC7             | —         | _              | _                                                                  | _                            | _                                | _   | IOCC7     | RX1/DT1 <sup>(1)</sup>                                                                       | _   | —                                            | Y       |                 |
| RE3                | 1                        | 26            | _                | —         | _              | —                                                                  | _                            | _                                | _   | IOCE3     | _                                                                                            |     | _                                            | Y       | VPP/MCLR        |
| Vss                | 19                       | 16            | —                | —         | —              | —                                                                  | —                            | —                                | _   | —         | —                                                                                            | _   | —                                            | —       | Vss             |
| Vdd                | 20                       | 17            | _                | —         | _              | —                                                                  | —                            | —                                |     |           | —                                                                                            | —   | —                                            | _       | Vdd             |
| Vss                | 8                        | 5             | —                | —         | _              | —                                                                  | _                            | —                                | _   |           | —                                                                                            |     | —                                            | _       | Vss             |
| OUT <sup>(2)</sup> | _                        | _             | ADGRDA<br>ADGRDB | _         | C1OUT<br>C2OUT | TMR0                                                               | CCP1<br>CCP2<br>PWM3<br>PWM4 | CWG1A<br>CWG1B<br>CWG1C<br>CWG1D | _   | _         | TX1/CK1 <sup>(3)</sup><br>DT1 <sup>(3)</sup><br>TX2/CK2 <sup>(3)</sup><br>DT2 <sup>(3)</sup> | DSM | SDO1<br>SCK1<br>SDO2<br>SCK2                 | _       | _               |

Note 1: Default peripheral input. Input can be moved to any other pin with the PPS input selection registers (Register 17-1).

2: All pin outputs default to PORT latch data. Any pin can be selected as a peripheral digital output with the PPS output selection registers.

3: These peripheral functions are bidirectional. The output pin selections must be the same as the input pin selections.

4: These pins are configured for I<sup>2</sup>C logic levels; The SCL/SDAx signals may be assigned to any of these pins. PPS assignments to the other pins (e.g., RB1) will operate, but input logic levels will be standard TTL/ST as selected by the INLVL register, instead of the I<sup>2</sup>C specific or SMBus input buffer thresholds.

# 10.5 Register Definitions: Status

|                 | U-Z. UTATO                    | 0. 01A100                        |                      |                     |                                |                  |           |
|-----------------|-------------------------------|----------------------------------|----------------------|---------------------|--------------------------------|------------------|-----------|
| U-0             | R-1/q                         | R-1/q                            | R/W-0/u              | R/W-0/u             | R/W-0/u                        | R/W-0/u          | R/W-0/u   |
| _               | TO                            | PD                               | Ν                    | OV                  | Z                              | DC               | С         |
| bit 7           |                               |                                  |                      |                     |                                |                  | bit 0     |
|                 |                               |                                  |                      |                     |                                |                  |           |
| Legend:         |                               |                                  |                      |                     |                                |                  |           |
| R = Readable    | bit                           | W = Writable                     | bit                  | U = Unimplei        | mented bit, read               | as '0'           |           |
| -n = Value at F | POR                           | '1' = Bit is set                 |                      | '0' = Bit is cle    | eared                          | x = Bit is unki  | nown      |
| 1.11.7          |                               |                                  | - 1                  |                     |                                |                  |           |
| bit /           | Unimplemen                    | ted: Read as                     | 0′                   |                     |                                |                  |           |
| bit 6           | TO: Time-Out                  | t bit                            |                      |                     |                                |                  |           |
|                 | 1 = Set at po<br>0 = A WDT ti | wer-up or by e<br>me-out occurre | xecution of CI<br>ed | RWDT <b>OF</b> SLEE | IP Instruction                 |                  |           |
| bit 5           | PD: Power-D                   | own bit                          |                      |                     |                                |                  |           |
|                 | 1 = Set at po                 | wer-up or by e                   | xecution of CI       | RWDT instructi      | ion                            |                  |           |
|                 | 0 = Set by ex                 | ecution of the                   | SLEEP instruc        | ction               |                                |                  |           |
| bit 4           | N: Negative b                 | it used for sigr                 | ed arithmetic        | (2's compleme       | ent); indicates if             | the result is ne | egative,  |
|                 | (ALU MSb = 1                  | 1).                              |                      |                     |                                |                  |           |
|                 | 1 = 1 he resu                 | It is negative                   |                      |                     |                                |                  |           |
| hit 2           |                               | hit used for sid                 | and orithmoti        | $a/2^{2}a$ complete | nant); indiaataa               | an avarflaw of   | the 7 hit |
| DILS            | magnitude w                   | hich causes the                  | e sign bit (bit 2    | 7) to change st     | tate                           | an overnow or    | the 7-bit |
|                 | 1 = Overflow                  | occurred for c                   | urrent signed        | arithmetic ope      | ration                         |                  |           |
|                 | 0 = No overfl                 | ow occurred                      |                      |                     |                                |                  |           |
| bit 2           | Z: Zero bit                   |                                  |                      |                     |                                |                  |           |
|                 | 1 = The resu                  | It of an arithme                 | tic or logic op      | eration is zero     |                                |                  |           |
|                 | 0 = The resu                  | It of an arithme                 | tic or logic op      | eration is not z    | zero                           |                  |           |
| bit 1           | DC: Digit Car                 | ry/Borrow bit (2                 | ADDWF, ADDLW         | , SUBLW, SUBW       | ≀F instructions) <sup>(′</sup> | 1)               |           |
|                 | 1 = A carry-o                 | ut from the 4th                  | low-order bit        | of the result of    | ccurred                        |                  |           |
|                 | 0 = No carry-                 | -out from the 4                  | th low-order b       | it of the result    | (4.2)                          |                  |           |
| bit 0           | C: Carry/Borr                 | ow bit (ADDWF,                   | ADDLW, SUBL          | W, SUBWF instr      | uctions) <sup>(1,2)</sup>      |                  |           |
|                 | 1 = A carry-o                 | out from the Mo                  | st Significant       | bit of the resul    | t occurred                     |                  |           |
|                 |                               | rity is reversed                 |                      |                     | an occurred                    | o's complome     | at of the |
| Secon           | nd operand                    |                                  |                      |                     | by accurry the tw              | o a complementer |           |
| 2. For B        | otate (PPF PL                 | F) instructions                  | this hit is load     | led with either     | the high or low-               | order hit of the | Source    |

# REGISTER 10-2: STATUS: STATUS REGISTER

2: For Rotate (RRF, RLF) instructions, this bit is loaded with either the high or low-order bit of the Source register.

# 13.6 CRC Check Value

The CRC check value will be located in the CRCACC registers after the CRC calculation has finished. The check value will depend on two mode settings of the CRCCON register: ACCM and SHIFTM.

When the ACCM bit is set, the CRC module augments the data with a number of zeros equal to the length of the polynomial to align the final check value. When the ACCM bit is not set, the CRC will stop at the end of the data. A number of zeros equal to the length of the polynomial can then be entered into CRCDAT to find the same check value as augmented mode. Alternatively, the expected check value can be entered at this point to make the final result equal 0.

When the CRC check value is computed with the SHIFTM bit set, selecting LSb first, and the ACCM bit is set then the final value in the CRCACC registers will be reversed such that the LSb will be in the MSb position and vice versa. This is the expected check value in bit reversed form. If you are creating a check value to be appended to a data stream then a bit reversal must be performed on the final value to achieve the correct checksum. You can use the CRC to do this reversal by the following method:

- Save CRCACC value in user RAM space
- Clear the CRCACC registers
- Clear the CRCXOR registers
- Write the saved CRCACC value to the CRCDAT input

The properly oriented check value will be in the CRCACC registers as the result.

# 13.7 CRC Interrupt

The CRC will generate an interrupt when the BUSY bit transitions from 1 to 0. The CRCIF Interrupt Flag bit of the PIR7 register is set every time the BUSY bit transitions, regardless of whether or not the CRC interrupt is enabled. The CRCIF bit can only be cleared in software. The CRC interrupt enable is the CRCIE bit of the PIE7 register.

# 13.8 Configuring the CRC

The following steps illustrate how to properly configure the CRC.

- Determine if the automatic program memory scan will be used with the scanner or manual calculation through the SFR interface and perform the actions specified in Section 13.5 "CRC Data Sources", depending on which decision was made.
- 2. If desired, seed a starting CRC value into the CRCACCH/L registers.
- 3. Program the CRCXORH/L registers with the desired generator polynomial.
- Program the DLEN<3:0> bits of the CRCCON1 register with the length of the data word - 1 (refer to Example 13-1). This determines how many times the shifter will shift into the accumulator for each data word.
- 5. Program the PLEN<3:0> bits of the CRCCON1 register with the length of the polynomial -2 (refer to Example 13-1).
- Determine whether shifting in trailing zeros is desired and set the ACCM bit of the CRCCON0 register appropriately.
- 7. Likewise, determine whether the MSb or LSb should be shifted first and write the SHIFTM bit of the CRCCON0 register appropriately.
- 8. Write the CRCGO bit of the CRCCON0 register to begin the shifting process.
- 9a. If manual SFR entry is used, monitor the FULL bit of the CRCCON0 register. When FULL = 0, another word of data can be written to the CRCDATH/L registers, keeping in mind that CRCDATH should be written first if the data has more than eight bits, as the shifter will begin upon the CRCDATL register being written.
- 9b. If the scanner is used, the scanner will automatically stuff words into the CRCDATH/L registers as needed, as long as the SCANGO bit is set.
- 10a. If using the Flash memory scanner, monitor the SCANIF (or the SCANGO bit) for the scanner to finish pushing information into the CRCDATA registers. After the scanner is completed, monitor the BUSY bit to determine that the CRC has been completed and the check value can be read from the CRCACC registers. If both the interrupt flags are set (or both BUSY and SCANGO bits are cleared), the completed CRC calculation can be read from the CRCACCH/L registers.
- 10b. If manual entry is used, monitor the BUSY bit to determine when the CRCACC registers will hold the check value.

#### REGISTER 19-3: TMRxCLK: TIMERx CLOCK REGISTER

| U-0   | U-0 | U-0 | U-0 | R/W-0/u | R/W-0/u | R/W-0/u | R/W-0/u |
|-------|-----|-----|-----|---------|---------|---------|---------|
| —     | —   | —   | —   |         | CS<     | :3:0>   |         |
| bit 7 |     |     |     |         |         |         | bit 0   |
|       |     |     |     |         |         |         |         |

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

#### bit 7-4 Unimplemented: Read as '0'

bit 3-0 **CS<3:0>:** Timerx Clock Source Selection bits

| <u> </u>  | Timer1             | Timer3             | Timer5             |
|-----------|--------------------|--------------------|--------------------|
|           | Clock Source       | Clock Source       | Clock Source       |
| 1111-1100 | Reserved           | Reserved           | Reserved           |
| 1011      | TMR5 overflow      | TMR5 overflow      | Reserved           |
| 1010      | TMR3 overflow      | Reserved           | TMR3 overflow      |
| 1001      | Reserved           | TMR1 overflow      | TMR1 overflow      |
| 1000      | TMR0 overflow      | TMR0 overflow      | TMR0 overflow      |
| 0111      | CLKREF             | CLKREF             | CLKREF             |
| 0110      | SOSC               | SOSC               | SOSC               |
| 0101      | MFINTOSC (500 kHz) | MFINTOSC (500 kHz) | MFINTOSC (500 kHz) |
| 0100      | LFINTOSC           | LFINTOSC           | LFINTOSC           |
| 0011      | HFINTOSC           | HFINTOSC           | HFINTOSC           |
| 0010      | Fosc               | Fosc               | Fosc               |
| 0001      | Fosc/4             | Fosc/4             | Fosc/4             |
| 0000      | T1CKIPPS           | T3CKIPPS           | T5CKIPPS           |

# REGISTER 19-4: TMRxGATE: TIMERx GATE ISM REGISTER

| U-0   | U-0 | U-0 | U-0 | R/W-0/u | R/W-0/u | R/W-0/u | R/W-0/u |
|-------|-----|-----|-----|---------|---------|---------|---------|
| _     | —   | —   | _   |         | GSS     | <3:0>   |         |
| bit 7 |     |     |     |         |         |         | bit 0   |
|       |     |     |     |         |         |         |         |

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

#### bit 7-4 Unimplemented: Read as '0'

bit 3-0 **GSS<3:0>:** Timerx Gate Source Selection bits

| 688  | Timer1                 | Timer3                 | Timer5                 |
|------|------------------------|------------------------|------------------------|
| 033  | Gate Source            | Gate Source            | Gate Source            |
| 1111 | Reserved               | Reserved               | Reserved               |
| 1110 | ZCDOUT                 | ZCDOUT                 | ZCDOUT                 |
| 1101 | CMP2OUT                | CMP2OUT                | CMP2OUT                |
| 1100 | CMP1OUT                | CMP1OUT                | CMP1OUT                |
| 1011 | PWM4OUT                | PWM4OUT                | PWM4OUT                |
| 1010 | PWM3OUT                | PWM3OUT                | PWM3OUT                |
| 1001 | CCP2OUT                | CCP2OUT                | CCP2OUT                |
| 1000 | CCP1OUT                | CCP10UT                | CCP1OUT                |
| 0111 | TMR6OUT (post-scaled)  | TMR6OUT (post-scaled)  | TMR6OUT (post-scaled)  |
| 0110 | TMR5 overflow          | TMR5 overflow          | Reserved               |
| 0101 | TMR4OUT (post-scaled)  | TMR4OUT (post-scaled)  | TMR4OUT (post-scaled)  |
| 0100 | TMR3 overflow          | Reserved               | TMR3 overflow          |
| 0011 | TMR2OUT (post-scaled)  | TMR2OUT (post-scaled)  | TMR2OUT (post-scaled)  |
| 0010 | Reserved               | TMR1 overflow          | TMR1 overflow          |
| 0001 | TMR0 overflow          | TMR0 overflow          | TMR0 overflow          |
| 0000 | Pin selected by T1GPPS | Pin selected by T3GPPS | Pin selected by T5GPPS |



# FIGURE 20-13: LEVEL-TRIGGERED HARDWARE LIMIT ONE-SHOT MODE TIMING DIAGRAM (MODE = 10110)

# 21.5.5 PWM DUTY CYCLE

The PWM duty cycle is specified by writing a 10-bit value to the CCPRxH:CCPRxL register pair. The alignment of the 10-bit value is determined by the FMT bit of the CCPxCON register (see Figure 21-5). The CCPRxH:CCPRxL register pair can be written to at any time; however the duty cycle value is not latched into the 10-bit buffer until after a match between PR2 and TMR2.

Equation 21-2 is used to calculate the PWM pulse width.

Equation 21-3 is used to calculate the PWM duty cycle ratio.

FIGURE 21-5: PWM 10-BIT ALIGNMENT



## EQUATION 21-2: PULSE WIDTH

| Pulse Width = (CCPRxH | H:CCPRxL register pair) • |
|-----------------------|---------------------------|
| Tosc                  | • (TMR2 Prescale Value)   |

# EQUATION 21-3: DUTY CYCLE RATIO

$$Duty Cycle Ratio = \frac{(CCPRxH:CCPRxL register pair)}{4(PR2 + 1)}$$

CCPRxH:CCPRxL register pair are used to double buffer the PWM duty cycle. This double buffering is essential for glitchless PWM operation.

The 8-bit timer TMR2 register is concatenated with either the 2-bit internal system clock (FOSC), or two bits of the prescaler, to create the 10-bit time base. The system clock is used if the Timer2 prescaler is set to 1:1.

When the 10-bit time base matches the CCPRxH:CCPRxL register pair, then the CCPx pin is cleared (see Figure 21-4).

# 21.5.6 PWM RESOLUTION

The resolution determines the number of available duty cycles for a given period. For example, a 10-bit resolution will result in 1024 discrete duty cycles, whereas an 8-bit resolution will result in 256 discrete duty cycles.

The maximum PWM resolution is ten bits when PR2 is 255. The resolution is a function of the PR2 register value as shown by Equation 21-4.

# EQUATION 21-4: PWM RESOLUTION

Resolution = 
$$\frac{\log[4(PR2 + 1)]}{\log(2)}$$
 bits

**Note:** If the pulse-width value is greater than the period the assigned PWM pin(s) will remain unchanged.

## 22.1.9 SETUP FOR PWM OPERATION USING PWMx PINS

The following steps should be taken when configuring the module for PWM operation using the PWMx pins:

- 1. Disable the PWMx pin output driver(s) by setting the associated TRIS bit(s).
- 2. Clear the PWMxCON register.
- 3. Load the PR2 register with the PWM period value.
- 4. Load the PWMxDCH register and bits <7:6> of the PWMxDCL register with the PWM duty cycle value.
- 5. Configure and start Timer2:
  - Clear the TMR2IF interrupt flag bit of the PIR4 register. See Note 1 below.
  - Select the timer clock source to be as Fosc/4 using the TxCLKCON register. This is required for correct operation of the PWM module.
  - Configure the T2CKPS bits of the T2CON register with the Timer2 prescale value.
  - Enable Timer2 by setting the T2ON bit of the T2CON register.
- Enable PWM output pin and wait until Timer2 overflows, TMR2IF bit of the PIR4 register is set. See note below.
- Enable the PWMx pin output driver(s) by clearing the associated TRIS bit(s) and setting the desired pin PPS control bits.
- 8. Configure the PWM module by loading the PWMxCON register with the appropriate values.
  - Note 1: In order to send a complete duty cycle and period on the first PWM output, the above steps must be followed in the order given. If it is not critical to start with a complete PWM signal, then move Step 8 to replace Step 4.
    - **2:** For operation with other peripherals only, disable PWMx pin outputs.

# 22.1.10 SETUP FOR PWM OPERATION TO OTHER DEVICE PERIPHERALS

The following steps should be taken when configuring the module for PWM operation to be used by other device peripherals:

- 1. Disable the PWMx pin output driver(s) by setting the associated TRIS bit(s).
- 2. Clear the PWMxCON register.
- 3. Load the PR2 register with the PWM period value.
- Load the PWMxDCH register and bits <7:6> of the PWMxDCL register with the PWM duty cycle value.
- 5. Configure and start Timer2:
  - Clear the TMR2IF interrupt flag bit of the PIR4 register. See Note 1 below.
  - Select the timer clock source to be as Fosc/4 using the TxCLKCON register. This is required for correct operation of the PWM module.
  - Configure the T2CKPS bits of the T2CON register with the Timer2 prescale value.
  - Enable Timer2 by setting the T2ON bit of the T2CON register.
- 6. Enable PWM output pin:
  - Wait until Timer2 overflows, TMR2IF bit of the PIR4 register is set. See Note 1 below.
- 7. Configure the PWM module by loading the PWMxCON register with the appropriate values.

Note 1: In order to send a complete duty cycle and period on the first PWM output, the above steps must be included in the setup sequence. If it is not critical to start with a complete PWM signal on the first output, then step 6 may be ignored.





# FIGURE 24-15: SHUTDOWN FUNCTIONALITY, AUTO-RESTART DISABLED (REN = 0, LSAC = 01, LSBD = 01)







## 26.3 SPI Mode Registers

The MSSP module has five registers for SPI mode operation. These are:

- MSSP STATUS register (SSPxSTAT)
- MSSP Control register 1 (SSPxCON1)
- MSSP Control register 3 (SSPxCON3)
- MSSP Data Buffer register (SSPxBUF)
- MSSP Address register (SSPxADD)
- MSSP Shift register (SSPSR) (Not directly accessible)

SSPxCON1 and SSPxSTAT are the control and STATUS registers in SPI mode operation. The SSPxCON1 register is readable and writable. The lower six bits of the SSPxSTAT are read-only. The upper two bits of the SSPxSTAT are read/write.

In one SPI master mode, SSPxADD can be loaded with a value used in the Baud Rate Generator. More information on the Baud Rate Generator is available in **Section 26.11 "Baud Rate Generator"**.

SSPSR is the shift register used for shifting data in and out. SSPxBUF provides indirect access to the SSPSR register. SSPxBUF is the buffer register to which data bytes are written, and from which data bytes are read.

In receive operations, SSPSR and SSPxBUF together create a buffered receiver. When SSPSR receives a complete byte, it is transferred to SSPxBUF and the SSPxIF interrupt is set.

During transmission, the SSPxBUF is not buffered. A write to SSPxBUF will write to both SSPxBUF and SSPSR.

© 2015-2017 Microchip Technology Inc.

| Name       | Bit 7    | Bit 6                | Bit 5 | Bit 4    | Bit 3       | Bit 2      | Bit 1   | Bit 0   | Reset<br>Values<br>on Page |  |
|------------|----------|----------------------|-------|----------|-------------|------------|---------|---------|----------------------------|--|
| INTCON     | GIE/GIEH | PEIE/GIEL            | IPEN  | —        | —           | INT2EDG    | INT1EDG | INT0EDG | 170                        |  |
| PIE3       | RC2IE    | TX2IE                | RC1IE | TX1IE    | BCL2IE      | SSP2IE     | BCL1IE  | SSP1IE  | 182                        |  |
| PIR3       | RC2IF    | TX2IF                | RC1IF | TX1IF    | BCL2IF      | SSP2IF     | BCL1IF  | SSP1IF  | 174                        |  |
| IPR3       | RC2IP    | TX2IP                | RC1IP | TX1IP    | BCL2IP      | SSP2IP     | BCL1IP  | SSP1IP  | 190                        |  |
| RxyPPS     | _        | —                    |       |          | RxyPPS<4:0> |            |         |         |                            |  |
| SSPxADD    | ADD<7:0> |                      |       |          |             |            |         |         | 340                        |  |
| SSPxBUF    |          |                      |       | BUF<     | <7:0>       |            |         |         | 336*                       |  |
| SSPxCLKPPS | —        | —                    | -     |          | SS          | SPCLKPPS<4 | :0>     |         | 216                        |  |
| SSPxCON1   | WCOL     | SSPOV                | SSPEN | CKP      |             | SSPN       | 1<3:0>  |         | 338                        |  |
| SSPxCON2   | GCEN     | ACKSTAT              | ACKDT | ACKEN    | RCEN        | PEN        | RSEN    | SEN     | 355                        |  |
| SSPxCON3   | ACKTIM   | PCIE                 | SCIE  | BOEN     | SDAHT       | SBCDE      | AHEN    | DHEN    | 339                        |  |
| SSPxDATPPS | —        | — — — SSPDATPPS<4:0> |       |          |             |            |         | 216     |                            |  |
| SSPxMSK    |          |                      |       | MSK<7:0> |             |            |         |         | 357                        |  |
| SSPxSTAT   | SMP      | CKE                  | D/A   | Р        | S           | R/W        | UA      | BF      | 337                        |  |

# TABLE 26-4: SUMMARY OF REGISTERS ASSOCIATED WITH I<sup>2</sup>C OPERATION

Legend: — = unimplemented location, read as '0'. Shaded cells are not used by the MSSP module in I<sup>2</sup>C mode. \* Page provides register information.



The operation of the EUSART module is controlled through three registers:

- Transmit Status and Control (TXxSTA)
- Receive Status and Control (RCxSTA)
- Baud Rate Control (BAUDxCON)

These registers are detailed in Register 27-1, Register 27-2 and Register 27-3, respectively.

The RXx/DTx and TXx/CKx input pins are selected with the RXxPPS and TXxPPS registers, respectively. TXx, CKx, and DTx output pins are selected with each pin's RxyPPS register. Since the RX input is coupled with the DT output in Synchronous mode, it is the user's responsibility to select the same pin for both of these functions when operating in Synchronous mode. The EUSART control logic will control the data direction drivers automatically.

# 27.2.1.5 TSR Status

The TRMT bit of the TXxSTA register indicates the status of the TSR register. This is a read-only bit. The TRMT bit is set when the TSR register is empty and is cleared when a character is transferred to the TSR register from the TXxREG. The TRMT bit remains clear until all bits have been shifted out of the TSR register. No interrupt logic is tied to this bit, so the user has to poll this bit to determine the TSR status.

| Note: | The TSR register is not mapped in data      |
|-------|---------------------------------------------|
|       | memory, so it is not available to the user. |

## 27.2.1.6 Transmitting 9-Bit Characters

The EUSART supports 9-bit character transmissions. When the TX9 bit of the TXxSTA register is set, the EUSART will shift nine bits out for each character transmitted. The TX9D bit of the TXxSTA register is the ninth, and Most Significant data bit. When transmitting 9-bit data, the TX9D data bit must be written before writing the eight Least Significant bits into the TXxREG. All nine bits of data will be transferred to the TSR shift register immediately after the TXxREG is written.

A special 9-bit Address mode is available for use with multiple receivers. See **Section 27.2.2.7 "Address Detection"** for more information on the Address mode.

## 27.2.1.7 Asynchronous Transmission Setup:

- Initialize the SPxBRGH, SPxBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 27.4 "EUSART Baud Rate Generator (BRG)").
- 2. Enable the asynchronous serial port by clearing the SYNC bit and setting the SPEN bit.
- 3. If 9-bit transmission is desired, set the TX9 control bit. A set ninth data bit will indicate that the eight Least Significant data bits are an address when the receiver is set for address detection.
- 4. Set SCKP bit if inverted transmit is desired.
- 5. Enable the transmission by setting the TXEN control bit. This will cause the TXxIF interrupt bit to be set.
- If interrupts are desired, set the TXxIE interrupt enable bit of the PIE3 register. An interrupt will occur immediately provided that the GIE and PEIE bits of the INTCON register are also set.
- 7. If 9-bit transmission is selected, the ninth bit should be loaded into the TX9D data bit.
- 8. Load 8-bit data into the TXxREG register. This will start the transmission.



#### FIGURE 27-3: ASYNCHRONOUS TRANSMISSION

# TABLE 27-9:SUMMARY OF REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE<br/>TRANSMISSION

| Name     | Bit 7    | Bit 6     | Bit 5 | Bit 4       | Bit 3       | Bit 2   | Bit 1   | Bit 0   | Register<br>on Page |  |
|----------|----------|-----------|-------|-------------|-------------|---------|---------|---------|---------------------|--|
| BAUDxCON | ABDOVF   | RCIDL     |       | SCKP        | BRG16       | —       | WUE     | ABDEN   | 395                 |  |
| INTCON   | GIE/GIEH | PEIE/GIEL | IPEN  |             | _           | INT2EDG | INT1EDG | INT0EDG | 170                 |  |
| PIE3     | RC2IE    | TX2IE     | RC1IE | TX1IE       | BCL2IE      | SSP2IE  | BCL1IE  | SSP1IE  | 182                 |  |
| PIR3     | RC2IF    | TX2IF     | RC1IF | TX1IF       | BCL2IF      | SSP2IF  | BCL1IF  | SSP1IF  | 174                 |  |
| IPR3     | RC2IP    | TX2IP     | RC1IP | TX1IP       | BCL2IP      | SSP2IP  | BCL1IP  | SSP1IP  | 190                 |  |
| RCxSTA   | SPEN     | RX9       | SREN  | CREN        | ADDEN       | FERR    | OERR    | RX9D    | 394                 |  |
| RxyPPS   |          | _         |       |             | RxyPPS<4:0> |         |         |         |                     |  |
| TXxPPS   |          | _         |       | TXPPS<4:0>  |             |         |         |         |                     |  |
| TXxREG   |          |           | EUSA  | RTx Transmi | 396*        |         |         |         |                     |  |
| TXxSTA   | CSRC     | TX9       | TXEN  | SYNC        | SENDB       | BRGH    | TRMT    | TX9D    | 393                 |  |

Legend: — = unimplemented location, read as '0'. Shaded cells are not used for synchronous slave transmission.

Page provides register information.

## 31.1.3 ADC VOLTAGE REFERENCE

The ADPREF<1:0> bits of the ADREF register provide control of the positive voltage reference. The positive voltage reference can be:

- VREF+ pin
- Vdd
- FVR 1.024V
- FVR 2.048V
- FVR 4.096V

The ADNREF bit of the ADREF register provides control of the negative voltage reference. The negative voltage reference can be:

- VREF- pin
- Vss

See Section 28.0 "Fixed Voltage Reference (FVR)" for more details on the Fixed Voltage Reference.

#### 31.1.4 CONVERSION CLOCK

The source of the conversion clock is software selectable via the ADCLK register and the ADCS bits of the ADCON0 register. There are 66 possible clock options:

- Fosc/2
- Fosc/4
- Fosc/6
- Fosc/8
- Fosc/10
  - •
  - •
  - •
- Fosc/128
- FRC (dedicated RC oscillator)

The time to complete one bit conversion is defined as TAD. One full 10-bit conversion requires 11.5 TAD periods as shown in Figure 31-2.

For correct conversion, the appropriate TAD specification must be met. Refer to Table 37-14 for more information. Table 31-1 gives examples of appropriate ADC clock selections.

| Note 1: | Unless using the FRC, any changes in the<br>system clock frequency will change the<br>ADC clock frequency, which may<br>adversely affect the ADC result.                                                                                                                        |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:      | The internal control logic of the ADC runs<br>off of the clock selected by the ADCS bit<br>of ADCON0. What this can mean is when<br>the ADCS bit of ADCON0 is set to '1'<br>(ADC runs on FRC), there may be<br>unexpected delays in operation when<br>setting ADC control bits. |

FIGURE 31-9: DIFFERENTIAL CVD WITH GUARD RING OUTPUT WAVEFORM





| Precharge<br>Time<br>1-255 TINST                            | Precharge       Acquisition/       Conversion Time         Time       Sharing Time       (Traditional Timing of ADC Conversion)         1-255 TINST       1-255 TINST |                                                                                                                                                                    |         |        |      |                                       | on)                                            |                                        |                         |         |      |       |       |
|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------|------|---------------------------------------|------------------------------------------------|----------------------------------------|-------------------------|---------|------|-------|-------|
| (Tpre)                                                      | (TACQ)                                                                                                                                                                | TCY - TAI                                                                                                                                                          | TAD1    | TAD2   | TAD3 | TAD4                                  | TAD5                                           | TAD6                                   | TAD7                    | TAD8    | TAD9 | TAD10 | TAD11 |
| External and Internal<br>Channels are<br>charged/discharged | External and Internal<br>Channels share<br>charge                                                                                                                     | <ul> <li>b9 b8 b7 b6 b5 b4 b3 b2 b1 b0</li> <li>Conversion starts</li> <li>Holding capacitor CHOLD is disconnected from analog input (typically 100 ns)</li> </ul> |         |        |      |                                       |                                                |                                        |                         |         |      |       |       |
| If ADPRE ≠ 0<br>et GO/DONE bit                              | If ADPR<br>If ADAC<br>(Traditic                                                                                                                                       | :E = 0<br>;Q = 0<br>mal Op                                                                                                                                         | eration | Start) |      | On th<br>AADF<br>ADI <u>F</u><br>GO/D | e follov<br>RES0H<br><u>bit is</u> s<br>OONE t | wing cy<br>I:AADF<br>set,<br>pit is cl | ycle:<br>RES0L<br>eared | is load | ed,  |       |       |

# 31.4.5 ADDITIONAL SAMPLE AND HOLD CAPACITANCE

Additional capacitance can be added in parallel with the internal sample and hold capacitor (CHOLD) by using the ADCAP register. This register selects a digitally programmable capacitance which is added to the ADC conversion bus, increasing the effective internal capacitance of the sample and hold capacitor in the ADC module. This is used to improve the match between internal and external capacitance for a better sensing performance. The additional capacitance does not affect analog performance of the ADC because it is not connected during conversion. See Figure 31-11.





# 33.10 Register Definitions: HLVD Control

Long bit name prefixes for the HLVD peripheral is shown in Table 33-1. Refer to **Section 1.4.2.2 "Long Bit Names"** for more information.

# TABLE 33-1:

| Peripheral | Bit Name Prefix |  |  |  |  |
|------------|-----------------|--|--|--|--|
| HLVD       | HLVD            |  |  |  |  |

#### REGISTER 33-1: HLVDCON1: LOW-VOLTAGE DETECT CONTROL REGISTER 1

| U-0   | U-0 | U-0 | U-0 | R/W-0/u  | R/W-0/u | R/W-0/u | R/W-0/u |  |  |
|-------|-----|-----|-----|----------|---------|---------|---------|--|--|
| _     | _   | _   |     | SEL<3:0> |         |         |         |  |  |
| bit 7 |     |     |     |          |         |         | bit 0   |  |  |

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

#### bit 7-4 Unimplemented: Read as '0'

## bit 3-0 SEL<3:0>: High/Low Voltage Detection Limit Selection bits

| SEL<3:0> | Typical Voltage |
|----------|-----------------|
| 1111     | Reserved        |
| 1110     | 4.63V           |
| 1101     | 4.32V           |
| 1100     | 4.12V           |
| 1011     | 3.91V           |
| 1010     | 3.71V           |
| 1001     | 3.60V           |
| 1000     | 3.4V            |
| 0111     | 3.09V           |
| 0110     | 2.88V           |
| 0101     | 2.78V           |
| 0100     | 2.57V           |
| 0011     | 2.47V           |
| 0010     | 2.26V           |
| 0001     | 2.06V           |
| 0000     | 1.85V           |

| Field           | Description                                                                                                                                                     |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| a               | RAM access bit<br>a = 0: RAM location in Access RAM (BSR register is ignored)<br>a = 1: RAM bank is specified by BSR register                                   |
| bbb             | Bit address within an 8-bit file register (0 to 7).                                                                                                             |
| BSR             | Bank Select Register. Used to select the current RAM bank.                                                                                                      |
| C, DC, Z, OV, N | ALU Status bits: Carry, Digit Carry, Zero, Overflow, Negative.                                                                                                  |
| d               | Destination select bit<br>d = 0: store result in WREG<br>d = 1: store result in file register f                                                                 |
| dest            | Destination: either the WREG register or the specified register file location.                                                                                  |
| f               | 8-bit Register file address (00h to FFh) or 2-bit FSR designator (0h to 3h).                                                                                    |
| fs              | 12-bit Register file address (000h to FFFh). This is the source address.                                                                                        |
| fd              | 12-bit Register file address (000h to FFFh). This is the destination address.                                                                                   |
| GIE             | Global Interrupt Enable bit.                                                                                                                                    |
| k               | Literal field, constant data or label (may be either an 8-bit, 12-bit or a 20-bit value).                                                                       |
| label           | Label name.                                                                                                                                                     |
| mm              | The mode of the TBLPTR register for the table read and table write instructions.<br>Only used with table read and table write instructions:                     |
| *               | No change to register (such as TBLPTR with table reads and writes)                                                                                              |
| *+              | Post-Increment register (such as TBLPTR with table reads and writes)                                                                                            |
| *_              | Post-Decrement register (such as TBLPTR with table reads and writes)                                                                                            |
| +*              | Pre-Increment register (such as TBLPTR with table reads and writes)                                                                                             |
| n               | The relative address (2's complement number) for relative branch instructions or the direct address for CALL/BRANCH and RETURN instructions.                    |
| PC              | Program Counter.                                                                                                                                                |
| PCL             | Program Counter Low Byte.                                                                                                                                       |
| PCH             | Program Counter High Byte.                                                                                                                                      |
| PCLATH          | Program Counter High Byte Latch.                                                                                                                                |
| PCLATU          | Program Counter Upper Byte Latch.                                                                                                                               |
| PD              | Power-down bit.                                                                                                                                                 |
| PRODH           | Product of Multiply High Byte.                                                                                                                                  |
| PRODL           | Product of Multiply Low Byte.                                                                                                                                   |
| s               | Fast Call/Return mode select bit<br>s = 0: do not update into/from shadow registers<br>s = 1: certain registers loaded into/from shadow registers (Fast mode)   |
| TBLPTR          | 21-bit Table Pointer (points to a Program Memory location).                                                                                                     |
| TABLAT          | 8-bit Table Latch.                                                                                                                                              |
| TO              | Time-out bit.                                                                                                                                                   |
| TOS             | Top-of-Stack.                                                                                                                                                   |
| u               | Unused or unchanged.                                                                                                                                            |
| WDT             | Watchdog Timer.                                                                                                                                                 |
| WREG            | Working register (accumulator).                                                                                                                                 |
| x               | Don't care ('0' or '1'). The assembler will generate code with $x = 0$ . It is the recommended form of use for compatibility with all Microchip software tools. |
| Zs              | 7-bit offset value for indirect addressing of register files (source).                                                                                          |
| zd              | 7-bit offset value for indirect addressing of register files (destination).                                                                                     |
| { }             | Optional argument.                                                                                                                                              |
| [text]          | Indicates an indexed address.                                                                                                                                   |
| (text)          | The contents of text.                                                                                                                                           |
| [expr] <n></n>  | Specifies bit n of the register indicated by the pointer expr.                                                                                                  |
| $\rightarrow$   | Assigned to.                                                                                                                                                    |
| < >             | Register bit field.                                                                                                                                             |
| E               | In the set of.                                                                                                                                                  |
| italics         | User defined term (font is Courier).                                                                                                                            |

# TABLE 35-1: OPCODE FIELD DESCRIPTIONS

# 44-Lead Plastic Quad Flat, No Lead Package (ML) - 8x8 mm Body [QFN or VQFN]

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



|                         | MILLIMETERS      |          |          |      |  |  |  |
|-------------------------|------------------|----------|----------|------|--|--|--|
| Dimension               | Dimension Limits |          |          | MAX  |  |  |  |
| Number of Pins          | Ν                | 44       |          |      |  |  |  |
| Pitch                   | е                |          | 0.65 BSC |      |  |  |  |
| Overall Height          | Α                | 0.80     | 0.90     | 1.00 |  |  |  |
| Standoff                | A1               | 0.00     | 0.02     | 0.05 |  |  |  |
| Terminal Thickness      | A3               | 0.20 REF |          |      |  |  |  |
| Overall Width           | E                | 8.00 BSC |          |      |  |  |  |
| Exposed Pad Width       | E2               | 6.25     | 6.45     | 6.60 |  |  |  |
| Overall Length          | D                | 8.00 BSC |          |      |  |  |  |
| Exposed Pad Length      | D2               | 6.25     | 6.45     | 6.60 |  |  |  |
| Terminal Width          | b                | 0.20     | 0.30     | 0.35 |  |  |  |
| Terminal Length         | L                | 0.30     | 0.40     | 0.50 |  |  |  |
| Terminal-to-Exposed-Pad | К                | 0.20     | -        | -    |  |  |  |

Notes:

- 1. Pin 1 visual index feature may vary, but must be located within the hatched area.
- 2. Package is saw singulated
- 3. Dimensioning and tolerancing per ASME Y14.5M
  - BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-103D Sheet 2 of 2