



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                      | 20MHz                                                                     |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                         |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                     |
| Number of I/O              | 25                                                                        |
| Program Memory Size        | 3.5KB (2K x 14)                                                           |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 128 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 5.5V                                                               |
| Data Converters            | A/D 11x8b                                                                 |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 28-VQFN Exposed Pad                                                       |
| Supplier Device Package    | 28-QFN (6x6)                                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f722t-i-ml |

Email: info@E-XFL.COM

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

#### 2.2.2.1 STATUS Register

The STATUS register, shown in Register 2-1, contains:

- the arithmetic status of the ALU
- · the Reset status
- the bank select bits for data memory (SRAM)

The STATUS register can be the destination for any instruction, like any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the TO and PD bits are not writable. Therefore, the result of an instruction with the STATUS register as destination may be different than intended.

For example, CLRF STATUS will clear the upper three bits and set the Z bit. This leaves the STATUS register as '000u uluu' (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions are used to alter the STATUS register, because these instructions do not affect any Status bits. For other instructions not affecting any Status bits (Refer to **Section 21.0** "Instruction Set Summary").

**Note 1:** The <u>C</u> and <u>DC</u> bits operate as Borrow and <u>Digit</u> Borrow out bits, respectively, in subtraction.

REGISTER 2-1: STATUS: STATUS REGISTER

| R/W-0 | R/W-0 | R/W-0 | R-1 | R-1 | R/W-x | R/W-x             | R/W-x            |
|-------|-------|-------|-----|-----|-------|-------------------|------------------|
| IRP   | RP1   | RP0   | TO  | PD  | Z     | DC <sup>(1)</sup> | C <sup>(1)</sup> |
| bit 7 |       |       |     |     |       |                   | bit 0            |

| Legend:                                                     |                             |                                    |                                    |                                   |  |  |
|-------------------------------------------------------------|-----------------------------|------------------------------------|------------------------------------|-----------------------------------|--|--|
| R = Read                                                    | lable bit                   | W = Writable bit                   | U = Unimplemented bit,             | , read as '0'                     |  |  |
| -n = Value                                                  | e at POR                    | '1' = Bit is set                   | '0' = Bit is cleared               | x = Bit is unknown                |  |  |
|                                                             |                             |                                    |                                    |                                   |  |  |
| bit 7                                                       | IRP: Re                     | gister Bank Select bit (used f     | or indirect addressing)            |                                   |  |  |
|                                                             | 1 = Banl                    | k 2, 3 (100h-1FFh)                 |                                    |                                   |  |  |
|                                                             | 0 = Banl                    | k 0, 1 (00h-⊢⊢h)                   |                                    |                                   |  |  |
| bit 6-5                                                     | RP<1:0:                     | Register Bank Select bits (        | used for direct addressing)        |                                   |  |  |
|                                                             | 00 = Bai                    | nk 0 (00h-7Fh)                     |                                    |                                   |  |  |
|                                                             | 01 = Bai<br>10 = Bai        | nk 1 (800-FFN)<br>nk 2 (100h-17Fh) |                                    |                                   |  |  |
| 11 = Bark 3 (180h-1FFh)                                     |                             |                                    |                                    |                                   |  |  |
| bit 4                                                       | TO: Tim                     | e-out bit                          |                                    |                                   |  |  |
| 1 = After power-up, CLRWDT instruction or SLEEP instruction |                             |                                    |                                    |                                   |  |  |
|                                                             | 0 = A W                     | DT time out occurred               |                                    |                                   |  |  |
| bit 3                                                       | PD: Pov                     | ver-down bit                       |                                    |                                   |  |  |
|                                                             | 1 = After                   | r power-up or by the CLRWDT        | instruction                        |                                   |  |  |
|                                                             | 0 = By e                    | execution of the SLEEP instru      | ction                              |                                   |  |  |
| bit 2                                                       | Z: Zero                     | bit                                |                                    |                                   |  |  |
|                                                             | 1 = The                     | result of an arithmetic or logi    | c operation is zero                |                                   |  |  |
|                                                             | 0 = 1 he                    | result of an arithmetic or logi    | c operation is not zero            |                                   |  |  |
| bit 1                                                       | DC: Digi                    | it Carry/Digit Borrow bit (ADD     | WF, ADDLW , SUBLW , SUBWF INS      | structions)                       |  |  |
|                                                             | 1 = A ca                    | rry out from the 4th low-orde      | r bit of the result occurred       |                                   |  |  |
| hit 0                                                       | 0 = 1000                    | Arrow hit(1) (Arrow hit(1)         |                                    | vno)(1)                           |  |  |
|                                                             |                             | BOILOW DIC" (ADDWF, ADDL)          | v, SUBLW, SUBWF Instruction        |                                   |  |  |
|                                                             | $\perp = A ca$<br>0 = No ca | arry out from the Most Signific    | icant bit of the result occurred   |                                   |  |  |
|                                                             | 0 = 100                     |                                    |                                    |                                   |  |  |
| Note 1:                                                     | For Borrow, t               | he polarity is reversed. A sub     | traction is executed by adding     | the two's complement of the       |  |  |
|                                                             | second opera                | and. For rotate (RRF, RLF) ins     | tructions, this bit is loaded with | either the high-order or low-orde |  |  |

bit of the source register.

# 6.3 PORTB and TRISB Registers

PORTB is an 8-bit wide, bidirectional port. The corresponding data direction register is TRISB (Register 6-6). Setting a TRISB bit (= 1) will make the corresponding PORTB pin an input (i.e., put the corresponding output driver in a High-Impedance mode). Clearing a TRISB bit (= 0) will make the corresponding PORTB pin an output (i.e., enable the output driver and put the contents of the output latch on the selected pin). Example 6-2 shows how to initialize PORTB.

Reading the PORTB register (Register 6-5) reads the status of the pins, whereas writing to it will write to the PORT latch. All write operations are read-modify-write operations. Therefore, a write to a port implies that the port pins are read, this value is modified and then written to the PORT data latch.

The TRISB register (Register 6-6) controls the PORTB pin output drivers, even when they are being used as analog inputs. The user should ensure the bits in the TRISB register are maintained set when using them as analog inputs. I/O pins configured as analog input always read '0'. Example 6-2 shows how to initialize PORTB.

### EXAMPLE 6-2: INITIALIZING PORTB

| BANKSEL | PORTB       | i                       |
|---------|-------------|-------------------------|
| CLRF    | PORTB       | ;Init PORTB             |
| BANKSEL | ANSELB      |                         |
| CLRF    | ANSELB      | ;Make RB<7:0> digital   |
| BANKSEL | TRISB       | ;                       |
| MOVLW   | B'11110000' | ;Set RB<7:4> as inputs  |
|         |             | ;and RB<3:0> as outputs |
| MOVWF   | TRISB       | ;                       |

Note: The ANSELB register must be initialized to configure an analog channel as a digital input. Pins configured as analog inputs will read '0'.

# 6.3.1 ANSELB REGISTER

The ANSELB register (Register 6-9) is used to configure the Input mode of an I/O pin to analog. Setting the appropriate ANSELB bit high will cause all digital reads on the pin to be read as '0' and allow analog functions on the pin to operate correctly.

The state of the ANSELB bits has no affect on digital output functions. A pin with TRIS clear and ANSELB set will still operate as a digital output, but the Input mode will be analog. This can cause unexpected behavior when executing read-modify-write instructions on the affected port.

# 6.3.2 WEAK PULL-UPS

Each of the PORTB pins has an individually configurable internal weak pull-up. Control bits WPUB<7:0> enable or disable each pull-up (see Register 6-7). Each weak pull-up is automatically turned off when the port pin is configured as an output. All pull-ups are disabled on a Power-on Reset by the RBPU bit of the OPTION register.

# 6.3.3 INTERRUPT-ON-CHANGE

All of the PORTB pins are individually configurable as an interrupt-on-change pin. Control bits IOCB<7:0> enable or disable the interrupt function for each pin. Refer to Register 6-8. The interrupt-on-change feature is disabled on a Power-on Reset.

For enabled interrupt-on-change pins, the present value is compared with the old value latched on the last read of PORTB to determine which bits have changed or mismatched the old value. The 'mismatch' outputs of the last read are OR'd together to set the PORTB Change Interrupt flag bit (RBIF) in the INTCON register.

This interrupt can wake the device from Sleep. The user, in the Interrupt Service Routine, clears the interrupt by:

- a) Any read or write of PORTB. This will end the mismatch condition.
- b) Clear the flag bit RBIF.

A mismatch condition will continue to set flag bit RBIF. Reading or writing PORTB will end the mismatch condition and allow flag bit RBIF to be cleared. The latch holding the last read value is not affected by a MCLR nor Brown-out Reset. After these Resets, the RBIF flag will continue to be set if a mismatch is present.

**Note:** When a pin change occurs at the same time as a read operation on PORTB, the RBIF flag will always be set. If multiple PORTB pins are configured for the interrupt-on-change, the user may not be able to identify which pin changed state.





# 6.6.1 RE0/AN5<sup>(1)</sup>

Figure 6-22 shows the diagram for this pin. This pin is configurable to function as one of the following:

• a general purpose I/O

• an analog input for the ADC

| Note 1: | RE0/AN5 is available on |
|---------|-------------------------|
|         | PIC16F724/LF724 and     |
|         | PIC16F727/LF727 only.   |

# 6.6.2 RE1/AN6<sup>(1)</sup>

Figure 6-22 shows the diagram for this pin. This pin is configurable to function as one of the following:

- a general purpose I/O
- an analog input for the ADC

| Note 1: | RE0/AN5 is available on |
|---------|-------------------------|
|         | PIC16F724/LF724 and     |
|         | PIC16F727/LF727 only.   |

### 6.6.3 RE2/AN7<sup>(1)</sup>

Figure 6-22 shows the diagram for this pin. This pin is configurable to function as one of the following:

- a general purpose I/O
- an analog input for the ADC

Note 1: RE0/AN5 is available on PIC16F724/LF724 and PIC16F727/LF727 only.

#### 6.6.4 RE3/MCLR/VPP

Figure 6-23 shows the diagram for this pin. This pin is configurable to function as one of the following:

- a general purpose input
- as Master Clear Reset with weak pull-up
- · a programming voltage reference input

# 7.0 OSCILLATOR MODULE

# 7.1 Overview

The oscillator module has a wide variety of clock sources and selection features that allow it to be used in a wide range of applications while maximizing performance and minimizing power consumption. Figure 7-1 illustrates a block diagram of the oscillator module.

Clock sources can be configured from external oscillators, quartz crystal resonators, ceramic resonators and Resistor-Capacitor (RC) circuits. In addition, the system can be configured to use an internal calibrated high-frequency oscillator as clock source, with a choice of selectable speeds via software.

Clock source modes are configured by the FOSC bits in Configuration Word 1 (CONFIG1). The oscillator module can be configured for one of eight modes of operation.

- 1. RC External Resistor-Capacitor (RC) with Fosc/4 output on OSC2/CLKOUT.
- 2. RCIO External Resistor-Capacitor (RC) with I/O on OSC2/CLKOUT.
- 3. INTOSC Internal oscillator with Fosc/4 output on OSC2 and I/O on OSC1/CLKIN.
- 4. INTOSCIO Internal oscillator with I/O on OSC1/CLKIN and OSC2/CLKOUT.
- 5. EC External clock with I/O on OSC2/CLKOUT.
- 6. HS High Gain Crystal or Ceramic Resonator mode.
- 7. XT Medium Gain Crystal or Ceramic Resonator Oscillator mode.
- 8. LP Low-Power Crystal mode.



FIGURE 7-1: SIMPLIFIED PIC<sup>®</sup> MCU CLOCK SOURCE BLOCK DIAGRAM









# 11.0 TIMER0 MODULE

The Timer0 module is an 8-bit timer/counter with the following features:

- 8-bit timer/counter register (TMR0)
- 8-bit prescaler (shared with Watchdog Timer)
- Programmable internal or external clock source
- Programmable external clock edge selection
- Interrupt on overflow
- TMR0 can be used to gate Timer1

Figure 11-1 is a block diagram of the Timer0 module.

# 11.1 Timer0 Operation

The Timer0 module can be used as either an 8-bit timer or an 8-bit counter.

### 11.1.1 8-BIT TIMER MODE

The Timer0 module will increment every instruction cycle, if used without a prescaler. 8-Bit Timer mode is selected by clearing the T0CS bit of the OPTION register.

When TMR0 is written, the increment is inhibited for two instruction cycles immediately following the write.

Note: The value written to the TMR0 register can be adjusted, in order to account for the two instruction cycle delay when TMR0 is written.

# 11.1.2 8-BIT COUNTER MODE

In 8-Bit Counter mode, the Timer0 module will increment on every rising or falling edge of the T0CKI pin or the Capacitive Sensing Oscillator (CPSOSC) signal.

8-Bit Counter mode using the T0CKI pin is selected by setting the T0CS bit in the OPTION register to '1' and resetting the T0XCS bit in the CPSCON0 register to '0'.

8-Bit Counter mode using the Capacitive Sensing Oscillator (CPSOSC) signal is selected by setting the TOCS bit in the OPTION register to '1' and setting the T0XCS bit in the CPSCON0 register to '1'.

The rising or falling transition of the incrementing edge for either input source is determined by the T0SE bit in the OPTION register.

# FIGURE 11-1: BLOCK DIAGRAM OF THE TIMER0/WDT PRESCALER



| FIGURE 12-5:           | TIMER1 GATE SINGLE-PULSE MODE                                           |
|------------------------|-------------------------------------------------------------------------|
|                        |                                                                         |
| TMR1GE                 |                                                                         |
| T1GPOL                 |                                                                         |
| T1GSPM                 |                                                                         |
| T1GG <u>O/</u><br>DONE | Cleared by hardware on<br>falling edge of T1GVAL                        |
| T1G_IN                 | rising edge of T1G                                                      |
| Т1СКІ                  |                                                                         |
| T1GVAL                 |                                                                         |
| TIMER1                 | N N + 1 N + 2                                                           |
| TMR1GIF                | Cleared by software<br>Cleared by hardware on<br>falling edge of T1GVAL |

| U-0                   | R/W-0         | R/W-0            | R/W-0          | R/W-0             | R/W-0           | R/W-0           | R/W-0   |
|-----------------------|---------------|------------------|----------------|-------------------|-----------------|-----------------|---------|
| _                     | TOUTPS3       | TOUTPS2          | TOUTPS1        | TOUTPS0           | TMR2ON          | T2CKPS1         | T2CKPS0 |
| bit 7                 |               |                  |                |                   |                 | 1               | bit 0   |
|                       |               |                  |                |                   |                 |                 |         |
| Legend:               |               |                  |                |                   |                 |                 |         |
| R = Readable          | bit           | W = Writable     | bit            | U = Unimplem      | nented bit, rea | d as '0'        |         |
| -n = Value at POR     |               | '1' = Bit is set |                | '0' = Bit is clea | ared            | x = Bit is unkr | nown    |
|                       |               |                  |                |                   |                 |                 |         |
| bit 7                 | Unimplemen    | ted: Read as '   | 0'             |                   |                 |                 |         |
| bit 6-3               | TOUTPS<3:0    | >: Timer2 Out    | out Postscaler | Select bits       |                 |                 |         |
|                       | 0000 = 1:1 P  | ostscaler        |                |                   |                 |                 |         |
|                       | 0001 = 1:2 P  | ostscaler        |                |                   |                 |                 |         |
|                       | 0010 = 1:3 P  | ostscaler        |                |                   |                 |                 |         |
| 0011 = 1:4 Postscaler |               |                  |                |                   |                 |                 |         |
| 0100 = 1.5 Postscaler |               |                  |                |                   |                 |                 |         |
|                       | 0101 = 1:6 P  | ostscaler        |                |                   |                 |                 |         |
|                       | 0110 = 1.7 Pc | ostscaler        |                |                   |                 |                 |         |
|                       | 0111 = 1.8 P  | ostscaler        |                |                   |                 |                 |         |
|                       | 1000 = 1.9 P  | Ostscaler        |                |                   |                 |                 |         |
|                       | 1001 = 1.10   |                  |                |                   |                 |                 |         |
|                       | 1010 = 1.11   | Postscaler       |                |                   |                 |                 |         |
|                       | 1100 - 1.12   | Postscaler       |                |                   |                 |                 |         |
|                       | 1100 = 1.101  | Postscaler       |                |                   |                 |                 |         |
|                       | 1110 = 1:15   | Postscaler       |                |                   |                 |                 |         |
|                       | 1111 = 1:16   | Postscaler       |                |                   |                 |                 |         |
| bit 2                 | TMR2ON: Tir   | mer2 On bit      |                |                   |                 |                 |         |
|                       | 1 = Timer2 is | son              |                |                   |                 |                 |         |
|                       | 0 = Timer2 is | s off            |                |                   |                 |                 |         |
| bit 1-0               | T2CKPS<1:0    | >: Timer2 Cloc   | k Prescale Se  | lect bits         |                 |                 |         |
|                       | 00 = Prescale | er is 1          |                |                   |                 |                 |         |
|                       | 01 = Prescale | er is 4          |                |                   |                 |                 |         |
|                       | 1x = Prescale | er is 16         |                |                   |                 |                 |         |
| TARI E 13-1-          | SUMMAD        | V OF REGIST      | FRS ASSO       |                   |                 |                 |         |

# REGISTER 13-1: T2CON: TIMER2 CONTROL REGISTER

| TABLE 13-1: | SUMMARY OF REGISTERS | ASSOCIATED WITH TIMER |
|-------------|----------------------|-----------------------|
| TABLE 13-1: | SUMMARY OF REGISTERS | ASSOCIATED WITH TIME  |

| Name   | Bit 7                                        | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2  | Bit 1   | Bit 0   | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|--------|----------------------------------------------|---------|---------|---------|---------|--------|---------|---------|----------------------|---------------------------------|
| INTCON | GIE                                          | PEIE    | T0IE    | INTE    | RBIE    | T0IF   | INTF    | RBIF    | 0000 000x            | 0000 000x                       |
| PIE1   | TMR1GIE                                      | ADIE    | RCIE    | TXIE    | SSPIE   | CCP1IE | TMR2IE  | TMR1IE  | 0000 0000            | 0000 0000                       |
| PIR1   | TMR1GIF                                      | ADIF    | RCIF    | TXIF    | SSPIF   | CCP1IF | TMR2IF  | TMR1IF  | 0000 0000            | 0000 0000                       |
| PR2    | Timer2 Module Period Register                |         |         |         |         |        |         |         | 1111 1111            | 1111 1111                       |
| TMR2   | Holding Register for the 8-bit TMR2 Register |         |         |         |         |        |         |         | 0000 0000            | 0000 0000                       |
| T2CON  | _                                            | TOUTPS3 | TOUTPS2 | TOUTPS1 | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 | -000 0000            | -000 0000                       |
| · · ·  |                                              |         |         |         |         |        |         |         |                      |                                 |

x = unknown, u = unchanged, - = unimplemented read as '0'. Shaded cells are not used for Timer2 module. Legend:

| R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                           | U-0                                                                                                                                                                                   | U-0              | U-0 | R/W-0            | R/W-0            | R-0             | R/W-0 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----|------------------|------------------|-----------------|-------|
| CPSON                                                                                                                                                                                                                                                                                                                                                                                                                           | —                                                                                                                                                                                     | —                | —   | CPSRNG1          | CPSRNG0          | CPSOUT          | TOXCS |
| bit 7                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                       |                  |     |                  |                  |                 | bit 0 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                       |                  |     |                  |                  |                 |       |
| Legend:                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                       |                  |     |                  |                  |                 |       |
| R = Readable I                                                                                                                                                                                                                                                                                                                                                                                                                  | bit                                                                                                                                                                                   | W = Writable     | bit | U = Unimpler     | mented bit, read | l as '0'        |       |
| -n = Value at P                                                                                                                                                                                                                                                                                                                                                                                                                 | OR                                                                                                                                                                                    | '1' = Bit is set |     | '0' = Bit is cle | ared             | x = Bit is unkr | nown  |
| bit 7                                                                                                                                                                                                                                                                                                                                                                                                                           | bit 7 <b>CPSON:</b> Capacitive Sensing Module Enable bit<br>1 = Capacitive sensing module is operating<br>0 = Capacitive sensing module is shut off and consumes no operating current |                  |     |                  |                  |                 |       |
| bit 6-4                                                                                                                                                                                                                                                                                                                                                                                                                         | Unimplemen                                                                                                                                                                            | ted: Read as '   | כ'  |                  |                  |                 |       |
| bit 3-2 <b>CPSRNG&lt;1:0&gt;:</b> Capacitive Sensing Oscillator Range bits<br>00 = Oscillator is Off.<br>01 = Oscillator is in low range. Charge/discharge current is nominally 0.1 μA.<br>10 = Oscillator is in medium range. Charge/discharge current is nominally 1.2 μA.<br>11 = Oscillator is in high range. Charge/discharge current is nominally 18 μA.                                                                  |                                                                                                                                                                                       |                  |     |                  |                  |                 |       |
| bit 1 <b>CPSOUT:</b> Capacitive Sensing Oscillator Status bit<br>1 = Oscillator is sourcing current (Current flowing out the pin)<br>0 = Oscillator is sinking current (Current flowing into the pin)                                                                                                                                                                                                                           |                                                                                                                                                                                       |                  |     |                  |                  |                 |       |
| bit 0 <b>TOXCS:</b> Timer0 External Clock Source Select bit<br>$\frac{\text{If TOCS} = 1}{\text{The TOXCS bit controls which clock external to the core/Timer0 module supplies Timer0:}$ $1 = \text{Timer0 Clock Source is the capacitive sensing oscillator}$ $0 = \text{Timer0 Clock Source is the TOCKI pin}$ $\frac{\text{If TOCS} = 0}{\text{Timer0 clock source is controlled by the core/Timer0 module and is Fosc/4.}}$ |                                                                                                                                                                                       |                  |     |                  | 0:               |                 |       |

# REGISTER 14-1: CPSCON0: CAPACITIVE SENSING CONTROL REGISTER 0

# 15.3 PWM Mode

The PWM mode generates a Pulse-Width Modulated signal on the CCPx pin. The duty cycle, period and resolution are determined by the following registers:

- PR2
- T2CON
- CCPRxL
- CCPxCON

In Pulse-Width Modulation (PWM) mode, the CCP module produces up to a 10-bit resolution PWM output on the CCPx pin.

Figure 15-3 shows a simplified block diagram of PWM operation.

Figure 15-4 shows a typical waveform of the PWM signal.

For a step-by-step procedure on how to set up the CCP module for PWM operation, refer to **Section 15.3.8** "Setup for PWM Operation".

FIGURE 15-3: SIMPLIFIED PWM BLOCK DIAGRAM



The PWM output (Figure 15-4) has a time base (period) and a time that the output stays high (duty cycle).

FIGURE 15-4: CCP PWM OUTPUT



# 15.3.1 CCPx PIN CONFIGURATION

In PWM mode, the CCPx pin is multiplexed with the PORT data latch. The user must configure the CCPx pin as an output by clearing the associated TRIS bit.

Either RC1 or RB3 can be selected as the CCP2 pin. Refer to **Section 6.1** "Alternate Pin Function" for more information.

Note: Clearing the CCPxCON register will relinquish CCPx control of the CCPx pin.

# 16.1.2.4 Receive Framing Error

Each character in the receive FIFO buffer has a corresponding framing error Status bit. A framing error indicates that a Stop bit was not seen at the expected time. The framing error status is accessed via the FERR bit of the RCSTA register. The FERR bit represents the status of the top unread character in the receive FIFO. Therefore, the FERR bit must be read before reading the RCREG.

The FERR bit is read-only and only applies to the top unread character in the receive FIFO. A framing error (FERR = 1) does not preclude reception of additional characters. It is not necessary to clear the FERR bit. Reading the next character from the FIFO buffer will advance the FIFO to the next character and the next corresponding framing error.

The FERR bit can be forced clear by clearing the SPEN bit of the RCSTA register which resets the AUSART. Clearing the CREN bit of the RCSTA register does not affect the FERR bit. A framing error by itself does not generate an interrupt.

| Note: | If all receive characters in the receive  |
|-------|-------------------------------------------|
|       | FIFO have framing errors, repeated reads  |
|       | of the RCREG will not clear the FERR bit. |

### 16.1.2.5 Receive Overrun Error

The receive FIFO buffer can hold two characters. An overrun error will be generated if a third character, in its entirety, is received before the FIFO is accessed. When this happens the OERR bit of the RCSTA register is set. The characters already in the FIFO buffer can be read but no additional characters will be received until the error is cleared. The error must be cleared by either clearing the CREN bit of the RCSTA register or by setting the AUSART by clearing the SPEN bit of the RCSTA register.

#### 16.1.2.6 Receiving 9-bit Characters

The AUSART supports 9-bit character reception. When the RX9 bit of the RCSTA register is set the AUSART will shift nine bits into the RSR for each character received. The RX9D bit of the RCSTA register is the ninth and Most Significant data bit of the top unread character in the receive FIFO. When reading 9-bit data from the receive FIFO buffer, the RX9D data bit must be read before reading the eight Least Significant bits from the RCREG.

#### 16.1.2.7 Address Detection

A special Address Detection mode is available for use when multiple receivers share the same transmission line, such as in RS-485 systems. Address detection is enabled by setting the ADDEN bit of the RCSTA register.

Address detection requires 9-bit character reception. When address detection is enabled, only characters with the ninth data bit set will be transferred to the receive FIFO buffer, thereby setting the RCIF interrupt bit of the PIR1 register. All other characters will be ignored.

Upon receiving an address character, user software determines if the address matches its own. Upon address match, user software must disable address detection by clearing the ADDEN bit before the next Stop bit occurs. When user software detects the end of the message, determined by the message protocol used, software places the receiver back into the Address Detection mode by setting the ADDEN bit.



### FIGURE 17-4: SPI MODE WAVEFORM (SLAVE MODE WITH CKE = 0)

#### SS SCK (CKP = 0 $\dot{C}KE = 1)$ SCK (CKP = 1 CKE = 1) Write to SSPBUF bit 6 bit 5 bit 4 bit 2 bit 1 bit 0 SDO bit '7 bit 3 ï SDI (SMP = 0)I bit 0 bit 7 Input Sample (SMP = 0)SSPIF Interrupt Flag SSPSR to SSPBUF 1 . i . . . .

# FIGURE 17-5: SPI MODE WAVEFORM (SLAVE MODE WITH CKE = 1)

# 17.2.6 TRANSMISSION

When the R/W bit of the received address byte is set and an address match occurs, the R/W bit of the SSPSTAT register is set and the slave will respond to the master by reading out data. After the address match, an ACK pulse is generated by the slave hardware and the SCL pin is held low (clock is automatically stretched) until the slave is ready to respond. See **Section 17.2.7 "Clock Stretching"**. The data the slave will transmit must be loaded into the SSPBUF register, which sets the BF bit. The SCL line is released by setting the CKP bit of the SSPCON register.

An SSP interrupt is generated for each transferred data byte. The SSPIF flag bit of the PIR1 register initiates an SSP interrupt, and must be cleared by software before the next byte is transmitted. The BF bit of the SSPSTAT register is cleared on the falling edge of the eighth received clock pulse. The SSPIF flag bit is set on the falling edge of the ninth clock pulse. Following the eighth falling clock edge, control of the SDA line is released back to the master so that the master can acknowledge or not acknowledge the response. If the master sends a not acknowledge, the slave's transmission is complete and the slave must monitor for the next Start condition. If the master acknowledges, control of the bus is returned to the slave to transmit another byte of data. Just as with the previous byte, the clock is stretched by the slave, data must be loaded into the SSPBUF and CKP must be set to release the clock line (SCL).



### FIGURE 17-12: I<sup>2</sup>C WAVEFORMS FOR TRANSMISSION (7-BIT ADDRESS)

# FIGURE 24-7: PIC16F722/3/4/6/7 TYPICAL IDD vs. VDD OVER Fosc, EXTRC MODE, VCAP = $0.1 \mu$ F









#### FIGURE 24-33: PIC16F722/3/4/6/7 BOR IPD vs. VDD, VCAP = 0.1 µF







### FIGURE 24-61: PIC16F722/3/4/6/7 A/D INTERNAL RC OSCILLATOR PERIOD



FIGURE 24-62: PIC16F722/3/4/6/7 CAP SENSE OUTPUT CURRENT, POWER MODE = HIGH







# 44-Lead Plastic Thin Quad Flatpack (PT) – 10x10x1 mm Body, 2.00 mm [TQFP]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



#### Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. Chamfers at corners are optional; size may vary.

3. Dimensions D1 and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.25 mm per side.

4. Dimensioning and tolerancing per ASME Y14.5M.

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-076B

NOTES: