

#### 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

-XF

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

Email: info@E-XFL.COM

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

## TABLE 4-7: PIC16(L)F15324/44 MEMORY MAP, BANKS 56-63

|       | BANK 56                      |       | BANK 57                      |                | BANK 58                      |                 | BANK 59                      |       | BANK 60                      |                 | BANK 61                      |                 | BANK 62                      |       | BANK 63                      |  |
|-------|------------------------------|-------|------------------------------|----------------|------------------------------|-----------------|------------------------------|-------|------------------------------|-----------------|------------------------------|-----------------|------------------------------|-------|------------------------------|--|
| 1C00h | Core Register<br>(Table 4-3) | 1C80h | Core Register<br>(Table 4-3) | 1D00h          | Core Register<br>(Table 4-3) | 1D80h           | Core Register<br>(Table 4-3) | 1E00h | Core Register<br>(Table 4-3) | 1E80h           | Core Register<br>(Table 4-3) | 1F00h           | Core Register<br>(Table 4-3) | 1F80h | Core Register<br>(Table 4-3) |  |
| 1C0BH |                              | 1C8Ch |                              | 1D0BH<br>1D0Ch |                              | 1Dobii<br>1D8Ch |                              | 1E0Bh |                              | 1E0DII<br>1E8Ch |                              | 1F0DII<br>1F0Ch |                              | 1F8Ch |                              |  |
| 1C0Dh |                              | 1C8Dh |                              | 1D00h          |                              | D8Dh1           |                              | 1E00h |                              | 1E8Dh           |                              | 1F0Dh           |                              | 1F8Dh |                              |  |
| 1C0Eh | _                            | 1C8Eh | _                            | 1D0Eh          | _                            | 1D8Eh           |                              | 1E0Eh |                              | 1E8Eh           |                              | 1F0Eh           |                              | 1F8Eh |                              |  |
| 1C0Fh | _                            | 1C8Fh | _                            | 1D0Fh          | _                            | 1D8Fh           |                              | 1E0Fh |                              | 1E8Fh           |                              | 1F0Fh           |                              | 1F8Fh |                              |  |
| 1C10h | —                            | 1C90h | _                            | 1D10h          | _                            | 1D90h           | —                            | 1E10h |                              | 1E90h           |                              | 1F10h           |                              | 1F90h |                              |  |
| 1C11h | _                            | 1C91h | _                            | 1D11h          | _                            | 1D91h           | _                            | 1E11h |                              | 1E91h           |                              | 1F11h           |                              | 1F91h |                              |  |
| 1C12h | _                            | 1C92h |                              | 1D12h          | _                            | 1D92h           | _                            | 1E12h |                              | 1E92h           |                              | 1F12h           |                              | 1F92h |                              |  |
| 1C13h | —                            | 1C93h | —                            | 1D13h          | —                            | 1D93h           | —                            | 1E13h |                              | 1E93h           |                              | 1F13h           |                              | 1F93h |                              |  |
| 1C14h | —                            | 1C94h | —                            | 1D14h          | —                            | 1D94h           | _                            | 1E14h |                              | 1E94h           |                              | 1F14h           |                              | 1F94h |                              |  |
| 1C15h | —                            | 1C95h | —                            | 1D15h          | —                            | 1D95h           | _                            | 1E15h |                              | 1E95h           |                              | 1F15h           |                              | 1F95h |                              |  |
| 1C16h | —                            | 1C96h | —                            | 1D16h          | —                            | 1D96h           | —                            | 1E16h |                              | 1E96h           |                              | 1F16h           | B BBB 6 4 4                  | 1F96h |                              |  |
| 1C17h | —                            | 1C97h | —                            | 1D17h          | —                            | 1D97h           | —                            | 1E17h | CLC Controls                 | 1E97h           | nnnPPS Controls              | 1F17h           | RxyPPS Controls              | 1F97h | (See Table 4-8 for           |  |
| 1C18h | —                            | 1C98h | _                            | 1D18h          | _                            | 1D98h           | —                            | 1E18h | (See Table 4-8 for           | 1E98h           | (See Table 4-8 for           | 1F18h           | (See Table 4-8 for           | 1F98h | register mapping             |  |
| 1C19h | _                            | 1C99h | _                            | 1D19h          | _                            | 1D99h           |                              | 1E19h | register mapping             | 1E99h           | register mapping             | 1F19h           | register mapping             | 1F99h | details)                     |  |
| 1C1Ah | —                            | 1C9Ah | _                            | 1D1Ah          | —                            | 1D9Ah           |                              | 1E1Ah | details)                     | 1E9Ah           | details)                     | 1F1Ah           | details)                     | 1F9Ah |                              |  |
| 1C1Bh | _                            | 1C9Bh | _                            | 1D1Bh          | _                            | 1D9Bh           |                              | 1E1Bh |                              | 1E9Bh           |                              | 1F1Bh           |                              | 1F9Bh |                              |  |
| 1C1Ch | —                            | 1C9Ch | —                            | 1D1Ch          | _                            | 1D9Ch           |                              | 1E1Ch |                              | 1E9Ch           |                              | 1F1Ch           |                              | 1F9Ch |                              |  |
| 1C1Dh | —                            | 1C9Dh | —                            | 1D1Dh          | _                            | 1D9Dh           |                              | 1E1Dh |                              | 1E9Dh           |                              | 1F1Dh           |                              | 1F9Dh |                              |  |
| 1C1Eh | _                            | 1C9Eh | _                            | 1D1Eh          | _                            | 1D9Eh           |                              | 1E1Eh |                              | 1E9Eh           |                              | 1F1Eh           |                              | 1F9Eh |                              |  |
| 1C1Fh | —                            | 1C9Fh | —                            | 1D1Fh          | —                            | 1D9Fh           | —                            | 1E1Fh |                              | 1E9Fh           |                              | 1F1Fh           |                              | 1F9Fh |                              |  |
| 1C20h |                              | 1CA0h |                              | 1D20h          |                              | 1DA0h           |                              | 1E20h |                              | 1EA0h           |                              | 1F20h           |                              | 1FA0h |                              |  |
|       | Unimplemented<br>Read as '0' |       | Unimplemented<br>Read as '0' |                | Unimplemented<br>Read as '0' |                 | Unimplemented<br>Read as '0' |       |                              |                 |                              |                 |                              |       |                              |  |
| 1C6Fh |                              | 1CEFh |                              | 1D6Fh          |                              | 1DEFh           |                              | 1E6Fh |                              | 1EEFh           |                              | 1F6Fh           |                              | 1FEFh |                              |  |
| 1C70h | Common RAM                   | 1CF0h | Common RAM                   | 1D70h          | Common RAM                   | 1DF0h           | Common RAM                   | 1E70h | Common RAM                   | 1EF0h           | Common RAM                   | 1F70h           | Common RAM                   | 1FF0h | Common RAM                   |  |
|       | Accesses                     |       | Accesses                     |                | Accesses                     |                 | Accesses                     |       | Accesses                     |                 | Accesses                     |                 | Accesses                     |       | Accesses                     |  |
| 1C7Fh | 70h-7Fh                      | 1CFFh | 70h-7Fh                      | 1D7Fh          | 70h-7Fh                      | 1DFFh           | 70h-7Fh                      | 1E7Fh | 70h-7Fh                      | 1EFFh           | 70h-7Fh                      | 1F7Fh           | 70h-7Fh                      | 1FFFh | 70h-7Fh                      |  |

Note 1: Unimplemented locations read as '0'.

2: The banks 24-55 have been omitted from the tables in the data sheet since the banks have unimplemented registers.

### 4.6.2 LINEAR DATA MEMORY

The linear data memory is the region from FSR address 0x2000 to FSR address 0X2FEF. This region is a virtual region that points back to the 80-byte blocks of GPR memory in all the banks. Refer to Figure 4-10 for the Linear Data Memory Map.

Note: The address range 0x2000 to 0x2FF0 represents the complete addressable Linear Data Memory up to Bank 50. The actual implemented Linear Data Memory will differ from one device to the other in a family. Confirm the memory limits on every device.

Unimplemented memory reads as  $0 \times 00$ . Use of the linear data memory region allows buffers to be larger than 80 bytes because incrementing the FSR beyond one bank will go directly to the GPR memory of the next bank.

The 16 bytes of common memory are not included in the linear data memory region.



### FIGURE 4-10: LINEAR DATA MEMORY MAP

### 4.6.3 PROGRAM FLASH MEMORY

To make constant data access easier, the entire Program Flash Memory is mapped to the upper half of the FSR address space. When the MSB of FSRnH is set, the lower 15 bits are the address in program memory which will be accessed through INDF. Only the lower eight bits of each memory location is accessible via INDF. Writing to the Program Flash Memory cannot be accomplished via the FSR/INDF interface. All instructions that access Program Flash Memory via the FSR/INDF interface will require one additional instruction cycle to complete.

### FIGURE 4-11: PROGRAM FLASH MEMORY MAP





## FIGURE 9-1:



## 11.4 Register Definitions: Voltage Regulator and DOZE Control

| U-0                                     | U-0 | U-0               | U-0            | U-0           | U-0              | R/W-0/0     | U-1   |
|-----------------------------------------|-----|-------------------|----------------|---------------|------------------|-------------|-------|
| —                                       | —   | —                 | —              | —             | —                | VREGPM      | —     |
| bit 7                                   |     | •                 |                |               |                  |             | bit 0 |
|                                         |     |                   |                |               |                  |             |       |
| Legend:                                 |     |                   |                |               |                  |             |       |
| R = Readable b                          | oit | W = Writable I    | bit            | U = Unimpler  | mented bit, read | as '0'      |       |
| u = Bit is unchanged x = Bit is unknown |     | iown              | -n/n = Value a | at POR and BO | R/Value at all o | ther Resets |       |
| '1' = Bit is set                        |     | '0' = Bit is clea | ared           |               |                  |             |       |
|                                         |     |                   |                |               |                  |             |       |

## **REGISTER 11-1:** VREGCON: VOLTAGE REGULATOR CONTROL REGISTER<sup>(1)</sup>

bit 7-2 Unimplemented: Read as '0'

VREGPM: Voltage Regulator Power Mode Selection bit

1 = Low-Power Sleep mode enabled in Sleep<sup>(2)</sup>

Draws lowest current in Sleep, slower wake-up

Normal Power mode enabled in Sleep<sup>(2)</sup>
 Draws higher current in Sleep, faster wake-up

bit 0 Unimplemented: Read as '1'. Maintain this bit set

Note 1: PIC16F15324/44 only.

bit 1

2: See Section 37.0 "Electrical Specifications".

## 14.5 Register Definitions: PORTB

## REGISTER 14-9: PORTB: PORTB REGISTER

| R/W-x/u                                 | R/W-x/u | R/W-x/u | R/W-x/u                                               | U-0 | U-0 | U-0 | U-0   |  |
|-----------------------------------------|---------|---------|-------------------------------------------------------|-----|-----|-----|-------|--|
| RB7                                     | RB6     | RB5     | RB4                                                   | —   | —   | —   | —     |  |
| bit 7                                   | ·       |         |                                                       |     |     | •   | bit 0 |  |
|                                         |         |         |                                                       |     |     |     |       |  |
| Legend:                                 | 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-4 | RB<7:4>: PORTB I/O Value bits <sup>(1)</sup> |
|---------|----------------------------------------------|
|         | 1 = Port pin is <u>&gt;</u> Vін              |
|         | 0 = Port pin is <u>&lt;</u> VIL              |
|         |                                              |

bit 3-0 Unimplemented: Read as '0'

**Note 1:** Writes to PORTB are actually written to corresponding LATB register. The actual I/O pin values are read from the PORTB register.

## REGISTER 14-10: TRISB: PORTB TRI-STATE REGISTER

| R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 | U-0 | U-0 | U-0 | U-0   |
|---------|---------|---------|---------|-----|-----|-----|-------|
| TRISB7  | TRISB6  | TRISB5  | TRISB4  | _   | —   | —   | —     |
| 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-4 | TRISB<7:4>: PORTB Tri-State Control bit           |
|---------|---------------------------------------------------|
|         | 1 = PORTB pin configured as an input (tri-stated) |
|         | 0 = PORTB pin configured as an output             |
| bit 3-0 | Unimplemented: Read as '0'                        |

## 20.0 ANALOG-TO-DIGITAL CONVERTER (ADC) MODULE

The Analog-to-Digital Converter (ADC) allows conversion of an analog input signal to a 10-bit binary representation of that signal. This device uses analog inputs, which are multiplexed into a single sample and hold circuit. The output of the sample and hold is connected to the input of the converter. The converter generates a 10-bit binary result via successive approximation and stores the conversion result into the ADC result registers (ADRESH:ADRESL register pair). Figure 20-1 shows the block diagram of the ADC.

The ADC voltage reference is software selectable to be either internally generated or externally supplied.

The ADC can generate an interrupt upon completion of a conversion. This interrupt can be used to wake-up the device from Sleep.





## 23.2 Comparator Control

Each comparator has two control registers: CMxCON0 and CMxCON1.

The CMxCON0 register (see Register 23-1) contains Control and Status bits for the following:

- Enable
- Output
- Output polarity
- · Hysteresis enable
- · Timer1 output synchronization

The CMxCON1 register (see Register 23-2) contains Control bits for the following:

- · Interrupt on positive/negative edge enables
- The CMxNSEL and CMxPSEL (Register 23-3 and Register 23-4) contain control bits for the following:
  - Positive input channel selection
  - Negative input channel selection

### 23.2.1 COMPARATOR ENABLE

Setting the CxON bit of the CMxCON0 register enables the comparator for operation. Clearing the CxON bit disables the comparator resulting in minimum current consumption.

### 23.2.2 COMPARATOR OUTPUT

The output of the comparator can be monitored by reading either the CxOUT bit of the CMxCON0 register or the MCxOUT bit of the CMOUT register.

The comparator output can also be routed to an external pin through the RxyPPS register (Register 15-2). The corresponding TRIS bit must be clear to enable the pin as an output.

**Note 1:** The internal output of the comparator is latched with each instruction cycle. Unless otherwise specified, external outputs are not latched.

## 23.2.3 COMPARATOR OUTPUT POLARITY

Inverting the output of the comparator is functionally equivalent to swapping the comparator inputs. The polarity of the comparator output can be inverted by setting the CxPOL bit of the CMxCON0 register. Clearing the CxPOL bit results in a non-inverted output.

Table 23-2 shows the output state versus input conditions, including polarity control.

### TABLE 23-2: COMPARATOR OUTPUT STATE VS. INPUT CONDITIONS

| Input Condition | CxPOL | CxOUT |
|-----------------|-------|-------|
| CxVN > CxVP     | 0     | 0     |
| CxVN < CxVP     | 0     | 1     |
| CxVN > CxVP     | 1     | 1     |
| CxVN < CxVP     | 1     | 0     |

## 26.3 Timer Prescaler

Timer1 has four prescaler options allowing 1, 2, 4 or 8 divisions of the clock input. The CKPS bits of the T1CON register control the prescale counter. The prescale counter is not directly readable or writable; however, the prescaler counter is cleared upon a write to TMR1H or TMR1L.

## 26.4 Timer Operation in Asynchronous Counter Mode

If the control bit SYNC of the T1CON register is set, the external clock input is not synchronized. The timer increments asynchronously to the internal phase clocks. If the external clock source is selected then the timer will continue to run during Sleep and can generate an interrupt on overflow, which will wake-up the processor. However, special precautions in software are needed to read/write the timer (see Section 26.4.1 "Reading and Writing Timer1 in Asynchronous Counter Mode").

Note: When switching from synchronous to asynchronous operation, it is possible to skip an increment. When switching from asynchronous to synchronous operation, it is possible to produce an additional increment.

### 26.4.1 READING AND WRITING TIMER1 IN ASYNCHRONOUS COUNTER MODE

Reading TMR1H or TMR1L while the timer is running from an external asynchronous clock will ensure a valid read (taken care of in hardware). However, the user should keep in mind that reading the 16-bit timer in two 8-bit values itself, poses certain problems, since the timer may overflow between the reads.

For writes, it is recommended that the user simply stop the timer and write the desired values. A write contention may occur by writing to the timer registers, while the register is incrementing. This may produce an unpredictable value in the TMR1H:TMR1L register pair.

## 26.5 Timer Gate

Timer1 can be configured to count freely or the count can be enabled and disabled using the time gate circuitry. This is also referred to as Timer Gate Enable.

The timer gate can also be driven by multiple selectable sources.

### 26.5.1 TIMER GATE ENABLE

The Timer Gate Enable mode is enabled by setting the GE bit of the T1GCON register. The polarity of the Timer Gate Enable mode is configured using the GPOL bit of the T1GCON register.

When Timer Gate Enable signal is enabled, the timer will increment on the rising edge of the Timer1 clock source. When Timer Gate Enable signal is disabled, the timer always increments, regardless of the GE bit. See Figure 26-3 for timing details.

TABLE 26-2: TIMER GATE ENABLE SELECTIONS

| T1CLK      | T1GPOL | T1G | Timer Operation |
|------------|--------|-----|-----------------|
| $\uparrow$ | 1      | 1   | Counts          |
| $\uparrow$ | 1      | 0   | Holds Count     |
| 1          | 0      | 1   | Holds Count     |
| 1          | 0      | 0   | Counts          |

# PIC16(L)F15324/44

| FIGURE 26-4:           | TIMER1 GATE TOGGLE MODE                                                                                                                  |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
|                        |                                                                                                                                          |
| TMRxGE                 |                                                                                                                                          |
| TxGPOL                 |                                                                                                                                          |
| TxGT <u>M</u>          |                                                                                                                                          |
| Selected<br>gate input |                                                                                                                                          |
| TxCKI                  |                                                                                                                                          |
| TxGVAL                 |                                                                                                                                          |
| TMRxH:TMRxL<br>Count   | $N \qquad \qquad$ |

## FIGURE 26-5: TIMER1 GATE SINGLE-PULSE MODE



### 27.5.5 SOFTWARE START ONE-SHOT MODE

In One-Shot mode the timer resets and the ON bit is cleared when the timer value matches the PRx period value. The ON bit must be set by software to start another timer cycle. Setting MODE<4:0> = 01000 selects One-Shot mode which is illustrated in Figure 27-8. In the example, ON is controlled by BSF and BCF instructions. In the first case, a BSF instruction sets ON and the counter runs to completion and clears ON. In the second case, a BSF instruction starts the cycle, BCF/BSF instructions turn the counter off and on during the cycle, and then it runs to completion.

When One-Shot mode is used in conjunction with the CCP PWM operation the PWM pulse drive starts concurrent with setting the ON bit. Clearing the ON bit while the PWM drive is active will extend the PWM drive. The PWM drive will terminate when the timer value matches the CCPRx pulse width value. The PWM drive will remain off until software sets the ON bit to start another cycle. If software clears the ON bit after the CCPRx match but before the PRx match then the PWM drive will be extended by the length of time the ON bit remains cleared. Another timing cycle can only be initiated by setting the ON bit after it has been cleared by a PRx period count match.

FIGURE 27-8: SOFTWARE START ONE-SHOT MODE TIMING DIAGRAM (MODE = 01000)







## 28.3.2 SETUP FOR PWM OPERATION

The following steps should be taken when configuring the CCP module for standard PWM operation:

- Use the desired output pin RxyPPS control to select CCPx as the source and disable the CCPx pin output driver by setting the associated TRIS bit.
- 2. Load the PR2 register with the PWM period value.
- Configure the CCP module for the PWM mode by loading the CCPxCON register with the appropriate values.
- Load the CCPRxL register, and the CCPRxH register with the PWM duty cycle value and configure the CCPxFMT bit of the CCPxCON register to set the proper register alignment.
- 5. Configure and start Timer2:
  - Clear the TMR2IF interrupt flag bit of the PIR4 register. See Note below.
  - Configure the CKPS bits of the T2CON register with the Timer prescale value.
  - Enable the Timer by setting the Timer2 ON bit of the T2CON register.

- 6. Enable PWM output pin:
  - Wait until the Timer overflows and the TMR2IF bit of the PIR4 register is set. See Note below.
  - Enable the CCPx pin output driver by clearing the associated TRIS bit.
- Note: In order to send a complete duty cycle and period on the first PWM output, the above steps must be included in the setup sequence. If it is not critical to start with a complete PWM signal on the first output, then step 6 may be ignored.

### 28.3.3 CCP/PWM CLOCK SELECTION

The PIC16(L)F15324/44 allows each individual CCP and PWM module to select the timer source that controls the module. Each module has an independent selection.

## 29.2 Register Definitions: PWM Control

| R/W-0/0          | U-0                                               | R-0               | R/W-0/0 | U-0                                                   | U-0              | U-0      | U-0   |  |  |  |  |
|------------------|---------------------------------------------------|-------------------|---------|-------------------------------------------------------|------------------|----------|-------|--|--|--|--|
| PWMxEN           | —                                                 | PWMxOUT           | PWMxPOL | —                                                     | —                | —        | —     |  |  |  |  |
| bit 7            |                                                   |                   |         |                                                       |                  |          | bit 0 |  |  |  |  |
|                  |                                                   |                   |         |                                                       |                  |          |       |  |  |  |  |
| Legend:          |                                                   |                   |         |                                                       |                  |          |       |  |  |  |  |
| R = Readable     | bit                                               | W = Writable      | bit     | U = Unimpler                                          | mented bit, read | d as '0' |       |  |  |  |  |
| u = Bit is uncha | anged                                             | x = Bit is unkr   | nown    | -n/n = Value at POR and BOR/Value at all other Resets |                  |          |       |  |  |  |  |
| '1' = Bit is set |                                                   | '0' = Bit is clea | ared    |                                                       |                  |          |       |  |  |  |  |
|                  |                                                   |                   |         |                                                       |                  |          |       |  |  |  |  |
| bit 7            | 7 PWMxEN: PWM Module Enable bit                   |                   |         |                                                       |                  |          |       |  |  |  |  |
|                  | 1 = PWM module is enabled                         |                   |         |                                                       |                  |          |       |  |  |  |  |
|                  | 0 = PWM module is disabled                        |                   |         |                                                       |                  |          |       |  |  |  |  |
| bit 6            | Unimplemented: Read as '0'                        |                   |         |                                                       |                  |          |       |  |  |  |  |
| bit 5            | PWMxOUT: PWM Module Output Level when Bit is Read |                   |         |                                                       |                  |          |       |  |  |  |  |
| bit 4            | PWMxPOL: PWMx Output Polarity Select bit          |                   |         |                                                       |                  |          |       |  |  |  |  |
|                  | 1 = PWM out                                       | tput is active-lo | W       |                                                       |                  |          |       |  |  |  |  |
|                  | 0 = PWM out                                       | tput is active-hi | gh      |                                                       |                  |          |       |  |  |  |  |
| bit 3-0          | Unimplemen                                        | ted: Read as '    | 0'      |                                                       |                  |          |       |  |  |  |  |

### REGISTER 29-1: PWMxCON: PWM CONTROL REGISTER

| U-1                               | U-1                                                                                                                                         | U-1               | R/W-0/0                            | R/W-0/0                                               | R/W-0/0         | R/W-0/0 | R/W-0/0 |  |  |  |  |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------------------------------|-------------------------------------------------------|-----------------|---------|---------|--|--|--|--|
|                                   |                                                                                                                                             |                   | AS4E                               | AS3E                                                  | AS2E            | AS1E    | AS0E    |  |  |  |  |
| bit 7                             |                                                                                                                                             |                   |                                    |                                                       |                 |         | bit 0   |  |  |  |  |
|                                   |                                                                                                                                             |                   |                                    |                                                       |                 |         |         |  |  |  |  |
| Legend:                           |                                                                                                                                             |                   |                                    |                                                       |                 |         |         |  |  |  |  |
| R = Readable bit W = Writable bit |                                                                                                                                             |                   | U = Unimplemented bit, read as '0' |                                                       |                 |         |         |  |  |  |  |
| u = Bit is uncha                  | anged                                                                                                                                       | x = Bit is unkr   | iown                               | -n/n = Value at POR and BOR/Value at all other Resets |                 |         |         |  |  |  |  |
| '1' = Bit is set                  |                                                                                                                                             | '0' = Bit is clea | ared                               | q = Value dep                                         | pends on condit | ion     |         |  |  |  |  |
|                                   |                                                                                                                                             |                   |                                    |                                                       |                 |         |         |  |  |  |  |
| bit 7-5                           | Unimplement                                                                                                                                 | ted: Read as '    | )'                                 |                                                       |                 |         |         |  |  |  |  |
| bit 4                             | AS4E: CLC2                                                                                                                                  | Output bit        |                                    |                                                       |                 |         |         |  |  |  |  |
|                                   | 1 = LC2_out                                                                                                                                 | shut-down is e    | nabled                             |                                                       |                 |         |         |  |  |  |  |
|                                   | $0 = LC2_out$                                                                                                                               | shut-down is d    | isabled                            |                                                       |                 |         |         |  |  |  |  |
| bit 3                             | AS3E: Comparator C2 Output bit                                                                                                              |                   |                                    |                                                       |                 |         |         |  |  |  |  |
|                                   | 1 = C2 output                                                                                                                               | t shut-down is    | enabled                            |                                                       |                 |         |         |  |  |  |  |
| hit 0                             |                                                                                                                                             | aratar C1 Outp    |                                    |                                                       |                 |         |         |  |  |  |  |
| DIL 2                             |                                                                                                                                             |                   |                                    |                                                       |                 |         |         |  |  |  |  |
|                                   | 1 = C1 output shut-down is enabled<br>0 = C1 output shut-down is disabled                                                                   |                   |                                    |                                                       |                 |         |         |  |  |  |  |
| bit 2                             | AS1F: TMR2 Postscale Output bit                                                                                                             |                   |                                    |                                                       |                 |         |         |  |  |  |  |
|                                   | 1 = TMR2 Postscale shut-down is enabled                                                                                                     |                   |                                    |                                                       |                 |         |         |  |  |  |  |
|                                   | 0 = TMR2 Pc                                                                                                                                 | stscale shut-de   | own is disable                     | d                                                     |                 |         |         |  |  |  |  |
| bit 0                             | AS0E: CWG1                                                                                                                                  | Input Pin bit     |                                    |                                                       |                 |         |         |  |  |  |  |
|                                   | <ul> <li>1 = Input pin selected by CWG1PPS shut-down is enabled</li> <li>0 = Input pin selected by CWG1PPS shut-down is disabled</li> </ul> |                   |                                    |                                                       |                 |         |         |  |  |  |  |

## REGISTER 30-6: CWG1AS1: CWG1 AUTO-SHUTDOWN CONTROL REGISTER 1

## 32.3.1 CLOCK STRETCHING

When a slave device has not completed processing data, it can delay the transfer of more data through the process of clock stretching. An addressed slave device may hold the SCL clock line low after receiving or sending a bit, indicating that it is not yet ready to continue. The master that is communicating with the slave will attempt to raise the SCL line in order to transfer the next bit, but will detect that the clock line has not yet been released. Because the SCL connection is open-drain, the slave has the ability to hold that line low until it is ready to continue communicating.

Clock stretching allows receivers that cannot keep up with a transmitter to control the flow of incoming data.

### 32.3.2 ARBITRATION

Each master device must monitor the bus for Start and Stop bits. If the device detects that the bus is busy, it cannot begin a new message until the bus returns to an Idle state.

However, two master devices may try to initiate a transmission on or about the same time. When this occurs, the process of arbitration begins. Each transmitter checks the level of the SDA data line and compares it to the level that it expects to find. The first transmitter to observe that the two levels do not match, loses arbitration, and must stop transmitting on the SDA line.

For example, if one transmitter holds the SDA line to a logical one (lets it float) and a second transmitter holds it to a logical zero (pulls it low), the result is that the SDA line will be low. The first transmitter then observes that the level of the line is different than expected and concludes that another transmitter is communicating.

The first transmitter to notice this difference is the one that loses arbitration and must stop driving the SDA line. If this transmitter is also a master device, it also must stop driving the SCL line. It then can monitor the lines for a Stop condition before trying to reissue its transmission. In the meantime, the other device that has not noticed any difference between the expected and actual levels on the SDA line continues with its original transmission.

Slave Transmit mode can also be arbitrated, when a master addresses multiple slaves, but this is less common.

## 32.4 I<sup>2</sup>C MODE OPERATION

All MSSP I<sup>2</sup>C communication is byte oriented and shifted out MSb first. Six SFR registers and two interrupt flags interface the module with the  $PIC^{$ <sup>®</sup>} microcontroller and user software. Two pins, SDA and SCL, are exercised by the module to communicate with other external I<sup>2</sup>C devices.

### 32.4.1 BYTE FORMAT

All communication in  $I^2C$  is done in 9-bit segments. A byte is sent from a master to a slave or vice-versa, followed by an Acknowledge bit sent back. After the eighth falling edge of the SCL line, the device outputting data on the SDA changes that pin to an input and reads in an acknowledge value on the next clock pulse.

The clock signal, SCL, is provided by the master. Data is valid to change while the SCL signal is low, and sampled on the rising edge of the clock. Changes on the SDA line while the SCL line is high define special conditions on the bus, explained below.

### 32.4.2 DEFINITION OF I<sup>2</sup>C TERMINOLOGY

There is language and terminology in the description of  $I^2C$  communication that have definitions specific to  $I^2C$ . That word usage is defined below and may be used in the rest of this document without explanation. This table was adapted from the Philips  $I^2C$  specification.

### 32.4.3 SDA AND SCL PINS

Selection of any I<sup>2</sup>C mode with the SSPEN bit set, forces the SCL and SDA pins to be open-drain. These pins should be set by the user to inputs by setting the appropriate TRIS bits.

| Note 1: | Any device pin can be selected for SDA        |
|---------|-----------------------------------------------|
|         | and SCL functions with the PPS periph-        |
|         | eral. These functions are bidirectional.      |
|         | The SDA input is selected with the            |
|         | SSPDATPPS registers. The SCL input is         |
|         | selected with the SSPCLKPPS registers.        |
|         | Outputs are selected with the RxyPPS          |
|         | registers. It is the user's responsibility to |
|         | make the selections so that both the input    |
|         | and the output for each function is on the    |
|         | same pin.                                     |

## 33.2 Clock Accuracy with Asynchronous Operation

The factory calibrates the internal oscillator block output (INTOSC). However, the INTOSC frequency may drift as VDD or temperature changes, and this directly affects the asynchronous baud rate. Two methods may be used to adjust the baud rate clock, but both require a reference clock source of some kind.

The first (preferred) method uses the OSCTUNE register to adjust the INTOSC output. Adjusting the value in the OSCTUNE register allows for fine resolution changes to the system clock source. See Section 9.2.2.2 "Internal Oscillator Frequency Adjustment" for more information.

The other method adjusts the value in the Baud Rate Generator. This can be done automatically with the Auto-Baud Detect feature (see Section 33.3.1 "Auto-Baud Detect"). There may not be fine enough resolution when adjusting the Baud Rate Generator to compensate for a gradual change in the peripheral clock frequency.

### 33.4.1.6 Slave Clock

Synchronous data transfers use a separate clock line, which is synchronous with the data. A device configured as a slave receives the clock on the TX/CK line. The TX/CK pin output driver is automatically disabled when the device is configured for synchronous slave transmit or receive operation. Serial data bits change on the leading edge to ensure they are valid at the trailing edge of each clock. One data bit is transferred for each clock cycle. Only as many clock cycles should be received as there are data bits.

| Note: | If the device is configured as a slave and  |
|-------|---------------------------------------------|
|       | the TX/CK function is on an analog pin, the |
|       | corresponding ANSEL bit must be cleared.    |

### 33.4.1.7 Receive Overrun Error

The receive FIFO buffer can hold two characters. An overrun error will be generated if a third character, in its entirety, is received before RCxREG is read to access the FIFO. When this happens the OERR bit of the RCxSTA register is set. Previous data in the FIFO will not be overwritten. The two characters in the FIFO buffer can be read, however, no additional characters will be received until the error is cleared. The OERR bit can only be cleared by clearing the overrun condition. If the overrun error occurred when the SREN bit is set and CREN is clear then the error is cleared by reading RCxREG. If the overrun occurred when the CREN bit is set then the error condition is cleared by either clearing the CREN bit of the RCxSTA register or by clearing the SPEN bit which resets the EUSART.

### 33.4.1.8 Receiving 9-bit Characters

The EUSART supports 9-bit character reception. When the RX9 bit of the RCxSTA register is set the EUSART will shift nine bits into the RSR for each character received. The RX9D bit of the RCxSTA register is the ninth, and Most Significant, data bit of the top unread character in the receive FIFO. When reading 9-bit data from the receive FIFO buffer, the RX9D data bit must be read before reading the eight Least Significant bits from the RCxREG.

## 33.4.1.9 Synchronous Master Reception Set-up:

- 1. Initialize the SPxBRGH, SPxBRGL register pair for the appropriate baud rate. Set or clear the BRGH and BRG16 bits, as required, to achieve the desired baud rate.
- 2. Clear the ANSEL bit for the RX pin (if applicable).
- 3. Enable the synchronous master serial port by setting bits SYNC, SPEN and CSRC.
- 4. Ensure bits CREN and SREN are clear.
- 5. If interrupts are desired, set the RXxIE bit of the PIE3 register and the GIE and PEIE bits of the INTCON register.
- 6. If 9-bit reception is desired, set bit RX9.
- 7. Start reception by setting the SREN bit or for continuous reception, set the CREN bit.
- Interrupt flag bit RXxIF will be set when reception of a character is complete. An interrupt will be generated if the enable bit RXxIE was set.
- 9. Read the RCxSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception.
- 10. Read the 8-bit received data by reading the RCxREG register.
- 11. If an overrun error occurs, clear the error by either clearing the CREN bit of the RCxSTA register or by clearing the SPEN bit which resets the EUSART.



### FIGURE 33-12: SYNCHRONOUS RECEPTION (MASTER MODE, SREN)

 $\wedge$ 

| TABLE 37-3: POWER-DO | WN CURRENT (IPD) <sup>(1,2)</sup> |
|----------------------|-----------------------------------|
|----------------------|-----------------------------------|

| PIC16LF15324/44 |           |                                          |                        | Standard Operating Conditions (unless otherwise stated)               |                   |                |       |        |                                  |
|-----------------|-----------|------------------------------------------|------------------------|-----------------------------------------------------------------------|-------------------|----------------|-------|--------|----------------------------------|
| PIC16F15324/44  |           |                                          |                        | Standard Operating Conditions (unless otherwise stated)<br>VREGPM = 1 |                   |                |       |        |                                  |
| Param.<br>No.   | Symbol    | Device Characteristics                   | Min.                   | Тур.†                                                                 | Max.<br>+85°C     | Max.<br>+125°C | Units | VDD    | Conditions<br>Note               |
| D200            | IPD       | IPD Base                                 | —                      | 0.06                                                                  | 2                 | 9              | μΑ    | 3.00   | $\langle \langle \rangle$        |
| D200            | IPD       | IPD Base                                 | _                      | 0.4                                                                   | 4                 | 12             | ~#A_  | 3.0V   | $\langle \rangle$                |
| D200A           |           |                                          |                        | 18                                                                    | 22                | 27 🔇           | рţА.  | 3.0∀   | VREGPM = 0                       |
| D201            | IPD_WDT   | Low-Frequency Internal<br>Oscillator/WDT | -                      | 0.8                                                                   | 4.0               | 11.5           | μΑ    | 73.0₩_ |                                  |
| D201            | IPD_WDT   | Low-Frequency Internal<br>Oscillator/WDT | —                      | 0.9                                                                   | 5.0 <             | 13             | μA    | 3.0V   |                                  |
| D203            | IPD_FVR   | FVR                                      | —                      | 33                                                                    | <u>_</u> 47       | 47             | μA    | 3.0V   |                                  |
| D203            | IPD_FVR   | FVR                                      | —                      | 28                                                                    | 44                | 44             | μÀ    | 3.0V   |                                  |
| D204            | IPD_BOR   | Brown-out Reset (BOR)                    | _                      | 10                                                                    | 17                | 19             | μA    | 3.0V   |                                  |
| D204            | IPD_BOR   | Brown-out Reset (BOR)                    |                        | 14                                                                    | 18                | 20             | μΑ    | 3.0V   |                                  |
| D205            | IPD_LPBOR | Low-Power Brown-out Reset (LPBOR)        |                        | 0.5                                                                   | 4                 | 10             | μΑ    | 3.0V   |                                  |
| D207            | IPD_ADCA  | ADC - Active                             | $\leq$                 | 250                                                                   | $ $ $\rightarrow$ | > -            | μΑ    | 3.0V   | ADC is converting <sup>(4)</sup> |
| D207            | IPD_ADCA  | ADC - Active                             |                        | 280                                                                   | $\overline{)}$    |                | μΑ    | 3.0V   | ADC is converting <sup>(4)</sup> |
| D208            | IPD_CMP   | Comparator                               |                        | 30                                                                    | <b>A</b> 2        | 44             | μΑ    | 3.0V   |                                  |
| D208            | IPD_CMP   | Comparator                               | $\left  \right\rangle$ | 33                                                                    | 44                | 45             | μΑ    | 3.0V   |                                  |

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

Note 1: The peripheral current is the sum of the base IDD and the additional current consumed when this peripheral is enabled. The peripheral ∆ current can be determined by subtracting the base IDD or IPD current from this limit. Max. values should be used when calculating total current consumption.

2: The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part in Sleep mode with all I/O pins in high-impedance state and tied to Vss.

3: All peripheral currents listed are on a per-peripheral basis if more than one instance of a peripheral is available.

4: ADC clock source is FRC.

5: = F device /

## PIC16(L)F15324/44



## **PRODUCT IDENTIFICATION SYSTEM**

To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office.

| PART NO.                 | [ <u>X</u> ] <sup>(1)</sup>                                                     | - <u>x</u>                                                                                 | <u>/xx</u>                 | xxx     | Exa  | mples                   | :                                                                                                                                                                                                                                                                                      |
|--------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|----------------------------|---------|------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device                   | Tape and Reel<br>Option                                                         | Temperature<br>Range                                                                       | e Package                  | Pattern | a)   | PIC16<br>Extend<br>PDIP | F15324- E/P<br>ded temperature<br>package                                                                                                                                                                                                                                              |
| Device:                  | PIC16F15324<br>PIC16F15344                                                      | , PIC16LF15324<br>, PIC16LF15344                                                           |                            |         |      |                         |                                                                                                                                                                                                                                                                                        |
| Tape and Reel<br>Option: | Blank = Stan<br>T = Tape                                                        | idard packaging<br>e and Reel <sup>(1)</sup>                                               | (tube or tray)             |         |      |                         |                                                                                                                                                                                                                                                                                        |
| Temperature<br>Range:    | I = -40<br>E = -40                                                              | °C to +85°C<br>°C to +125°C                                                                | (Industrial)<br>(Extended) |         |      |                         |                                                                                                                                                                                                                                                                                        |
| Package: <sup>(2)</sup>  | JQ = 16-<br>P = 14-<br>SL = 14-<br>SO = 20-<br>SS = 20-<br>ST = 14-<br>GZ = 20- | lead<br>lead, 20-lead PD<br>lead SOIC<br>lead SOIC<br>lead SSOP<br>lead TSSOP<br>lead UQFN | ΝP                         |         | Note | 1:                      | Tape and Reel identifier only appears in<br>the catalog part number description. This<br>identifier is used for ordering purposes and<br>is not printed on the device package.<br>Check with your Microchip Sales Office<br>for package availability with the Tape and<br>Reel option. |
| Pattern:                 | QTP, SQTP, C<br>(blank otherwi                                                  | ode or Special F<br>se)                                                                    | Requirements               |         |      | 2:                      | Small form-factor packaging options may<br>be available. Check<br><u>www.microchip.com/packaging</u> for<br>small-form factor package availability, or<br>contact your local Sales Office.                                                                                             |