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 - Microcontrollers</u>" | Details | | |----------------------------|------------------------------------------------------------------------------| | 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 | 14-SOIC (0.154", 3.90mm Width) | | Supplier Device Package | 14-SOIC | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf15324t-i-sl | **TABLE 1-3:** PIC16(L)F15344 PINOUT DESCRIPTION (CONTINUED) | Name | Function | Input<br>Type | Output Type | Description | |----------------------------------------------------------------------------------------------------------------------|-----------------------|------------------|-------------|---------------------------------------------------------------------------------------------------| | RC0/ANC0/C2IN0+/SCK1 <sup>(1)</sup> /SCL1 <sup>(1,4)</sup> /TX2 <sup>(1)</sup> /CK2 <sup>(1)</sup> /IOCC0 | RC0 | TTL/ST | CMOS/OD | General purpose I/O. | | 1X2. 7CKZ. 710CC0 | ANC0 | AN | _ | ADC Channel C0 input. | | | C2IN0+ | AN | _ | Comparator 2 positive input. | | | SCK1 <sup>(1)</sup> | TTL/ST | CMOS/OD | MSSP1 SPI clock input/output (default input location, SCK1 is a PPS remappable input and output). | | | SCL1 <sup>(1,4)</sup> | I <sup>2</sup> C | OD | MSSP1 I <sup>2</sup> C input/output. | | | TX2 <sup>(1)</sup> | _ | CMOS | EUSART2 asynchronous transmit. | | | CK2 <sup>(1)</sup> | TTL/ST | CMOS/OD | EUSART2 synchronous mode clock input/output. | | | IOCC0 | TTL/ST | | Interrupt-on-change input. | | RC1/ANC1/C1IN1-/C2IN1-/SDA1 <sup>(1,4)</sup> /<br>SDI1 <sup>(1)</sup> /RX2 <sup>(1)</sup> /DT2 <sup>(1)</sup> /IOCC1 | RC1 | TTL/ST | CMOS/OD | General purpose I/O. | | SDIT TRAZE TOTZE TIOCCT | ANC1 | AN | _ | ADC Channel C1 input. | | | C1IN1- | AN | _ | Comparator 1 negative input. | | | C2IN1- | AN | _ | Comparator 2 negative input. | | | SDA1 <sup>(1,4)</sup> | I <sup>2</sup> C | OD | MSSP1 I <sup>2</sup> C serial data input/output. | | | SDI1 <sup>(1)</sup> | TTL/ST | _ | MSSP1 SPI serial data input. | | | RX2 <sup>(1)</sup> | TTL/ST | _ | EUSART2 Asynchronous mode receiver data input. | | | DT2 <sup>(1)</sup> | TTL/ST | CMOS/OD | EUSART2 Synchronous mode data input/output. | | | IOCC1 | TTL/ST | _ | Interrupt-on-change input. | | RC2/ANC2/C1IN2-/C2IN2-/IOCC2 | RC2 | TTL/ST | CMOS/OD | General purpose I/O. | | | ANC2 | AN | _ | ADC Channel C2 input. | | | C1IN2- | AN | _ | Comparator 1 negative input. | | | C2IN2- | AN | _ | Comparator 2 negative input. | | | IOCC2 | TTL/ST | _ | Interrupt-on-change input. | | RC3/ANC3/C1IN3-/C2IN3-/CCP2 <sup>(1)</sup> /<br>CLCIN1 <sup>(1)</sup> /IOCC3 | RC3 | TTL/ST | CMOS/OD | General purpose I/O. | | CLCIN IV //IOCC3 | ANC3 | AN | _ | ADC Channel C3 input. | | | C1IN3- | AN | _ | Comparator 1 negative input. | | | C2IN3- | AN | _ | Comparator 2 negative input. | | | CCP2 <sup>(1)</sup> | TTL/ST | CMOS/OD | Capture/compare/PWM2 (default input location for capture function). | | | CLCIN1 <sup>(1)</sup> | TTL/ST | _ | Configurable Logic Cell source input. | | | IOCC3 | TTL/ST | _ | Interrupt-on-change input. | | RC4/ANC4/IOCC4 | RC4 | TTL/ST | CMOS/OD | General purpose I/O. | | | ANC4 | AN | _ | ADC Channel C4 input. | | | IOCC4 | TTL/ST | _ | Interrupt-on-change input. | Legend: AN = Analog input or output CMOS = CMOS compatible input or output TTL = TTL compatible input = Open-Drain ST Schmitt Trigger input with CMOS levels I<sup>2</sup>C = Schmitt Trigger input with I<sup>2</sup>C HV = High Voltage XTAL = Crystal levels Note This is a PPS remappable input signal. The input function may be moved from the default location shown to one of several other PORTx pins. Refer to Table 15-3 for details on which PORT pins may be used for this signal. - All output signals shown in this row are PPS remappable. These signals may be mapped to output onto one of several PORTx pin options as described in Table 15-3. - This is a bidirectional signal. For normal module operation, the firmware should map this signal to the same pin in both the PPS input and PPS output registers. - These pins are configured for $I^2C$ logic levels. The SCLx/SDAx signals may be assigned to any of the RB1/RB2/RC3/RC4 pins. PPS assignments to the other pins (e.g., RA5) will operate, but input logic levels will be standard TTL/ST, as selected by the INLVL register, instead of the I<sup>2</sup>C specific or SMBus input buffer thresholds. - For 14/16-pin package only. - For 20-pin package only **Preliminary** © 2017 Microchip Technology Inc. DS40001889A-page 23 # 4.3 Data Memory Organization The data memory is partitioned into 64 memory banks with 128 bytes in each bank. Each bank consists of: - · 12 core registers - Up to 100 Special Function Registers (SFR) - Up to 80 bytes of General Purpose RAM (GPR) - · 16 bytes of common RAM # FIGURE 4-2: BANKED MEMORY PARTITIONING #### 4.3.1 BANK SELECTION The active bank is selected by writing the bank number into the Bank Select Register (BSR). All data memory can be accessed either directly (via instructions that use the file registers) or indirectly via the two File Select Registers (FSR). See Section 4.6 "Indirect Addressing" for more information. Data memory uses a 13-bit address. The upper six bits of the address define the Bank address and the lower seven bits select the registers/RAM in that bank. #### 4.3.2 CORE REGISTERS The core registers contain the registers that directly affect the basic operation. The core registers occupy the first 12 addresses of every data memory bank (addresses x00h/x08h through x0Bh/x8Bh). These registers are listed below in Table 4-3. TABLE 4-3: CORE REGISTERS | Addresses | BANKx | |--------------|--------| | 00h or x80h | INDF0 | | k01h or x81h | INDF1 | | x02h or x82h | PCL | | x03h or x83h | STATUS | | x04h or x84h | FSR0L | | x05h or x85h | FSR0H | | x06h or x86h | FSR1L | | x07h or x87h | FSR1H | | x08h or x88h | BSR | | x09h or x89h | WREG | | x0Ah or x8Ah | PCLATH | | x0Bh or x8Bh | INTCON | # 4.3.3 SPECIAL FUNCTION REGISTER The Special Function Registers are registers used by the application to control the desired operation of peripheral functions in the device. The Special Function Registers occupy the 20 bytes of the data banks 0-59 and 100 bytes of the data banks 60-63, after the core registers. The SFRs associated with the operation of the peripherals are described in the appropriate peripheral chapter of this data sheet. # 4.3.4 GENERAL PURPOSE RAM There are up to 80 bytes of GPR in each data memory bank. #### 4.3.4.1 Linear Access to GPR The general purpose RAM can be accessed in a non-banked method via the FSRs. This can simplify access to large memory structures. See **Section 4.6.2** "Linear Data Memory" for more information. #### 4.3.5 COMMON RAM There are 16 bytes of common RAM accessible from all banks. #### 4.3.6 DEVICE MEMORY MAPS The memory maps are as shown in through . TABLE 4-10: SPECIAL FUNCTION REGISTER SUMMARY BANKS 0-63 (CONTINUED) | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR, BOR | V <u>alue o</u> n:<br>MCLR | |---------|------------------------------------------------|--------------------|-------------------|---------|---------------|-------------------|-----------|----------|-----------|-----------------------|----------------------------| | Bank 6 | | | | | | | | | | | | | | | | | CPU COF | RE REGISTERS; | see Table 4-3 for | specifics | | | | | | 30Ch | CCPR1L | Capture/Compare/PV | VM Register 1 (LS | SB) | | | | | | xxxx xxxx | uuuu uuuu | | 30Dh | CCPR1H | Capture/Compare/PV | VM Register 1 (M | SB) | | | | | | xxxx xxxx | uuuu uuuu | | 30Eh | CCP1CON | EN | _ | OUT | FMT | | MOI | DE<3:0> | | 0-00 0000 | 0-00 0000 | | 30Fh | CCP1CAP | _ | _ | 1 | _ | _ | | CTS<2:0> | | 000 | 000 | | 310h | 0h CCPR2L Capture/Compare/PWM Register 2 (LSB) | | | | | | | | | xxxx xxxx | uuuu uuuu | | 311h | CCPR2H Capture/Compare/PWM Register 2 (MSB) | | | | | | | | xxxx xxxx | uuuu uuuu | | | 312h | CCP2CON | EN | _ | OUT | FMT | | MODE<3:0> | | | | 0-00 0000 | | 313h | CCP2CAP | _ | _ | 1 | _ | _ | | CTS<2:0> | | 000 | 000 | | 314h | PWM3DCL | DC<1:0 | 0> | 1 | _ | _ | 1 | _ | _ | xx | uu | | 315h | PWM3DCH | | | | DC<9 | 9:0> | | | | xxxx xxxx | uuuu uuuu | | 316h | PWM3CON | EN | _ | OUT | POL | _ | _ | _ | _ | 0-00 | 0-00 | | 317h | _ | | | | Unimpler | mented | | | | _ | ı | | 318h | PWM4DCL | DC<1:0 | 0> | 1 | _ | _ | 1 | _ | _ | xx | uu | | 319h | PWM4DCH | | | | DC<9 | 9:0> | | | | xxxx xxxx | uuuu uuuu | | 31Ah | PWM4CON | EN | _ | OUT | POL | _ | _ | _ | _ | 0-00 | 0-00 | | 31Bh | _ | | | | Unimpler | mented | | | | _ | _ | | 31Ch | PWM5DCL | DC<1:0> | | | | | | | xx | uu | | | 31Dh | PWM5DCH | DC<9:0> | | | | | | | | xxxx xxxx | uuuu uuuu | | 31Eh | PWM5CON | EN | _ | OUT | POL | _ | - | _ | _ | 0-00 | 0-00 | | 31Fh | _ | | | | Unimpler | mented | | | | _ | _ | PIC16(L)F15324/44 Legend: x = unknown, u = unchanged, q = depends on condition, - = unimplemented, read as '0', r = reserved. Shaded locations unimplemented, read as '0'. ## REGISTER 10-2: PIE0: PERIPHERAL INTERRUPT ENABLE REGISTER 0 | U-0 | U-0 | R/W-0/0 | R/W-0/0 | U-0 | U-0 | U-0 | R/W-0/0 | |-------|-----|---------|---------|-----|-----|-----|---------| | _ | _ | TMR0IE | IOCIE | _ | _ | | INTE | | bit 7 | | | | | | | bit 0 | bit 7-6 Unimplemented: Read as '0' bit 5 TMR0IE: Timer0 Overflow Interrupt Enable bit 1 = Enables the Timer0 interrupt 0 = Disables the Timer0 interrupt bit 4 IOCIE: Interrupt-on-Change Interrupt Enable bit 1 = Enables the IOC change interrupt 0 = Disables the IOC change interrupt bit 3-1 Unimplemented: Read as '0' bit 0 **INTE:** INT External Interrupt Flag bit<sup>(1)</sup> 1 = Enables the INT external interrupt 0 = Disables the INT external interrupt Note 1: The External Interrupt GPIO pin is selected by INTPPS (Register 15-1). Note: Bit PEIE of the INTCON register must be set to enable any peripheral interrupt controlled by PIE1-PIE7. Interrupt sources controlled by the PIE0 register do not require PEIE to be set in order to allow interrupt vectoring (when GIE is set). #### REGISTER 14-15: SLRCONB: PORTB SLEW RATE CONTROL 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 | |---------|---------|---------|---------|-----|-----|-----|-------| | SLRB7 | SLRB6 | SLRB5 | SLRB4 | _ | _ | _ | _ | | 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 SLRB<7:4>: PORTB Slew Rate Enable bits For RB<7:4> pins, respectively 1 = Port pin slew rate is limited 0 = Port pin slews at maximum rate bit 3-0 **Unimplemented**: Read as '0' #### REGISTER 14-16: INLVLB: PORTB INPUT LEVEL CONTROL 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 | |---------|---------|---------|---------|-----|-----|-----|-------| | INLVLB7 | INLVLB6 | INLVLB5 | INLVLB4 | _ | _ | _ | _ | | 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 INLVLB<7:4>: PORTB Input Level Select bits For RB<7:4> pins, respectively 1 = ST input used for PORT reads and interrupt-on-change 0 = TTL input used for PORT reads and interrupt-on-change bit 3-0 **Unimplemented**: Read as '0' # TABLE 14-3: SUMMARY OF REGISTERS ASSOCIATED WITH PORTB | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Register on Page | |---------|---------|---------|---------|---------|-------|-------|-------|-------|------------------| | PORTB | RB7 | RB6 | RB5 | RB4 | _ | _ | _ | _ | 185 | | TRISB | TRISB7 | TRISB6 | TRISB5 | TRISB4 | _ | _ | _ | _ | 185 | | LATB | LATB7 | LATB6 | LATB5 | LATB4 | _ | _ | _ | _ | 186 | | ANSELB | ANSB7 | ANSB6 | ANSB5 | ANSB4 | _ | _ | _ | _ | 186 | | WPUB | WPUB7 | WPUB6 | WPUB5 | WPUB4 | _ | _ | _ | _ | 187 | | ODCONB | ODCB7 | ODCB6 | ODCB5 | ODCB4 | _ | _ | _ | _ | 187 | | SLRCONB | SLRB7 | SLRB6 | SLRB5 | SLRB4 | _ | _ | _ | _ | 188 | | INLVLB | INLVLB7 | INLVLB6 | INLVLB5 | INLVLB4 | _ | _ | _ | _ | 188 | **Legend:** x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by PORTB. ## 14.6 PORTC Registers #### 14.6.1 DATA REGISTER PORTC is a 6 to 8-bit wide bidirectional port. The corresponding data direction register is TRISC (Register 14-18). Setting a TRISC bit (= 1) will make the corresponding PORTC pin an input (i.e., put the corresponding output driver in a High-Impedance mode). Clearing a TRISC bit (= 0) will make the corresponding PORTC pin an output (i.e., enable the output driver and put the contents of the output latch on the selected pin). Figure 14-1 shows how to initialize an I/O port. Reading the PORTC register (Register 14-17) reads the status of the pins, whereas writing to it will write to the PORT latch. All write operations are read-modify-write operations. Therefore, a write to a port implies that the port pins are read, this value is modified and then written to the PORT data latch (LATC). The PORT data latch LATC (Register 14-19) holds the output port data, and contains the latest value of a LATC or PORTC write. #### 14.6.2 DIRECTION CONTROL The TRISC register (Register 14-18) controls the PORTC pin output drivers, even when they are being used as analog inputs. The user should ensure the bits in the TRISC register are maintained set when using them as analog inputs. I/O pins configured as analog inputs always read '0'. #### 14.6.3 OPEN-DRAIN CONTROL The ODCONC register (Register 14-22) controls the open-drain feature of the port. Open-drain operation is independently selected for each pin. When an ODCONC bit is set, the corresponding port output becomes an open-drain driver capable of sinking current only. When an ODCONC bit is cleared, the corresponding port output pin is the standard push-pull drive capable of sourcing and sinking current. **Note:** It is not necessary to set open-drain control when using the pin for I<sup>2</sup>C; the I<sup>2</sup>C module controls the pin and makes the pin open-drain. # 14.6.4 SLEW RATE CONTROL The SLRCONC register (Register 14-23) controls the slew rate option for each port pin. Slew rate control is independently selectable for each port pin. When an SLRCONC bit is set, the corresponding port pin drive is slew rate limited. When an SLRCONC bit is cleared, The corresponding port pin drive slews at the maximum rate possible. #### 14.6.5 INPUT THRESHOLD CONTROL The INLVLC register (Register 14-24) controls the input voltage threshold for each of the available PORTC input pins. A selection between the Schmitt Trigger CMOS or the TTL Compatible thresholds is available. The input threshold is important in determining the value of a read of the PORTC register and also the level at which an interrupt-on-change occurs, if that feature is enabled. See Table 37-4 for more information on threshold levels. Changing the input threshold selection should be performed while all peripheral modules are disabled. Changing the threshold level during the time a module is active may inadvertently generate a transition associated with an input pin, regardless of the actual voltage level on that pin. #### 14.6.6 ANALOG CONTROL Note: The ANSELC register (Register 14-20) is used to configure the Input mode of an I/O pin to analog. Setting the appropriate ANSELC bit high will cause all digital reads on the pin to be read as '0' and allow analog functions on the pin to operate correctly. The state of the ANSELC bits has no effect on digital output functions. A pin with TRIS clear and ANSELC set will still operate as a digital output, but the Input mode will be analog. This can cause unexpected behavior when executing read-modify-write instructions on the affected port. Note: The ANSELC bits default to the Analog mode after Reset. To use any pins as digital general purpose or peripheral inputs, the corresponding ANSEL bits must be initialized to '0' by user software. #### 14.6.7 WEAK PULL-UP CONTROL The WPUC register (Register 14-21) controls the individual weak pull-ups for each port pin. # 14.6.8 PORTC FUNCTIONS AND OUTPUT PRIORITIES Each pin defaults to the PORT latch data after Reset. Other output functions are selected with the peripheral pin select logic. See **Section 15.0 "Peripheral Pin Select (PPS) Module"** for more information. Analog input functions, such as ADC and comparator inputs, are not shown in the peripheral pin select lists. Digital output functions may continue to control the pin when it is in Analog mode. #### 23.10 CWG1 Auto-shutdown Source The output of the comparator module can be used as an auto-shutdown source for the CWG1 module. When the output of the comparator is active and the corresponding ASxE is enabled, the CWG operation will be suspended immediately (see **Section 30.10** "Auto-Shutdown"). # 23.11 Operation in Sleep Mode The comparator module can operate during Sleep. The comparator clock source is based on the Timer1 clock source. If the Timer1 clock source is either the system clock (Fosc) or the instruction clock (Fosc/4), Timer1 will not operate during Sleep, and synchronized comparator outputs will not operate. A comparator interrupt will wake the device from Sleep. The CxIE bits of the PIE2 register must be set to enable comparator interrupts. # REGISTER 26-2: T1GCON: TIMER1 GATE CONTROL REGISTER | R/W-0/u | R/W-0/u | R/W-0/u | R/W-0/u | R/W/HC-0/u | R-x/x | U-0 | U-0 | |---------|---------|---------|---------|------------|-------|-----|-------| | GE | GPOL | GTM | GSPM | GGO/DONE | GVAL | _ | _ | | 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 | HC = Bit is cleared by hardware | | bit 7 | GE: Timer1 Gate Enable bit | |---------|--------------------------------------------------------------------------------------| | | $\underline{IfON} = 0:$ | | | This bit is ignored | | | If ON = 1: | | | 1 = Timer1 counting is controlled by the Timer1 gate function | | | 0 = Timer1 is always counting | | bit 6 | GPOL: Timer1 Gate Polarity bit | | | 1 = Timer1 gate is active-high (Timer1 counts when gate is high) | | | 0 = Timer1 gate is active-low (Timer1 counts when gate is low) | | bit 5 | GTM: Timer1 Gate Toggle Mode bit | | | 1 = Timer1 Gate Toggle mode is enabled | | | 0 = Timer1 Gate Toggle mode is disabled and toggle flip-flop is cleared | | | Timer1 gate flip-flop toggles on every rising edge. | | bit 4 | GSPM: Timer1 Gate Single-Pulse Mode bit | | | 1 = Timer1 Gate Single-Pulse mode is enabled | | | 0 = Timer1 Gate Single-Pulse mode is disabled | | bit 3 | GGO/DONE: Timer1 Gate Single-Pulse Acquisition Status bit | | | 1 = Timer1 gate single-pulse acquisition is ready, waiting for an edge | | | 0 = Timer1 gate single-pulse acquisition has completed or has not been started | | | This bit is automatically cleared when GSPM is cleared | | bit 2 | GVAL: Timer1 Gate Value Status bit | | | Indicates the current state of the Timer1 gate that could be provided to TMR1H:TMR1L | | | Unaffected by Timer1 Gate Enable (GE) | | bit 1-0 | Unimplemented: Read as '0' | | | | PIC16(L)F15324/44 # 28.0 CAPTURE/COMPARE/PWM MODULES The Capture/Compare/PWM module is a peripheral that allows the user to time and control different events, and to generate Pulse-Width Modulation (PWM) signals. In Capture mode, the peripheral allows the timing of the duration of an event. The Compare mode allows the user to trigger an external event when a predetermined amount of time has expired. The PWM mode can generate Pulse-Width Modulated signals of varying frequency and duty cycle. The Capture/Compare/PWM modules available are shown in Table 28-1. TABLE 28-1: AVAILABLE CCP MODULES | Device | CCP1 | CCP2 | |-------------------|------|------| | PIC16(L)F15324/44 | • | • | The Capture and Compare functions are identical for all CCP modules. - Note 1: In devices with more than one CCP module, it is very important to pay close attention to the register names used. A number placed after the module acronym is used to distinguish between separate modules. For example, the CCP1CON and CCP2CON control the same operational aspects of two completely different CCP modules. - 2: Throughout this section, generic references to a CCP module in any of its operating modes may be interpreted as being equally applicable to CCPx module. Register names, module signals, I/O pins, and bit names may use the generic designator 'x' to indicate the use of a numeral to distinguish a particular module, when required. #### 29.1.1 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.1.2 USING THE TMR2 WITH THE PWM MODULF This device has a newer version of the TMR2 module that has many new modes, which allow for greater customization and control of the PWM signals than on older parts. Refer to **Section 27.5** "**Operation Examples**" for examples of PWM signal generation using the different modes of Timer2. **Note:** PWM operation requires that the timer used as the PWM time base has the FOSC/4 clock source selected. #### 29.1.3 PWM PERIOD Referring to Figure 29-1, the PWM output has a period and a pulse width. The frequency of the PWM is the inverse of the period (1/period). The PWM period is specified by writing to the PR2 register. The PWM period can be calculated using the following formula: ## **EQUATION 29-1: PWM PERIOD** $$PWM \ Period = [(PR2) + 1] \cdot 4 \cdot TOSC \cdot (TMR2 \ Prescale \ Value)$$ Note 1: Tosc = 1/Fosc When TMR2 is equal to PR2, the following three events occur on the next increment cycle: - · TMR2 is cleared - The PWMx pin is set (Exception: If the PWM duty cycle = 0%, the pin will not be set.) - The PWM pulse width is latched from PWMxDC. **Note:** If the pulse width value is greater than the period the assigned PWM pin(s) will remain unchanged. #### 29.1.4 PWM DUTY CYCLE The PWM duty cycle is specified by writing a 10-bit value to the PWMxDC register. The PWMxDCH contains the eight MSbs and the PWMxDCL<7:6> bits contain the two LSbs. The PWMDC register is double-buffered and can be updated at any time. This double buffering is essential for glitch-free PWM operation. New values take effect when TMR2 = PR2. Note that PWMDC is left-justified. The 8-bit timer TMR2 register is concatenated with either the 2-bit internal system clock (FOSC), or two bits of the prescaler, to create the 10-bit time base. The system clock is used if the Timer2 prescaler is set to 1:1 Equation 29-2 is used to calculate the PWM pulse width. Equation 29-3 is used to calculate the PWM duty cycle ratio #### **EQUATION 29-2: PULSE WIDTH** Pulse Width = $(PWMxDC) \cdot TOSC \cdot (TMR2 Prescale Value)$ #### **EQUATION 29-3: DUTY CYCLE RATIO** $$Duty\ Cycle\ Ratio = \frac{(PWMxDC)}{4(PR2+1)}$$ #### 29.1.5 PWM RESOLUTION The resolution determines the number of available duty cycles for a given period. For example, a 10-bit resolution will result in 1024 discrete duty cycles, whereas an 8-bit resolution will result in 256 discrete duty cycles. The maximum PWM resolution is ten bits when PR2 is 255. The resolution is a function of the PR2 register value as shown by Equation 29-4. ## **EQUATION 29-4: PWM RESOLUTION** $$Resolution = \frac{\log[4(PR2+1)]}{\log(2)} \ bits$$ FIGURE 31-3: PROGRAMMABLE LOGIC FUNCTIONS #### 32.6.6 I<sup>2</sup>C MASTER MODE TRANSMISSION Transmission of a data byte, a 7-bit address or the other half of a 10-bit address is accomplished by simply writing a value to the SSP1BUF register. This action will set the Buffer Full flag bit, BF, and allow the Baud Rate Generator to begin counting and start the next transmission. Each bit of address/data will be shifted out onto the SDA pin after the falling edge of SCL is asserted. SCL is held low for one Baud Rate Generator rollover count (TBRG). Data should be valid before SCL is released high. When the SCL pin is released high, it is held that way for TBRG. The data on the SDA pin must remain stable for that duration and some hold time after the next falling edge of SCL. After the eighth bit is shifted out (the falling edge of the eighth clock), the BF flag is cleared and the master releases SDA. This allows the slave device being addressed to respond with an ACK bit during the ninth bit time if an address match occurred, or if data was received properly. The status of $\overline{\mathsf{ACK}}$ is written into the ACKSTAT bit on the rising edge of the ninth clock. If the master receives an Acknowledge, the Acknowledge Status bit, ACKSTAT, is cleared. If not, the bit is set. After the ninth clock, the SSP1IF bit is set and the master clock (Baud Rate Generator) is suspended until the next data byte is loaded into the SSP1BUF, leaving SCL low and SDA unchanged (Figure 32-28). After the write to the SSP1BUF, each bit of the address will be shifted out on the falling edge of SCL until all seven address bits and the R/W bit are completed. On the falling edge of the eighth clock, the master will release the SDA pin, allowing the slave to respond with an Acknowledge. On the falling edge of the ninth clock, the master will sample the SDA pin to see if the address was recognized by a slave. The status of the ACK bit is loaded into the ACKSTAT Status bit of the SSP1CON2 register. Following the falling edge of the ninth clock transmission of the address, the SSP1IF is set, the BF flag is cleared and the Baud Rate Generator is turned off until another write to the SSP1BUF takes place, holding SCL low and allowing SDA to float. #### 32.6.6.1 BF Status Flag In Transmit mode, the BF bit of the SSP1STAT register is set when the CPU writes to SSP1BUF and is cleared when all eight bits are shifted out. # 32.6.6.2 WCOL Status Flag If the user writes the SSP1BUF when a transmit is already in progress (i.e., SSP1SR is still shifting out a data byte), the WCOL bit is set and the contents of the buffer are unchanged (the write does not occur). WCOL must be cleared by software before the next transmission. #### 32.6.6.3 ACKSTAT Status Flag In Transmit mode, the ACKSTAT bit of the SSP1CON2 register is cleared when the slave has sent an Acknowledge ( $\overline{ACK} = 0$ ) and is set when the slave does not Acknowledge ( $\overline{ACK} = 1$ ). A slave sends an Acknowledge when it has recognized its address (including a general call), or when the slave has properly received its data. #### 32.6.6.4 Typical transmit sequence: - 1. The user generates a Start condition by setting the SEN bit of the SSP1CON2 register. - SSP1IF is set by hardware on completion of the Start. - 3. SSP1IF is cleared by software. - 4. The MSSP module will wait the required start time before any other operation takes place. - The user loads the SSP1BUF with the slave address to transmit. - Address is shifted out the SDA pin until all eight bits are transmitted. Transmission begins as soon as SSP1BUF is written to. - 7. The MSSP module shifts in the ACK bit from the slave device and writes its value into the ACKSTAT bit of the SSP1CON2 register. - The MSSP module generates an interrupt at the end of the ninth clock cycle by setting the SSP1IF bit. - The user loads the SSP1BUF with eight bits of data - Data is shifted out the SDA pin until all eight bits are transmitted. - 11. The MSSP module shifts in the ACK bit from the slave device and writes its value into the ACKSTAT bit of the SSP1CON2 register. - 12. Steps 8-11 are repeated for all transmitted data bytes. - 13. The user generates a Stop or Restart condition by setting the PEN or RSEN bits of the SSP1CON2 register. Interrupt is generated once the Stop/Restart condition is complete. PIC16(L)F15324/4 TABLE 33-3: BAUD RATE FORMULAS | C | Configuration Bi | ts | DD0/5H0ADT Mada | Bould Bate Formula | | | |------|------------------|------|---------------------|--------------------|--|--| | SYNC | BRG16 | BRGH | BRG/EUSART Mode | Baud Rate Formula | | | | 0 | 0 | 0 | 8-bit/Asynchronous | Fosc/[64 (n+1)] | | | | 0 | 0 | 1 | 8-bit/Asynchronous | Face//40 (5.44)] | | | | 0 | 1 | 0 | 16-bit/Asynchronous | Fosc/[16 (n+1)] | | | | 0 | 1 | 1 | 16-bit/Asynchronous | | | | | 1 | 0 | Х | 8-bit/Synchronous | Fosc/[4 (n+1)] | | | | 1 | 1 | Х | 16-bit/Synchronous | | | | **Legend:** x = Don't care, n = value of SPxBRGH, SPxBRGL register pair. TABLE 33-4: BAUD RATE FOR ASYNCHRONOUS MODES | | SYNC = 0, BRGH = 0, BRG16 = 0 | | | | | | | | | | | | |--------|-------------------------------|------------|-----------------------------|-------------------|------------|-----------------------------|-------------------|------------|-----------------------------|--------------------|------------|-----------------------------| | BAUD | Fosc = 32.000 MHz | | | Fosc = 20.000 MHz | | | Fosc = 18.432 MHz | | | Fosc = 11.0592 MHz | | | | RATE | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | | 300 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | 1200 | _ | _ | _ | 1221 | 1.73 | 255 | 1200 | 0.00 | 239 | 1200 | 0.00 | 143 | | 2400 | 2404 | 0.16 | 207 | 2404 | 0.16 | 129 | 2400 | 0.00 | 119 | 2400 | 0.00 | 71 | | 9600 | 9615 | 0.16 | 51 | 9470 | -1.36 | 32 | 9600 | 0.00 | 29 | 9600 | 0.00 | 17 | | 10417 | 10417 | 0.00 | 47 | 10417 | 0.00 | 29 | 10286 | -1.26 | 27 | 10165 | -2.42 | 16 | | 19.2k | 19.23k | 0.16 | 25 | 19.53k | 1.73 | 15 | 19.20k | 0.00 | 14 | 19.20k | 0.00 | 8 | | 57.6k | 55.55k | -3.55 | 3 | _ | _ | _ | 57.60k | 0.00 | 7 | 57.60k | 0.00 | 2 | | 115.2k | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | | | SYNC = 0, BRGH = 0, BRG16 = 0 | | | | | | | | | | | | |--------|-------------------------------|------------|-----------------------------|------------------|------------|-----------------------------|-------------------|------------|-----------------------------|------------------|------------|-----------------------------| | BAUD | Fosc = 8.000 MHz | | | Fosc = 4.000 MHz | | | Fosc = 3.6864 MHz | | | Fosc = 1.000 MHz | | | | RATE | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | | 300 | _ | _ | _ | 300 | 0.16 | 207 | 300 | 0.00 | 191 | 300 | 0.16 | 51 | | 1200 | 1202 | 0.16 | 103 | 1202 | 0.16 | 51 | 1200 | 0.00 | 47 | 1202 | 0.16 | 12 | | 2400 | 2404 | 0.16 | 51 | 2404 | 0.16 | 25 | 2400 | 0.00 | 23 | _ | _ | _ | | 9600 | 9615 | 0.16 | 12 | _ | _ | _ | 9600 | 0.00 | 5 | _ | _ | _ | | 10417 | 10417 | 0.00 | 11 | 10417 | 0.00 | 5 | _ | _ | _ | _ | _ | _ | | 19.2k | _ | _ | _ | _ | _ | _ | 19.20k | 0.00 | 2 | _ | _ | _ | | 57.6k | _ | _ | _ | _ | _ | _ | 57.60k | 0.00 | 0 | _ | _ | _ | | 115.2k | _ | _ | _ | _ | _ | _ | _ | _ | | _ | | _ | | LSLF | Logical Left Shift | | | | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Syntax: | [ label ] LSLF f {,d} | | | | | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | | | | | Operation: | $(f<7>) \rightarrow C$<br>$(f<6:0>) \rightarrow dest<7:1>$<br>$0 \rightarrow dest<0>$ | | | | | | Status Affected: | C, Z | | | | | | Description: | The contents of register 'f' are shifted one bit to the left through the Carry flag. A '0' is shifted into the LSb. If 'd' is '0', the result is placed in W. If 'd' is '1', the result is stored back in register 'f'. | | | | | | | C register f ←0 | | | | | | LSRF | Logical Right Shift | | | | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Syntax: | [ label ] LSRF f {,d} | | | | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | | | | Operation: | $\begin{array}{l} 0 \rightarrow \text{dest<7>} \\ (\text{f<7:1>}) \rightarrow \text{dest<6:0>}, \\ (\text{f<0>}) \rightarrow \text{C}, \end{array}$ | | | | | Status Affected: | C, Z | | | | | Description: | The contents of register 'f' are shifted one bit to the right through the Carry flag. A '0' is shifted into the MSb. If 'd' is '0', the result is placed in W. If 'd' is '1', the result is stored back in register 'f'. | | | | | | 0 → register f | | | | | MOVF | Move f | | | | | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Syntax: | [label] MOVF f,d | | | | | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | | | | | Operation: | $(f) \rightarrow (dest)$ | | | | | | Status Affected: | Z | | | | | | Description: | The contents of register f is moved to a destination dependent upon the status of d. If $d = 0$ , destination is W register. If $d = 1$ , the destination is file register f itself. $d = 1$ is useful to test a file register since status flag Z is affected. | | | | | | Words: | 1 | | | | | | Cycles: | 1 | | | | | | Example: | MOVF FSR, 0 | | | | | | | After Instruction W = value in FSR register Z = 1 | | | | | | RETLW | Return with literal in W | | | | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Syntax: | [label] RETLW k | | | | | | Operands: | $0 \leq k \leq 255$ | | | | | | Operation: | $k \rightarrow (W);$<br>TOS $\rightarrow$ PC | | | | | | Status Affected: | None | | | | | | Description: | The W register is loaded with the 8-bit literal 'k'. The program counter is loaded from the top of the stack (the return address). This is a 2-cycle instruction. | | | | | | Words: | 1 | | | | | | Cycles: | 2 | | | | | | Example: | CALL TABLE; W contains table ;offset value • ;W now has table value | | | | | | TABLE | . ADDWF PC ;W = offset RETLW k1 ;Begin table RETLW k2 ; RETLW kn ; End of table Before Instruction W = 0x07 | | | | | | | After Instruction W = value of k8 | | | | | | RETURN | Return from Subroutine | | | | | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Syntax: | [ label ] RETURN | | | | | | Operands: | None | | | | | | Operation: | $TOS \rightarrow PC$ | | | | | | Status Affected: | None | | | | | | Description: | Return from subroutine. The stack is POPed and the top of the stack (TOS) is loaded into the program counter. This is a 2-cycle instruction. | | | | | | RLF | Rotate Left f through Carry | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [label] RLF f,d | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | See description below | | Status Affected: | С | | Description: | The contents of register 'f' are rotated one bit to the left through the Carry flag. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is stored back in register 'f'. | | Words: | 1 | | Cycles: | 1 | | Example: | RLF REG1,0 | | | Before Instruction | | | REG1 = 1110 0110 | | | C = 0 | | | After Instruction | | | REG1 = 1110 0110 | | | W = 1100 1100 | | | C = 1 | | RRF | Rotate Right f through Carry | | Syntax: | [label] RRF f,d | # RRF Rotate Right f through Carry Syntax: [label] RRF f,d Operands: $0 \le f \le 127$ $d \in [0,1]$ Operation: See description below Status Affected: C Description: The contents of register 'f' are rotated one bit to the right through the Carry flag. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed back in register 'f'.