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, SPI, UART/USART | | Peripherals | Brown-out Detect/Reset, POR, PWM, WDT | | Number of I/O | 11 | | Program Memory Size | 7KB (4K x 14) | | Program Memory Type | FLASH | | EEPROM Size | 256 x 8 | | RAM Size | 256 x 8 | | Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V | | Data Converters | A/D 8x10b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 125°C (TA) | | Mounting Type | Through Hole | | Package / Case | 14-DIP (0.300", 7.62mm) | | Supplier Device Package | 14-PDIP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf1824-e-p | TABLE 1-3: PIC16(L)F1828 PINOUT DESCRIPTION (CONTINUED) | Name | Function | Input<br>Type | Output<br>Type | Description | |---------------------------------------------------------|----------|------------------|----------------|---------------------------------------| | RA5/CLKIN/OSC1/T1OSI/ | RA5 | TTL | CMOS | General purpose I/O. | | T1CKI/P2A <sup>(1)</sup> /CCP2 <sup>(1)</sup> | CLKIN | CMOS | _ | External clock input (EC mode). | | | OSC1 | XTAL | _ | Crystal/Resonator (LP, XT, HS modes). | | | T10SI | XTAL | XTAL | Timer1 oscillator connection. | | | T1CKI | ST | _ | Timer1 clock input. | | | P2A | _ | CMOS | PWM output. | | | CCP2 | ST | CMOS | Capture/Compare/PWM2. | | RB4/AN10/CPS10/SDA1/SDI1 | RB4 | TTL | CMOS | General purpose I/O. | | | AN10 | AN | _ | A/D Channel 10 input. | | | CPS10 | AN | _ | Capacitive sensing input 10. | | | SDA1 | I <sup>2</sup> C | OD | I <sup>2</sup> C data input/output. | | | SDI1 | CMOS | _ | SPI data input. | | RB5/AN11/CPS11/RX <sup>(1,2)</sup> /DT <sup>(1,2)</sup> | RB5 | TTL | CMOS | General purpose I/O. | | | AN11 | AN | _ | A/D Channel 11 input. | | | CPS11 | AN | _ | Capacitive sensing input 11. | | | RX | ST | _ | USART asynchronous input. | | | DT | ST | CMOS | USART synchronous data. | | RB6/SCL1/SCK1 | RB6 | TTL | CMOS | General purpose I/O. | | | SCL1 | I <sup>2</sup> C | OD | I <sup>2</sup> C™ clock 1. | | | SCK1 | ST | CMOS | SPI clock 1. | | RB7/TX <sup>(1,2)</sup> /CK <sup>(1,2)</sup> | RB7 | TTL | CMOS | General purpose I/O. | | | TX | _ | CMOS | USART asynchronous transmit. | | | CK | ST | CMOS | USART synchronous clock. | | RC0/AN4/CPS4/C2IN+/P1D <sup>(1)</sup> | RC0 | TTL | CMOS | General purpose I/O. | | | AN4 | AN | _ | A/D Channel 4 input. | | | CPS4 | AN | _ | Capacitive sensing input 4. | | | C2IN+ | AN | _ | Comparator C2 positive input. | | | P1D | _ | CMOS | PWM output. | | RC1/AN5/CPS5/C12IN1-/P1C <sup>(1)</sup> | RC1 | TTL | CMOS | General purpose I/O. | | | AN5 | AN | _ | A/D Channel 5 input. | | | CPS5 | AN | _ | Capture/Compare/PWM4. | | | C12IN1- | AN | _ | Comparator C1 or C2 negative input. | | | P1C | _ | CMOS | PWM output. | | RC2/AN6/CPS6/C12IN2-/ | RC2 | TTL | CMOS | General purpose I/O. | | P1D <sup>(1,2)</sup> /P2B <sup>(1,2)</sup> /MDCIN1 | AN6 | AN | _ | A/D Channel 6 input. | | | CPS6 | AN | _ | Capacitive sensing input 6. | | | C12IN2- | AN | _ | Comparator C1 or C2 negative input. | | | P1D | _ | CMOS | PWM output. | | | P2B | _ | CMOS | PWM output. | | | MDCIN1 | ST | _ | Modulator Carrier Input 1. | **Legend:** AN = Analog input or output CMOS = CMOS compatible input or output OD = Open Drain TTL = TTL compatible input ST = Schmitt Trigger input with CMOS levels $I^2C^{TM}$ = Schmitt Trigger input with $I^2C$ HV = High Voltage XTAL = Crystal levels Note 1: Pin functions can be moved using the APFCONO and APFCON1 registers (Register 12-1 and Register 12-2). 2: Default function location. DS40001419F-page 24 | TABL | .E 3-4: PI | C16F | 1824/PIC16I | F1828 | MEMORY I | MAP, | BANKS 0-7 | | | | | | | | | |---------------|----------------------|--------------|----------------------|---------------|---------------------|--------------|-----------------------|---------------|---------------------|--------------|----------------|--------------|----------------|--------------|-----------------------| | | BANK 0 | | BANK 1 | | BANK 2 | • | BANK 3 | | BANK 4 | | BANK 5 | | BANK 6 | | BANK 7 | | 000h | INDF0 | 080h | INDF0 | 100h | INDF0 | 180h | INDF0 | 200h | INDF0 | 280h | INDF0 | 300h | INDF0 | 380h | INDF0 | | 001h | INDF1 | 081h | INDF1 | ] 101h [ | INDF1 | 181h | INDF1 | 201h | INDF1 | 281h | INDF1 | 301h | INDF1 | 381h | INDF1 | | 002h | PCL | 082h | PCL | 102h | PCL | 182h | PCL | 202h | PCL | 282h | PCL | 302h | PCL | 382h | PCL | | 003h | STATUS | 083h | STATUS | 103h | STATUS | 183h | STATUS | 203h | STATUS | 283h | STATUS | 303h | STATUS | 383h | STATUS | | 004h | FSR0L | 084h | FSR0L | 104h | FSR0L | 184h | FSR0L | 204h | FSR0L | 284h | FSR0L | 304h | FSR0L | 384h | FSR0L | | 005h | FSR0H | 085h | FSR0H | 105h | FSR0H | 185h | FSR0H | 205h | FSR0H | 285h | FSR0H | 305h | FSR0H | 385h | FSR0H | | 006h<br>007h | FSR1L<br>FSR1H | 086h<br>087h | FSR1L<br>FSR1H | 106h<br>107h | FSR1L<br>FSR1H | 186h<br>187h | FSR1L<br>FSR1H | 206h<br>207h | FSR1L<br>FSR1H | 286h<br>287h | FSR1L<br>FSR1H | 306h<br>307h | FSR1L<br>FSR1H | 386h<br>387h | FSR1L<br>FSR1H | | 00711<br>008h | BSR | 088h | BSR | 10711<br>108h | BSR | 188h | BSR | 20711<br>208h | BSR | 288h | BSR | 308h | BSR | 388h | BSR | | 000h | WREG | 089h | WREG | 100h | WREG | 189h | WREG | 209h | WREG | 289h | WREG | 309h | WREG | 389h | WREG | | 00Ah | PCLATH | 08Ah | PCLATH | 10Ah | PCLATH | 18Ah | PCLATH | 20Ah | PCLATH | 28Ah | PCLATH | 30Ah | PCLATH | 38Ah | PCLATH | | 00Bh | INTCON | 08Bh | INTCON | 10Bh | INTCON | 18Bh | INTCON | 20Bh | INTCON | 28Bh | INTCON | 30Bh | INTCON | 38Bh | INTCON | | 00Ch | PORTA | 08Ch | TRISA | 10Ch | LATA | 18Ch | ANSELA | 20Ch | WPUA | 28Ch | _ | 30Ch | _ | 38Ch | INLVLA | | 00Dh | PORTB <sup>(1)</sup> | 08Dh | TRISB <sup>(1)</sup> | 10Dh | LATB <sup>(1)</sup> | 18Dh | ANSELB <sup>(1)</sup> | 20Dh | WPUB <sup>(1)</sup> | 28Dh | _ | 30Dh | _ | 38Dh | INLVLB <sup>(1)</sup> | | 00Eh | PORTC | 08Eh | TRISC | 10Eh | LATC | 18Eh | ANSELC | 20Eh | WPUC | 28Eh | _ | 30Eh | _ | 38Eh | INLVLC | | 00Fh | _ | 08Fh | _ | 10Fh | _ | 18Fh | _ | 20Fh | _ | 28Fh | _ | 30Fh | _ | 38Fh | _ | | 010h | _ | 090h | | 110h | | 190h | _ | 210h | _ | 290h | _ | 310h | _ | 390h | _ | | 011h | PIR1 | 091h | PIE1 | 111h | CM1CON0 | 191h | EEADRL | 211h | SSP1BUF | 291h | CCPR1L | 311h | CCPR3L | 391h | IOCAP | | 012h | PIR2 | 092h | PIE2 | 112h | CM1CON1 | 192h | EEADRH | 212h | SSP1ADD | 292h | CCPR1H | 312h | CCPR3H | 392h | IOCAN | | 013h | PIR3 | 093h | PIE3 | 113h | CM2CON0 | 193h | EEDATL | 213h | SSP1MSK | 293h | CCP1CON | 313h | CCP3CON | 393h | IOCAF | | 014h | _ | 094h | _ | 114h | CM2CON1 | 194h | EEDATH | 214h | SSP1STAT | 294h | PWM1CON | 314h | _ | 394h | IOCBP <sup>(1)</sup> | | 015h | TMR0 | 095h | OPTION | 115h | CMOUT | 195h | EECON1 | 215h | SSP1CON | 295h | CCP1AS | 315h | _ | 395h | IOCBN <sup>(1)</sup> | | 016h | TMR1L | 096h | PCON | 116h | BORCON | 196h | EECON2 | 216h | SSP1CON2 | 296h | PSTR1CON | 316h | _ | 396h | IOCBF <sup>(1)</sup> | | 017h | TMR1H | 097h | WDTCON | 117h | FVRCON | 197h | - | 217h | SSP1CON3 | 297h | _ | 317h | _ | 397h | _ | | 018h | T1CON | 098h | OSCTUNE | 118h | DACCON0 | 198h | 1 | 218h | | 298h | CCPR2L | 318h | CCPR4L | 398h | _ | | 019h | T1GCON | 099h | OSCCON | 119h | DACCON1 | 199h | RCREG | 219h | 1 | 299h | CCPR2H | 319h | CCPR4H | 399h | _ | | 01Ah | TMR2 | 09Ah | OSCSTAT | 11Ah | SRCON0 | 19Ah | TXREG | 21Ah | _ | 29Ah | CCP2CON | 31Ah | CCP4CON | 39Ah | CLKRCON | | 01Bh | PR2 | 09Bh | ADRESL | 11Bh | SRCON1 | 19Bh | SPBRGL | 21Bh | _ | 29Bh | PWM2CON | 31Bh | _ | 39Bh | _ | | 01Ch | T2CON | 09Ch | ADRESH | 11Ch | | 19Ch | SPBRGH | 21Ch | _ | 29Ch | CCP2AS | 31Ch | _ | 39Ch | MDCON | | 01Dh | _ | 09Dh | ADCON0 | 11Dh | APFCON0 | 19Dh | RCSTA | 21Dh | _ | 29Dh | PSTR2CON | 31Dh | _ | 39Dh | MDSRC | | 01Eh | CPSCON0 | 09Eh | ADCON1 | 11Eh | APFCON1 | 19Eh | TXSTA | 21Eh | _ | 29Eh | CCPTMRS0 | 31Eh | _ | 39Eh | MDCARL | | 01Fh | CPSCON1 | 09Fh | | 11Fh | | 19Fh | BAUDCON | 21Fh | _ | 29Fh | _ | 31Fh | _ | 39Fh | MDCARH | | 020h | | 0A0h | | 120h | | 1A0h | | 220h | | 2A0h | | 320h | | 3A0h | | | | General | | General | | General | | | | | | | | | | | | | Purpose | | Purpose | | Purpose | | Unimplemented | | Unimplemented | | Unimplemented | | Unimplemented | | Unimplemented | | | Register | | Register | | Register | | Read as '0' | | Read as '0' | | Read as '0' | | Read as '0' | | Read as '0' | | | 80 Bytes | | 80 Bytes | | 80 Bytes | | | | | | | | | | | | 06Fh | | 0EFh | | 16Fh | | 1EFh | | 26Fh | | 2EFh | | 36Fh | | 3EFh | | | 070h | | 0F0h | | 170h | | 1F0h | | 270h | | 2F0h | | 370h | | 3F0h | | | | Common RAM | | Accesses | | | 70h – 7Fh 07Fh | | 0FFh | | 17Fh | | 1FFh | | 27Fh | | 2FFh | | 37Fh | | 3FFh | | **Legend:** Unimplemented data memory locations, read as '0'. Note 1: Available only on PIC16(L)F1828. #### 5.2.2.1 HFINTOSC The High-Frequency Internal Oscillator (HFINTOSC) is a factory calibrated 16 MHz internal clock source. The frequency of the HFINTOSC can be altered via software using the OSCTUNE register (Register 5-3). The output of the HFINTOSC connects to a postscaler and multiplexer (see Figure 5-1). One of nine frequencies derived from the HFINTOSC can be selected via software using the IRCF<3:0> bits of the OSCCON register. See Section 5.2.2.7 "Internal Oscillator Clock Switch Timing" for more information. The HFINTOSC is enabled by: - Configure the IRCF<3:0> bits of the OSCCON register for the desired HF frequency, and - FOSC<2:0> = 100, or - Set the System Clock Source (SCS) bits of the OSCCON register to '1x'. The High-Frequency Internal Oscillator Ready bit (HFIOFR) of the OSCSTAT register indicates when the HFINTOSC is running and can be utilized. The High-Frequency Internal Oscillator Status Locked bit (HFIOFL) of the OSCSTAT register indicates when the HFINTOSC is running within 2% of its final value. The High-Frequency Internal Oscillator Status Stable bit (HFIOFS) of the OSCSTAT register indicates when the HFINTOSC is running within 0.5% of its final value. #### 5.2.2.2 MFINTOSC The Medium-Frequency Internal Oscillator (MFINTOSC) is a factory calibrated 500 kHz internal clock source. The frequency of the MFINTOSC can be altered via software using the OSCTUNE register (Register 5-3). The output of the MFINTOSC connects to a postscaler and multiplexer (see Figure 5-1). One of nine frequencies derived from the MFINTOSC can be selected via software using the IRCF<3:0> bits of the OSCCON register. See Section 5.2.2.7 "Internal Oscillator Clock Switch Timing" for more information. The MFINTOSC is enabled by: - Configure the IRCF<3:0> bits of the OSCCON register for the desired HF frequency, and - FOSC<2:0> = 100, or - Set the System Clock Source (SCS) bits of the OSCCON register to '1x' The Medium-Frequency Internal Oscillator Ready bit (MFIOFR) of the OSCSTAT register indicates when the MFINTOSC is running and can be utilized. ## 5.2.2.3 Internal Oscillator Frequency Adjustment The 500 kHz internal oscillator is factory calibrated. This internal oscillator can be adjusted in software by writing to the OSCTUNE register (Register 5-3). Since the HFINTOSC and MFINTOSC clock sources are derived from the 500 kHz internal oscillator a change in the OSCTUNE register value will apply to both. The default value of the OSCTUNE register is '0'. The value is a 6-bit two's complement number. A value of 1Fh will provide an adjustment to the maximum frequency. A value of 20h will provide an adjustment to the minimum frequency. When the OSCTUNE register is modified, the oscillator frequency will begin shifting to the new frequency. Code execution continues during this shift. There is no indication that the shift has occurred. OSCTUNE does not affect the LFINTOSC frequency. Operation of features that depend on the LFINTOSC clock source frequency, such as the Power-up Timer (PWRT), Watchdog Timer (WDT), Fail-Safe Clock Monitor (FSCM) and peripherals, are *not* affected by the change in frequency. #### 5.2.2.4 LFINTOSC The Low-Frequency Internal Oscillator (LFINTOSC) is an uncalibrated 31 kHz internal clock source. The output of the LFINTOSC connects to a multiplexer (see Figure 5-1). Select 31 kHz, via software, using the IRCF<3:0> bits of the OSCCON register. See Section 5.2.2.7 "Internal Oscillator Clock Switch Timing" for more information. The LFINTOSC is also the frequency for the Power-up Timer (PWRT), Watchdog Timer (WDT) and Fail-Safe Clock Monitor (FSCM). The LFINTOSC is enabled by selecting 31 kHz (IRCF<3:0> bits of the OSCCON register = 000) as the system clock source (SCS bits of the OSCCON register = 1x), or when any of the following are enabled: - Configure the IRCF<3:0> bits of the OSCCON register for the desired LF frequency, and - FOSC<2:0> = 100, or - Set the System Clock Source (SCS) bits of the OSCCON register to '1x' Peripherals that use the LFINTOSC are: - Power-up Timer (PWRT) - Watchdog Timer (WDT) - Fail-Safe Clock Monitor (FSCM) The Low-Frequency Internal Oscillator Ready bit (LFIOFR) of the OSCSTAT register indicates when the LFINTOSC is running and can be utilized. #### TABLE 6-1: SUMMARY OF REGISTERS ASSOCIATED WITH REFERENCE CLOCK SOURCES | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Register on Page | |---------|--------|--------|---------|-------|---------|-------|-------------|-------|------------------| | CLKRCON | CLKREN | CLKROE | CLKRSLR | CLKRI | OC<1:0> | С | LKRDIV<2:0> | > | 72 | **Legend:** — = unimplemented locations, read as '0'. Shaded cells are not used by reference clock sources. #### TABLE 6-2: SUMMARY OF CONFIGURATION WORD WITH REFERENCE CLOCK SOURCES | Name | Bits | Bit -/7 | Bit -/6 | Bit 13/5 | Bit 12/4 | Bit 11/3 | Bit 10/2 | Bit 9/1 | Bit 8/0 | Register on Page | |---------|------|---------|---------|----------|----------|----------|----------|-----------|---------|------------------| | CONFIG1 | 13:8 | I | _ | FCMEN | IESO | CLKOUTEN | BOREI | N<1:0> | CPD | 40 | | CONFIGI | 7:0 | CP | MCLRE | PWRTE | WDTE | E<1:0> | | FOSC<2:0> | | 48 | **Legend:** — = unimplemented locations, read as '0'. Shaded cells are not used by reference clock sources. #### 7.0 RESETS There are multiple ways to reset this device: - Power-on Reset (POR) - Brown-out Reset (BOR) - MCLR Reset - · WDT Reset - RESET instruction - · Stack Overflow - · Stack Underflow - · Programming mode exit To allow VDD to stabilize, an optional Power-up Timer can be enabled to extend the Reset time after a BOR or POR event. A simplified block diagram of the On-Chip Reset Circuit is shown in Figure 7-1. FIGURE 7-1: SIMPLIFIED BLOCK DIAGRAM OF ON-CHIP RESET CIRCUIT #### REGISTER 7-1: BORCON: BROWN-OUT RESET CONTROL REGISTER | R/W-1/u | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R-q/u | |---------|-----|-----|-----|-----|-----|-----|--------| | SBOREN | _ | _ | _ | _ | _ | _ | BORRDY | | 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 q = Value depends on condition bit 7 SBOREN: Software Brown-out Reset Enable bit If BOREN <1:0> in Configuration Word 1 ≠ 01: SBOREN is read/write, but has no effect on the BOR. If BOREN <1:0> in Configuration Word 1 = 01: 1 = BOR Enabled0 = BOR Disabled bit 6-1 Unimplemented: Read as '0' bit 0 BORRDY: Brown-out Reset Circuit Ready Status bit 1 = The Brown-out Reset circuit is active0 = The Brown-out Reset circuit is inactive © 2010-2015 Microchip Technology Inc. TABLE 8-1: SUMMARY OF REGISTERS ASSOCIATED WITH INTERRUPTS | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Register<br>on Page | |------------|---------|--------|--------|--------|--------|--------|--------|--------|---------------------| | INTCON | GIE | PEIE | TMR0IE | INTE | IOCIE | TMR0IF | INTF | IOCIF | 89 | | OPTION_REG | WPUEN | INTEDG | TMR0CS | TMR0SE | PSA | PS2 | PS1 | PS0 | 176 | | PIE1 | TMR1GIE | ADIE | RCIE | TXIE | SSP1IE | CCP1IE | TMR2IE | TMR1IE | 90 | | PIE2 | OSFIE | C2IE | C1IE | EEIE | BCL1IE | 1 | 1 | CCP2IE | 91 | | PIE3 | 1 | _ | CCP4IE | CCP3IE | TMR6IE | 1 | TMR4IE | _ | 92 | | PIR1 | TMR1GIF | ADIF | RCIF | TXIF | SSP1IF | CCP1IF | TMR2IF | TMR1IF | 93 | | PIR2 | OSFIF | C2IF | C1IF | EEIF | BCL1IF | _ | _ | CCP2IF | 94 | | PIR3 | _ | _ | CCP4IF | CCP3IF | TMR6IF | _ | TMR4IF | _ | 95 | **Legend:** — = unimplemented locations, read as '0'. Shaded cells are not used by interrupts. ## 12.4.3 PORTC FUNCTIONS AND OUTPUT PRIORITIES Each PORTC pin is multiplexed with other functions. The pins, their combined functions and their output priorities are briefly described here. For additional information, refer to the appropriate section in this data sheet. When multiple outputs are enabled, the actual pin control goes to the peripheral with the lowest number in the following lists. Analog input and some digital input functions are not included in the list below. These input functions can remain active when the pin is configured as an output. Certain digital input functions override other port functions and are included in the priority list. #### RC0 - 1. SCL (MSSP) (PIC16(L)F1824 only) - 2. SCK (MSSP) (PIC16(L)F1824 only) - 3. P1D #### RC1 - 1. SDA (MSSP) (PIC16(L)F1824 only) - 2. P1C - 3. CCP4 (PIC16(L)F1828 only) #### RC2 - 1. SDO (MSSP) (PIC16(L)F1824 only) - 2. P1D - 3. P2B #### RC3 - 1. SS (MSSP) (PIC16(L)F1824 only) - 2. CCP2 - 3. P1C - 4. P2A #### RC4 - 1. MDOUT - 2. SRNQ - 3. C2OUT - 4. TX/CK - 5. P1B #### RC5 - 1. RX/DT - 2. CCP1/P1A #### RC6 (PIC16(L)F1828 only) - 1. SS (MSSP) - 2. CCP4 #### RC7 (PIC16(L)F1828 only) 1. SDO (MSSP) ## REGISTER 13-4: IOCBP: INTERRUPT-ON-CHANGE PORTB POSITIVE EDGE REGISTER (PIC16(L)F1828 ONLY) | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | U-0 | U-0 | U-0 | U-0 | |---------|---------|---------|---------|-----|-----|-----|-------| | IOCBP7 | IOCBP6 | IOCBP5 | IOCBP4 | _ | _ | _ | _ | | 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 IOCBP<7:4>: Interrupt-on-Change PORTB Positive Edge Enable bits 1 = Interrupt-on-Change enabled on the pin for a positive going edge. Associated Status bit and interrupt flag will be set upon detecting an edge. 0 = Interrupt-on-Change disabled for the associated pin. bit 3-0 **Unimplemented:** Read as '0' ## REGISTER 13-5: IOCBN: INTERRUPT-ON-CHANGE PORTB NEGATIVE EDGE REGISTER (PIC16(L)F1828 ONLY) | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | U-0 | U-0 | U-0 | U-0 | |---------|---------|---------|---------|-----|-----|-----|-------| | IOCBN7 | IOCBN6 | IOCBN5 | IOCBN4 | _ | _ | _ | _ | | 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 IOCAN<7:4>: Interrupt-on-Change PORTB Negative Edge Enable bits 1 = Interrupt-on-Change enabled on the pin for a negative going edge. Associated Status bit and interrupt flag will be set upon detecting an edge. 0 = Interrupt-on-Change disabled for the associated pin. bit 3-0 **Unimplemented:** Read as '0' ### 16.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 16-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. #### 19.0 COMPARATOR MODULE Comparators are used to interface analog circuits to a digital circuit by comparing two analog voltages and providing a digital indication of their relative magnitudes. Comparators are very useful mixed signal building blocks because they provide analog functionality independent of program execution. The analog comparator module includes the following features: - · Independent comparator control - · Programmable input selection - · Comparator output is available internally/externally - · Programmable output polarity - · Interrupt-on-change - · Wake-up from Sleep - · Programmable Speed/Power optimization - · PWM shutdown - · Programmable and Fixed Voltage Reference #### 19.1 Comparator Overview A single comparator is shown in Figure 19-1 along with the relationship between the analog input levels and the digital output. When the analog voltage at VIN+ is less than the analog voltage at VIN-, the output of the comparator is a digital low level. When the analog voltage at VIN+ is greater than the analog voltage at VIN-, the output of the comparator is a digital high level. # FIGURE 19-1: SINGLE COMPARATOR **Note:** The black areas of the output of the comparator represents the uncertainty due to input offsets and response time. #### FIGURE 19-2: COMPARATOR MODULE SIMPLIFIED BLOCK DIAGRAM #### 21.7 Timer1 Interrupt The Timer1 register pair (TMR1H:TMR1L) increments to FFFFh and rolls over to 0000h. When Timer1 rolls over, the Timer1 interrupt flag bit of the PIR1 register is set. To enable the interrupt on rollover, you must set these bits: - · TMR1ON bit of the T1CON register - TMR1IE bit of the PIE1 register - · PEIE bit of the INTCON register - · GIE bit of the INTCON register The interrupt is cleared by clearing the TMR1IF bit in the Interrupt Service Routine. Note: The TMR1H:TMR1L register pair and the TMR1IF bit should be cleared before enabling interrupts. #### 21.8 Timer1 Operation During Sleep Timer1 can only operate during Sleep when set up in Asynchronous Counter mode. In this mode, an external crystal or clock source can be used to increment the counter. To set up the timer to wake the device: - TMR1ON bit of the T1CON register must be set - TMR1IE bit of the PIE1 register must be set - · PEIE bit of the INTCON register must be set - T1SYNC bit of the T1CON register must be set - TMR1CS bits of the T1CON register must be configured - T10SCEN bit of the T1CON register must be configured The device will wake-up on an overflow and execute the next instructions. If the GIE bit of the INTCON register is set, the device will call the Interrupt Service Routine. Timer1 oscillator will continue to operate in Sleep regardless of the $\overline{\text{T1SYNC}}$ bit setting. ## 21.9 ECCP/CCP Capture/Compare Time Base The CCP modules use the TMR1H:TMR1L register pair as the time base when operating in Capture or Compare mode. In Capture mode, the value in the TMR1H:TMR1L register pair is copied into the CCPR1H:CCPR1L register pair on a configured event. In Compare mode, an event is triggered when the value CCPR1H:CCPR1L register pair matches the value in the TMR1H:TMR1L register pair. This event can be a Special Event Trigger. For more information, see Section 24.0 "Capture/Compare/PWM Modules". #### 21.10 ECCP/CCP Special Event Trigger When any of the CCP's are configured to trigger a special event, the trigger will clear the TMR1H:TMR1L register pair. This special event does not cause a Timer1 interrupt. The CCP module may still be configured to generate a CCP interrupt. In this mode of operation, the CCPR1H:CCPR1L register pair becomes the period register for Timer1. Timer1 should be synchronized and Fosc/4 should be selected as the clock source in order to utilize the Special Event Trigger. Asynchronous operation of Timer1 can cause a Special Event Trigger to be missed. In the event that a write to TMR1H or TMR1L coincides with a Special Event Trigger from the CCP, the write will take precedence. For more information, see **Section 16.2.5** "**Special Event Trigger**". #### FIGURE 21-2: TIMER1 INCREMENTING EDGE Note 1: Arrows indicate counter increments. 2: In Counter mode, a falling edge must be registered by the counter prior to the first incrementing rising edge of the clock. The $I^2C$ interface supports the following modes and features: - · Master mode - · Slave mode - · Byte NACKing (Slave mode) - · Limited multi-master support - · 7-bit and 10-bit addressing - · Start and Stop interrupts - · Interrupt masking - · Clock stretching - · Bus collision detection - · General call address matching - · Address masking - · Address Hold and Data Hold modes - · Selectable SDA hold times Figure 25-2 is a block diagram of the I<sup>2</sup>C interface module in Master mode. Figure 25-3 is a diagram of the I<sup>2</sup>C interface module in Slave mode. FIGURE 25-2: MSSP1 BLOCK DIAGRAM (I<sup>2</sup>C™ MASTER MODE) #### 25.4.5 START CONDITION The I<sup>2</sup>C specification defines a Start condition as a transition of SDA from a high to a low state while SCL line is high. A Start condition is always generated by the master and signifies the transition of the bus from an Idle to an Active state. Figure 25-12 shows wave forms for Start and Stop conditions. A bus collision can occur on a Start condition if the module samples the SDA line low before asserting it low. This does not conform to the I<sup>2</sup>C Specification that states no bus collision can occur on a Start. #### 25.4.6 STOP CONDITION A Stop condition is a transition of the SDA line from low-to-high state while the SCL line is high. **Note:** At least one SCL low time must appear before a Stop is valid, therefore, if the SDA line goes low then high again while the SCL line stays high, only the Start condition is detected. #### 25.4.7 RESTART CONDITION A Restart is valid any time that a Stop would be valid. A master can issue a Restart if it wishes to hold the bus after terminating the current transfer. A Restart has the same effect on the slave that a Start would, resetting all slave logic and preparing it to clock in an address. The master may want to address the same or another slave. In 10-bit Addressing Slave mode a Restart is required for the master to clock data out of the addressed slave. Once a slave has been fully addressed, matching both high and low address bytes, the master can issue a Restart and the high address byte with the $R/\overline{W}$ bit set. The slave logic will then hold the clock and prepare to clock out data. After a full match with $R/\overline{W}$ clear in 10-bit mode, a prior match flag is set and maintained. Until a Stop condition, a high address with $R/\overline{W}$ clear, or high address match fails. ## 25.4.8 START/STOP CONDITION INTERRUPT MASKING The SCIE and PCIE bits of the SSP1CON3 register can enable the generation of an interrupt in Slave modes that do not typically support this function. Slave modes where interrupt on Start and Stop detect are already enabled, these bits will have no effect. FIGURE 25-12: I<sup>2</sup>C START AND STOP CONDITIONS FIGURE 25-13: I<sup>2</sup>C RESTART CONDITION ## 26.1.2 EUSART ASYNCHRONOUS RECEIVER The Asynchronous mode is typically used in RS-232 systems. The receiver block diagram is shown in Figure 26-2. The data is received on the RX/DT pin and drives the data recovery block. The data recovery block is actually a high-speed shifter operating at 16 times the baud rate, whereas the serial Receive Shift Register (RSR) operates at the bit rate. When all eight or nine bits of the character have been shifted in, they are immediately transferred to a two character First-In-First-Out (FIFO) memory. The FIFO buffering allows reception of two complete characters and the start of a third character before software must start servicing the EUSART receiver. The FIFO and RSR registers are not directly accessible by software. Access to the received data is via the RCREG register. #### 26.1.2.1 Enabling the Receiver The EUSART receiver is enabled for asynchronous operation by configuring the following three control bits: - CREN = 1 - SYNC = 0 - SPEN = 1 All other EUSART control bits are assumed to be in their default state. Setting the CREN bit of the RCSTA register enables the receiver circuitry of the EUSART. Clearing the SYNC bit of the TXSTA register configures the EUSART for asynchronous operation. Setting the SPEN bit of the RCSTA register enables the EUSART. The programmer must set the corresponding TRIS bit to configure the TX/CK I/O pin as an input. Note 1: If the RX/DT function is on an analog pin, the corresponding ANSEL bit must be cleared for the receiver to function. #### 26.1.2.2 Receiving Data The receiver data recovery circuit initiates character reception on the falling edge of the first bit. The first bit, also known as the Start bit, is always a zero. The data recovery circuit counts one-half bit time to the center of the Start bit and verifies that the bit is still a zero. If it is not a zero then the data recovery circuit aborts character reception, without generating an error, and resumes looking for the falling edge of the Start bit. If the Start bit zero verification succeeds then the data recovery circuit counts a full bit time to the center of the next bit. The bit is then sampled by a majority detect circuit and the resulting '0' or '1' is shifted into the RSR. This repeats until all data bits have been sampled and shifted into the RSR. One final bit time is measured and the level sampled. This is the Stop bit, which is always a '1'. If the data recovery circuit samples a '0' in the Stop bit position then a framing error is set for this character, otherwise the framing error is cleared for this character. See Section 26.1.2.4 "Receive Framing Error" for more information on framing errors. Immediately after all data bits and the Stop bit have been received, the character in the RSR is transferred to the EUSART receive FIFO and the RCIF interrupt flag bit of the PIR1 register is set. The top character in the FIFO is transferred out of the FIFO by reading the RCREG register. Note: If the receive FIFO is overrun, no additional characters will be received until the overrun condition is cleared. See Section 26.1.2.5 "Receive Overrun Error" for more information on overrun errors. #### 26.1.2.3 Receive Interrupts The RCIF interrupt flag bit of the PIR1 register is set whenever the EUSART receiver is enabled and there is an unread character in the receive FIFO. The RCIF interrupt flag bit is read-only, it cannot be set or cleared by software. RCIF interrupts are enabled by setting all of the following bits: - · RCIE interrupt enable bit of the PIE1 register - PEIE peripheral interrupt enable bit of the INTCON register - GIE global interrupt enable bit of the INTCON register The RCIF interrupt flag bit will be set when there is an unread character in the FIFO, regardless of the state of interrupt enable bits. FIGURE 26-10: SYNCHRONOUS TRANSMISSION FIGURE 26-11: SYNCHRONOUS TRANSMISSION (THROUGH TXEN) **TABLE 26-7:** SUMMARY OF REGISTERS ASSOCIATED WITH SYNCHRONOUS MASTER **TRANSMISSION** | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Register on<br>Page | | | | |---------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | RXDTSEL | SDOSEL <sup>(1)</sup> | SSSEL <sup>(1)</sup> | _ | T1GSEL | TXCKSEL | _ | _ | 117 | | | | | ABDOVF | RCIDL | _ | SCKP | BRG16 | _ | WUE | ABDEN | 296 | | | | | GIE | PEIE | TMR0IE | INTE | IOCIE | TMR0IF | INTF | IOCIF | 89 | | | | | TMR1GIE | ADIE | RCIE | TXIE | SSP1IE | CCP1IE | TMR2IE | TMR1IE | 90 | | | | | TMR1GIF | ADIF | RCIF | TXIF | SSP1IF | CCP1IF | TMR2IF | TMR1IF | 93 | | | | | SPEN | RX9 | SREN | CREN | ADDEN | FERR | OERR | RX9D | 295 | | | | | BRG7 | BRG6 | BRG5 | BRG4 | BRG3 | BRG2 | BRG1 | BRG0 | 297* | | | | | BRG15 | BRG14 | BRG13 | BRG12 | BRG11 | BRG10 | BRG9 | BRG8 | 297* | | | | | | | E | JSART Transn | nit Data Regist | er | | | 287* | | | | | CSRC | TX9 | TXEN | SYNC | SENDB | BRGH | TRMT | TX9D | 294 | | | | | | RXDTSEL ABDOVF GIE TMR1GIE TMR1GIF SPEN BRG7 BRG15 | RXDTSEL SDOSEL <sup>(1)</sup> ABDOVF RCIDL GIE PEIE TMR1GIE ADIE TMR1GIF ADIF SPEN RX9 BRG7 BRG6 BRG15 BRG14 | RXDTSEL SDOSEL <sup>(1)</sup> SSSEL <sup>(1)</sup> ABDOVF RCIDL — GIE PEIE TMR0IE TMR1GIE ADIE RCIE TMR1GIF ADIF RCIF SPEN RX9 SREN BRG7 BRG6 BRG5 BRG15 BRG14 BRG13 EI | RXDTSEL SDOSEL <sup>(1)</sup> SSSEL <sup>(1)</sup> — ABDOVF RCIDL — SCKP GIE PEIE TMR0IE INTE TMR1GIE ADIE RCIE TXIE TMR1GIF ADIF RCIF TXIF SPEN RX9 SREN CREN BRG7 BRG6 BRG5 BRG4 BRG15 BRG14 BRG13 BRG12 EUSART Transn | RXDTSEL SDOSEL <sup>(1)</sup> SSSEL <sup>(1)</sup> — T1GSEL ABDOVF RCIDL — SCKP BRG16 GIE PEIE TMR0IE INTE IOCIE TMR1GIE ADIE RCIE TXIE SSP1IE TMR1GIF ADIF RCIF TXIF SSP1IF SPEN RX9 SREN CREN ADDEN BRG7 BRG6 BRG5 BRG4 BRG3 BRG15 BRG14 BRG13 BRG12 BRG11 EUSART Transmit Data Registr | RXDTSEL SDOSEL <sup>(1)</sup> SSSEL <sup>(1)</sup> — T1GSEL TXCKSEL ABDOVF RCIDL — SCKP BRG16 — GIE PEIE TMR0IE INTE IOCIE TMR0IF TMR1GIE ADIE RCIE TXIE SSP1IE CCP1IE TMR1GIF ADIF RCIF TXIF SSP1IF CCP1IF SPEN RX9 SREN CREN ADDEN FERR BRG7 BRG6 BRG5 BRG4 BRG3 BRG2 BRG15 BRG14 BRG13 BRG12 BRG11 BRG10 EUSART Transmit Data Register | RXDTSEL SDOSEL(1) SSSEL(1) — T1GSEL TXCKSEL — ABDOVF RCIDL — SCKP BRG16 — WUE GIE PEIE TMR0IE INTE IOCIE TMR0IF INTF TMR1GIE ADIE RCIE TXIE SSP1IE CCP1IE TMR2IE TMR1GIF ADIF RCIF TXIF SSP1IF CCP1IF TMR2IF SPEN RX9 SREN CREN ADDEN FERR OERR BRG7 BRG6 BRG5 BRG4 BRG3 BRG2 BRG1 BRG15 BRG14 BRG13 BRG12 BRG11 BRG10 BRG9 EUSART Transmit Data Register | RXDTSEL SDOSEL <sup>(1)</sup> SSSEL <sup>(1)</sup> — T1GSEL TXCKSEL — — ABDOVF RCIDL — SCKP BRG16 — WUE ABDEN GIE PEIE TMR0IE INTE IOCIE TMR0IF INTF IOCIF TMR1GIE ADIE RCIE TXIE SSP1IE CCP1IE TMR2IE TMR1IE TMR1GIF ADIF RCIF TXIF SSP1IF CCP1IF TMR2IF TMR1IF SPEN RX9 SREN CREN ADDEN FERR OERR RX9D BRG7 BRG6 BRG5 BRG4 BRG3 BRG2 BRG1 BRG0 BRG15 BRG14 BRG13 BRG12 BRG11 BRG10 BRG9 BRG8 EUSART Transmit Data Register | | | | — = unimplemented location, read as '0'. Shaded cells are not used for synchronous master transmission. Page provides register information. PIC16(L)F1824 only. Legend: Note 1: TABLE 30-21: DC CHARACTERISTICS FOR IPD SPECIFICATIONS FOR PIC16F1824/8-H (High Temp.) | | remp.) | | | | | | | |--------|------------------------|------------------------|------|--------|-------|-----|----------------------------------------------------------------------| | PIC16F | 1824/8 | | | | | | herwise stated)<br>for High Temperature | | Param | Device Characteristics | Min. | Time | Max. | Units | | Condition | | No. | Device Characteristics | IVIII. | Тур. | IVIAX. | Units | VDD | Note | | | Power-Down Base Curren | t (IPD) <sup>(2)</sup> | | | | | | | D022 | | _ | _ | 60 | μА | 3.0 | WDT, BOR, FVR, and T1OSC | | | | _ | _ | 75 | μΑ | 5.0 | disabled, all Peripherals Inactive | | D023 | | | _ | 60 | μΑ | 3.0 | LPWDT Current (Note 1) | | | | _ | _ | 75 | μΑ | 5.0 | | | D023A | | _ | _ | 75 | μΑ | 3.0 | FVR current (Note 1) | | | | _ | _ | 120 | μΑ | 5.0 | | | D024 | | | | 55 | μΑ | 3.0 | BOR Current (Note 1) | | | | _ | _ | 75 | μΑ | 5.0 | | | D025 | | | | 65 | μΑ | 3.0 | T1OSC Current (Note 1) | | | | _ | | 80 | μΑ | 5.0 | | | D026 | | | — | 55 | μΑ | 3.0 | A/D Current (Note 1, Note 3), | | | | _ | _ | 70 | μΑ | 5.0 | no conversion in progress | | D027 | | _ | _ | _ | _ | _ | Cap Sense module is not intended for use in high temperature devices | | D028 | | _ | | 70 | μΑ | 3.0 | Comparator Current, Low- | | | | _ | _ | 90 | μΑ | 5.0 | Power mode (Note 1) | | D028B | | _ | _ | 100 | μΑ | 3.0 | Comparator Current, High- | | | | _ | _ | 115 | μΑ | 5.0 | Power mode (Note 1) | <sup>†</sup> 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 or IPD and the additional current consumed when this peripheral is enabled. The peripheral $\Delta$ 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. <sup>2:</sup> 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 set to inputs state and tied to VDD. <sup>3:</sup> A/D oscillator source is FRC. #### 16-Lead Plastic Quad Flat, No Lead Package (ML) – 4x4x0.9 mm Body [QFN] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | | MILLIMETERS | 3 | | | | |------------------------|------------------|----------|-------------|------|--|--|--| | | Dimension Limits | MIN | NOM | MAX | | | | | Number of Pins | N | | 16 | • | | | | | Pitch | е | 0.65 BSC | | | | | | | Overall Height | A | 0.80 | 0.90 | 1.00 | | | | | Standoff | A1 | 0.00 | 0.02 | 0.05 | | | | | Contact Thickness | A3 | | 0.20 REF | • | | | | | Overall Width | E | | 4.00 BSC | | | | | | Exposed Pad Width | E2 | 2.50 | 2.65 | 2.80 | | | | | Overall Length | D | | 4.00 BSC | • | | | | | Exposed Pad Length | D2 | 2.50 | 2.65 | 2.80 | | | | | Contact Width | b | 0.25 | 0.30 | 0.35 | | | | | Contact Length | L | 0.30 | 0.40 | 0.50 | | | | | Contact-to-Exposed Pad | K | 0.20 | _ | _ | | | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Package is saw singulated. - 3. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-127B #### 20-Lead Ultra Thin Plastic Quad Flat, No Lead Package (GZ) - 4x4x0.5 mm Body [UQFN] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | | MILLIMETERS | | | |-------------------------|-------|-----------|-------------|------|--| | Dimension Limits | | MIN | NOM | MAX | | | Number of Terminals | N | 20 | | | | | Pitch | е | 0.50 BSC | | | | | Overall Height | Α | 0.45 | 0.50 | 0.55 | | | Standoff | A1 | 0.00 | 0.02 | 0.05 | | | Terminal Thickness | A3 | 0.127 REF | | | | | Overall Width | Е | 4.00 BSC | | | | | Exposed Pad Width | E2 | 2.60 | 2.70 | 2.80 | | | Overall Length | D | 4.00 BSC | | | | | Exposed Pad Length | D2 | 2.60 | 2.70 | 2.80 | | | Terminal Width | b | 0.20 | 0.25 | 0.30 | | | Terminal Length | Ĺ | 0.30 | 0.40 | 0.50 | | | Terminal-to-Exposed-Pad | K | 0.20 | - | - | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Package is saw singulated - 3. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-255A Sheet 2 of 2