



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 48MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                  |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 17                                                                         |
| Program Memory Size        | 8KB (4K x 16)                                                              |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 256 x 8                                                                    |
| RAM Size                   | 256 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                                |
| Data Converters            | A/D 12x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 20-SSOP (0.209", 5.30mm Width)                                             |
| Supplier Device Package    | 20-SSOP                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f13k22-e-ss |

Email: info@E-XFL.COM

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

#### FIGURE 3-9: COMPARING ADDRESSING OPTIONS FOR BIT-ORIENTED AND BYTE-ORIENTED INSTRUCTIONS (EXTENDED INSTRUCTION SET ENABLED)

**EXAMPLE INSTRUCTION:** ADDWF, f, d, a (Opcode: 0010 01da ffff ffff)

#### When 'a' = 0 and $f \ge 60h$ :

The instruction executes in Direct Forced mode. 'f' is interpreted as a location in the Access RAM between 060h and 0FFh. This is the same as locations F60h to FFFh (Bank 15) of data memory.

Locations below 60h are not available in this addressing mode.



Note that in this mode, the correct syntax is now: ADDWF [k], d where 'k' is the same as 'f'.

#### When 'a' = 1 (all values of f):

The instruction executes in Direct mode (also known as Direct Long mode). 'f' is interpreted as a location in one of the 16 banks of the data memory space. The bank is designated by the Bank Select Register (BSR). The address can be in any implemented bank in the data memory space.



# 3.5.3 MAPPING THE ACCESS BANK IN INDEXED LITERAL OFFSET MODE

The use of Indexed Literal Offset Addressing mode effectively changes how the first 96 locations of Access RAM (00h to 5Fh) are mapped. Rather than containing just the contents of the bottom section of Bank 0, this mode maps the contents from a user defined "window" that can be located anywhere in the data memory space. The value of FSR2 establishes the lower boundary of the addresses mapped into the window, while the upper boundary is defined by FSR2 plus 95 (5Fh). Addresses in the Access RAM above 5Fh are mapped as previously described (see **Section 3.3.2** "**Access Bank**"). An example of Access Bank remapping in this addressing mode is shown in Figure 3-10. Remapping of the Access Bank applies *only* to operations using the Indexed Literal Offset mode. Operations that use the BSR (Access RAM bit is '1') will continue to use direct addressing as before.

# 3.6 PIC18 Instruction Execution and the Extended Instruction Set

Enabling the extended instruction set adds eight additional commands to the existing PIC18 instruction set. These instructions are executed as described in **Section 24.2 "Extended Instruction Set**".

#### FIGURE 3-10: REMAPPING THE ACCESS BANK WITH INDEXED LITERAL OFFSET ADDRESSING







## 4.2 Control Registers

Several control registers are used in conjunction with the  ${\tt TBLRD}$  and  ${\tt TBLWT}$  instructions. These include the:

- · EECON1 register
- EECON2 register
- TABLAT register
- TBLPTR registers

#### 4.2.1 EECON1 AND EECON2 REGISTERS

The EECON1 register (Register 4-1) is the control register for memory accesses. The EECON2 register is not a physical register; it is used exclusively in the memory write and erase sequences. Reading EECON2 will read all '0's.

The EEPGD control bit determines if the access will be a program or data EEPROM memory access. When EEPGD is clear, any subsequent operations will operate on the data EEPROM memory. When EEPGD is set, any subsequent operations will operate on the program memory.

The CFGS control bit determines if the access will be to the Configuration/Calibration registers or to program memory/data EEPROM memory. When CFGS is set, subsequent operations will operate on Configuration registers regardless of EEPGD (see **Section 23.0 "Special Features of the CPU"**). When CFGS is clear, memory selection access is determined by EEPGD. The FREE bit allows the program memory erase operation. When FREE is set, an erase operation is initiated on the next WR command. When FREE is clear, only writes are enabled.

The WREN bit, when set, will allow a write operation. The WREN bit is clear on power-up.

The WRERR bit is set by hardware when the WR bit is set and cleared when the internal programming timer expires and the write operation is complete.

| Note: | During normal operation, the WRERR is       |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|
|       | read as '1'. This can indicate that a write |  |  |  |  |  |
|       | operation was prematurely terminated by     |  |  |  |  |  |
|       | a Reset, or a write operation was           |  |  |  |  |  |
|       | attempted improperly.                       |  |  |  |  |  |

The WR control bit initiates write operations. The WR bit cannot be cleared, only set, by firmware. Then WR bit is cleared by hardware at the completion of the write operation.

Note: The EEIF interrupt flag bit of the PIR2 register is set when the write is complete. The EEIF flag stays set until cleared by firmware.

# 7.0 INTERRUPTS

The PIC18(L)F1XK22 devices have multiple interrupt sources and an interrupt priority feature that allows most interrupt sources to be assigned a high priority level or a low priority level. The high priority interrupt vector is at 0008h and the low priority interrupt vector is at 0018h. A high priority interrupt event will interrupt a low priority interrupt that may be in progress.

There are twelve registers which are used to control interrupt operation. These registers are:

- RCON
- INTCON
- INTCON2
- INTCON3
- PIR1, PIR2
- PIE1, PIE2
- IPR1, IPR2

It is recommended that the Microchip header files supplied with MPLAB<sup>®</sup> IDE be used for the symbolic bit names in these registers. This allows the assembler/ compiler to automatically take care of the placement of these bits within the specified register.

In general, interrupt sources have three bits to control their operation. They are:

- Flag bit to indicate that an interrupt event occurred
- Enable bit that allows program execution to branch to the interrupt vector address when the flag bit is set
- **Priority bit** to select high priority or low priority

### 7.1 Mid-Range Compatibility

When the IPEN bit is cleared (default state), the interrupt priority feature is disabled and interrupts are compatible with PIC<sup>®</sup> microcontroller mid-range devices. In Compatibility mode, the interrupt priority bits of the IPRx registers have no effect. The PEIE bit of the INTCON register is the global interrupt enable for the peripherals. The PEIE bit disables only the peripheral interrupt sources when the GIE bit is also set. The GIE bit of the INTCON register is the global interrupt enable which enables all non-peripheral interrupt sources and disables all interrupt sources, including the peripherals. All interrupts branch to address 0008h in Compatibility mode.

### 7.2 Interrupt Priority

The interrupt priority feature is enabled by setting the IPEN bit of the RCON register. When interrupt priority is enabled the GIE and PEIE global interrupt enable bits of Compatibility mode are replaced by the GIEH high priority, and GIEL low priority, global interrupt enables. When set, the GIEH bit of the INTCON register enables all interrupts that have their associated IPRx register or INTCONx register priority bit set (high priority). When clear, the GIEL bit disables all interrupt sources including those selected as low priority. When clear, the GIEL bit of the INTCON register disables only the interrupts that have their associated priority bit set (low priority). When set, the GIEL bit of the INTCON register disables only the interrupts that have their associated priority bit cleared (low priority). When set, the GIEL bit enables the low priority sources when the GIEH bit is also set.

When the interrupt flag, enable bit and appropriate global interrupt enable bit are all set, the interrupt will vector immediately to address 0008h for high priority, or 0018h for low priority, depending on level of the interrupting source's priority bit. Individual interrupts can be disabled through their corresponding interrupt enable bits.

#### 7.3 Interrupt Response

When an interrupt is responded to, the global interrupt enable bit is cleared to disable further interrupts. The GIE bit is the global interrupt enable when the IPEN bit is cleared. When the IPEN bit is set, enabling interrupt priority levels, the GIEH bit is the high priority global interrupt enable and the GIEL bit is the low priority global interrupt enable. High-priority interrupt sources can interrupt a low-priority interrupt. Low-priority interrupts are not processed while high-priority interrupts are in progress.

The return address is pushed onto the stack and the PC is loaded with the interrupt vector address (0008h or 0018h). Once in the Interrupt Service Routine, the source(s) of the interrupt can be determined by polling the interrupt flag bits in the INTCONx and PIRx registers. The interrupt flag bits must be cleared by software before re-enabling interrupts to avoid repeating the same interrupt.

The "return-from-interrupt" instruction, RETFIE, exits the interrupt routine and sets the GIE bit (GIEH or GIEL if priority levels are used), which re-enables interrupts.

For external interrupt events, such as the INT pins or the PORTB interrupt-on-change, the interrupt latency will be three to four instruction cycles. The exact latency is the same for one-cycle or two-cycle instructions. Individual interrupt flag bits are set, regardless of the status of their corresponding enable bits or the global interrupt enable bit.

| Name    | Bit 7    | Bit 6     | Bit 5                 | Bit 4                 | Bit 3                | Bit 2  | Bit 1  | Bit 0  | Reset<br>Values on<br>page |
|---------|----------|-----------|-----------------------|-----------------------|----------------------|--------|--------|--------|----------------------------|
| ANSEL   | ANS7     | ANS6      | ANS5                  | ANS4                  | ANS3                 | ANS2   | ANS1   | ANS0   | 247                        |
| INTCON  | GIE/GIEH | PEIE/GIEL | TMR0IE                | INT0IE                | RABIE                | TMR0IF | INT0IF | RABIF  | 244                        |
| INTCON2 | RABPU    | INTEDG0   | INTEDG1               | INTEDG2               | _                    | TMR0IP | _      | RABIP  | 244                        |
| IOCA    | —        | —         | IOCA5                 | IOCA4                 | IOCA3 <sup>(2)</sup> | IOCA2  | IOCA1  | IOCA0  | 247                        |
| LATA    | _        | _         | LATA5 <sup>(1)</sup>  | LATA4 <sup>(1)</sup>  | _                    | LATA2  | LATA1  | LATA0  | 247                        |
| PORTA   | —        | —         | RA5 <sup>(1)</sup>    | RA4 <sup>(1)</sup>    | RA3 <sup>(2)</sup>   | RA2    | RA1    | RA0    | 247                        |
| SLRCON  | —        | —         | —                     | —                     | —                    | SLRC   | SLRB   | SLRA   | 247                        |
| TRISA   | —        | —         | TRISA5 <sup>(1)</sup> | TRISA4 <sup>(1)</sup> | _(3)                 | TRISA2 | TRISA1 | TRISA0 | 247                        |
| WPUA    |          | —         | WPUA5                 | WPUA4                 | WPUA3 <sup>(2)</sup> | WPUA2  | WPUA1  | WPUA0  | 244                        |

**Legend:** — = unimplemented, read as '0'. Shaded cells are not used by PORTA.

**Note 1:** RA<5:4> and their associated latch and data direction bits are enabled as I/O pins based on oscillator configuration; otherwise, they are read as '0'.

2: Implemented only when Master Clear functionality is disabled (MCLRE Configuration bit = 0).

**3:** Unimplemented, read as '1'.

#### 10.2 Timer1 16-Bit Read/Write Mode

Timer1 can be configured for 16-bit reads and writes (see Figure 10-2). When the RD16 control bit of the T1CON register is set, the address for TMR1H is mapped to a buffer register for the high byte of Timer1. A read from TMR1L will load the contents of the high byte of Timer1 into the Timer1 high byte buffer. This provides the user with the ability to accurately read all 16 bits of Timer1 without the need to determine whether a read of the high byte, followed by a read of the low byte, has become invalid due to a rollover or carry between reads.

Writing to TMR1H does not directly affect Timer1. Instead, the high byte of Timer1 is updated with the contents of TMR1H when a write occurs to TMR1L. This allows all 16 bits of Timer1 to be updated at once.

The high byte of Timer1 is not directly readable or writable in this mode. All reads and writes must take place through the Timer1 High Byte Buffer register. Writes to TMR1H do not clear the Timer1 prescaler. The prescaler is only cleared on writes to TMR1L.

#### **10.3 Clock Source Selection**

The TMR1CS bit of the T1CON register is used to select the clock source. When TMR1CS = 0, the clock source is FOSC/4. When TMR1CS = 1, the clock source is supplied externally.

| Clock<br>Source | T1OSCEN | FOSC<br>Mode      | TMR1CS |
|-----------------|---------|-------------------|--------|
| Fosc/4          | х       | xxx               | 0      |
| T1CKI pin       | 0       | xxx               | 1      |
| T1LPOSC         | 1       | LP or<br>INTOSCIO | 1      |

#### 10.3.1 INTERNAL CLOCK SOURCE

When the internal clock source is selected the TMR1H:TMR1L register pair will increment on multiples of Fosc as determined by the Timer1 prescaler.

### 10.3.2 EXTERNAL CLOCK SOURCE

When the external clock source is selected, the Timer1 module may work as a timer or a counter.

When counting, Timer1 is incremented on the rising edge of the external clock input T1CKI. In addition, the Counter mode clock can be synchronized to the microcontroller system clock or run asynchronously. If an external clock oscillator is needed (and the microcontroller is using the INTOSC without CLKOUT), Timer1 can use the LP oscillator as a clock source.

| Note: | In Counter mode, a falling edge must be<br>registered by the counter prior to the first<br>incrementing rising edge after any one or<br>more of the following conditions: |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Timer1 enabled after POR                                                                                                                                                  |
|       | <ul> <li>Write to TMR1H or TMR1L</li> </ul>                                                                                                                               |
|       | <ul> <li>Timer1 is disabled</li> </ul>                                                                                                                                    |
|       | <ul> <li>Timer1 is disabled (TMR1ON 0)</li> </ul>                                                                                                                         |
|       | when T1CKI is high then Timer1 is                                                                                                                                         |
|       | enabled (TMR1ON= 1) when T1CKI is low.                                                                                                                                    |
| Note: | See Figure 9-2.                                                                                                                                                           |

### 10.4 Timer1 Oscillator

An on-chip crystal oscillator circuit is incorporated between pins OSC1 (input) and OSC2 (amplifier output). It is enabled by setting the Timer1 Oscillator Enable bit, T1OSCEN of the T1CON register. The oscillator is a low-power circuit rated for 32 kHz crystals. It will continue to run during all power-managed modes. The circuit for a typical LP oscillator is shown in Figure 10-3. Table 10-1 shows the capacitor selection for the Timer1 oscillator.

The Timer1 oscillator is shared with the system LP oscillator. Thus, Timer1 can use this mode only when the primary system clock is derived from the internal oscillator or when the oscillator is in the LP mode. The user must provide a software time delay to ensure proper oscillator start-up.

#### FIGURE 10-3: EXTERNAL COMPONENTS FOR THE TIMER1 LP OSCILLATOR



#### 13.2.4 CCP PRESCALER

There are four prescaler settings in Capture mode; they are specified as part of the operating mode selected by the mode select bits (CCP1M<3:0>). Whenever the CCP module is turned off or Capture mode is disabled, the prescaler counter is cleared. This means that any Reset will clear the prescaler counter.

Switching from one capture prescaler to another may generate an interrupt. Also, the prescaler counter will not be cleared; therefore, the first capture may be from a non-zero prescaler. Example 13-1 shows the recommended method for switching between capture prescalers. This example also clears the prescaler counter and will not generate the "false" interrupt.

#### EXAMPLE 13-1: CHANGING BETWEEN CAPTURE PRESCALERS

| nodule off |
|------------|
| with the   |
| aler mode  |
| CCP ON     |
| CON with   |
| è          |
| 1          |

#### FIGURE 13-1: CAPTURE MODE OPERATION BLOCK DIAGRAM



#### 13.4.1 HALF-BRIDGE MODE

In Half-Bridge mode, two pins are used as outputs to drive push-pull loads. The PWM output signal is output on the CCP1/P1A pin, while the complementary PWM output signal is output on the P1B pin (see Figure 13-6). This mode can be used for half-bridge applications, as shown in Figure 13-7, or for full-bridge applications, where four power switches are being modulated with two PWM signals.

In Half-Bridge mode, the programmable dead-band delay can be used to prevent shoot-through current in half-bridge power devices. The value of the PDC<6:0> bits of the PWM1CON register sets the number of instruction cycles before the output is driven active. If the value is greater than the duty cycle, the corresponding output remains inactive during the entire cycle. See **Section 13.4.6 "Programmable Dead-Band Delay Mode"** for more details of the dead-band delay operations. Since the P1A and P1B outputs are multiplexed with the PORT data latches, the associated TRIS bits must be cleared to configure P1A and P1B as outputs.

#### FIGURE 13-6: EXAMPLE OF HALF-BRIDGE PWM OUTPUT



### FIGURE 13-7: EXAMPLE OF HALF-BRIDGE APPLICATIONS



# 14.3.4.5 Clock Synchronization and the CKP bit

When the CKP bit is cleared, the SCL output is forced to '0'. However, clearing the CKP bit will not assert the SCL output low until the SCL output is already sampled low. Therefore, the CKP bit will not assert the SCL line until an external  $I^2C$  master device has already asserted the SCL line. The SCL output will remain low until the CKP bit is set and all other devices on the  $I^2C$  bus have deasserted SCL. This ensures that a write to the CKP bit will not violate the minimum high time requirement for SCL (see Figure 14-12).











#### TABLE 15-1: REGISTERS ASSOCIATED WITH ASYNCHRONOUS TRANSMISSION

| Name    | Bit 7                                          | Bit 6     | Bit 5  | Bit 4  | Bit 3 | Bit 2  | Bit 1  | Bit 0  | Reset<br>Values<br>on page |
|---------|------------------------------------------------|-----------|--------|--------|-------|--------|--------|--------|----------------------------|
| BAUDCON | ABDOVF                                         | RCIDL     | DTRXP  | CKTXP  | BRG16 | —      | WUE    | ABDEN  | 247                        |
| INTCON  | GIE/GIEH                                       | PEIE/GIEL | TMR0IE | INT0IE | RABIE | TMR0IF | INT0IF | RABIF  | 245                        |
| IPR1    | —                                              | ADIP      | RCIP   | TXIP   | SSPIP | CCP1IP | TMR2IP | TMR1IP | 248                        |
| PIE1    | —                                              | ADIE      | RCIE   | TXIE   | SSPIE | CCP1IE | TMR2IE | TMR1IE | 248                        |
| PIR1    | —                                              | ADIF      | RCIF   | TXIF   | SSPIF | CCP1IF | TMR2IF | TMR1IF | 248                        |
| RCSTA   | SPEN                                           | RX9       | SREN   | CREN   | ADDEN | FERR   | OERR   | RX9D   | 247                        |
| SPBRG   | EUSART Baud Rate Generator Register, Low Byte  |           |        |        |       |        |        | 247    |                            |
| SPBRGH  | EUSART Baud Rate Generator Register, High Byte |           |        |        |       |        |        | 247    |                            |
| TXREG   | EUSART Transmit Register                       |           |        |        |       |        | 247    |        |                            |
| TXSTA   | CSRC                                           | TX9       | TXEN   | SYNC   | SENDB | BRGH   | TRMT   | TX9D   | 247                        |

**Legend:** — = unimplemented locations read as '0'. Shaded cells are not used for asynchronous transmission.

### 22.2 Master Clear (MCLR)

The MCLR pin provides a method for triggering an external Reset of the device. A Reset is generated by holding the pin low. These devices have a noise filter in the MCLR Reset path which detects and ignores small pulses.

The MCLR pin is not driven low by any internal Resets, including the WDT.

In PIC18(L)F1XK22 devices, the MCLR input can be disabled with the MCLRE Configuration bit. When MCLR is disabled, the pin becomes a digital input. See **Section 8.1 "PORTA, TRISA and LATA Registers"** for more information.

#### 22.3 Power-on Reset (POR)

A Power-on Reset pulse is generated on-chip whenever VDD rises above a certain threshold. This allows the device to start in the initialized state when VDD is adequate for operation.

To take advantage of the POR circuitry, tie the  $\overline{\text{MCLR}}$  pin through a resistor (1 k $\Omega$  to 10 k $\Omega$ ) to VDD. This will eliminate external RC components usually needed to create a Power-on Reset delay.

When the device starts normal operation (i.e., exits the Reset condition), device operating parameters (voltage, frequency, temperature, etc.) must be met to ensure operation. If these conditions are not met, the device must be held in Reset until the operating conditions are met.

POR events are captured by the POR bit of the RCON register. The state of the bit is set to '0' whenever a POR occurs; it does not change for any other Reset event. POR is not reset to '1' by any hardware event. To capture multiple events, the user must manually set the bit to '1' by software following any POR.

#### FIGURE 22-2:

#### EXTERNAL POWER-ON RESET CIRCUIT (FOR SLOW VDD POWER-UP)



- Note 1: External Power-on Reset circuit is required only if the VDD power-up slope is too slow. The diode D helps discharge the capacitor quickly when VDD powers down.
  - 2:  $R < 40 \text{ k}\Omega$  is recommended to make sure that the voltage drop across R does not violate the device's electrical specification.
  - 3:  $\underline{R1 \ge 1} \ k\Omega$  will limit any current flowing into  $\overline{MCLR}$  from external capacitor C, in the event of  $\overline{MCLR}/VPP$  pin breakdown, due to Electrostatic Discharge (ESD) or Electrical Overstress (EOS).

#### U-0 U-0 U-0 U-0 U-0 U-0 R/C-1 R/C-1 CP1 CP0 \_ \_ — \_\_\_\_ \_\_\_\_ bit 7 bit 0

#### **REGISTER 23-6: CONFIG5L: CONFIGURATION REGISTER 5 LOW**

| Legend:                                |                                    |  |
|----------------------------------------|------------------------------------|--|
| R = Readable bit                       | U = Unimplemented bit, read as '0' |  |
| -n = Value when device is unprogrammed | C = Clearable only bit             |  |
|                                        |                                    |  |

| bit 7-2 | Unimplemented: Read as '0'                                                                      |
|---------|-------------------------------------------------------------------------------------------------|
| bit 1   | <b>CP1:</b> Code Protection bit<br>1 = Block 1 not code-protected<br>0 = Block 1 code-protected |
| bit 0   | <b>CP0:</b> Code Protection bit<br>1 = Block 0 not code-protected<br>0 = Block 0 code-protected |

#### **REGISTER 23-7: CONFIG5H: CONFIGURATION REGISTER 5 HIGH**

| R/C-1     | R/C-1 | U-0 | U-0 | U-0 | U-0 | U-0   | U-0 |
|-----------|-------|-----|-----|-----|-----|-------|-----|
| CPD       | CPB   | —   | —   | —   | —   | —     | —   |
| bit 7 bit |       |     |     |     |     | bit 0 |     |

| Legend:                                |                                    |
|----------------------------------------|------------------------------------|
| R = Readable bit                       | U = Unimplemented bit, read as '0' |
| -n = Value when device is unprogrammed | C = Clearable only bit             |
|                                        |                                    |

| bit 7 | <b>CPD:</b> Data EEPROM Code Protection bit<br>1 = Data EEPROM not code-protected<br>0 = Data EEPROM code-protected |
|-------|---------------------------------------------------------------------------------------------------------------------|
| bit 6 | <b>CPB:</b> Boot Block Code Protection bit<br>1 = Boot block not code-protected<br>0 = Boot block code-protected    |

bit 5-0 Unimplemented: Read as '0'

| BNC                           | v                                                                                                                                                                                                                                                                                    | Branch if                                      | Branch if Not Overflow                                   |                   |  |  |  |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|----------------------------------------------------------|-------------------|--|--|--|
| Synta                         | ax:                                                                                                                                                                                                                                                                                  | BNOV n                                         |                                                          |                   |  |  |  |
| Oper                          | ands:                                                                                                                                                                                                                                                                                | $-128 \le n \le 127$                           |                                                          |                   |  |  |  |
| Oper                          | ation:                                                                                                                                                                                                                                                                               | if OVERFL0<br>(PC) + 2 + 2                     | if OVERFLOW bit is '0'<br>(PC) + 2 + 2n $\rightarrow$ PC |                   |  |  |  |
| Statu                         | s Affected:                                                                                                                                                                                                                                                                          | None                                           | None                                                     |                   |  |  |  |
| Enco                          | oding:                                                                                                                                                                                                                                                                               | 1110                                           | 0101 nnnn nnnn                                           |                   |  |  |  |
| Desc                          | If the OVERFLOW bit is '0', then the<br>program will branch.<br>The 2's complement number '2n' is<br>added to the PC. Since the PC will ha<br>incremented to fetch the next<br>instruction, the new address will be<br>PC + 2 + 2n. This instruction is then<br>2-cycle instruction. |                                                |                                                          |                   |  |  |  |
| Words: 1                      |                                                                                                                                                                                                                                                                                      |                                                |                                                          |                   |  |  |  |
| Cycle                         | es:                                                                                                                                                                                                                                                                                  | 1(2)                                           |                                                          |                   |  |  |  |
| Q Cycle Activity:<br>If Jump: |                                                                                                                                                                                                                                                                                      | 02                                             | 03                                                       | 04                |  |  |  |
|                               | Decode                                                                                                                                                                                                                                                                               | Q2<br>Read literal                             | Process                                                  | Q4<br>Write to PC |  |  |  |
|                               | Decode                                                                                                                                                                                                                                                                               | 'n'                                            | Data                                                     | White to FC       |  |  |  |
|                               | No<br>operation                                                                                                                                                                                                                                                                      | No<br>operation                                | No<br>operation                                          | No<br>operation   |  |  |  |
| If No Jump:                   |                                                                                                                                                                                                                                                                                      |                                                |                                                          |                   |  |  |  |
|                               | Q1                                                                                                                                                                                                                                                                                   | Q2                                             | Q3                                                       | Q4                |  |  |  |
|                               | Decode                                                                                                                                                                                                                                                                               | Read literal<br>'n'                            | Process<br>Data                                          | No<br>operation   |  |  |  |
| Exan                          | nple:                                                                                                                                                                                                                                                                                | HERE                                           | BNOV Jump                                                |                   |  |  |  |
| Before Instruction            |                                                                                                                                                                                                                                                                                      |                                                |                                                          |                   |  |  |  |
|                               | PC<br>After Instructio<br>If OVERI<br>PC<br>If OVERI                                                                                                                                                                                                                                 | = ado<br>on<br>FLOW = 0;<br>= ado<br>FLOW = 1; | dress (HERE<br>dress (Jump                               | )                 |  |  |  |
|                               | PC                                                                                                                                                                                                                                                                                   | = ad                                           | dress (HERE                                              | + 2)              |  |  |  |

| BNZ                                                                                                                                                                                                                                                             |                                  | Branch if                   | Branch if Not Zero                                |                                                                                 |             |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------|---------------------------------------------------|---------------------------------------------------------------------------------|-------------|--|--|--|
| Synta                                                                                                                                                                                                                                                           | ax:                              | BNZ n                       |                                                   |                                                                                 |             |  |  |  |
| Operands:                                                                                                                                                                                                                                                       |                                  | -128 ≤ n ≤ 1                | -128 ≤ n ≤ 127                                    |                                                                                 |             |  |  |  |
| Operation:                                                                                                                                                                                                                                                      |                                  | if ZERO bit<br>(PC) + 2 + 2 | if ZERO bit is '0' (PC) + 2 + 2n $\rightarrow$ PC |                                                                                 |             |  |  |  |
| Statu                                                                                                                                                                                                                                                           | s Affected:                      | None                        |                                                   |                                                                                 |             |  |  |  |
| Enco                                                                                                                                                                                                                                                            | ding:                            | 1110                        | 1110 0001 nnnn nnnn                               |                                                                                 |             |  |  |  |
| Description:<br>If the ZERO bit is '0', then the<br>will branch.<br>The 2's complement number '2<br>added to the PC. Since the PC<br>incremented to fetch the next<br>instruction, the new address w<br>PC + 2 + 2n. This instruction is<br>2-cycle instruction |                                  |                             |                                                   | the program<br>per '2n' is<br>PC will have<br>ext<br>ss will be<br>on is then a |             |  |  |  |
| Word                                                                                                                                                                                                                                                            | s:                               | 1                           | 1                                                 |                                                                                 |             |  |  |  |
| Cycles:                                                                                                                                                                                                                                                         |                                  | 1(2)                        | 1(2)                                              |                                                                                 |             |  |  |  |
| Q Cycle Activity:<br>If Jump:                                                                                                                                                                                                                                   |                                  | 02                          | 03                                                |                                                                                 | 04          |  |  |  |
|                                                                                                                                                                                                                                                                 | Daada                            | Q2<br>Dood litoral          | Droop                                             |                                                                                 | Write to DC |  |  |  |
|                                                                                                                                                                                                                                                                 | Decode                           | 'n'                         | Data                                              | a 85                                                                            |             |  |  |  |
|                                                                                                                                                                                                                                                                 | No                               | No                          | No                                                |                                                                                 | No          |  |  |  |
|                                                                                                                                                                                                                                                                 | operation                        | operation                   | operation                                         |                                                                                 | operation   |  |  |  |
| lf No                                                                                                                                                                                                                                                           | Jump:                            |                             |                                                   |                                                                                 |             |  |  |  |
|                                                                                                                                                                                                                                                                 | Q1                               | Q2                          | Q3                                                |                                                                                 | Q4          |  |  |  |
|                                                                                                                                                                                                                                                                 | Decode                           | Read literal                | Proce                                             | ess                                                                             | No          |  |  |  |
|                                                                                                                                                                                                                                                                 |                                  | 'n'                         | Data                                              | а                                                                               | operation   |  |  |  |
| <u>Exan</u>                                                                                                                                                                                                                                                     | n <u>ple</u> :<br>Before Instruc | HERE                        | BNZ .                                             | Jump                                                                            |             |  |  |  |
| PC =                                                                                                                                                                                                                                                            |                                  |                             | dress (H                                          | ERE)                                                                            |             |  |  |  |
|                                                                                                                                                                                                                                                                 | A 44 a. a. 1                     |                             |                                                   |                                                                                 |             |  |  |  |

#### 25.6 MPLAB X SIM Software Simulator

The MPLAB X 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 X SIM Software Simulator fully supports symbolic debugging using the MPLAB XC Compilers, and the MPASM and MPLAB 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.

#### 25.7 MPLAB REAL ICE In-Circuit Emulator System

The MPLAB REAL ICE In-Circuit Emulator System is Microchip's next generation high-speed emulator for Microchip Flash DSC and MCU devices. It debugs and programs all 8, 16 and 32-bit MCU, and DSC devices with the easy-to-use, powerful graphical user interface of the MPLAB X IDE.

The emulator is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with either a connector compatible with in-circuit debugger systems (RJ-11) or with the new high-speed, noise tolerant, Low-Voltage Differential Signal (LVDS) interconnection (CAT5).

The emulator is field upgradable through future firmware downloads in MPLAB X IDE. MPLAB REAL ICE offers significant advantages over competitive emulators including full-speed emulation, run-time variable watches, trace analysis, complex breakpoints, logic probes, a ruggedized probe interface and long (up to three meters) interconnection cables.

#### 25.8 MPLAB ICD 3 In-Circuit Debugger System

The MPLAB ICD 3 In-Circuit Debugger System is Microchip's most cost-effective, high-speed hardware debugger/programmer for Microchip Flash DSC and MCU devices. It debugs and programs PIC Flash microcontrollers and dsPIC DSCs with the powerful, yet easy-to-use graphical user interface of the MPLAB IDE.

The MPLAB ICD 3 In-Circuit Debugger probe is connected to the design engineer's PC using a highspeed USB 2.0 interface and is connected to the target with a connector compatible with the MPLAB ICD 2 or MPLAB REAL ICE systems (RJ-11). MPLAB ICD 3 supports all MPLAB ICD 2 headers.

### 25.9 PICkit 3 In-Circuit Debugger/ Programmer

The MPLAB PICkit 3 allows debugging and programming of PIC and dsPIC Flash microcontrollers at a most affordable price point using the powerful graphical user interface of the MPLAB IDE. The MPLAB PICkit 3 is connected to the design engineer's PC using a full-speed USB interface and can be connected to the target via a Microchip debug (RJ-11) connector (compatible with MPLAB ICD 3 and MPLAB REAL ICE). The connector uses two device I/O pins and the Reset line to implement in-circuit debugging and In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>).

### 25.10 MPLAB PM3 Device Programmer

The MPLAB PM3 Device Programmer is a universal, CE compliant device programmer with programmable voltage verification at VDDMIN and VDDMAX for maximum reliability. It features a large LCD display (128 x 64) for menus and error messages, and a modular, detachable socket assembly to support various package types. The ICSP cable assembly is included as a standard item. In Stand-Alone mode, the MPLAB PM3 Device Programmer can read, verify and program PIC devices without a PC connection. It can also set code protection in this mode. The MPLAB PM3 connects to the host PC via an RS-232 or USB cable. The MPLAB PM3 has high-speed communications and optimized algorithms for quick programming of large memory devices, and incorporates an MMC card for file storage and data applications.

| Param.<br>No. | Symbol                                | Characteristic                                                        |          | Min.        | Тур.† | Max. | Units | Conditions |
|---------------|---------------------------------------|-----------------------------------------------------------------------|----------|-------------|-------|------|-------|------------|
| SP70*         | TssL2scH,<br>TssL2scL                 | $\overline{SS}\downarrow$ to SCK $\downarrow$ or SCK $\uparrow$ input |          | Тсү         | —     | —    | ns    |            |
| SP71*         | TscH                                  | SCK input high time (Slave mo                                         | de)      | Tcy + 20    | _     | _    | ns    |            |
| SP72*         | TscL                                  | SCK input low time (Slave mod                                         | le)      | Tcy + 20    | _     | —    | ns    |            |
| SP73*         | TDIV2scH,<br>TDIV2scL                 | Setup time of SDI data input to SCK edge                              |          | 100         | —     | _    | ns    |            |
| SP74*         | TscH2dlL,<br>TscL2dlL                 | Hold time of SDI data input to SCK edge                               |          | 100         | —     | _    | ns    |            |
| SP75*         | TDOR                                  | SDO data output rise time                                             | 3.0-5.5V | —           | 10    | 25   | ns    |            |
|               |                                       | 1.8-5.5V                                                              | —        | 25          | 50    | ns   |       |            |
| SP76*         | TDOF                                  | SDO data output fall time                                             |          | —           | 10    | 25   | ns    |            |
| SP77*         | TssH2doZ                              | SS↑ to SDO output high-impedance                                      |          | 10          | _     | 50   | ns    |            |
| SP78* TscR    | SCK output rise time<br>(Master mode) | 3.0-5.5V                                                              | —        | 10          | 25    | ns   |       |            |
|               |                                       | 1.8-5.5V                                                              | —        | 25          | 50    | ns   |       |            |
| SP79*         | TscF                                  | SCK output fall time (Master mode)                                    |          | —           | 10    | 25   | ns    |            |
| SP80*         | SP80* TscH2doV,                       | SDO data output valid after                                           | 3.0-5.5V | —           | _     | 50   | ns    |            |
| TscL2DoV      | SCK edge                              | 1.8-5.5V                                                              | —        | _           | 145   | ns   |       |            |
| SP81*         | TDOV2scH,<br>TDOV2scL                 | SDO data output setup to SCK edge                                     |          | Тсу         | _     |      | ns    |            |
| SP82*         | TssL2doV                              | SDO data output valid after $\overline{\text{SS}}\downarrow$ edge     |          | _           | —     | 50   | ns    |            |
| SP83*         | TscH2ssH,<br>TscL2ssH                 | SS ↑ after SCK edge                                                   |          | 1.5Tcy + 40 | —     |      | ns    |            |

### TABLE 26-26: SPI MODE REQUIREMENTS

\* These parameters are characterized but not tested.

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

### FIGURE 26-21: I<sup>2</sup>C BUS START/STOP BITS TIMING























FIGURE 27-24: PIC18(L)F1XK22 SCHMITT BUFFER TYPICAL VIL

# 28.0 PACKAGING INFORMATION

### 28.1 Package Marking Information



| Legend | : XXX<br>Y<br>YY<br>WW<br>NNN<br>@3<br>* | Customer-specific information<br>Year code (last digit of calendar year)<br>Year code (last 2 digits of calendar year)<br>Week code (week of January 1 is week '01')<br>Alphanumeric traceability code<br>Pb-free JEDEC <sup>®</sup> designator for Matte Tin (Sn)<br>This package is Pb-free. The Pb-free JEDEC designator (e3)<br>can be found on the outer packaging for this package. |
|--------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note:  | In the even<br>be carried<br>characters  | nt the full Microchip part number cannot be marked on one line, it will<br>d over to the next line, thus limiting the number of available<br>s for customer-specific information.                                                                                                                                                                                                         |