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 | Obsolete | | Core Processor | PIC | | Core Size | 8-Bit | | Speed | 40MHz | | Connectivity | I <sup>2</sup> C, SPI, UART/USART | | • | | | Peripherals | Brown-out Detect/Reset, LVD, Power Control PWM, QEI, POR, PWM, WDT | | Number of I/O | 36 | | Program Memory Size | 16KB (8K x 16) | | Program Memory Type | FLASH | | EEPROM Size | 256 x 8 | | RAM Size | 768 x 8 | | Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V | | Data Converters | A/D 9x10b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 44-TQFP | | Supplier Device Package | 44-TQFP (10x10) | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf4431t-i-pt | #### 6.5 Data Memory Organization The data memory in PIC18 devices is implemented as static RAM. Each register in the data memory has a 12-bit address, allowing up to 4,096 bytes of data memory. The memory space is divided into as many as 16 banks that contain 256 bytes each. PIC18F2331/2431/4331/4431 devices implement all 16 banks. Figure 6-6 shows the data memory organization for the PIC18F2331/2431/4331/4431 devices. The data memory contains Special Function Registers (SFRs) and General Purpose Registers (GPRs). The SFRs are used for control and status of the controller and peripheral functions, while GPRs are used for data storage and scratchpad operations in the user's application. Any read of an unimplemented location will read as '0's. The instruction set and architecture allow operations across all banks. The entire data memory may be accessed by Direct, Indirect or Indexed Addressing modes. Addressing modes are discussed later in this subsection. To ensure that commonly used registers (SFRs and select GPRs) can be accessed in a single cycle, PIC18 devices implement an Access Bank. This is a 256-byte memory space that provides fast access to SFRs and the lower portion of GPR Bank 0 without using the BSR. **Section 6.5.2 "Access Bank"** provides a detailed description of the Access RAM. FIGURE 6-6: DATA MEMORY MAP FOR PIC18F2331/2431/4331/4431 DEVICES #### 6.5.4 SPECIAL FUNCTION REGISTERS The Special Function Registers (SFRs) are registers used by the CPU and peripheral modules for controlling the desired operation of the device. These registers are implemented as static RAM. A list of these registers is given in Table 6-1 and Table 6-2. The SFRs can be classified into two sets: those associated with the "core" function and those related to the peripheral functions. Those registers related to the "core" are described in this section, while those related to the operation of the peripheral features are described in the section of that peripheral feature. The SFRs are typically distributed among the peripherals whose functions they control. The unused SFR locations will be unimplemented and read as '0's. TABLE 6-1: SPECIAL FUNCTION REGISTER MAP FOR PIC18F2331/2431/4331/4431 DEVICES | Address | Name | Address | Name | Address | Name | Address | Name | Address | Name | |---------|-------------------------|---------|-------------------------|---------|---------|---------|----------------------|---------|----------------------| | FFFh | TOSU | FDFh | INDF2 <sup>(1)</sup> | FBFh | CCPR1H | F9Fh | IPR1 | F7Fh | PTCON0 | | FFEh | TOSH | FDEh | POSTINC2 <sup>(1)</sup> | FBEh | CCPR1L | F9Eh | PIR1 | F7Eh | PTCON1 | | FFDh | TOSL | FDDh | POSTDEC2 <sup>(1)</sup> | FBDh | CCP1CON | F9Dh | PIE1 | F7Dh | PTMRL | | FFCh | STKPTR | FDCh | PREINC2 <sup>(1)</sup> | FBCh | CCPR2H | F9Ch | (2) | F7Ch | PTMRH | | FFBh | PCLATU | FDBh | PLUSW2 <sup>(1)</sup> | FBBh | CCPR2L | F9Bh | OSCTUNE | F7Bh | PTPERL | | FFAh | PCLATH | FDAh | FSR2H | FBAh | CCP2CON | F9Ah | ADCON3 | F7Ah | PTPERH | | FF9h | PCL | FD9h | FSR2L | FB9h | ANSEL1 | F99h | ADCHS | F79h | PDC0L | | FF8h | TBLPTRU | FD8h | STATUS | FB8h | ANSEL0 | F98h | (2) | F78h | PDC0H | | FF7h | TBLPTRH | FD7h | TMR0H | FB7h | T5CON | F97h | (2) | F77h | PDC1L | | FF6h | TBLPTRL | FD6h | TMR0L | FB6h | QEICON | F96h | TRISE <sup>(3)</sup> | F76h | PDC1H | | FF5h | TABLAT | FD5h | T0CON | FB5h | (2) | F95h | TRISD(3) | F75h | PDC2L | | FF4h | PRODH | FD4h | (2) | FB4h | (2) | F94h | TRISC | F74h | PDC2H | | FF3h | PRODL | FD3h | OSCCON | FB3h | (2) | F93h | TRISB | F73h | PDC3L <sup>(3)</sup> | | FF2h | INTCON | FD2h | LVDCON | FB2h | (2) | F92h | TRISA | F72h | PDC3H <sup>(3)</sup> | | FF1h | INTCON2 | FD1h | WDTCON | FB1h | (2) | F91h | PR5H | F71h | SEVTCMPL | | FF0h | INTCON3 | FD0h | RCON | FB0h | SPBRGH | F90h | PR5L | F70h | SEVTCMPH | | FEFh | INDF0 <sup>(1)</sup> | FCFh | TMR1H | FAFh | SPBRG | F8Fh | (2) | F6Fh | PWMCON0 | | FEEh | POSTINCO <sup>(1)</sup> | FCEh | TMR1L | FAEh | RCREG | F8Eh | (2) | F6Eh | PWMCON1 | | FEDh | POSTDEC0 <sup>(1)</sup> | FCDh | T1CON | FADh | TXREG | F8Dh | LATE <sup>(3)</sup> | F6Dh | DTCON | | FECh | PREINCO <sup>(1)</sup> | FCCh | TMR2 | FACh | TXSTA | F8Ch | LATD <sup>(3)</sup> | F6Ch | FLTCONFIG | | FEBh | PLUSW0 <sup>(1)</sup> | FCBh | PR2 | FABh | RCSTA | F8Bh | LATC | F6Bh | OVDCOND | | FEAh | FSR0H | FCAh | T2CON | FAAh | BAUDCON | F8Ah | LATB | F6Ah | OVDCONS | | FE9h | FSR0L | FC9h | SSPBUF | FA9h | EEADR | F89h | LATA | F69h | CAP1BUFH | | FE8h | WREG | FC8h | SSPADD | FA8h | EEDATA | F88h | TMR5H | F68h | CAP1BUFL | | FE7h | INDF1 <sup>(1)</sup> | FC7h | SSPSTAT | FA7h | EECON2 | F87h | TMR5L | F67h | CAP2BUFH | | FE6h | POSTINC1 <sup>(1)</sup> | FC6h | SSPCON | FA6h | EECON1 | F86h | (2) | F66h | CAP2BUFL | | FE5h | POSTDEC1 <sup>(1)</sup> | FC5h | (2) | FA5h | IPR3 | F85h | (2) | F65h | CAP3BUFH | | FE4h | PREINC1 <sup>(1)</sup> | FC4h | ADRESH | FA4h | PIR3 | F84h | PORTE | F64h | CAP3BUFL | | FE3h | PLUSW1 <sup>(1)</sup> | FC3h | ADRESL | FA3h | PIE3 | F83h | PORTD <sup>(3)</sup> | F63h | CAP1CON | | FE2h | FSR1H | FC2h | ADCON0 | FA2h | IPR2 | F82h | PORTC | F62h | CAP2CON | | FE1h | FSR1L | FC1h | ADCON1 | FA1h | PIR2 | F81h | PORTB | F61h | CAP3CON | | FE0h | BSR | FC0h | ADCON2 | FA0h | PIE2 | F80h | PORTA | F60h | DFLTCON | Note 1: This is not a physical register. - 2: Unimplemented registers are read as '0'. - 3: This register is not available on 28-pin devices. #### 10.2 PIR Registers The PIR registers contain the individual flag bits for the peripheral interrupts. Due to the number of peripheral interrupt sources, there are three Peripheral Interrupt Request (Flag) Registers (PIR1, PIR2 and PIR3). - Note 1: Interrupt flag bits are set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the Global Interrupt Enable bit, GIE (INTCON<7>). - 2: User software should ensure the appropriate interrupt flag bits are cleared prior to enabling an interrupt and after servicing that interrupt. #### REGISTER 10-4: PIR1: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 1 | U-0 | R/W-0 | R-0 | R-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-------|------|------|-------|--------|--------|--------| | _ | ADIF | RCIF | TXIF | SSPIF | CCP1IF | TMR2IF | TMR1IF | | bit 7 | | | | | | | bit 0 | | | _ | ~ | _ | | ᆈ | | |---|---|-----|---|---|---|--| | _ | e | O I | е | n | u | | 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 **Unimplemented:** Read as '0' bit 6 ADIF: A/D Converter Interrupt Flag bit 1 = An A/D conversion completed (must be cleared in software) 0 = The A/D conversion is not complete bit 5 RCIF: EUSART Receive Interrupt Flag bit 1 = The EUSART receive buffer, RCREG, is full (cleared when RCREG is read) 0 = The EUSART receive buffer is empty bit 4 **TXIF:** EUSART Transmit Interrupt Flag bit 1 = The EUSART transmit buffer, TXREG, is empty (cleared when TXREG is written) 0 = The EUSART transmit buffer is full bit 3 SSPIF: Synchronous Serial Port Interrupt Flag bit 1 = The transmission/reception is complete (must be cleared in software) 0 = Waiting to transmit/receive bit 2 CCP1IF: CCP1 Interrupt Flag bit #### Capture mode: 1 = A TMR1 register capture occurred (must be cleared in software) 0 = No TMR1 register capture occurred #### Compare mode: 1 = A TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred #### PWM mode: Unused in this mode. bit 1 TMR2IF: TMR2 to PR2 Match Interrupt Flag bit 1 = TMR2 to PR2 match occurred (must be cleared in software) 0 = No TMR2 to PR2 match occurred bit 0 TMR1IF: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflowed (must be cleared in software) 0 = TMR1 register did not overflow #### REGISTER 10-9: PIE3: PERIPHERAL INTERRUPT ENABLE REGISTER 3 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-----|-------|---------|---------|-------|--------| | _ | _ | _ | PTIE | IC3DRIE | IC2QEIE | IC1IE | TMR5IE | | 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-5 **Unimplemented:** Read as '0' bit 4 PTIE: PWM Time Base Interrupt Enable bit 1 = PTIF enabled0 = PTIF disabled bit 3 IC3DRIE: IC3 Interrupt Enable/Direction Change Interrupt Enable bit IC3 Enabled (CAP3CON<3:0>):1 = IC3 interrupt enabled0 = IC3 interrupt disabledQEI Enabled (QEIM<2:0>): 1 = Change of direction interrupt enabled0 = Change of direction interrupt disabled bit 2 IC2QEIE: IC2 Interrupt Flag/QEI Interrupt Flag Enable bit IC2 Enabled (CAP2CON<3:0>): 1 = IC2 interrupt enabled) 0 = IC2 interrupt disabled QEI Enabled (QEIM<2:0>): 1 = QEI interrupt enabled 0 = QEI interrupt disabled bit 1 IC1IE: IC1 Interrupt Enable bit 1 = IC1 interrupt enabled0 = IC1 interrupt disabled bit 0 **TMR5IE:** Timer5 Interrupt Enable bit 1 = Timer5 interrupt enabled0 = Timer5 interrupt disabled FIGURE 19-1: SSP BLOCK DIAGRAM (SPI MODE) To enable the serial port, SSP Enable bit, SSPEN (SSPCON<5>), must be set. To reset or reconfigure SPI mode, clear bit SSPEN, reinitialize the SSPCON register and then set bit SSPEN. This configures the SDI, SDO, SCK and SS pins as serial port pins. For the pins to behave as the serial port function, they must have their data direction bits (in the TRISC register) appropriately programmed. That is: - Serial Data Out (SDO) RC7/RX/DT/SDO or RD1/SDO - SDI must have TRISC<4> or TRISD<2> set - SDO must have TRISC<7> or TRISD<1> cleared - SCK (Master mode) must have TRISC<5> or TRISD<3> cleared - SCK (Slave mode) must have TRISC<5> or TRISD<3> set - SS must have TRISA<6> set - Note 1: When the SPI is in Slave mode, with the SS pin control enabled, (SSPCON<3:0> = 0100), the SPI module will reset if the SS pin is set to - 2: If the SPI is used in Slave mode with CKE = 1, then the SS pin control must be enabled. - 3: When the SPI is in Slave mode with \$\overline{SS}\$ pin control enabled (SSPCON<3:0> = 0100), the state of the \$\overline{SS}\$ pin can affect the state read back from the TRISC<6> bit. The peripheral OE signal from the SSP module into PORTC controls the state that is read back from the TRISC<6> bit (see Section 11.3 "PORTC, TRISC and LATC Registers" for information on PORTC). If Read-Modify-Write instructions, such as BSF, are performed on the TRISC register while the \$\overline{SS}\$ pin is high, this will cause the TRISC<6> bit to be set, thus disabling the SDO output. # 20.2 EUSART Baud Rate Generator (BRG) The BRG is a dedicated 8-bit or 16-bit generator, that supports both the Asynchronous and Synchronous modes of the EUSART. By default, the BRG operates in 8-bit mode. Setting the BRG16 bit (BAUDCON<3>) selects 16-bit mode. The SPBRGH:SPBRG register pair controls the period of a free-running timer. In Asynchronous mode, bits BRGH (TXSTA<2>) and BRG16 also control the baud rate. In Synchronous mode, bit BRGH is ignored. Table 20-1 shows the formula for computation of the baud rate for different EUSART modes, which only apply in Master mode (internally generated clock). Given the desired baud rate and Fosc, the nearest integer value for the SPBRGH:SPBRG registers can be calculated using the formulas in Table 20-1. From this, the error in baud rate can be determined. An example calculation is shown in Example 20-1. Typical baud rates and error values for the various Asynchronous modes are shown in Table 20-2. It may be advantageous to use the high baud rate (BRGH = 1), or the 16-bit BRG, to reduce the baud rate error or achieve a slow baud rate for a fast oscillator frequency. Writing a new value to the SPBRGH:SPBRG registers causes the BRG timer to be reset (or cleared). This ensures the BRG does not wait for a timer overflow before outputting the new baud rate. ## 20.2.1 POWER-MANAGED MODE OPERATION The system clock is used to generate the desired baud rate. However, when a power-managed mode is entered, the clock source may be operating at a different frequency than in PRI\_RUN mode. In Sleep mode, no clocks are present and in PRI\_IDLE, the primary clock source continues to provide clocks to the Baud Rate Generator. However, in other power-managed modes, the clock frequency will probably change. This may require the value in SPBRG to be adjusted. If the system clock is changed during an active receive operation, a receive error or data loss may result. To avoid this problem, check the status of the RCIDL bit and make sure that the receive operation is Idle before changing the system clock. #### 20.2.2 SAMPLING The data on the RC7/RX/DT/SDO pin is sampled three times by a majority detect circuit to determine if a high or a low level is present at the RX pin. TABLE 20-1: BAUD RATE FORMULAS | Configuration Bits | | its | BRG/EUSART Mode | Paud Pata Farmula | | |--------------------|-------------|------|---------------------|-------------------|--| | 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 | F000/[16 (p ± 1)] | | | 0 | 1 | 0 | 16-Bit/Asynchronous | Fosc/[16 (n + 1)] | | | 0 | 1 | 1 | 16-Bit/Asynchronous | | | | 1 | 1 0 x 1 1 x | | 8-Bit/Synchronous | Fosc/[4 (n + 1)] | | | 1 | | | 16-Bit/Synchronous | | | **Legend:** x = Don't care, n = value of SPBRGH:SPBRG register pair #### FIGURE 20-2: EUSART TRANSMIT BLOCK DIAGRAM #### FIGURE 20-3: ASYNCHRONOUS TRANSMISSION #### FIGURE 20-4: ASYNCHRONOUS TRANSMISSION (BACK TO BACK) #### 20.3.5 BREAK CHARACTER SEQUENCE The Enhanced USART module has the capability of sending the special Break character sequences that are required by the LIN/J2602 bus standard. The Break character transmit consists of a Start bit, followed by twelve '0' bits and a Stop bit. The Frame Break character is sent whenever the SENDB and TXEN bits (TXSTA<3> and TXSTA<5>) are set while the Transmit Shift register is loaded with data. Note that the value of data written to TXREG will be ignored and all '0's will be transmitted. The SENDB bit is automatically reset by hardware after the corresponding Stop bit is sent. This allows the user to preload the transmit FIFO with the next transmit byte following the Break character (typically, the Sync character in the LIN/J2602 specification). Note that the data value written to the TXREG for the Break character is ignored. The write simply serves the purpose of initiating the proper sequence. The TRMT bit indicates when the transmit operation is active or Idle, just as it does during normal transmission. See Figure 20-9 for the timing of the Break character sequence. #### 20.3.5.1 Break and Sync Transmit Sequence The following sequence will send a message frame header made up of a Break, followed by an Auto-Baud Sync byte. This sequence is typical of a LIN/J2602 bus master - 1. Configure the EUSART for the desired mode. - Set the TXEN and SENDB bits to setup the Break character. - 3. Load the TXREG with a dummy character to initiate transmission (the value is ignored). - 4. Write '55h' to TXREG to load the Sync character into the transmit FIFO buffer. - After the Break has been sent, the SENDB bit is reset by hardware. The Sync character now transmits in the preconfigured mode. When the TXREG becomes empty, as indicated by the TXIF, the next data byte can be written to TXREG. #### 20.3.6 RECEIVING A BREAK CHARACTER The Enhanced USART module can receive a Break character in two ways. The first method forces configuration of the baud rate at a frequency of 9/13 of the typical speed. This allows for the Stop bit transition to be at the correct sampling location (13 bits for Break versus Start bit and 8 data bits for typical data). The second method uses the auto-wake-up feature described in **Section 20.3.4** "**Auto-Wake-up on Sync Break Character**". By enabling this feature, the EUSART will sample the next two transitions on RX/DT, cause an RCIF interrupt and receive the next data byte followed by another interrupt. Note that following a Break character, the user will typically want to enable the Auto-Baud Rate Detect feature. For both methods, the user can set the ABD bit before placing the EUSART in its Sleep mode. #### 24.2 Instruction Set | ADD | LW | ADD Lite | ADD Literal to W | | | | | | |-------|----------------|-----------------------------------|------------------|------|---------------------------|--|--|--| | Synta | ax: | [label] Al | DDLW | k | | | | | | Oper | ands: | $0 \le k \le 255$ | i | | | | | | | Oper | ation: | $(W) + k \rightarrow$ | W | | | | | | | Statu | s Affected: | N, OV, C, [ | OC, Z | | | | | | | Enco | ding: | 0000 | 1111 | kkkk | kkkk | | | | | Desc | ription: | The conter<br>8-bit literal<br>W. | | | ed to the<br>is placed in | | | | | Word | ls: | 1 | 1 | | | | | | | Cycle | es: | 1 | 1 | | | | | | | QC | ycle Activity: | | | | | | | | | | Q1 | Q2 | Q3 | 3 | Q4 | | | | | | Decode | Read<br>literal 'k' | Proce<br>Data | | Write to<br>W | | | | Example: ADDLW 0x15 Before Instruction W = 0x10After Instruction W = 0x25 | ADD | )WF | ADD W to | f | | | |-------------------|-------------|--------------------------------------------------------------------------------|--------------------------------|---------------------------------------------|---------------------------| | Synta | ax: | [ label ] AD | DWF | f [,d [,a]] | | | Oper | ands: | $\begin{array}{l} 0 \leq f \leq 255 \\ d \in [0,1] \\ a \in [0,1] \end{array}$ | | | | | Oper | ation: | $(W) + (f) \rightarrow$ | dest | | | | Statu | s Affected: | N, OV, C, E | )C, Z | | | | Enco | ding: | 0010 | 01da | ffff | ffff | | Desc | ription: | Add W to re result is sto result is sto is '0', the A If 'a' is '1', t | ored in Wored back<br>ccess Ba | . If 'd' is '1<br>in registe<br>ank will be | ', the<br>er, 'f'. If 'a' | | Word | ls: | 1 | | | | | Cycle | es: | 1 | | | | | Q Cycle Activity: | | | | | | | | Q1 | Q2 | Q3 | 3 | Q4 | | | Decode | Read | Proce | | Vrite to | | | | register 'f' | Data | a de | stination | Example: ADDWF REG, W Before Instruction W = 0x17 REG = 0xC2 After Instruction W = 0xD9 REG = 0xC2 | RETURN | Return from Subroutine | | | | | | | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Syntax: | [label] RETURN [s] | | | | | | | | Operands: | $s \in [0,1]$ | | | | | | | | Operation: | (TOS) → PC;<br>if s = 1:<br>(WS) → W,<br>(STATUSS) → STATUS,<br>(BSRS) → BSR,<br>PCLATU, PCLATH are unchanged | | | | | | | | Status Affected: | None | | | | | | | | Encoding: | 0000 0000 0001 001s | | | | | | | | Description: | Return from subroutine. The stack is popped and the top of the stack (TOS) is loaded into the program counter. If 's'= 1, the contents of the shadow registers, WS, STATUSS and BSRS, are loaded into their corresponding registers, W, STATUS and BSR. If 's' = 0, no update of these registers occurs. | | | | | | | | Words: | 1 | | | | | | | | Cycles: | 2 | | | | | | | | Q1 | Q2 | Q3 | Q4 | |-----------|-----------|-----------|------------| | Decode | No | Process | POP PC | | | operation | Data | from stack | | No | No | No | No | | operation | operation | operation | operation | Example: RETURN After Interrupt PC = TOS Q Cycle Activity: | RLC | LCF Rotate Left f through Carry | | | | | | | | |-------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------------------|--|--|--| | Synta | ax: | [ label ] | RLCF | f [,d [,a]] | | | | | | Oper | ands: | $0 \le f \le 255$<br>$d \in [0,1]$<br>$a \in [0,1]$ | 5 | | | | | | | Oper | ation: | (f<7>) → ( | (f <n>) → dest<n +="" 1="">,<br/>(f&lt;7&gt;) → C,<br/>(C) → dest&lt;0&gt;</n></n> | | | | | | | Statu | s Affected: | C, N, Z | | | | | | | | Enco | ding: | 0011 | 01da | ffff | ffff | | | | | | ription: | The conternous one bit to the state of the content | the left thr<br>the result<br>result is st<br>' is '0', tho<br>d, overrid<br>hen the ba | ough the is placed tored back e Access ing the Bank will be | Carry flag.<br>in W. If 'd'<br>c in regis-<br>Bank will<br>SR value. | | | | | Word | ls: | 1 | | | | | | | | Cycle | es: | 1 | | | | | | | | QC | ycle Activity: | | | | | | | | | | Q1 | Q2 | Q3 | | Q4 | | | | | | Decode | Read<br>register 'f' | Proces<br>Data | _ | rite to stination | | | | | | | | | | | | | | $\underline{\text{Example:}} \hspace{1cm} \texttt{RLCF} \hspace{1cm} \texttt{REG, W}$ Before Instruction REG = 1110 0110 C = 0 After Instruction REG = 1110 0110 W = 1100 1100 C = 1 | RLN | ICF | Rotate Left f (No Carry) | | | | | | | |--------------|----------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------|--|--|--| | Synta | ax: | [ label ] | RLNCF | f [,d [,a]] | | | | | | Oper | ands: | $0 \le f \le 255$<br>d $\in [0,1]$<br>a $\in [0,1]$ | 5 | | | | | | | Oper | ration: | $ (f < n >) \rightarrow 0 $ $ (f < 7 >) \rightarrow 0 $ | | >, | | | | | | Statu | s Affected: | N, Z | | | | | | | | Enco | oding: | 0100 | 01da | ffff | ffff | | | | | Description: | | The conte one bit to to placed in N stored back Access Baing the BS bank will be value. | he left. If 'c<br>W. If 'd' is '<br>k in registe<br>ank will be<br>R value. If<br>be selected | d' is '0', th<br>1', the re-<br>er, 'f'. If 'a'<br>selected,<br>i 'a' is '1', | e result is<br>sult is<br>is '0', the<br>overrid-<br>then the | | | | | Word | ds: | 1 | | | | | | | | Cycle | es: | 1 | | | | | | | | QC | ycle Activity: | | | | | | | | | | Q1 | Q2 | Q3 | | Q4 | | | | | | Decode | Read | Process | s W | rite to | | | | register 'f' Example: REG REG register 'f' RLNCF Example: RRCF REG, W Before Instruction 1010 1011 Before Instruction **REG** 1110 0110 After Instruction 0 0101 0111 After Instruction REG 1110 0110 destination Data **RRCF** Syntax: Operands: Operation: Encoding: Words: Cycles: Q Cycle Activity: Q1 Decode W С Description: Status Affected: Rotate Right f through Carry [label] RRCF f [,d [,a]] $(f < n >) \rightarrow dest < n - 1 >$ 00da 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 W. If 'd' is '1', the result is placed back in register, 'f'. If 'a' is '0', the Access Bank will be selected, overriding the BSR value. If 'a' is '1', then the bank will be selected as per the BSR value. register f Q3 **Process** Data ffff ffff Q4 Write to destination $0 \leq f \leq 255$ $d \in \left[0,1\right]$ $a \in \left[0,1\right]$ $(f<0>) \rightarrow C$ , $(C) \rightarrow dest<7>$ C, N, Z 0011 С 1 1 Q2 Read 0111 0011 FIGURE 26-6: CLKO AND I/O TIMING TABLE 26-7: CLKO AND I/O TIMING REQUIREMENTS | Param<br>No. | Symbol | Characteri | stic | Min | Тур† | Max | Units | Conditions | |--------------|----------|------------------------------------------------|-------------|---------------|------|--------------|-------|------------| | 10 | TosH2ckL | OSC1 ↑ to CLKO ↓ | | _ | 75 | 200 | ns | (Note 1) | | 11 | TosH2ckH | OSC1 ↑ to CLKO ↑ | | _ | 75 | 200 | ns | (Note 1) | | 12 | TckR | CLKO Rise Time | | _ | 35 | 100 | ns | (Note 1) | | 13 | TckF | CLKO Fall Time | | _ | 35 | 100 | ns | (Note 1) | | 14 | TckL2ioV | CLKO ↓ to Port Out Valid | | _ | _ | 0.5 Tcy + 20 | ns | (Note 1) | | 15 | TioV2ckH | Port In Valid before CLKO ↑ | | 0.25 Tcy + 25 | | _ | ns | (Note 1) | | 16 | TckH2iol | Port In Hold after CLKO ↑ | | 0 | | _ | ns | (Note 1) | | 17 | TosH2ioV | OSC1 ↑ (Q1 cycle) to Port Out Valid | | _ | 50 | 150 | ns | | | 18 | TosH2iol | OSC1 ↑ (Q2 cycle) to | PIC18FXX31 | 100 | | _ | ns | | | 18A | | Port Input Invalid (I/O in hold time) | PIC18LFXX31 | 200 | _ | _ | ns | | | 19 | TioV2osH | Port Input Valid to OSC1 ↑ (I/O in setup time) | | 0 | _ | _ | ns | | | 20 | TioR | Port Output Rise Time | PIC18FXX31 | _ | 10 | 25 | ns | | | 20A | | | PIC18LFXX31 | _ | _ | 60 | ns | | | 21 | TioF | Port Output Fall Time | PIC18FXX31 | _ | 10 | 25 | ns | | | 21A | | | PIC18LFXX31 | _ | _ | 60 | ns | | | 22† | TINP | INTx Pin High or Low Time | | Tcy | _ | _ | ns | | | 23† | TRBP | RB<7:4> Change INTx High or Low Time | | Tcy | _ | _ | ns | | <sup>†</sup> These parameters are asynchronous events not related to any internal clock edges. Note 1: Measurements are taken in RC mode, where CLKO output is 4 x Tosc. TABLE 26-11: EXAMPLE SPI MODE REQUIREMENTS (MASTER MODE, CKE = 0) | Param<br>No. | Symbol | Characterist | Min | Max | Units | Conditions | | |--------------|-----------------------|-----------------------------------------------------------|-------------|--------------|-------|------------|--| | 73 | TdiV2scH,<br>TdiV2scL | Setup Time of SDI Data Input to SCK Edge | | 20 | | ns | | | 73A | Tb2b | Last Clock Edge of Byte 1 to the 1st Clock Edge of Byte 2 | | 1.5 Tcy + 40 | _ | ns | | | 74 | TscH2diL,<br>TscL2diL | Hold Time of SDI Data Input to SCK Edge | | 40 | _ | ns | | | 75 | TdoR | SDO Data Output Rise Time | PIC18FXX31 | _ | 25 | ns | | | | | | PIC18LFXX31 | _ | 45 | ns | | | 76 | TdoF | SDO Data Output Fall Time | | _ | 25 | ns | | | 78 | TscR | SCK Output Rise Time | PIC18FXX31 | _ | 25 | ns | | | | | | PIC18LFXX31 | _ | 45 | ns | | | 79 | TscF | SCK Output Fall Time | | _ | 25 | ns | | | 80 | TscH2doV,<br>TscL2doV | • | PIC18FXX31 | _ | 50 | ns | | | | | | PIC18LFXX31 | _ | 100 | ns | | # 28-Lead Plastic Quad Flat, No Lead Package (ML) – 6x6 mm Body [QFN] with 0.55 mm Contact Length **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Units **MILLIMETERS** NOM MIN MAX **Dimension Limits** Contact Pitch 0.65 BSC Ε Optional Center Pad Width W2 4.25 Optional Center Pad Length T2 4.25 Contact Pad Spacing C1 5.70 Contact Pad Spacing C2 5.70 Contact Pad Width (X28) X1 0.37 Y1 G 0.20 #### Notes: 1. Dimensioning and tolerancing per ASME Y14.5M Contact Pad Length (X28) Distance Between Pads BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing No. C04-2105A 1.00 | CCP2 | 145 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CCPR2H Register | 145 | | CCPR2L Register | 145 | | Compare Mode. See Compare. | | | Timer Resources | 145 | | CKE Bit | | | CKP Bit | | | Clock Sources | | | Effects of Power-Managed Modes | | | Selection Using OSCCON Register | | | Clocking Scheme/Instruction Cycle | | | CLRF | | | CLRWDT | 299 | | Code Examples | | | Changing Between Capture Prescalers | | | Computed GOTO Using an Offset Value | | | Data EEPROM Read | 81 | | Data EEPROM Refresh Routine | | | Data EEPROM Write | | | Erasing a Flash Program Memory Row | | | Fast Register Stack | 64 | | How to Clear RAM (Bank 1) Using | 7.5 | | Indirect Addressing | /5 | | Implementing a Real-Time Clock Using a | 125 | | Timer1 Interrupt Service | | | Initializing PORTA | | | Initializing PORTBInitializing PORTC | | | Initializing PORTO | | | Initializing PORTE | | | | | | Doading a Flach Drogram Momory Word | 90 | | Reading a Flash Program Memory Word | 89 | | Saving STATUS, WREG and BSR | | | Saving STATUS, WREG and BSR Registers in RAM | 112 | | Saving STATUS, WREG and BSR Registers in RAM Writing to Flash Program Memory | 112<br>93–94 | | Saving STATUS, WREG and BSR Registers in RAM Writing to Flash Program Memory 16 x 16 Signed Multiply Routine | 112<br>93–94<br>96 | | Saving STATUS, WREG and BSR Registers in RAM Writing to Flash Program Memory 16 x 16 Signed Multiply Routine 16 x 16 Unsigned Multiply Routine | 112<br>93–94<br>96 | | Saving STATUS, WREG and BSR Registers in RAM Writing to Flash Program Memory 16 x 16 Signed Multiply Routine 16 x 16 Unsigned Multiply Routine 8 x 8 Signed Multiply Routine | 112<br>93–94<br>96<br>96 | | Saving STATUS, WREG and BSR Registers in RAM Writing to Flash Program Memory 16 x 16 Signed Multiply Routine 16 x 16 Unsigned Multiply Routine 8 x 8 Signed Multiply Routine 8 x 8 Unsigned Multiply Routine | 112<br>93–94<br>96<br>95 | | Saving STATUS, WREG and BSR Registers in RAM Writing to Flash Program Memory | 112<br>93–94<br>96<br>95<br>95<br>95 | | Saving STATUS, WREG and BSR Registers in RAM Writing to Flash Program Memory | 112<br>93–94<br>96<br>95<br>95<br>95<br>95<br>263, 279 | | Saving STATUS, WREG and BSR Registers in RAM Writing to Flash Program Memory | 112<br>93–94<br>96<br>96<br>95<br>95<br>263, 279<br>279 | | Saving STATUS, WREG and BSR Registers in RAM Writing to Flash Program Memory | 112<br>93–94<br>96<br>96<br>95<br>95<br>263, 279<br>279<br>282 | | Saving STATUS, WREG and BSR Registers in RAM Writing to Flash Program Memory | 112<br>93–94<br>96<br>96<br>95<br>95<br>263, 279<br>279<br>282<br>300 | | Saving STATUS, WREG and BSR Registers in RAM Writing to Flash Program Memory | 112<br>93–94<br>96<br>96<br>95<br>95<br>263, 279<br>279<br>282<br>300 | | Saving STATUS, WREG and BSR Registers in RAM | 112<br>93–94<br>96<br>96<br>95<br>95<br>263, 279<br>279<br>282<br>280<br>300<br>147 | | Saving STATUS, WREG and BSR Registers in RAM | 112<br>93–94<br>96<br>96<br>95<br>95<br>263, 279<br>279<br>282<br>300<br>147<br>148 | | Saving STATUS, WREG and BSR Registers in RAM | 112<br>93–94<br>96<br>96<br>95<br>95<br>263, 279<br>279<br>282<br>300<br>147<br>148 | | Saving STATUS, WREG and BSR Registers in RAM | 112<br>93–94<br>96<br>96<br>95<br>95<br>263, 279<br>279<br>282<br>300<br>147<br>148<br>147 | | Saving STATUS, WREG and BSR Registers in RAM | 112<br>93–94<br>96<br>96<br>95<br>95<br>263, 279<br>282<br>280<br>300<br>147<br>147<br>147 | | Saving STATUS, WREG and BSR Registers in RAM | 112<br>93–94<br>96<br>96<br>95<br>95<br>263, 279<br>282<br>280<br>300<br>147<br>147<br>147 | | Saving STATUS, WREG and BSR Registers in RAM | 112<br>93–94<br>96<br>96<br>95<br>95<br>263, 279<br>282<br>280<br>300<br>147<br>147<br>147<br>147 | | Saving STATUS, WREG and BSR Registers in RAM | 11293–94969695263, 279280300147147147147147147147147147147 | | Saving STATUS, WREG and BSR Registers in RAM | 11293–94969695263, 279280300147147147147147147147147147147 | | Saving STATUS, WREG and BSR Registers in RAM | 11293–94969695263, 279280300147147147147147147147147147147147147147 | | Saving STATUS, WREG and BSR Registers in RAM | 11293–94969695263, 279280300147147147147147147147147147147147147147137147147147147147 | | Saving STATUS, WREG and BSR Registers in RAM | 112<br>93–94<br>96<br>96<br>95<br>263, 279<br>282<br>300<br>147<br>147<br>147<br>147<br>147<br>147<br>147<br>147<br>147<br>147<br>147<br>263<br>282<br>300<br>300 | | Saving STATUS, WREG and BSR Registers in RAM | 112<br>93–94<br>96<br>96<br>95<br>263, 279<br>282<br>300<br>147<br>147<br>147<br>147<br>147<br>147<br>147<br>147<br>147<br>147<br>147<br>263<br>282<br>300<br>301 | | Saving STATUS, WREG and BSR Registers in RAM | 11293–9496969595263, 27928030014714714714714714714714714714714736328237630030130129 | | Saving STATUS, WREG and BSR Registers in RAM | 11293–9496969595263, 27928030014714714714714714726328237630030130129387 | | D | | |------------------------------------------------------------------------------|------| | D/A Bit | 206 | | Data Addressing Modes | | | Direct | | | Indirect | | | Inherent and Literal | | | Data EEPROM Memory | 79 | | Associated Registers | 83 | | EEADR Register | | | EECON1 and EECON2 Registers | 79 | | Operation During Code-Protect | 82 | | Protection Against Spurious Write | | | Reading | | | Using | 82 | | Write Verify | | | Writing | | | Data Memory | | | Access Bank | | | Bank Select Register (BSR) | | | General Purpose Register (GPR) File | 68 | | Map for PIC18F2331/2431/4331/4431 | | | Special Function Registers (SFRs) | | | DAW | | | DC Characteristics | | | Power-Down and Supply Current | | | Supply Voltage | | | DCFSNZ | | | DECF | | | DECFSZ | | | Development Support | | | Device Differences | | | Device Overview | | | Features (table) | | | New Core Features | | | Other Special Features Device Reset Timers | 14 | | Oscillator Start-up Timer (OST) | E/ | | PLL Lock Time-out | | | Power-up Timer (PWRT) | | | Time-out Sequence | | | Direct Addressing | | | E | / ( | | <del>-</del> | | | Electrical Characteristics | 329 | | Enhanced Universal Synchronous Asynchronous | 04. | | Receiver Transmitter (EUSART) | 21 | | Equations A/D A activisition Time | 0.47 | | A/D Acquisition Time | | | Conversion Time for Multi-Channel Modes | | | Minimum A/D Holding Capacitor Charging Time PWM Period for Free-Running Mode | | | PWM Period for Up/Down Count Mode | | | PWM Resolution | | | 16 x 16 Signed Multiplication Algorithm | | | 16 x 16 Unsigned Multiplication Algorithm | | | Errata | | | | | | MOVLW | 300 | I <sup>2</sup> C Mode | | |------------------------------------------------------------------------|------|----------------------------------------------|-----| | MOVWF | | Operation | 215 | | MULLW | | I <sup>2</sup> C Mode (SSP) | 212 | | MULWF | | Addressing | 215 | | NEGF | | Associated Registers | | | NOP | | Master Mode | | | POP | | Mode Selection | | | | | Multi-Master Mode | | | PUSH | | | | | RCALL | | Operation | | | Read-Modify-Write Operations | | Reception | | | RESET | | Slave Mode | | | RETFIE | | SCL and SDA Pins | | | RETLW | | Transmission | 215 | | RETURN | | L | | | RLCF | | | 00- | | RLNCF | | LFSR | | | RRCF | | Low-Voltage Detect | | | RRNCF | | Applications | | | SETF | 317 | Associated Registers | | | SLEEP | 318 | Characteristics | | | SUBFWB | 318 | Current Consumption | | | SUBLW | 319 | Effects of a Reset | | | SUBWF | 319 | Operation | 259 | | SUBWFB | 320 | Operation During Sleep | 261 | | Summary | 283 | Setup | 259 | | Summary Table | | Start-up Time | 260 | | SWAPF | | LVD. See Low-Voltage Detect. | | | TBLRD | | | | | TBLWT | | M | | | TSTFSZ | | Master Clear (MCLR) | 49 | | XORLW | | Memory Organization | 61 | | XORWF | | Data Memory | | | NTCON Register | 524 | Program Memory | | | RBIF Bit | 116 | Memory Programming Requirements | | | NTCON Registers | | MFM | | | nter-Integrated Circuit (I <sup>2</sup> C). See I <sup>2</sup> C Mode. | 99 | Input Capture | | | | 20 | Edge Capture Mode | 156 | | nternal Oscillator Block | | Entering and Timing | | | Adjustment | | IC Interrupts | 150 | | INTIO Modes | | Pulse-Width Measurement Mode | | | INTRC Output Frequency | | Special Event Trigger (CAP1 Only) | | | OSCTUNE Register | 32 | State Change | | | nternal RC Oscillator | | | | | Use with WDT | | Time Base Reset Summary | | | nternet Address | | Timer5 Reset | | | nterrupt Sources | | Input Capture (IC) Submode | 153 | | Capture Complete (CCP) | 146 | Input Capture Mode | | | Interrupt-on-Change (RB7:RB4) | 116 | Period Measurement Mode | | | INTx Pin | 112 | Noise Filters | | | PORTB, Interrupt-on-Change | 112 | Microchip Internet Web Site | | | TMR0 | 112 | Migration From Baseline to Enhanced Devices | | | TMR1 Overflow | 131 | Migration From High-End to Enhanced Devices | 377 | | TMR2 to PR2 Match (PWM) | | Migration From Mid-Range to Enhanced Devices | 377 | | nterrupts | | Motion Feedback Module (MFM) | 151 | | Context Saving, During | | Associated Registers | 171 | | nterrupts, Enable Bits | | Summary of Features | | | CCP1 Enable (CCP1IE Bit) | 146 | MOVF | | | nterrupts, Flag Bits | | MOVFF | 308 | | CCP1 Flag (CCP1IF Bit) | 1/16 | MOVLB | | | | | MOVLW | | | CCP1IF Flag (CCP1IF Bit) | | MOVWF | | | CCP2IF Flag (CCP2IF Bit) | 147 | MPLAB ASM30 Assembler, Linker, Librarian | | | Interrupt-on-Change (RB7:RB4) Flag | 440 | MPLAB Integrated Development | 520 | | (RBIF Bit) | 116 | | 201 | | NTOSC, INTRC. See Internal Oscillator Block. | | Environment Software | | | ORLW | | MPLAB PM3 Device Programmer | | | ORWF | | MPLAB REAL ICE In-Circuit Emulator System | 327 | | PR Registers | 108 | | |