



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                      | 64MHz                                                                        |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                    |
| Peripherals                | Brown-out Detect/Reset, LVD, POR, PWM, WDT                                   |
| Number of I/O              | 25                                                                           |
| 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 24x10b; D/A 1x5b                                                         |
| Oscillator Type            | Internal                                                                     |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                                |
| Package / Case             | 28-SSOP (0.209", 5.30mm Width)                                               |
| Supplier Device Package    | 28-SSOP                                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf26k40t-i-ss |

Email: info@E-XFL.COM

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

## 2.3 Master Clear (MCLR) Pin

The MCLR pin provides two specific device functions: Device Reset, and Device Programming and Debugging. If programming and debugging are not required in the end application, a direct connection to VDD may be all that is required. The addition of other components, to help increase the application's resistance to spurious Resets from voltage sags, may be beneficial. A typical configuration is shown in Figure 2-1. Other circuit designs may be implemented, depending on the application's requirements.

During programming and debugging, the resistance and capacitance that can be added to the pin must be considered. Device programmers and debuggers drive the MCLR pin. Consequently, specific voltage levels (VIH and VIL) and fast signal transitions must not be adversely affected. Therefore, specific values of R1 and C1 will need to be adjusted based on the application and PCB requirements. For example, it is recommended that the capacitor, C1, be isolated from the MCLR pin during programming and debugging operations by using a jumper (Figure 2-2). The jumper is replaced for normal run-time operations.

Any components associated with the  $\overline{\text{MCLR}}$  pin should be placed within 0.25 inch (6 mm) of the pin.

## FIGURE 2-2: EXAMPLE OF MCLR PIN CONNECTIONS



## 2.4 ICSP™ Pins

The PGC and PGD pins are used for In-Circuit Serial Programming<sup>TM</sup> (ICSP<sup>TM</sup>) and debugging purposes. It is recommended to keep the trace length between the ICSP connector and the ICSP pins on the device as short as possible. If the ICSP connector is expected to experience an ESD event, a series resistor is recommended, with the value in the range of a few tens of ohms, not to exceed 100 $\Omega$ .

Pull-up resistors, series diodes and capacitors on the PGC and PGD pins are not recommended as they will interfere with the programmer/debugger communications to the device. If such discrete components are an application requirement, they should be removed from the circuit during programming and debugging. Alternatively, refer to the AC/DC characteristics and timing requirements information in the respective device Flash programming specification for information on capacitive loading limits, and pin input voltage high (VIH) and input low (VIL) requirements.

For device emulation, ensure that the "Communication Channel Select" (i.e., PGCx/PGDx pins), programmed into the device, matches the physical connections for the ICSP to the Microchip debugger/emulator tool.

For more information on available Microchip development tools connection requirements, refer to **Section 36.0 "Development Support"**.



2: If the prefetched instruction clears the interrupt enable or GIEH/L, ISR vectoring will not occur, but DOZEN is cleared and the CPU will resume execution at full speed.

## 9.2 Independent Clock Source

The WWDT can derive its time base from either the 31 kHz LFINTOSC or 31.25 kHz MFINTOSC internal oscillators, depending on the value of WDTE<1:0> Configuration bits.

If WDTE = 2'blx, then the clock source will be enabled depending on the WDTCCS<2:0> Configuration bits.

If WDTE = 2'b01, the SEN bit should be set by software to enable WWDT, and the clock source is enabled by the WDTCS bits in the WDTCON1 register.

Time intervals in this chapter are based on a minimum nominal interval of 1 ms. See **Section 37.0 "Electrical Specifications"** for LFINTOSC and MFINTOSC tolerances.

## 9.3 WWDT Operating Modes

The Windowed Watchdog Timer module has four operating modes controlled by the WDTE<1:0> bits in Configuration Words. See Table 9-1.

## 9.3.1 WWDT IS ALWAYS ON

When the WDTE bits of Configuration Words are set to '11', the WWDT is always on.

WWDT protection is active during Sleep.

#### 9.3.2 WWDT IS OFF IN SLEEP

When the WDTE bits of Configuration Words are set to '10', the WWDT is on, except in Sleep.

WWDT protection is not active during Sleep.

#### 9.3.3 WWDT CONTROLLED BY SOFTWARE

When the WDTE bits of Configuration Words are set to '01', the WWDT is controlled by the SEN bit of the WDTCON0 register.

WWDT protection is unchanged by Sleep. See Table 9-1 for more details.

| TABLE 9-1: | WWDT OPERATING MODES |
|------------|----------------------|
|------------|----------------------|

| WDTE<1:0> | SEN | Device<br>Mode | WWDT<br>Mode |
|-----------|-----|----------------|--------------|
| 11        | Х   | Х              | Active       |
| 1.0       | 37  | Awake          | Active       |
| 10        | X   | Sleep          | Disabled     |
| 01        | 1   | Х              | Active       |
| UI        | 0   | Х              | Disabled     |
| 00        | Х   | Х              | Disabled     |

## 9.4 Time-out Period

If the WDTCPS<4:0> Configuration bits default to 5 'b11111, then the WDTPS bits of the WDTCON0 register set the time-out period from 1 ms to 256 seconds (nominal). If any value other than the default value is assigned to WDTCPS<4:0> Configuration bits, then the timer period will be based on the WDTCPS<4:0> bits in the CONFIG3L register. After a Reset, the default time-out period is 2s.

## 9.5 Watchdog Window

The Windowed Watchdog Timer has an optional Windowed mode that is controlled by the WDTCWS<2:0> Configuration bits and WINDOW<2:0> bits of the WDTCON1 register. In the Windowed mode, the CLRWDT instruction must occur within the allowed window of the WDT period. Any CLRWDT instruction that occurs outside of this window will trigger a window violation and will cause a WWDT Reset, similar to a WWDT time out. See Figure 9-2 for an example.

The window size is controlled by the WINDOW<2:0> Configuration bits, or the WINDOW<2:0> bits of WDTCON1, if WDTCWS<2:0> = 111.

The five Most Significant bits of the WDTTMR register are used to determine whether the window is open, as defined by the WINDOW<2:0> bits of the WDTCON1 register.

In the event of a <u>window</u> violation, a Reset will be generated and the WDTWV bit of the PCON0 register will be cleared. This bit is set by a POR or can be set in firmware.

## 9.6 Clearing the WWDT

The WWDT is cleared when any of the following conditions occur:

- Any Reset
- Valid CLRWDT instruction is executed
- Device enters Sleep
- Exit Sleep by Interrupt
- WWDT is disabled
- Oscillator Start-up Timer (OST) is running
- Any write to the WDTCON0 or WDTCON1
   registers

## 9.6.1 CLRWDT CONSIDERATIONS (WINDOWED MODE)

When in Windowed mode, the WWDT must be armed before a CLRWDT instruction will clear the timer. This is performed by reading the WDTCON0 register. Executing a CLRWDT instruction without performing such an arming action will trigger a window violation regardless of whether the window is open or not.

See Table 9-2 for more information.

## **10.3 PIC18 Instruction Cycle**

#### 10.3.1 CLOCKING SCHEME

The microcontroller clock input, whether from an internal or external source, is internally divided by four to generate four non-overlapping quadrature clocks (Q1, Q2, Q3 and Q4). Internally, the program counter is incremented on every Q1; the instruction is fetched from the program memory and latched into the instruction register during Q4. The instruction is decoded and executed during the following Q1 through Q4. The clocks and instruction execution flow are shown in Figure 10-2.

## 10.3.2 INSTRUCTION FLOW/PIPELINING

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

A fetch cycle begins with the Program Counter (PC) incrementing in Q1.

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



## FIGURE 10-2: CLOCK/INSTRUCTION CYCLE

#### **EXAMPLE 10-3: INSTRUCTION PIPELINE FLOW**

|                        | TCY0        | TCY1      | Tcy2      | Тсү3      | TcY4        | TcY5          |
|------------------------|-------------|-----------|-----------|-----------|-------------|---------------|
| 1. MOVLW 55h           | Fetch 1     | Execute 1 |           |           |             |               |
| 2. MOVWF PORTB         |             | Fetch 2   | Execute 2 |           | _           |               |
| 3. BRA SUB_1           |             |           | Fetch 3   | Execute 3 |             |               |
| 4. BSF PORTA, BIT3 (   | Forced NOP) |           |           | Fetch 4   | Flush (NOP) |               |
| 5. Instruction @ addre | ss SUB_1    |           |           |           | Fetch SUB_1 | Execute SUB_1 |

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

## EXAMPLE 11-4: WRITING TO PROGRAM FLASH MEMORY

|              | MOVLW   | D'64′            | ; number of bytes in erase block      |
|--------------|---------|------------------|---------------------------------------|
|              | MOVWF   | COUNTER          |                                       |
|              | MOVLW   | BUFFER_ADDR_HIGH | ; point to buffer                     |
|              | MOVWF   | FSR0H            |                                       |
|              | MOVLW   | BUFFER_ADDR_LOW  |                                       |
|              | MOVWF   | FSROL            |                                       |
|              | MOVLW   | CODE_ADDR_UPPER  | ; Load TBLPTR with the base           |
|              | MOVWF   | TBLPTRU          | ; address of the memory block         |
|              | MOVLW   | CODE_ADDR_HIGH   |                                       |
|              | MOVWF   | TBLPTRH          |                                       |
|              | MOVLW   | CODE ADDR LOW    |                                       |
|              | MOVWF   | TBLPTRL          |                                       |
| READ BLOCK   |         |                  |                                       |
|              | TBLRD*+ |                  | ; read into TABLAT, and inc           |
|              | MOVE    | TABLAT, W        | ; get data                            |
|              | MOVWF   | POSTINCO         | ; store data                          |
|              | DECESZ  | COUNTER          | ; done?                               |
|              | BRA     | READ BLOCK       | ; repeat                              |
| MODIEV WORD  | Didi    |                  | , repear                              |
| MODIFI_WORD  | MOVIN   | BUFFFD ADDD UTCU | : point to buffer                     |
|              | MOVINE  | FCDOU            | / point to builter                    |
|              | MOVWF   | FSRUH            |                                       |
|              | MOVLW   | BUFFER_ADDR_LOW  |                                       |
|              | MOVWF   | FSRUL            | · ···· data buffand                   |
|              | MOVLW   | NEW_DATA_LOW     | ; update builer word                  |
|              | MOVWF   | POSTINCO         |                                       |
|              | MOVLW   | NEW_DATA_HIGH    |                                       |
|              | MOVWF.  | INDF'0           |                                       |
| ERASE_BLOCK  |         |                  |                                       |
|              | MOVLW   | CODE_ADDR_UPPER  | ; load TBLPTR with the base           |
|              | MOVWF   | TBLPTRU          | ; address of the memory block         |
|              | MOVLW   | CODE_ADDR_HIGH   |                                       |
|              | MOVWF   | TBLPTRH          |                                       |
|              | MOVLW   | CODE_ADDR_LOW    |                                       |
|              | MOVWF   | TBLPTRL          |                                       |
|              | BCF     | NVMCON1, NVMREG0 | ; point to Program Flash Memory       |
|              | BSF     | NVMCON1, NVMREG1 | ; point to Program Flash Memory       |
|              | BSF     | NVMCON1, WREN    | ; enable write to memory              |
|              | BSF     | NVMCON1, FREE    | ; enable Erase operation              |
|              | BCF     | INTCON, GIE      | ; disable interrupts                  |
|              | MOVLW   | 55h              |                                       |
| Required     | MOVWF   | NVMCON2          | ; write 55h                           |
| Sequence     | MOVLW   | AAh              |                                       |
|              | MOVWF   | NVMCON2          | ; write OAAh                          |
|              | BSF     | NVMCON1, WR      | ; start erase (CPU stall)             |
|              | BSF     | INTCON, GIE      | ; re-enable interrupts                |
|              | TBLRD*- |                  | ; dummy read decrement                |
|              | MOVLW   | BUFFER_ADDR_HIGH | ; point to buffer                     |
|              | MOVWF   | FSROH            |                                       |
|              | MOVLW   | BUFFER_ADDR_LOW  |                                       |
|              | MOVWF   | FSROL            |                                       |
| WRITE_BUFFER | R_BACK  |                  |                                       |
|              | MOVLW   | BlockSize        | ; number of bytes in holding register |
|              | MOVWF   | COUNTER          |                                       |
|              | MOVLW   | D'64'/BlockSize  | ; number of write blocks in 64 bytes  |
|              | MOVWF   | COUNTER2         | -                                     |
|              |         |                  |                                       |

## 15.0 I/O PORTS

## TABLE 15-1: PORT AVAILABILITY PER DEVICE

| Device            | PORTA | PORTB | PORTC | PORTD | PORTE |
|-------------------|-------|-------|-------|-------|-------|
| PIC18(L)F26K40    | •     | •     | •     |       | •     |
| PIC18(L)F45/46K40 | •     | •     | •     | •     | ٠     |

Each port has eight registers to control the operation. These registers are:

- PORTx registers (reads the levels on the pins of the device)
- LATx registers (output latch)
- · TRISx registers (data direction)
- · ANSELx registers (analog select)
- WPUx registers (weak pull-up)
- INLVLx (input level control)
- SLRCONx registers (slew rate control)
- · ODCONx registers (open-drain control)

Most port pins share functions with device peripherals, both analog and digital. In general, when a peripheral is enabled on a port pin, that pin cannot be used as a general purpose output; however, the pin can still be read.

The Data Latch (LATx registers) is useful for read-modify-write operations on the value that the I/O pins are driving.

A write operation to the LATx register has the same effect as a write to the corresponding PORTx register. A read of the LATx register reads of the values held in the I/O PORT latches, while a read of the PORTx register reads the actual I/O pin value.

Ports that support analog inputs have an associated ANSELx register. When an ANSELx bit is set, the digital input buffer associated with that bit is disabled.

Disabling the input buffer prevents analog signal levels on the pin between a logic high and low from causing excessive current in the logic input circuitry. A simplified model of a generic I/O port, without the interfaces to other peripherals, is shown in Figure 15-1.

## FIGURE 15-1: GENERIC I/O PORT





| R/W-x/x         | R/W-x/x | R/W-x/x          | R/W-x/x | R/W-x/x          | R/W-x/x          | R/W-x/x         | R/W-x/x |
|-----------------|---------|------------------|---------|------------------|------------------|-----------------|---------|
|                 |         |                  | CCPR    | x<15:8>          |                  |                 |         |
| bit 7           |         |                  |         |                  |                  |                 | bit 0   |
|                 |         |                  |         |                  |                  |                 |         |
| Legend:         |         |                  |         |                  |                  |                 |         |
| R = Readable    | bit     | W = Writable     | bit     | U = Unimpler     | nented bit, read | 1 as '0'        |         |
| -n = Value at P | OR      | '1' = Bit is set |         | '0' = Bit is cle | ared             | x = Bit is unkr | nown    |
|                 |         |                  |         |                  |                  |                 |         |
| 1.1.7.0         | MODE    |                  |         |                  |                  |                 |         |

## REGISTER 21-5: CCPRxH: CCPx REGISTER HIGH BYTE

bit 7-0
MODE = Capture Mode:
CCPRxH<7:0>: MSB of captured TMR1 value
MODE = Compare Mode:
CCPRxH<7:0>: MSB compared to TMR1 value
MODE = PWM Mode && FMT = 0:
CCPRxH<7:2>: Not used
CCPRxH<7:2>: Not used
CCPRxH<1:0>: CCPW<9:8> – Pulse-Width MS 2 bits
MODE = PWM Mode && FMT = 1:
CCPRxH<7:0>: CCPW<9:2> – Pulse-Width MS 8 bits

## 23.2 ZCD Logic Output

The ZCD module includes a Status bit, which can be read to determine whether the current source or sink is active. The ZCDOUT bit of the ZCDCON register is set when the current sink is active, and cleared when the current source is active. The ZCDOUT bit is affected by the polarity bit.

The ZCDOUT signal can also be used as input to other modules. This is controlled by the registers of the corresponding module. ZCDOUT can be used as follows:

- Gate source for TMR1/3/5
- Clock source for TMR2/4/6
- Reset source for TMR2/4/6

## 23.3 ZCD Logic Polarity

The ZCDPOL bit of the ZCDCON register inverts the ZCDOUT bit relative to the current source and sink output. When the ZCDPOL bit is set, a ZCDOUT high indicates that the current source is active, and a low output indicates that the current sink is active.

The ZCDPOL bit affects the ZCD interrupts.

## 23.4 ZCD Interrupts

An interrupt will be generated upon a change in the ZCD logic output when the appropriate interrupt enables are set. A rising edge detector and a falling edge detector are present in the ZCD for this purpose.

The ZCDIF bit of the PIR2 register will be set when either edge detector is triggered and its associated enable bit is set. The ZCDINTP enables rising edge interrupts and the ZCDINTN bit enables falling edge interrupts. Both are located in the ZCDCON register. Priority of the interrupt can be changed if the IPEN bit of the INTCON register is set. The ZCD interrupt can be made high or low priority by setting or clearing the ZCDIP bit of the IPR2 register.

To fully enable the interrupt, the following bits must be set:

- · ZCDIE bit of the PIE2 register
- ZCDINTP bit of the ZCDCON register (for a rising edge detection)
- ZCDINTN bit of the ZCDCON register (for a falling edge detection)
- · PEIE and GIE bits of the INTCON register

Changing the ZCDPOL bit will cause an interrupt, regardless of the level of the ZCDSEN bit.

The ZCDIF bit of the PIR2 register must be cleared in software as part of the interrupt service. If another edge is detected while this flag is being cleared, the flag will still be set at the end of the sequence.

## 23.5 Correcting for VCPINV offset

The actual voltage at which the ZCD switches is the reference voltage at the non-inverting input of the ZCD op amp. For external voltage source waveforms other than square waves, this voltage offset from zero causes the zero-cross event to occur either too early or too late.

#### 23.5.1 CORRECTION BY AC COUPLING

When the external voltage source is sinusoidal, the effects of the ZCPINV offset can be eliminated by isolating the external voltage source from the ZCD pin with a capacitor, in addition to the voltage reducing resistor. The capacitor will cause a phase shift resulting in the ZCD output switch in advance of the actual zero-crossing event. The phase shift will be the same for both rising and falling zero crossings, which can be compensated for by either delaying the CPU response to the ZCD switch by a timer or other means, or selecting a capacitor value large enough that the phase shift is negligible.

To determine the series resistor and capacitor values for this configuration, start by computing the impedance, Z, to obtain a peak current of  $300 \ \mu$ A. Next, arbitrarily select a suitably large non-polar capacitor and compute its reactance, Xc, at the external voltage source frequency. Finally, compute the series resistor, capacitor peak voltage, and phase shift by the formulas shown in Equation 23-2.

When this technique is used and the input signal is not present, the ZCD will tend to oscillate. To avoid this oscillation, connect the ZCD pin to VDD or GND with a high-impedance resistor such as 200K.



## 24.2.2 PUSH-PULL MODE

In Push-Pull mode, two output signals are generated, alternating copies of the input as illustrated in Figure 24-4. This alternation creates the push-pull effect required for driving some transformer-based power supply designs. Steering modes are not used in Push-Pull mode. A basic block diagram for the Push-Pull mode is shown in Figure 24-3.

The push-pull sequencer is reset whenever EN = 0 or if an auto-shutdown event occurs. The sequencer is clocked by the first input pulse, and the first output appears on CWG1A.

The unused outputs CWG1C and CWG1D drive copies of CWG1A and CWG1B, respectively, but with polarity controlled by the POLC and POLD bits of the CWG1CON1 register, respectively.

## FIGURE 24-11: SIMPLIFIED CWG BLOCK DIAGRAM (OUTPUT STEERING MODES)





| REGISTER 24-6: CWG1AS0: CWG AUTO-SHUTDOWN CONTROL REGISTER 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                              |                                                                                                          |                                                                                        |                                                                                                                 |                                                                                                 |                                          |               |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|------------------------------------------|---------------|--|--|
| R/W/HS/HC-0/0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R/W-0/0                                                                                                      | R/W-0/0                                                                                                  | R/W-1/1                                                                                | R/W-0/0                                                                                                         | R/W-1/1                                                                                         | U-0                                      | U-0           |  |  |
| SHUTDOWN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | REN                                                                                                          | LSBD                                                                                                     | <1:0>                                                                                  | LSAC                                                                                                            | <1:0>                                                                                           | _                                        | _             |  |  |
| bit 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                              |                                                                                                          |                                                                                        |                                                                                                                 |                                                                                                 |                                          | bit 0         |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                              |                                                                                                          |                                                                                        |                                                                                                                 |                                                                                                 |                                          |               |  |  |
| Legend:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                              |                                                                                                          |                                                                                        |                                                                                                                 |                                                                                                 |                                          |               |  |  |
| R = Readable bit W = Writable bit U = Unimplemented                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                              |                                                                                                          |                                                                                        |                                                                                                                 |                                                                                                 | as '0'                                   |               |  |  |
| u = Bit is unchang                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ged                                                                                                          | x = Bit is unki                                                                                          | nown                                                                                   | -n/n = Value a                                                                                                  | t POR and BOP                                                                                   | R/Value at all c                         | other Resets  |  |  |
| '1' = Bit is set '0' = Bit is cleared HS/HC = Bit is set/cleared by hardware                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                              |                                                                                                          |                                                                                        |                                                                                                                 |                                                                                                 |                                          |               |  |  |
| q = Value depend                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ls on condition                                                                                              |                                                                                                          |                                                                                        |                                                                                                                 |                                                                                                 |                                          |               |  |  |
| bit 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | SHUTDOWN<br>1 = An auto<br>0 = No auto                                                                       | : Auto-Shutdo<br>-shutdown sta<br>-shutdown eve                                                          | wn Event Stat<br>te is in effect<br>ent has occurr                                     | tus bit <sup>(1,2)</sup><br>red                                                                                 |                                                                                                 |                                          |               |  |  |
| bit 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | bit 6 REN: Auto-Restart Enable bit          1 = Auto-restart is enabled         0 = Auto-restart is disabled |                                                                                                          |                                                                                        |                                                                                                                 |                                                                                                 |                                          |               |  |  |
| bit 5-4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | LSBD<1:0>:<br>11 = A logic 4<br>10 = A logic 4<br>01 = Pin is tri<br>00 = The ina<br>dead-ba                 | CWG1B and C<br>1' is placed or<br>0' is placed or<br>i-stated on CW<br>ctive state of<br>and interval wh | CWG1D Auto-<br>CWG1B/D w<br>CWG1B/D w<br>G1B/D when<br>the pin, inclu<br>en an auto-st | -Shutdown State<br>when an auto-sh<br>when an auto-sh<br>an auto-shutdo<br>ding polarity, is<br>nutdown event o | e Control bits<br>utdown event o<br>utdown event o<br>wn event occur<br>placed on CW<br>occurs. | occurs.<br>occurs.<br>s.<br>VG1B/D after | the required  |  |  |
| <ul> <li>bit 3-2</li> <li>LSAC&lt;1:0&gt;: CWG1A and CWG1C Auto-Shutdown State Control bits</li> <li>11 = A logic '1' is placed on CWG1A/C when an auto-shutdown event occurs.</li> <li>10 = A logic '0' is placed on CWG1A/C when an auto-shutdown event occurs.</li> <li>01 = Pin is tri-stated on CWG1A/C when an auto-shutdown event occurs.</li> <li>00 = The inactive state of the pin, including polarity, is placed on CWG1A/C after the required dead-band interval when an auto-shutdown event occurs.</li> </ul> |                                                                                                              |                                                                                                          |                                                                                        |                                                                                                                 |                                                                                                 |                                          |               |  |  |
| bit 1-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Unimplemen                                                                                                   | ted: Read as                                                                                             | '0'                                                                                    |                                                                                                                 |                                                                                                 |                                          |               |  |  |
| Note 1: This b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | it may be writte                                                                                             | en while EN =                                                                                            | 0 (Register 24                                                                         | 4-1), to place the                                                                                              | e outputs into th                                                                               | ne shutdown c                            | onfiguration. |  |  |

2: The outputs will remain in auto-shutdown state until the next rising edge of the CWG data input after this bit is cleared.

| U-0              | U-0                               | U-0                | U-0  | U-0                                                 | R/W-0/0 | R/W-0/0     | R/W-0/0     |  |
|------------------|-----------------------------------|--------------------|------|-----------------------------------------------------|---------|-------------|-------------|--|
| _                | _                                 | —                  | _    | —                                                   |         | CHS<2:0>(1) |             |  |
| bit 7            |                                   |                    |      |                                                     |         |             | bit 0       |  |
|                  |                                   |                    |      |                                                     |         |             |             |  |
| Legend:          |                                   |                    |      |                                                     |         |             |             |  |
| R = Readable     | R = Readable bit W = Writable bit |                    |      | U = Unimplemented bit, read as '0'                  |         |             |             |  |
| u = Bit is uncha | anged                             | x = Bit is unknown |      | -n/n = Value at POR and BOR/Value at all other Rese |         |             | ther Resets |  |
| '1' = Bit is set |                                   | '0' = Bit is clea  | ared |                                                     |         |             |             |  |
|                  |                                   |                    |      |                                                     |         |             |             |  |
| bit 7-3          | Unimplemen                        | ted: Read as '     | כ'   |                                                     |         |             |             |  |

| bit 7-5 | Ommplemented. Read as 0                         |
|---------|-------------------------------------------------|
| bit 2-0 | CHS<2:0>: Modulator Carrier High Selection bits |
|         | See Table 25-2 for signal list                  |

#### REGISTER 25-4: MDCARL: MODULATION LOW CARRIER CONTROL REGISTER

| U-0   | U-0 | U-0 | U-0 | U-0 | R/W-0/0 | R/W-0/0                 | R/W-0/0 |
|-------|-----|-----|-----|-----|---------|-------------------------|---------|
| —     | —   | —   | —   | —   |         | CLS<2:0> <sup>(1)</sup> |         |
| bit 7 |     |     |     |     |         |                         | bit 0   |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

bit 7-3 Unimplemented: Read as '0'

bit 2-0 CLS<2:0>: Modulator Carrier Low Input Selection bits See Table 25-2 for signal list

#### TABLE 25-2: MDCARH/MDCARL SELECTION MUX CONNECTIONS

| MDCARH  |   |                           | MDCARL   |   |                           |  |
|---------|---|---------------------------|----------|---|---------------------------|--|
| CHS<2:0 | > | Connection                | CLS<2:0> |   | Connection                |  |
| 111     | 7 | PWM4 OUT                  | 111      | 7 | PWM4 OUT                  |  |
| 110     | 6 | PWM3 OUT                  | 110      | 6 | PWM3 OUT                  |  |
| 101     | 5 | CCP2 OUT                  | 101      | 5 | CCP2 OUT                  |  |
| 100     | 4 | CCP1 OUT                  | 100      | 4 | CCP1 OUT                  |  |
| 011     | 3 | CLKREF output             | 011      | 3 | CLKREF output             |  |
| 010     | 2 | HFINTOSC                  | 010      | 2 | HFINTOSC                  |  |
| 001     | 1 | FOSC (system clock)       | 001      | 1 | FOSC (system clock)       |  |
| 000     | 0 | Pin selected by MDCARHPPS | 000      | 0 | Pin selected by MDCARLPPS |  |

© 2015-2017 Microchip Technology Inc.



PIC18(L)F26/45/46K40



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.

## 31.4.1 CVD OPERATION

A CVD operation begins with the ADC's internal and hold capacitor sample (С<sub>НОГ</sub>) being disconnected from the path which connects it to the external capacitive sensor node. While disconnected, CHOLD is precharged to VDD or Vss, while the path to the sensor node is also discharged to VDD or VSS. Typically, this node is discharged to the level opposite that of CHOLD. When the precharge phase is complete, the VDD/VSS bias paths for the two nodes are shut off and CHOLD and the path to the external sensor node are re-connected, at which time the acquisition phase of the CVD operation begins. During acquisition, a capacitive voltage divider is formed between the precharged CHOLD and sensor nodes, which results in a final voltage level setting on CHOLD which is determined by the capacitances and precharge levels of the two nodes. After acquisition, the ADC converts the voltage level on CHOLD. This process is then repeated with the selected precharge levels for both the CHOLD and the inverted sensor nodes. Figure 31-7 shows the waveform for two inverted CVD measurements, which is known as differential CVD measurement.





| U-0                  | U-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | U-0                                                               | R/W-0/0 | R/W-0/0       | R/W-0/0            | R/W-0/0 | R/W-0/0 |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|---------|---------------|--------------------|---------|---------|
|                      | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | —                                                                 |         |               | ADACT<4:0>         |         |         |
| bit 7                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                   |         |               |                    |         | bit 0   |
|                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                   |         |               |                    |         |         |
| Legend:              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                   |         |               |                    |         |         |
| R = Readable bi      | it                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | W = Writable b                                                    | oit     | U = Unimpleme | ented bit, read as | s 'O'   |         |
| u = Bit is unchanged |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | x = Bit is unknown -n/n = Value at POR and BOR/Value at all other |         |               |                    |         | Resets  |
| '1' = Bit is set     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | '0' = Bit is clea                                                 | ared    |               |                    |         |         |
|                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                   |         |               |                    |         |         |
| bit 7-5              | Unimplemente                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | d: Read as '0'                                                    |         |               |                    |         |         |
| bit 4-0              | <ul> <li>5 Unimplemented: Read as '0'</li> <li>ADACT&lt;4:0&gt;: Auto-Conversion Trigger Select I</li> <li>11111 = Software write to ADPCH</li> <li>11100 = Reserved, do not use</li> <li>11011 = Software read of ADRESH</li> <li>11000 = Software read of ADERRH</li> <li>11011 = Reserved, do not use</li> <li>•</li> &lt;</ul> |                                                                   |         |               |                    |         |         |

## REGISTER 31-32: ADACT: ADC AUTO CONVERSION TRIGGER CONTROL REGISTER

# PIC18(L)F26/45/46K40

| BTG    |                                                    | Bit Toggle f                                                                                                                                                                                    |                                                                                                                                                                              | BOV                                                                                                                                                           | ,                    | Branch if Overflow                                                   |                                                                          |                                                                                                                                                                                                                                                               |             |  |  |
|--------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|--|
| Syntax | C                                                  | BTG f, b {,a}                                                                                                                                                                                   |                                                                                                                                                                              | Synta                                                                                                                                                         | ax:                  | BOV n                                                                |                                                                          |                                                                                                                                                                                                                                                               |             |  |  |
| Opera  | Dperands: $0 \le f \le 255$                        |                                                                                                                                                                                                 | Oper                                                                                                                                                                         | ands:                                                                                                                                                         | -128 ≤ n ≤ 1         | $-128 \le n \le 127$                                                 |                                                                          |                                                                                                                                                                                                                                                               |             |  |  |
|        |                                                    | 0 ≤ b < 7<br>a ∈ [0,1]                                                                                                                                                                          | $\begin{array}{l} 0 \leq b < 7 \\ a \in [0,1] \end{array}$                                                                                                                   |                                                                                                                                                               | Oper                 | ation:                                                               | if OVERFLOW bit is '1'<br>(PC) + 2 + 2n $\rightarrow$ PC                 |                                                                                                                                                                                                                                                               |             |  |  |
| Operat | tion:                                              | $(\overline{f} < b >) \to f <$                                                                                                                                                                  | b>                                                                                                                                                                           |                                                                                                                                                               | Statu                | Status Affected:                                                     |                                                                          | None                                                                                                                                                                                                                                                          |             |  |  |
| Status | Affected:                                          | None                                                                                                                                                                                            |                                                                                                                                                                              |                                                                                                                                                               | Enco                 | Encoding:                                                            |                                                                          | 1110 0100 nnnn nnnn                                                                                                                                                                                                                                           |             |  |  |
| Encod  | ing:                                               | 0111                                                                                                                                                                                            | bbba ff                                                                                                                                                                      | ff ffff                                                                                                                                                       | Desc                 | Description:                                                         |                                                                          | If the OVERELOW bit is '1' then the                                                                                                                                                                                                                           |             |  |  |
| Descri | ption:                                             | Bit 'b' in da'<br>inverted.<br>If 'a' is '0', ti<br>If 'a' is '1', ti<br>GPR bank.<br>If 'a' is '0' a<br>set is enabl<br>in Indexed I<br>mode when<br>tion 35.2.3<br>Oriented Ir<br>eral Offset | ta memory loc<br>he Access Ba<br>he BSR is use<br>nd the extend<br>ed, this instruu<br>Literal Offset A<br>iever f ≤ 95 (5<br>"Byte-Orient<br>istructions in<br>Mode" for de | ation T is<br>nk is selected.<br>ed to select the<br>ed instruction<br>ction operates<br>Addressing<br>Fh). See Sec-<br>ed and Bit-<br>Indexed Lit-<br>tails. | Word<br>Cycle<br>Q C | Words:<br>Cycles:<br>Q Cycle Activity:                               |                                                                          | program will branch.<br>The 2's complement number '2n' is<br>added to the PC. Since the PC will have<br>incremented to fetch the next<br>instruction, the new address will be<br>PC + 2 + 2n. This instruction is then a<br>2-cycle instruction.<br>1<br>1(2) |             |  |  |
| Words  | :                                                  | 1                                                                                                                                                                                               |                                                                                                                                                                              |                                                                                                                                                               |                      | Q1                                                                   | Q2                                                                       | Q3                                                                                                                                                                                                                                                            | Q4          |  |  |
| Cycles | :                                                  | 1                                                                                                                                                                                               |                                                                                                                                                                              |                                                                                                                                                               |                      | Decode                                                               | Read literal<br>'n'                                                      | Process<br>Data                                                                                                                                                                                                                                               | Write to PC |  |  |
| Q Cyc  | cle Activity:                                      |                                                                                                                                                                                                 | ~~                                                                                                                                                                           | <u>.</u>                                                                                                                                                      |                      | No                                                                   | No                                                                       | No                                                                                                                                                                                                                                                            | No          |  |  |
| Г      | Q1<br>Decede                                       | Q2<br>Deed                                                                                                                                                                                      | Q3                                                                                                                                                                           | Q4                                                                                                                                                            |                      | operation                                                            | operation                                                                | operation                                                                                                                                                                                                                                                     | operation   |  |  |
|        | Decode                                             | register 'f'                                                                                                                                                                                    | Data                                                                                                                                                                         | register 'f'                                                                                                                                                  | lf No                | o Jump:                                                              |                                                                          |                                                                                                                                                                                                                                                               |             |  |  |
| L      |                                                    |                                                                                                                                                                                                 |                                                                                                                                                                              | 0                                                                                                                                                             |                      | Q1                                                                   | Q2                                                                       | Q3                                                                                                                                                                                                                                                            | Q4          |  |  |
| Examp  | <u>ole</u> :                                       | BTG P                                                                                                                                                                                           | ORTC, 4, (                                                                                                                                                                   | D                                                                                                                                                             |                      | Decode                                                               | read literal                                                             | Process<br>Data                                                                                                                                                                                                                                               | NO          |  |  |
| B      | efore Instruc<br>PORTC<br>fter Instructic<br>PORTC | :tion:<br>= 0111 (<br>on:<br>= 0110 (                                                                                                                                                           | 0101 <b>[75h]</b><br>0101 <b>[65h]</b>                                                                                                                                       |                                                                                                                                                               | <u>Exan</u>          | nple:<br>PC<br>After Instruction<br>If OVERI<br>PC<br>If OVERI<br>PC | HERE<br>stion<br>= adu<br>on<br>FLOW = 1;<br>= adu<br>FLOW = 0;<br>= adu | BOV Jump<br>dress (HERE<br>dress (Jump<br>dress (HERE                                                                                                                                                                                                         | ) + 2)      |  |  |

## **39.0 PACKAGING INFORMATION**

## Package Marking Information



- NNN Alphanumeric traceability code
- (e3) Pb-free JEDEC<sup>®</sup> designator for Matte Tin (Sn)
  - This package is Pb-free. The Pb-free JEDEC designator ((e3)) can be found on the outer packaging for this package.
- **Note:** In the event the full Microchip part number cannot be marked on one line, it will be carried over to the next line, thus limiting the number of available characters for customer-specific information.