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 | 40MHz | | Connectivity | I <sup>2</sup> C, SPI, UART/USART | | Peripherals | Brown-out Detect/Reset, HLVD, POR, PWM, WDT | | Number of I/O | 25 | | Program Memory Size | 32KB (16K x 16) | | Program Memory Type | FLASH | | EEPROM Size | 256 x 8 | | RAM Size | 1.5K x 8 | | Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V | | Data Converters | A/D 10x10b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Through Hole | | Package / Case | 28-DIP (0.300", 7.62mm) | | Supplier Device Package | 28-SPDIP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf2520-i-sp | TABLE 1-1: DEVICE FEATURES | Features | PIC18F2420 | PIC18F2520 | PIC18F4420 | PIC18F4520 | |-----------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------| | Operating Frequency | DC – 40 MHz | DC – 40 MHz | DC – 40 MHz | DC – 40 MHz | | Program Memory (Bytes) | 16384 | 32768 | 16384 | 32768 | | Program Memory<br>(Instructions) | 8192 | 16384 | 8192 | 16384 | | Data Memory (Bytes) | 768 | 1536 | 768 | 1536 | | Data EEPROM Memory (Bytes) | 256 | 256 | 256 | 256 | | Interrupt Sources | 19 | 19 | 20 | 20 | | I/O Ports | Ports A, B, C, (E) | Ports A, B, C, (E) | Ports A, B, C, D, E | Ports A, B, C, D, E | | Timers | 4 | 4 | 4 | 4 | | Capture/Compare/PWM Modules | 2 | 2 | 1 | 1 | | Enhanced<br>Capture/Compare/PWM Modules | 0 | 0 | 1 | 1 | | Serial Communications | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | | Parallel Communications (PSP) | No | No | Yes | Yes | | 10-Bit Analog-to-Digital Module | 10 Input Channels | 10 Input Channels | 13 Input Channels | 13 Input Channels | | Resets (and Delays) | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | | Programmable<br>High/Low-Voltage Detect | Yes | Yes | Yes | Yes | | Programmable Brown-out Reset | Yes | Yes | Yes | Yes | | Instruction Set | 75 Instructions;<br>83 with Extended<br>Instruction Set Enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set Enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set Enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set Enabled | | Packages | 28-Pin SPDIP<br>28-Pin SOIC<br>28-Pin QFN | 28-Pin SPDIP<br>28-Pin SOIC<br>28-Pin QFN | 40-Pin PDIP<br>44-Pin QFN<br>44-Pin TQFP | 40-Pin PDIP<br>44-Pin QFN<br>44-Pin TQFP | #### REGISTER 9-7: PIE2: PERIPHERAL INTERRUPT ENABLE REGISTER 2 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-------|-----|-------|-------|--------|--------|--------| | OSCFIE | CMIE | _ | EEIE | BCLIE | HLVDIE | TMR3IE | CCP2IE | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7 OSCFIE: Oscillator Fail Interrupt Enable bit 1 = Enabled 0 = Disabled bit 6 CMIE: Comparator Interrupt Enable bit 1 = Enabled 0 = Disabled bit 5 Unimplemented: Read as '0' bit 4 **EEIE:** Data EEPROM/Flash Write Operation Interrupt Enable bit 1 = Enabled0 = Disabled bit 3 BCLIE: Bus Collision Interrupt Enable bit 1 = Enabled 0 = Disabled bit 2 **HLVDIE:** High/Low-Voltage Detect Interrupt Enable bit 1 = Enabled 0 = Disabled bit 1 TMR3IE: TMR3 Overflow Interrupt Enable bit 1 = Enabled 0 = Disabled bit 0 CCP2IE: CCP2 Interrupt Enable bit 1 = Enabled0 = Disabled TABLE 10-2: SUMMARY OF REGISTERS ASSOCIATED WITH PORTA | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset<br>Values<br>on page | | | |--------|-----------------------|-----------------------|----------|----------------------------------------------------------|----------|-------|-------|-------|----------------------------|--|--| | PORTA | RA7 <sup>(1)</sup> | RA6 <sup>(1)</sup> | RA5 | RA4 | RA3 | RA2 | RA1 | RA0 | 52 | | | | LATA | LATA7 <sup>(1)</sup> | LATA6 <sup>(1)</sup> | PORTA Da | PORTA Data Latch Register (Read and Write to Data Latch) | | | | | | | | | TRISA | TRISA7 <sup>(1)</sup> | TRISA6 <sup>(1)</sup> | PORTA Da | ta Direction | Register | | | | 52 | | | | ADCON1 | _ | _ | VCFG1 | VCFG0 | PCFG3 | PCFG2 | PCFG1 | PCFG0 | 51 | | | | CMCON | C2OUT | C1OUT | C2INV | C1INV | CIS | CM2 | CM1 | CM0 | 51 | | | | CVRCON | CVREN | CVROE | CVRR | CVRSS | CVR3 | CVR2 | CVR1 | CVR0 | 51 | | | **Legend:** — = unimplemented, read as '0'. Shaded cells are not used by PORTA. **Note 1:** RA<7:6> and their associated latch and data direction bits are enabled as I/O pins based on oscillator configuration; otherwise, they are read as '0'. # 10.3 PORTC, TRISC and LATC Registers PORTC is an 8-bit wide, bidirectional port. The corresponding Data Direction register is TRISC. 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., put the contents of the output latch on the selected pin). The Data Latch register (LATC) is also memory mapped. Read-modify-write operations on the LATC register read and write the latched output value for PORTC. PORTC is multiplexed with several peripheral functions (Table 10-5). The pins have Schmitt Trigger input buffers. RC1 is normally configured by Configuration bit, CCP2MX, as the default peripheral pin of the CCP2 module (default/erased state, CCP2MX = 1). When enabling peripheral functions, care should be taken in defining TRIS bits for each PORTC pin. Some peripherals override the TRIS bit to make a pin an output, while other peripherals override the TRIS bit to make a pin an input. The user should refer to the corresponding peripheral section for additional information. **Note:** On a Power-on Reset, these pins are configured as digital inputs. The contents of the TRISC register are affected by peripheral overrides. Reading TRISC always returns the current contents, even though a peripheral device may be overriding one or more of the pins. #### **EXAMPLE 10-3: INITIALIZING PORTC** | CLRF | PORTC | ; Initialize PORTC by | |-------|-------|-------------------------| | | | ; clearing output | | | | ; data latches | | CLRF | LATC | ; Alternate method | | | | ; to clear output | | | | ; data latches | | MOVLW | 0CFh | ; Value used to | | | | ; initialize data | | | | ; direction | | MOVWF | TRISC | ; Set RC<3:0> as inputs | | | | ; RC<5:4> as outputs | | | | ; RC<7:6> as inputs | | | | | TABLE 10-5: PORTC I/O SUMMARY | Pin | Function | TRIS<br>Setting | I/O | I/O<br>Type | Description | | | |----------------|---------------------|-----------------|-----|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--| | RC0/T10S0/ | RC0 | 0 | 0 | DIG | LATC<0> data output. | | | | T13CKI | | 1 | I | ST | PORTC<0> data input. | | | | | T10S0 | х | 0 | ANA | Timer1 oscillator output; enabled when Timer1 oscillator enabled. Disables digital I/O. | | | | | T13CKI | 1 | ı | ST | Timer1/Timer3 counter input. | | | | RC1/T1OSI/CCP2 | RC1 | 0 | 0 | DIG | LATC<1> data output. | | | | | | 1 | - 1 | ST | PORTC<1> data input. | | | | | T1OSI | x | _ | ANA | Timer1 oscillator input; enabled when Timer1 oscillator enabled. Disables digital I/O. | | | | | CCP2 <sup>(1)</sup> | 0 | 0 | DIG | CCP2 compare and PWM output; takes priority over port data. | | | | | | 1 | ı | ST | CCP2 capture input. | | | | RC2/CCP1/P1A | RC2 | 0 | 0 | DIG | LATC<2> data output. | | | | | | 1 | ı | ST | PORTC<2> data input. | | | | | CCP1 | 0 | 0 | DIG | ECCP1 compare or PWM output; takes priority over port data. | | | | | | 1 | - 1 | ST | ECCP1 capture input. | | | | | P1A <sup>(2)</sup> | 0 | 0 | DIG | ECCP1 Enhanced PWM output, channel A. May be configured for tri-state during Enhanced PWM shutdown events. Takes priority over port data. | | | | RC3/SCK/SCL | RC3 | 0 | 0 | DIG | LATC<3> data output. | | | | | | 1 | ı | ST | PORTC<3> data input. | | | | | SCK | 0 | 0 | DIG | SPI clock output (MSSP module); takes priority over port data. | | | | | | 1 | I | ST | SPI clock input (MSSP module). | | | | | SCL | 0 | 0 | DIG | I <sup>2</sup> C™ clock output (MSSP module); takes priority over port data. | | | | | | 1 | ı | I <sup>2</sup> C/SMB | I <sup>2</sup> C clock input (MSSP module); input type depends on module setting. | | | | RC4/SDI/SDA | RC4 | 0 | 0 | DIG | LATC<4> data output. | | | | | | 1 | - 1 | ST | PORTC<4> data input. | | | | | SDI | 1 | ı | ST | SPI data input (MSSP module). | | | | | SDA | 1 | 0 | DIG | I <sup>2</sup> C data output (MSSP module); takes priority over port data. | | | | | | 1 | - 1 | I <sup>2</sup> C/SMB | I <sup>2</sup> C data input (MSSP module); input type depends on module setting. | | | | RC5/SDO | RC5 | 0 | 0 | DIG | LATC<5> data output. | | | | | | 1 | | ST | PORTC<5> data input. | | | | | SDO | 0 | 0 | DIG | SPI data output (MSSP module); takes priority over port data. | | | | RC6/TX/CK | RC6 | 0 | 0 | DIG | LATC<6> data output. | | | | | | 1 | | ST | PORTC<6> data input. | | | | | TX | 1 | 0 | DIG | Asynchronous serial transmit data output (EUSART module); takes priority over port data. User must configure as output. | | | | | CK | 1 | 0 | DIG | Synchronous serial clock output (EUSART module); takes priority over port data. | | | | | | 1 | I | ST | Synchronous serial clock input (EUSART module). | | | | RC7/RX/DT | RC7 | 0 | 0 | DIG | LATC<7> data output. | | | | | | 1 | I | ST | PORTC<7> data input. | | | | | RX | 1 | I | ST | Asynchronous serial receive data input (EUSART module). | | | | ŀ | DT | 1 | 0 | DIG | Synchronous serial data output (EUSART module); takes priority over port data. | | | | | | 1 | I | ST | Synchronous serial data input (EUSART module). User must configure as an input. | | | **Legend:** DIG = Digital level output; TTL = TTL input buffer; ST = Schmitt Trigger input buffer; ANA = Analog level input/output; I<sup>2</sup>C/SMB = I<sup>2</sup>C/SMBus input buffer; x = Don't care (TRIS bit does not affect port direction or is overridden for this option). Note 1: Default assignment for CCP2 when the CCP2MX Configuration bit is set. Alternate assignment is RB3. 2: Enhanced PWM output is available only on PIC18F4520 devices. #### TABLE 10-8: SUMMARY OF REGISTERS ASSOCIATED WITH PORTD | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset<br>Values<br>on page | | |----------------------|----------------------------------------------------------|---------------------|----------|---------|--------|--------|--------|--------|----------------------------|--| | PORTD | RD7 | RD6 | RD5 | RD4 | RD3 | RD2 | RD1 | RD0 | 52 | | | LATD | PORTD Data Latch Register (Read and Write to Data Latch) | | | | | | | | | | | TRISD | PORTD Da | ta Direction | Register | | | | | | 52 | | | TRISE <sup>(1)</sup> | IBF | OBF | IBOV | PSPMODE | _ | TRISE2 | TRISE1 | TRISE0 | 52 | | | CCP1CON | P1M1 <sup>(1)</sup> | P1M0 <sup>(1)</sup> | DC1B1 | DC1B0 | CCP1M3 | CCP1M2 | CCP1M1 | CCP1M0 | 51 | | **Legend:** — = unimplemented, read as '0'. Shaded cells are not used by PORTD. Note 1: These registers and/or bits are unimplemented on 28-oin devices. TABLE 10-9: PORTE I/O SUMMARY | Pin | Function | TRIS<br>Setting | 1/0 | I/O<br>Type | Description | |-----------------------------|----------|-----------------|-----------------------------------------------|-------------|-------------------------------------------------------------------------------------------------------| | RE0/RD/AN5 | RE0 | 0 | 0 | DIG | LATE<0> data output; not affected by analog input. | | | | 1 | 1 I ST PORTE<0> data input; disabled when ana | | PORTE<0> data input; disabled when analog input enabled. | | | RD | 1 | I | TTL | PSP read enable input (PSP enabled). | | | AN5 | 1 | I | ANA | A/D input channel 5; default input configuration on POR. | | RE1/WR/AN6 | RE1 | 0 | 0 | DIG | LATE<1> data output; not affected by analog input. | | | | 1 | I | ST | PORTE<1> data input; disabled when analog input enabled. | | | WR | 1 | ı | TTL | PSP write enable input (PSP enabled). | | | AN6 | 1 | I | ANA | A/D input channel 6; default input configuration on POR. | | RE2/CS/AN7 | RE2 | 0 | 0 | DIG | LATE<2> data output; not affected by analog input. | | | | 1 | I | ST | PORTE<2> data input; disabled when analog input enabled. | | | CS | 1 | ı | TTL | PSP write enable input (PSP enabled). | | | AN7 | 1 | I | ANA | A/D input channel 7; default input configuration on POR. | | MCLR/VPP/RE3 <sup>(1)</sup> | MCLR | | 1 | ST | External Master Clear input; enabled when MCLRE Configuration bit is set. | | | VPP | _ | 1 | ANA | High-voltage detection; used for ICSP™ mode entry detection. Always available regardless of pin mode. | | | RE3 | (2) | ļ | ST | PORTE<3> data input; enabled when MCLRE Configuration bit is clear. | **Legend:** DIG = Digital level output; TTL = TTL input buffer; ST = Schmitt Trigger input buffer; ANA = Analog level input/output; x = Don't care (TRIS bit does not affect port direction or is overridden for this option). Note 1: RE3 is available on both 28-pin and 40/44-pin devices. All other PORTE pins are only implemented on 40/44-pin devices. 2: RE3 does not have a corresponding TRIS bit to control data direction. TABLE 10-10: SUMMARY OF REGISTERS ASSOCIATED WITH PORTE | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset<br>Values<br>on page | |---------------------|-------|-------|-------|---------|----------------------|-----------|-------------|--------|----------------------------| | PORTE | _ | _ | _ | _ | RE3 <sup>(1,2)</sup> | RE2 | RE1 | RE0 | 52 | | LATE <sup>(2)</sup> | _ | _ | _ | _ | _ | LATE Data | Latch Regis | ster | 52 | | TRISE | IBF | OBF | IBOV | PSPMODE | _ | TRISE2 | TRISE1 | TRISE0 | 52 | | ADCON1 | _ | _ | VCFG1 | VCFG0 | PCFG3 | PCFG2 | PCFG1 | PCFG0 | 51 | **Legend:** — = unimplemented, read as '0'. Shaded cells are not used by PORTE. Note 1: Implemented only when Master Clear functionality is disabled (MCLRE Configuration bit = 0). **2:** RE3 is the only PORTE bit implemented on both 28-pin and 40/44-pin devices. All other bits are implemented only when PORTE is implemented (i.e., 40/44-pin devices). #### REGISTER 19-3: ADCON2: A/D CONTROL REGISTER 2 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-------|-------|-------|-------|-------|-------| | ADFM | _ | ACQT2 | ACQT1 | ACQT0 | ADCS2 | ADCS1 | ADCS0 | | bit 7 | | | | | | | bit 0 | Legend:R = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 7 ADFM: A/D Result Format Select bit 1 = Right justified 0 = Left justified bit 6 Unimplemented: Read as '0' bit 5-3 ACQT<2:0>: A/D Acquisition Time Select bits 111 **= 20 T**AD 110 **= 16 T**AD 101 **= 12 T**AD 100 **= 8 T**AD 011 = 6 TAD 010 = 4 TAD 001 **= 2 T**AD 000 = 0 TAD(1) bit 2-0 ADCS<2:0>: A/D Conversion Clock Select bits 111 = FRC (clock derived from A/D RC oscillator)(1) 110 = Fosc/64 101 = Fosc/16 100 = Fosc/4 011 = FRC (clock derived from A/D RC oscillator)(1) 010 = Fosc/32 001 = Fosc/8 000 = Fosc/2 **Note 1:** If the A/D FRC clock source is selected, a delay of one Tcy (instruction cycle) is added before the A/D clock starts. This allows the SLEEP instruction to be executed before starting a conversion. #### REGISTER 23-4: CONFIG3H: CONFIGURATION REGISTER 3 HIGH (BYTE ADDRESS 300005h) | R/P-1 | U-0 | U-0 | U-0 | U-0 | R/P-0 | R/P-1 | R/P-1 | |-------|-----|-----|-----|-----|---------|--------|--------| | MCLRE | _ | _ | _ | _ | LPT1OSC | PBADEN | CCP2MX | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit P = Programmable bit U = Unimplemented bit, read as '0' -n = Value when device is unprogrammed u = Unchanged from programmed state bit 7 MCLRE: MCLR Pin Enable bit 1 = MCLR pin enabled; RE3 input pin disabled 0 = RE3 input pin enabled; MCLR disabled bit 6-3 **Unimplemented:** Read as '0' bit 2 LPT10SC: Low-Power Timer1 Oscillator Enable bit 1 = Timer1 configured for low-power operation0 = Timer1 configured for higher power operation bit 1 PBADEN: PORTB A/D Enable bit (Affects ADCON1 Reset state. ADCON1 controls PORTB<4:0> pin configuration.) 1 = PORTB<4:0> pins are configured as analog input channels on Reset 0 = PORTB<4:0> pins are configured as digital I/O on Reset bit 0 CCP2MX: CCP2 MUX bit 1 = CCP2 input/output is multiplexed with RC10 = CCP2 input/output is multiplexed with RB3 #### REGISTER 23-5: CONFIG4L: CONFIGURATION REGISTER 4 LOW (BYTE ADDRESS 300006h) | R/P-1 | R/P-0 | U-0 | U-0 | U-0 | R/P-1 | U-0 | R/P-1 | |-------|-------|-----|-----|-----|-------|-----|--------| | DEBUG | XINST | _ | _ | _ | LVP | _ | STVREN | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit P = Programmable bit U = Unimplemented bit, read as '0' -n = Value when device is unprogrammed u = Unchanged from programmed state bit 7 **DEBUG:** Background Debugger Enable bit 1 = Background debugger disabled, RB6 and RB7 configured as general purpose I/O pins 0 = Background debugger enabled, RB6 and RB7 are dedicated to In-Circuit Debug bit 6 XINST: Extended Instruction Set Enable bit 1 = Instruction set extension and Indexed Addressing mode enabled 0 = Instruction set extension and Indexed Addressing mode disabled (Legacy mode) bit 5-3 **Unimplemented:** Read as '0' bit 2 LVP: Single-Supply ICSP™ Enable bit 1 = Single-Supply ICSP enabled 0 = Single-Supply ICSP disabled bit 1 **Unimplemented:** Read as '0' bit 0 STVREN: Stack Full/Underflow Reset Enable bit 1 = Stack full/underflow will cause Reset0 = Stack full/underflow will not cause Reset #### REGISTER 23-6: CONFIG5L: CONFIGURATION REGISTER 5 LOW (BYTE ADDRESS 300008h) | U-0 | U-0 | U-0 | U-0 | R/C-1 | R/C-1 | R/C-1 | R/C-1 | |-------|-----|-----|-----|--------------------|--------------------|-------|-------| | _ | _ | _ | _ | CP3 <sup>(1)</sup> | CP2 <sup>(1)</sup> | CP1 | CP0 | | bit 7 | | | | | | | bit 0 | #### Legend: R = Readable bit C = Clearable bit U = Unimplemented bit, read as '0' -n = Value when device is unprogrammed u = Unchanged from programmed state bit 7-4 **Unimplemented:** Read as '0' bit 3 **CP3:** Code Protection bit<sup>(1)</sup> 1 = Block 3 (006000-007FFFh) not code-protected 0 = Block 3 (006000-007FFFh) code-protected bit 2 **CP2:** Code Protection bit<sup>(1)</sup> $_1$ = Block 2 (004000-005FFFh) not code-protected $_0$ = Block 2 (004000-005FFFh) code-protected bit 1 CP1: Code Protection bit 1 = Block 1 (002000-003FFFh) not code-protected 0 = Block 1 (002000-003FFFh) code-protected bit 0 **CP0:** Code Protection bit 1 = Block 0 (000800-001FFFh) not code-protected 0 = Block 0 (000800-001FFFh) code-protected Note 1: Unimplemented in PIC18F2420/4420 devices; maintain this bit set. #### REGISTER 23-7: CONFIG5H: CONFIGURATION REGISTER 5 HIGH (BYTE ADDRESS 300009h) | R/C-1 | R/C-1 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | |-------|-------|-----|-----|-----|-----|-----|-------| | CPD | СРВ | _ | _ | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | #### Legend: R = Readable bit C = Clearable bit U = Unimplemented bit, read as '0' -n = Value when device is unprogrammed u = Unchanged from programmed state bit 7 CPD: Data EEPROM Code Protection bit 1 = Data EEPROM not code-protected 0 = Data EEPROM code-protected bit 6 **CPB:** Boot Block Code Protection bit 1 = Boot block (000000-0007FFh) not code-protected 0 = Boot block (000000-0007FFh) code-protected bit 5-0 **Unimplemented:** Read as '0' | COMF | Complement f | | | | | | | | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|------|--------------------|--|--|--|--| | Syntax: | COMF f | (,d {,a}} | | | | | | | | Operands: | $0 \le f \le 255$<br>$d \in [0,1]$<br>$a \in [0,1]$ | | | | | | | | | Operation: | $(\overline{f}) \to dest$ | | | | | | | | | Status Affected: | N, Z | | | | | | | | | Encoding: | 0001 | 11da | ffff | ffff | | | | | | Description: | Description: The contents of register 'f' are complemented. If 'd' is '0', the re stored in W. If 'd' is '1', the result stored back in register 'f' (default If 'a' is '0', the Access Bank is se If 'a' is '1', the BSR is used to sel GPR bank (default). If 'a' is '0' and the extended instrement set is enabled, this instruction op in Indexed Literal Offset Address mode whenever f ≤ 95 (5Fh). Se Section 24.2.3 "Byte-Oriented Bit-Oriented Instructions in Ind Literal Offset Mode" for details. | | | | | | | | | Words: | 1 | 1 | | | | | | | | Cycles: | 1 | 1 | | | | | | | | Q Cycle Activity: | | | | | | | | | | Q1 | Q2 | Q3 | | Q4 | | | | | | Decode | Read register 'f' | Proce<br>Data | | Vrite to stination | | | | | | Example: | | OMF | REG, | Ο, | 0 | |----------------------|-------------|------|------|----|---| | Before Instru<br>RFG | iction<br>= | 13h | | | | | After Instruct | | 1311 | | | | | REG | = | 13h | | | | | W | = | ECh | | | | | CPFS | SEQ | Compare | f with V | V, Sk | ip if | f = W | | | |--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|----------------|--|--| | Synta | x: | CPFSEQ | f {,a} | | | | | | | Opera | ands: | $0 \le f \le 255$ | | | | | | | | | | $a \in [0,1]$ | | | | | | | | Opera | ation: | (f) – (W),<br>skip if (f) = (W)<br>(unsigned comparison) | | | | | | | | Status | Affected: | None | | | | | | | | Encod | ding: | 0110 | 001a | fff | f | ffff | | | | Descri | iption: | location 'f' is performing If 'f' = W, the discarded as instead, mainstruction. If 'a' is '0', the GPR bank If 'a' is '0' as set is enable in Indexed mode where Section 24 | Compares the contents of data memory location 'f' to the contents of W by performing an unsigned subtraction. If 'f' = W, then the fetched instruction is discarded and a NOP is executed instead, making this a two-cycle instruction. If 'a' is '0', the Access Bank is selected. If 'a' is '1', the BSR is used to select the GPR bank (default). If 'a' is '0' and the extended instruction set is enabled, this instruction operates in Indexed Literal Offset Addressing mode whenever f ≤ 95 (5Fh). See Section 24.2.3 "Byte-Oriented and Bit-Oriented Instructions in Indexed | | | | | | | Words | 3: | 1 | | | | | | | | Cycle | s: | | . , | | | | | | | Q Cy | cle Activity: | · | | | | | | | | · | Q1 | Q2 | Q3 | ; | | Q4 | | | | Ī | Decode | Read | Proce | ess | | No | | | | | | register 'f' | Data | а | op | eration | | | | If ski | • | | | | | _ | | | | г | Q1 | Q2 | Q3 | | | Q4 | | | | | No<br>operation | No<br>operation | No | | | No<br>peration | | | | | | register 'f' | Data | operation | | | | | |-------|-----------------|-----------------|------------|-----------|--|--|--|--| | If sk | If skip: | | | | | | | | | | Q1 | Q2 | Q3 | Q4 | | | | | | | No | No | No | No | | | | | | | operation | operation | operation | operation | | | | | | If sk | ip and followed | d by 2-word ins | struction: | | | | | | | | Q1 | Q2 | Q3 | Q4 | | | | | | | No | No | No | No | | | | | | | operation | operation | operation | operation | | | | | | | No | Nο | No | No | | | | | | | QZ | QJ | Q4 | |---------|-----------|-------------------------|--------------------------------------| | No | No | No | No | | eration | operation | operation | operation | | No | No | No | No | | eration | operation | operation | operation | | | eration | eration operation No No | eration operation operation No No No | Example: HERE CPFSEQ REG, 0 NEQUAL : EQUAL Before Instruction PC Address = HERE W REG After Instruction > If REG W; Address (EQUAL) If REG PC Address (NEQUAL) #### 25.2 MPASM Assembler The MPASM Assembler is a full-featured, universal macro assembler for all PIC MCUs. The MPASM Assembler generates relocatable object files for the MPLINK Object Linker, Intel® standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code and COFF files for debugging. The MPASM Assembler features include: - · Integration into MPLAB IDE projects - User-defined macros to streamline assembly code - Conditional assembly for multi-purpose source files - Directives that allow complete control over the assembly process # 25.3 MPLAB C18 and MPLAB C30 C Compilers The MPLAB C18 and MPLAB C30 Code Development Systems are complete ANSI C compilers for Microchip's PIC18 and PIC24 families of microcontrollers and the dsPIC30 and dsPIC33 family of digital signal controllers. These compilers provide powerful integration capabilities, superior code optimization and ease of use not found with other compilers. For easy source level debugging, the compilers provide symbol information that is optimized to the MPLAB IDE debugger. #### 25.4 MPLINK Object Linker/ MPLIB Object Librarian The MPLINK Object Linker combines relocatable objects created by the MPASM Assembler and the MPLAB C18 C Compiler. It can link relocatable objects from precompiled libraries, using directives from a linker script. The MPLIB Object Librarian manages the creation and modification of library files of precompiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications. The object linker/library features include: - Efficient linking of single libraries instead of many smaller files - Enhanced code maintainability by grouping related modules together - Flexible creation of libraries with easy module listing, replacement, deletion and extraction ## 25.5 MPLAB ASM30 Assembler, Linker and Librarian MPLAB ASM30 Assembler produces relocatable machine code from symbolic assembly language for dsPIC30F devices. MPLAB C30 C Compiler uses the assembler to produce its object file. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include: - · Support for the entire dsPIC30F instruction set - · Support for fixed-point and floating-point data - · Command line interface - · Rich directive set - · Flexible macro language - · MPLAB IDE compatibility #### 25.6 MPLAB SIM Software Simulator The MPLAB SIM Software Simulator allows code development in a PC-hosted environment by simulating the PIC MCUs and dsPIC® DSCs on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a comprehensive stimulus controller. Registers can be logged to files for further run-time analysis. The trace buffer and logic analyzer display extend the power of the simulator to record and track program execution, actions on I/O, most peripherals and internal registers. The MPLAB SIM Software Simulator fully supports symbolic debugging using the MPLAB C18 and MPLAB C30 C Compilers, and the MPASM and MPLAB ASM30 Assemblers. The software simulator offers the flexibility to develop and debug code outside of the hardware laboratory environment, making it an excellent, economical software development tool. # 26.3 DC Characteristics: PIC18F2420/2520/4420/4520 (Industrial) PIC18LF2420/2520/4420/4520 (Industrial) (Continued) | | | Standard Operating Conditions (unless otherwise stated Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for industrial | | | | | |--------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|-------|------------------------------------------------------------------| | Param<br>No. | Symbol | Characteristic | Min | Max | Units | Conditions | | | Vol | Output Low Voltage | | | | | | D080 | | I/O Ports | _ | 0.6 | V | IOL = 8.5 mA, VDD = 4.5V,<br>-40°C to +85°C | | D083 | | OSC2/CLKO<br>(RC, RCIO, EC, ECIO modes) | _ | 0.6 | V | IOL = 1.6 mA, VDD = 4.5V,<br>-40°C to +85°C | | | Vон | Output High Voltage <sup>(3)</sup> | | | | | | D090 | | I/O Ports | VDD - 0.7 | _ | V | IOH = -3.0 mA, VDD = 4.5V,<br>-40°C to +85°C | | D092 | | OSC2/CLKO<br>(RC, RCIO, EC, ECIO modes) | VDD - 0.7 | _ | V | IOH = -1.3 mA, VDD = 4.5V,<br>-40°C to +85°C | | | | Capacitive Loading Specs on Output Pins | | | | | | D100 | COSC2 | OSC2 pin | _ | 15 | pF | In XT, HS and LP modes when external clock is used to drive OSC1 | | D101 | Сю | All I/O pins and OSC2<br>(in RC mode) | _ | 50 | pF | To meet the AC Timing Specifications | | D102 | Св | SCL, SDA | | 400 | pF | I <sup>2</sup> C™ Specification | **Note 1:** In RC oscillator configuration, the OSC1/CLKI pin is a Schmitt Trigger input. It is not recommended that the PIC<sup>®</sup> device be driven with an external clock while in RC mode. <sup>2:</sup> The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages. <sup>3:</sup> Negative current is defined as current sourced by the pin. #### FIGURE 26-22: EUSART SYNCHRONOUS RECEIVE (MASTER/SLAVE) TIMING #### TABLE 26-23: EUSART SYNCHRONOUS RECEIVE REQUIREMENTS | Param.<br>No. | Symbol | Characteristic | Min | Max | Units | Conditions | |---------------|----------|----------------------------------------------------------------|-----|-----|-------|------------| | 125 | | SYNC RCV (MASTER & SLAVE) Data Hold before CK ↓ (DT hold time) | 10 | _ | ns | | | 126 | TckL2dtl | Data Hold after CK ↓ (DT hold time) | 15 | | ns | | TABLE 26-24: A/D CONVERTER CHARACTERISTICS: PIC18F2420/2520/4420/4520 (INDUSTRIAL) PIC18LF2420/2520/4420/4520 (INDUSTRIAL) | Param<br>No. | Symbol | Charact | eristic | Min | Тур | Max | Units | Conditions | |--------------|----------------|--------------------------------------------|----------------------|------------|----------|------------------|--------------------------|-------------------------------------------------------------| | A01 | NR | Resolution | | _ | _ | 10 | bit | $\Delta VREF \ge 3.0V$ | | A03 | EIL | Integral Linearity | Error | _ | _ | <±1 | LSb | $\Delta$ VREF $\geq 3.0$ V | | A04 | EDL | Differential Linear | ity Error | _ | _ | <±1 | LSb | $\Delta$ VREF $\geq 3.0$ V | | A06 | Eoff | Offset Error | | _ | _ | <±2.0 | LSb | $\Delta VREF \ge 3.0V$ | | A07 | Egn | Gain Error | | _ | _ | <±1 | LSb | $\Delta VREF \ge 3.0V$ | | A10 | _ | Monotonicity | | Gu | aranteed | <mark>(1)</mark> | _ | Vss ≤ Vain ≤ Vref | | A20 | $\Delta V$ REF | Reference Voltage Range<br>(VREFH – VREFL) | | 1.8<br>3 | _ | | V<br>V | VDD < 3.0V<br>VDD ≥ 3.0V | | A21 | VREFH | Reference Voltage | e High | Vss | _ | VREFH | V | | | A22 | VREFL | Reference Voltage | e Low | Vss - 0.3V | _ | VDD - 3.0V | V | | | A25 | VAIN | Analog Input Volta | age | VREFL | _ | VREFH | V | | | A30 | ZAIN | Recommended In<br>Analog Voltage S | | _ | _ | 2.5 | kΩ | | | A40 | IAD | A/D Current from | PIC18FXXXX | _ | 180 | _ | μΑ | Average current during | | | | VDD | PIC18 <b>LF</b> XX20 | _ | 90 | _ | μΑ | conversion | | A50 | IREF | VREF Input Currer | nt <sup>(2)</sup> | | _ | 5<br>150 | μ <b>Α</b><br>μ <b>Α</b> | During VAIN acquisition.<br>During A/D conversion<br>cycle. | **Note 1:** The A/D conversion result never decreases with an increase in the input voltage and has no missing codes. **<sup>2:</sup>** VREFH current is from RA3/AN3/VREF+ pin or VDD, whichever is selected as the VREFH source. VREFL current is from RA2/AN2/VREF-/CVREF pin or VSS, whichever is selected as the VREFL source. | C | | External Signal | 235 | |----------------------------------------|-----|--------------------------------------|-----| | C Compilers | | Internal Signal | | | MPLAB C18 | 318 | Response Time | | | MPLAB C30 | | Comparator Specifications | | | CALL | | Comparator Voltage Reference | | | CALLW | | Accuracy and Error | | | Capture (CCP Module) | | Associated Registers | | | Associated Registers | | Configuring | 239 | | CCP Pin Configuration | | Connection Considerations | 240 | | CCPRxH:CCPRxL Registers | | Effects of a Reset | 240 | | Prescaler | | Operation During Sleep | 240 | | Software Interrupt | | Compare (CCP Module) | | | | | Associated Registers | | | Timer1/Timer3 Mode Selection | | CCPRx Register | | | Capture (ECCP Module) | | Pin Configuration | | | Capture/Compare/PWM (CCP) | 139 | Software Interrupt | | | Capture Mode. See Capture. | | Special Event Trigger | | | CCP Mode and Timer Resources | | Timer1/Timer3 Mode Selection | | | CCPRxH Register | | Compare (ECCP Module) | | | CCPRxL Register | 140 | Special Event Trigger | | | Compare Mode. See Compare. | | Computed GOTO | | | Interaction of Two CCP Modules | | Configuration Bits | | | Module Configuration | | Configuration Register Protection | | | Clock Sources | | Context Saving During Interrupts | | | Selecting the 31 kHz Source | | CPFSEQ | | | Selection Using OSCCON Register | 29 | CPFSGT | | | CLRF | 283 | CPFSLT | | | CLRWDT | 283 | Crystal Oscillator/Ceramic Resonator | | | Code Examples | | | | | 16 x 16 Signed Multiply Routine | 90 | Customer Change Notification Service | | | 16 x 16 Unsigned Multiply Routine | 90 | Customer Notification Service | | | 8 x 8 Signed Multiply Routine | 89 | Customer Support | 407 | | 8 x 8 Unsigned Multiply Routine | 89 | D | | | Changing Between Capture Prescalers | 141 | Data Addressing Mades | 60 | | Computed GOTO Using an Offset Value | 56 | Data Addressing Modes | 00 | | Data EEPROM Read | 85 | Comparing Addressing Modes with the | 74 | | Data EEPROM Refresh Routine | 86 | Extended Instruction Set Enabled | | | Data EEPROM Write | 85 | Direct | | | Erasing a Flash Program Memory Row | 78 | Indexed Literal Offset | | | Fast Register Stack | | Instructions Affected | | | How to Clear RAM (Bank 1) Using | | Indirect | | | Indirect Addressing | 68 | Inherent and Literal | 68 | | Implementing a Real-Time Clock Using | | Data EEPROM | | | a Timer1 Interrupt Service | 131 | Code Protection | | | Initializing PORTA | | Data EEPROM Memory | | | Initializing PORTB | | Associated Registers | | | Initializing PORTC | | EEADR Register | | | Initializing PORTD | | EECON1 and EECON2 Registers | | | Initializing PORTE | | Operation During Code-Protect | | | Loading the SSPBUF (SSPSR) Register | | Protection Against Spurious Write | | | Reading a Flash Program Memory Word | | Reading | | | Saving STATUS, WREG and BSR | | Using | | | Registers in RAM | 103 | Write Verify | | | Writing to Flash Program Memory | | Writing | 85 | | Code Protection | | Data Memory | 59 | | COMF | | Access Bank | 62 | | Comparator | | and the Extended Instruction Set | | | Analog Input Connection Considerations | | Bank Select Register (BSR) | 59 | | | | General Purpose Registers | | | Associated Registers | | Map for PIC18F2420/4420 | 60 | | Configuration | | Map for PIC18F2520/4520 | | | Effects of a Reset | | Special Function Registers | | | Interrupts | | DAW | | | Operation | | DC and AC Characteristics | | | Operation During Sleep | | Graphs and Tables | 361 | | Outputs | 235 | | | | W | | |----------------------------|--------------------| | Watchdog Timer (WDT) | 249, 258 | | Associated Registers | 259 | | Control Register | 258 | | During Oscillator Failure | 261 | | Programming Considerations | 258 | | WCOL | 189, 190, 191, 194 | | WCOL Status Flag | 189, 190, 191, 194 | | WWW Address | 407 | | WWW, On-Line Support | 6 | | | | | X | | |-------|----| | XORLW | 30 | | XORWF | 30 |