



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               | UART/USART                                                                |
| Peripherals                | Brown-out Detect/Reset, POR, WDT                                          |
| Number of I/O              | 12                                                                        |
| Program Memory Size        | 7KB (4K x 14)                                                             |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 256 x 8                                                                   |
| RAM Size                   | 256 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                 |
| Data Converters            | A/D 8x10b                                                                 |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 16-VQFN Exposed Pad                                                       |
| Supplier Device Package    | 16-QFN (4x4)                                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f688t-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.2 OPTION Register

The OPTION register is a readable and writable register, which contains various control bits to configure:

- Timer0/WDT prescaler
- External RA2/INT interrupt
- Timer0
- Weak pull-ups on PORTA

| Note:                    | To achieve a 1:1 prescaler assignment for |  |  |  |  |  |  |  |  |
|--------------------------|-------------------------------------------|--|--|--|--|--|--|--|--|
|                          | Timer0, assign the prescaler to the WDT   |  |  |  |  |  |  |  |  |
|                          | by setting PSA bit of the OPTION register |  |  |  |  |  |  |  |  |
|                          | to '1'. See Section 5.1.3 "Software       |  |  |  |  |  |  |  |  |
| Programmable Prescaler". |                                           |  |  |  |  |  |  |  |  |

### REGISTER 2-2: OPTION\_REG: OPTION REGISTER

| R/W-1                                                                | R/W-1                     | R/W-1            | R/W-1                     | R/W-1            | R/W-1     | R/W-1           | R/W-1 |  |  |  |
|----------------------------------------------------------------------|---------------------------|------------------|---------------------------|------------------|-----------|-----------------|-------|--|--|--|
| RAPU                                                                 | INTEDG                    | TOCS             | TOSE                      | PSA              | PS2       | PS1             | PS0   |  |  |  |
| bit 7                                                                |                           |                  |                           |                  |           |                 | bit 0 |  |  |  |
|                                                                      |                           |                  |                           |                  |           |                 |       |  |  |  |
| Legend:                                                              |                           |                  |                           |                  |           |                 |       |  |  |  |
| R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' |                           |                  |                           |                  |           |                 |       |  |  |  |
| -n = Value at P                                                      | OR                        | '1' = Bit is set |                           | '0' = Bit is cle | ared      | x = Bit is unkr | nown  |  |  |  |
|                                                                      |                           |                  |                           |                  |           |                 |       |  |  |  |
| bit 7                                                                | RAPU: PORT                | A Pull-up Enal   | ole bit                   |                  |           |                 |       |  |  |  |
|                                                                      | 1 = PORTA p               | ull-ups are disa | abled                     |                  |           |                 |       |  |  |  |
|                                                                      | 0 = PORTA p               | ull-ups are ena  | bled by indivi            | dual PORT late   | ch values |                 |       |  |  |  |
| bit 6                                                                | INTEDG: Inte              | rrupt Edge Sel   | ect bit                   |                  |           |                 |       |  |  |  |
|                                                                      | 1 = Interrupt c           | on rising edge   | of RA2/INT pi             | n                |           |                 |       |  |  |  |
| 1.5.5                                                                |                           | on failing edge  |                           | IN               |           |                 |       |  |  |  |
| DIT 5                                                                | TOCS: Timero              | Clock Source     | Select bit                |                  |           |                 |       |  |  |  |
|                                                                      | $\perp = 1$ ransition     | on RA2/10CK      | .i pin<br>. clock (Eosc// | 4)               |           |                 |       |  |  |  |
| hit 4                                                                |                           | ) Source Edge    | Select hit                | •)               |           |                 |       |  |  |  |
| bit 4                                                                | 1 = Increment             | t on high-to-lov | v transition on           | RA2/TOCKI ni     | 'n        |                 |       |  |  |  |
|                                                                      | 0 = Increment             | t on low-to-higi | transition on             | RA2/T0CKI pi     | n         |                 |       |  |  |  |
| bit 3                                                                | PSA: Prescal              | er Assignment    | bit                       |                  |           |                 |       |  |  |  |
|                                                                      | 1 = Prescaler             | is assigned to   | the WDT                   |                  |           |                 |       |  |  |  |
|                                                                      | 0 = Prescaler             | is assigned to   | the Timer0 m              | odule            |           |                 |       |  |  |  |
| bit 2-0                                                              | <b>PS&lt;2:0&gt;:</b> Pre | scaler Rate Se   | elect bits                |                  |           |                 |       |  |  |  |
|                                                                      | Bit \                     | /alue Timer0     | Rate WDT Ra               | ate              |           |                 |       |  |  |  |

| t value | Timeru Rate | WD1 Rate |
|---------|-------------|----------|
| 000     | 1:2         | 1:1      |
| 001     | 1:4         | 1:2      |
| 010     | 1:8         | 1:4      |
| 011     | 1:16        | 1:8      |
| 100     | 1:32        | 1:16     |
| 101     | 1:64        | 1:32     |
| 110     | 1 : 128     | 1:64     |
| 111     | 1 : 256     | 1 : 128  |
|         |             |          |

| IGURE 3-6:                              | INTERNAL OSCILLATOR SWITCH TIMING                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HF → LF <sup>(1)</sup><br>36378030362 3 | FINTOSC (FBCSS and WOT disabled)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| HFINTOSC                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| LFINTOSC                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IRCF <2:0>                              | $\neq 0$ $= 0$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| System Clock                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Store to Vitaa                          | n gearag fream Ciff to MIR.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| \$\$\$\$\$\$\$\$\$\$\$\$\$<br>\$\$\$    | LENNY COSIC (ENNY ar SECAN OF WILLY analysisci)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| HFINTOSC                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| LFINTOSC .                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IRCF <2:0>                              | $\neq 0 \qquad \qquad X = 0$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| System Clock                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| USBN2030 1                              | ATMATOSO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| LEBATOSC.                               | Image: Strategy in the second strategy in the |
| MERCOSO .                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| \$9:0F <2:6>                            | <u>4.9.</u> <u>4.9</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| System Chock                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

## 3.6 Clock Switching

The system clock source can be switched between external and internal clock sources via software using the System Clock Select (SCS) bit of the OSCCON register.

### 3.6.1 SYSTEM CLOCK SELECT (SCS) BIT

The System Clock Select (SCS) bit of the OSCCON register selects the system clock source that is used for the CPU and peripherals.

- When the SCS bit of the OSCCON register = 0, the system clock source is determined by configuration of the FOSC<2:0> bits in the Configuration Word register (CONFIG).
- When the SCS bit of the OSCCON register = 1, the system clock source is chosen by the internal oscillator frequency selected by the IRCF<2:0> bits of the OSCCON register. After a Reset, the SCS bit of the OSCCON register is always cleared.
- Note: Any automatic clock switch, which may occur from Two-Speed Start-up or Fail-Safe Clock Monitor, does not update the SCS bit of the OSCCON register. The user can monitor the OSTS bit of the OSCCON register to determine the current system clock source.

# 3.6.2 OSCILLATOR START-UP TIME-OUT STATUS (OSTS) BIT

The Oscillator Start-up Time-out Status (OSTS) bit of the OSCCON register indicates whether the system clock is running from the external clock source, as defined by the FOSC<2:0> bits in the Configuration Word register (CONFIG), or from the internal clock source. In particular, OSTS indicates that the Oscillator Start-up Timer (OST) has timed out for LP, XT or HS modes.

### 3.7 Two-Speed Clock Start-up Mode

Two-Speed Start-up mode provides additional power savings by minimizing the latency between external oscillator start-up and code execution. In applications that make heavy use of the Sleep mode, Two-Speed Start-up will remove the external oscillator start-up time from the time spent awake and can reduce the overall power consumption of the device.

This mode allows the application to wake-up from Sleep, perform a few instructions using the INTOSC as the clock source and go back to Sleep without waiting for the primary oscillator to become stable.

| Note: | Executing a SLEEP instruction will abort    |
|-------|---------------------------------------------|
|       | the oscillator start-up time and will cause |
|       | the OSTS bit of the OSCCON register to      |
|       | remain clear.                               |

When the oscillator module is configured for LP, XT or HS modes, the Oscillator Start-up Timer (OST) is enabled (see **Section 3.4.1 "Oscillator Start-up Timer (OST)"**). The OST will suspend program execution until 1024 oscillations are counted. Two-Speed Start-up mode minimizes the delay in code execution by operating from the internal oscillator as the OST is counting. When the OST count reaches 1024 and the OSTS bit of the OSCCON register is set, program execution switches to the external oscillator.

# 3.7.1 TWO-SPEED START-UP MODE CONFIGURATION

Two-Speed Start-up mode is configured by the following settings:

- IESO (of the Configuration Word register) = 1; Internal/External Switchover bit (Two-Speed Startup mode enabled).
- SCS (of the OSCCON register) = 0.
- FOSC<2:0> bits in the Configuration Word register (CONFIG) configured for LP, XT or HS mode.

Two-Speed Start-up mode is entered after:

- Power-on Reset (POR) and, if enabled, after Power-up Timer (PWRT) has expired, or
- Wake-up from Sleep.

If the external clock oscillator is configured to be anything other than LP, XT or HS mode, then Two-Speed Start-up is disabled. This is because the external clock oscillator does not require any stabilization time after POR or an exit from Sleep.

#### 3.7.2 TWO-SPEED START-UP SEQUENCE

- 1. Wake-up from Power-on Reset or Sleep.
- Instructions begin execution by the internal oscillator at the frequency set in the IRCF<2:0> bits of the OSCCON register.
- 3. OST enabled to count 1024 clock cycles.
- 4. OST timed out, wait for falling edge of the internal oscillator.
- 5. OSTS is set.
- 6. System clock held low until the next falling edge of new clock (LP, XT or HS mode).
- 7. System clock is switched to external clock source.

### FIGURE 7-2: COMPARATOR C1 OUTPUT BLOCK DIAGRAM



#### FIGURE 7-3: COMPARATOR C2 OUTPUT BLOCK DIAGRAM



#### EXAMPLE 8-1: A/D CONVERSION

```
;This code block configures the ADC
; for polling, Vdd reference, Frc clock
;and AN0 input.
;
;Conversion start & polling for completion
; are included.
;
BANKSEL ADCON1
                      ;
MOVLW B'01110000' ;ADC Frc clock
MOVWF ADCON1
                      ;
BANKSEL TRISA
                     ;
BSF TRISA,0 ;Set RA0 to input
BANKSEL ANSEL ;
BSF ANSEL,0 ;Set RA0 to analog
BANKSEL ADCON0
                      ;
MOVLW B'10000001' ;Right justify,
MOVWF ADCON0 ;Vdd Vref, ANO,
                      ;Vdd Vref, AN0, On
CALL SampleTime ;Acquisiton delay
BSF ADCON0,GO ;Start conversion
BTFSC ADCON0,GO ;Is conversion done?
                  ;No, test again
GOTO $-1
BANKSEL ADRESH
                    ;
MOVF ADRESH,W ;Read upper 2 bits
MOVWF RESULTHI ;store in GPR space
BANKSEL ADRESL ;
MOVF ADRESL,W ;Read lower 8 bits
MOVWF RESULTLO ;Store in GPR space
```

#### 10.1.2 EUSART ASYNCHRONOUS RECEIVER

The Asynchronous mode would typically be used in RS-232 systems. The receiver block diagram is shown in Figure 10-2. The data is received on the RX/DT pin and drives the data recovery block. The data recovery block is actually a high-speed shifter operating at 16 times the baud rate, whereas the serial Receive Shift Register (RSR) operates at the bit rate. When all 8 or 9 bits of the character have been shifted in, they are immediately transferred to a two character First-In-First-Out (FIFO) memory. The FIFO buffering allows reception of two complete characters and the start of a third character before software must start servicing the EUSART receiver. The FIFO and RSR registers are not directly accessible by software. Access to the received data is via the RCREG register.

#### 10.1.2.1 Enabling the Receiver

The EUSART receiver is enabled for asynchronous operation by configuring the following three control bits:

- CREN = 1
- SYNC = 0
- SPEN = 1

All other EUSART control bits are assumed to be in their default state.

Setting the CREN bit of the RCSTA register enables the receiver circuitry of the EUSART. Clearing the SYNC bit of the TXSTA register configures the EUSART for asynchronous operation. Setting the SPEN bit of the RCSTA register enables the EUSART and automatically configures the RX/DT I/O pin as an input. If the RX/DT pin is shared with an analog peripheral the analog I/O function must be disabled by clearing the corresponding ANSEL bit.

Note: When the SPEN bit is set the TX/CK I/O pin is automatically configured as an output, regardless of the state of the corresponding TRIS bit and whether or not the EUSART transmitter is enabled. The PORT latch is disconnected from the output driver so it is not possible to use the TX/CK pin as a general purpose output.

#### 10.1.2.2 Receiving Data

The receiver data recovery circuit initiates character reception on the falling edge of the first bit. The first bit, also known as the Start bit, is always a zero. The data recovery circuit counts one-half bit time to the center of the Start bit and verifies that the bit is still a zero. If it is not a zero then the data recovery circuit aborts character reception, without generating an error, and resumes looking for the falling edge of the Start bit. If the Start bit zero verification succeeds then the data recovery circuit counts a full bit time to the center of the next bit. The bit is then sampled by a majority detect circuit and the resulting '0' or '1' is shifted into the RSR. This repeats until all data bits have been sampled and shifted into the RSR. One final bit time is measured and the level sampled. This is the Stop bit, which is always a '1'. If the data recovery circuit samples a '0' in the Stop bit position then a framing error is set for this character, otherwise the framing error is cleared for this character. See Section 10.1.2.4 "Receive Framing Error" for more information on framing errors.

Immediately after all data bits and the Stop bit have been received, the character in the RSR is transferred to the EUSART receive FIFO and the RCIF interrupt flag bit of the PIR1 register is set. The top character in the FIFO is transferred out of the FIFO by reading the RCREG register.

| Note: | If the receive FIFO is overrun, no additional characters will be received until the overrun |  |  |  |  |  |  |  |
|-------|---------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|       | condition is cleared. See Section 10.1.2.5                                                  |  |  |  |  |  |  |  |
|       | "Receive Overrun Error" for more                                                            |  |  |  |  |  |  |  |
|       | information on overrun errors.                                                              |  |  |  |  |  |  |  |

#### 10.1.2.3 Receive Interrupts

The RCIF interrupt flag bit of the PIR1 register is set whenever the EUSART receiver is enabled and there is an unread character in the receive FIFO. The RCIF interrupt flag bit is read-only, it cannot be set or cleared by software.

RCIF interrupts are enabled by setting the following bits:

- RCIE interrupt enable bit of the PIE1 register
- PEIE peripheral interrupt enable bit of the INT-CON register
- GIE global interrupt enable bit of the INTCON register

The RCIF interrupt flag bit will be set when there is an unread character in the FIFO, regardless of the state of interrupt enable bits.

#### 10.4.1.5 Synchronous Master Reception

Data is received at the RX/DT pin. The RX/DT and TX/ CK pin output drivers are automatically disabled when the EUSART is configured for synchronous master receive operation.

In Synchronous mode, reception is enabled by setting either the Single Receive Enable bit (SREN of the RCSTA register) or the Continuous Receive Enable bit (CREN of the RCSTA register).

When SREN is set and CREN is clear, only as many clock cycles are generated as there are data bits in a single character. The SREN bit is automatically cleared at the completion of one character. When CREN is set, clocks are continuously generated until CREN is cleared. If CREN is cleared in the middle of a character the CK clock stops immediately and the partial character is discarded. If SREN and CREN are both set, then SREN is cleared at the completion of the first character and CREN takes precedence.

To initiate reception, set either SREN or CREN. Data is sampled at the RX/DT pin on the trailing edge of the TX/CK clock pin and is shifted into the Receive Shift Register (RSR). When a complete character is received into the RSR, the RCIF bit is set and the character is automatically transferred to the two character receive FIFO. The Least Significant eight bits of the top character in the receive FIFO are available in RCREG. The RCIF bit remains set as long as there are un-read characters in the receive FIFO.

#### 10.4.1.6 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 RCREG is read to access the FIFO. When this happens the OERR bit of the RCSTA register is set. Previous data in the FIFO will not be overwritten. The two characters in the FIFO buffer can be read, however, no additional characters will be received until the error is cleared. The OERR bit can only be cleared by clearing the overrun condition. If the overrun error occurred when the SREN bit is set and CREN is clear then the error is cleared by reading RCREG. If the overrun occurred when the CREN bit is set then the error condition is cleared by either clearing the CREN bit of the RCSTA register or by clearing the SPEN bit which resets the EUSART.

#### 10.4.1.7 Receiving 9-bit Characters

The EUSART supports 9-bit character reception. When the RX9 bit of the RCSTA register is set the EUSART will shift 9-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 8 Least Significant bits from the RCREG.

- 10.4.1.8 Synchronous Master Reception Setup:
- 1. Initialize the SPBRGH, SPBRG register pair for the appropriate baud rate. Set or clear the BRGH and BRG16 bits, as required, to achieve the desired baud rate.
- 2. Enable the synchronous master serial port by setting bits SYNC, SPEN and CSRC.
- 3. Ensure bits CREN and SREN are clear.
- 4. If using interrupts, set the GIE and PEIE bits of the INTCON register and set RCIE.
- 5. If 9-bit reception is desired, set bit RX9.
- 6. Start reception by setting the SREN bit or for continuous reception, set the CREN bit.
- 7. Interrupt flag bit RCIF will be set when reception of a character is complete. An interrupt will be generated if the enable bit RCIE was set.
- 8. Read the RCSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception.
- 9. Read the 8-bit received data by reading the RCREG register.
- 10. If an overrun error occurs, clear the error by either clearing the CREN bit of the RCSTA register or by clearing the SPEN bit which resets the EUSART.

#### 11.2.5 TIME-OUT SEQUENCE

On power-up, the time-out sequence is as follows: first, PWRT time-out is invoked after POR has expired, then OST is activated after the PWRT time-out has expired. The total time-out will vary based on oscillator configuration and PWRTE bit status. For example, in EC mode with PWRTE bit erased (PWRT disabled), there will be no time-out at all. Figure 11.2.1, Figure 11-5 and Figure 11-6 depict time-out sequences. The device can execute code from the INTOSC while OST is active by enabling Two-Speed Start-up or Fail-Safe Monitor (see Section 3.7.2 "Two-Speed Start-up Sequence" and Section 3.8 "Fail-Safe Clock Monitor").

Since the time-outs occur from the POR pulse, if MCLR is kept low long enough, the time-outs will expire. Then, bringing MCLR high will begin execution immediately (see Figure 11-5). This is useful for testing purposes or to synchronize more than one PIC16F688 device operating in parallel.

Table 11-5 shows the Reset conditions for some special registers, while Table 11-4 shows the Reset conditions for all the registers.

#### 11.2.6 POWER CONTROL (PCON) REGISTER

The Power Control (PCON) register (address 8Eh) has two Status bits to indicate what type of Reset that last occurred.

Bit 0 is BOR (Brown-out). BOR is unknown on Power-on Reset. It must then be set by the user and checked on subsequent Resets to see if  $\overline{BOR} = 0$ , indicating that a Brown-out has occurred. The BOR Status bit is a "don't care" and is not necessarily predictable if the brown-out circuit is disabled (BOREN<1:0> = 00 in the Configuration Word register).

Bit 1 is POR (Power-on Reset). It is a '0' on Power-on Reset and unaffected otherwise. The user must write a '1' to this bit following a Power-on Reset. On a subsequent Reset, if POR is '0', it will indicate that a Power-on Reset has occurred (i.e., VDD may have gone too low).

For more information, see Section 4.2.4 "Ultra Low-Power Wake-up" Section 11.2.4 and "Brown-Out Reset (BOR)".

| Oscillator Configuration | Powe                   | er-up       | Brown-o                | Wake-up     |             |
|--------------------------|------------------------|-------------|------------------------|-------------|-------------|
| Oscillator Configuration | <b>PWRTE</b> = 0       | PWRTE = 1   | <b>PWRTE</b> = 0       | PWRTE = 1   | from Sleep  |
| XT, HS, LP               | TPWRT + 1024<br>• Tosc | 1024 • Tosc | TPWRT + 1024<br>• Tosc | 1024 • Tosc | 1024 • Tosc |
| RC, EC, INTOSC           | TPWRT                  | —           | TPWRT                  | —           | —           |

#### TIME-OUT IN VARIOUS SITUATIONS **TABLE 11-1:**

| TABLE 11-2: | PCON BITS AND THEIR SIGNIFICANCE |
|-------------|----------------------------------|
|             |                                  |

| POR | BOR | то | PD | Condition                          |
|-----|-----|----|----|------------------------------------|
| 0   | u   | 1  | 1  | Power-on Reset                     |
| 1   | 0   | 1  | 1  | Brown-out Reset                    |
| u   | u   | 0  | u  | WDT Reset                          |
| u   | u   | 0  | 0  | WDT Wake-up                        |
| u   | u   | u  | u  | MCLR Reset during normal operation |
| u   | u   | 1  | 0  | MCLR Reset during Sleep            |

**Legend:** u = unchanged, x = unknown

#### **TABLE 11-3**: SUMMARY OF REGISTERS ASSOCIATED WITH BROWN-OUT RESET

| Name                  | Bit 9  | Bit 8  | 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 <sup>(1)</sup> |
|-----------------------|--------|--------|-------|-------|--------|--------|-------|-------|-------|-------|----------------------|------------------------------------------------|
| CONFIG <sup>(2)</sup> | BOREN1 | BOREN0 | CPD   | CP    | MCLRE  | PWRTE  | WDTE  | FOSC2 | FOSC1 | FOSC0 | _                    | _                                              |
| PCON                  |        |        |       | _     | ULPWUE | SBOREN | _     | _     | POR   | BOR   | 01qq                 | 0uuu                                           |
| STATUS                |        |        | IRP   | RP1   | RP0    | TO     | PD    | Z     | DC    | С     | 0001 1xxx            | 000q quuu                                      |

u = unchanged, x = unknown, - = unimplemented bit, reads as '0', q = value depends on condition. Shaded cells are not used by BOR. Other (non Power-up) Resets include MCLR Reset and Watchdog Timer Reset during normal operation. Legend: 1:

See Configuration Word register (Register 11-1) for operation of all register bits. 2.

Note



- 4: For minimum width of INT pulse, refer to AC specifications in Section 14.0 "Electrical Specifications".
- 5: INTF is enabled to be set any time during the Q4-Q1 cycles.

#### TABLE 11-6: SUMMARY OF REGISTERS ASSOCIATED WITH INTERRUPTS

| 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  | RAIE  | T0IF  | INTF  | RAIF   | 0000 000x            | 0000 000x                       |
| PIE1   | EEIE  | ADIE  | RCIE  | C2IE  | C1IE  | OSFIE | TXIE  | TMR1IE | 0000 0000            | 0000 0000                       |
| PIR1   | EEIF  | ADIF  | RCIF  | C2IF  | C1IF  | OSFIF | TXIF  | TMR1IF | 0000 0000            | 0000 0000                       |

**Legend:** x = unknown, u = unchanged, - = unimplemented read as '0', q = value depends upon condition. Shaded cells are not used by the Interrupt module.

NOTES:

# 14.0 ELECTRICAL SPECIFICATIONS

## Absolute Maximum Ratings<sup>(†)</sup>

| Ambient temperature under bias                                                                                | 40° to +125°C                       |
|---------------------------------------------------------------------------------------------------------------|-------------------------------------|
| Storage temperature                                                                                           | 65°C to +150°C                      |
| Voltage on VDD with respect to Vss                                                                            | 0.3V to +6.5V                       |
| Voltage on MCLR with respect to Vss                                                                           | 0.3V to +13.5V                      |
| Voltage on all other pins with respect to Vss                                                                 | 0.3V to (VDD + 0.3V)                |
| Total power dissipation <sup>(1)</sup>                                                                        |                                     |
| Maximum current out of Vss pin                                                                                | 95 mA                               |
| Maximum current into Vod pin                                                                                  | 95 mA                               |
| Input clamp current, Iıк (Vı < 0 or Vı > VDD)                                                                 | ± 20 mA                             |
| Output clamp current, Iок (Vo < 0 or Vo >VDD)                                                                 | ± 20 mA                             |
| Maximum output current sunk by any I/O pin                                                                    | 25 mA                               |
| Maximum output current sourced by any I/O pin                                                                 |                                     |
| Maximum current sunk by PORTA and PORTC (combined)                                                            | 90 mA                               |
| Maximum current sourced PORTA and PORTC (combined)                                                            | 90 mA                               |
| <b>Note 1:</b> Power dissipation is calculated as follows: PDIS = VDD x {IDD $-\sum$ IOH} + $\sum$ {(VD IOL). | $D - VOH$ ) x IOH} + $\Sigma(VOI x$ |

† NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure above maximum rating conditions for extended periods may affect device reliability.





#### TABLE 14-3: CLKOUT AND I/O TIMING PARAMETERS

| Standard Operating Conditions (unless otherwise stated)<br>Operating Temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ |          |                                                             |               |      |     |       |            |
|--------------------------------------------------------------------------------------------------------------------------|----------|-------------------------------------------------------------|---------------|------|-----|-------|------------|
| Param<br>No.                                                                                                             | Sym      | Characteristic                                              | Min           | Тур† | Max | Units | Conditions |
| OS11                                                                                                                     | TosH2ckL | Fosc↑ to CLKOUT↓ <sup>(1)</sup>                             | —             | _    | 70  | ns    | VDD = 5.0V |
| OS12                                                                                                                     | TosH2ckH | Fosc↑ to CLKOUT↑ <sup>(1)</sup>                             | —             | _    | 72  | ns    | VDD = 5.0V |
| OS13                                                                                                                     | TCKL2IOV | CLKOUT↓ to Port out valid <sup>(1)</sup>                    | —             | _    | 20  | ns    |            |
| OS14                                                                                                                     | ТюV2скН  | Port input valid before CLKOUT <sup>(1)</sup>               | Tosc + 200 ns | —    |     | ns    |            |
| OS15*                                                                                                                    | TosH2ıoV | Fosc↑ (Q1 cycle) to Port out valid                          | —             | 50   | 70  | ns    | VDD = 5.0V |
| OS16                                                                                                                     | TosH2ıol | Fosc↑ (Q2 cycle) to Port input invalid (I/O in hold time)   | 50            |      | —   | ns    | VDD = 5.0V |
| OS17                                                                                                                     | TioV2osH | Port input valid to Fosc↑ (Q2 cycle)<br>(I/O in setup time) | 20            |      | —   | ns    |            |
| OS18                                                                                                                     | TIOR     | Port output rise time <sup>(2)</sup>                        | —             | 15   | 72  | ns    | VDD = 2.0V |
|                                                                                                                          |          |                                                             | —             | 10   | 32  |       | VDD = 5.0V |
| OS19                                                                                                                     | TIOF     | Port output fall time <sup>(2)</sup>                        | —             | 28   | 55  | ns    | VDD = 2.0V |
|                                                                                                                          |          |                                                             | —             | 15   | 30  |       | VDD = 5.0V |
| OS20*                                                                                                                    | TINP     | INT pin input high or low time                              | 25            | _    | _   | ns    |            |
| OS21*                                                                                                                    | Trap     | PORTA interrupt-on-change new input level time              | Тсү           | _    | —   | ns    |            |

\* These parameters are characterized but not tested.

 $\dagger~$  Data in "Typ" column is at 5.0V, 25°C unless otherwise stated.

Note 1: Measurements are taken in RC mode where CLKOUT output is 4 x Tosc.

2: Includes OSC2 in CLKOUT mode.

#### TABLE 14-6: COMPARATOR SPECIFICATIONS

| Standard Operating Conditions (unless otherwise stated)<br>Operating Temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ |         |                                           |         |     |       |           |       |               |
|--------------------------------------------------------------------------------------------------------------------------|---------|-------------------------------------------|---------|-----|-------|-----------|-------|---------------|
| Param<br>No.                                                                                                             | Sym     | Characteristics                           |         | Min | Тур†  | Max       | Units | Comments      |
| CM01                                                                                                                     | Vos     | Input Offset Voltage                      |         | _   | ± 5.0 | ± 10      | mV    | (Vdd - 1.5)/2 |
| CM02                                                                                                                     | Vсм     | Input Common Mode Voltage                 |         | 0   |       | Vdd - 1.5 | V     |               |
| CM03*                                                                                                                    | CMRR    | Common Mode Rejection Ratio               |         | +55 | _     | _         | dB    |               |
| CM04*                                                                                                                    | Trt     | Response Time                             | Falling | _   | 150   | 600       | ns    | (NOTE 1)      |
|                                                                                                                          |         |                                           | Rising  |     | 200   | 1000      | ns    |               |
| CM05*                                                                                                                    | Тмc2coV | Comparator Mode Change to<br>Output Valid |         |     |       | 10        | μS    |               |

These parameters are characterized but not tested.

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

Note 1: Response time is measured with one comparator input at (VDD - 1.5)/2 - 100 mV to (VDD - 1.5)/2 + 20 mV.

#### TABLE 14-7: COMPARATOR VOLTAGE REFERENCE (CVREF) SPECIFICATIONS

| Standard Operating Conditions (unless otherwise stated) |                     |  |  |  |  |
|---------------------------------------------------------|---------------------|--|--|--|--|
| Operating temperature                                   | -40°C < TA < +125°C |  |  |  |  |

| Param<br>No. | Sym  | Characteristics              | Min | Тур†   | Max   | Units | Comments             |
|--------------|------|------------------------------|-----|--------|-------|-------|----------------------|
| CV01*        | CLSB | Step Size <sup>(2)</sup>     | —   | VDD/24 | _     | V     | Low Range (VRR = 1)  |
|              |      |                              | —   | VDD/32 |       | V     | High Range (VRR = 0) |
| CV02*        | CACC | Absolute Accuracy            | —   | —      | ± 1/2 | LSb   | Low Range (VRR = 1)  |
|              |      |                              | —   | —      | ± 1/2 | LSb   | High Range (VRR = 0) |
| CV03*        | CR   | Unit Resistor Value (R)      | _   | 2k     | _     | Ω     |                      |
| CV04*        | CST  | Settling Time <sup>(1)</sup> | _   |        | 10    | μS    |                      |

\* These parameters are characterized but not tested.

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

**Note 1:** Settling time measured while VRR = 1 and VR<3:0> transitions from '0000' to '1111'.

2: See Section 7.10 "Comparator Voltage Reference" for more information.



FIGURE 15-4: MAXIMUM IDD vs. Fosc OVER VDD (HS MODE)















FIGURE 15-14: MAXIMUM IPD vs. VDD (SLEEP MODE, ALL PERIPHERALS DISABLED)







#### FIGURE 15-38: TYPICAL HFINTOSC FREQUENCY CHANGE OVER DEVICE VDD (85°C)





14-Lead Plastic Thin Shrink Small Outline (ST) - 4.4 mm Body [TSSOP]

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



## RECOMMENDED LAND PATTERN

|                          | N   | ILLIMETER | S        |      |
|--------------------------|-----|-----------|----------|------|
| Dimension                | MIN | NOM       | MAX      |      |
| Contact Pitch            | E   |           | 0.65 BSC |      |
| Contact Pad Spacing      | C1  |           | 5.90     |      |
| Contact Pad Width (X28)  | X1  |           |          | 0.45 |
| Contact Pad Length (X28) | Y1  |           |          | 1.45 |
| Distance Between Pads    | G   | 0.20      |          |      |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

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

Microchip Technology Drawing No. C04-2087A

## THE MICROCHIP WEB SITE

Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information:

- Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

# CUSTOMER CHANGE NOTIFICATION SERVICE

Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, access the Microchip web site at www.microchip.com, click on Customer Change Notification and follow the registration instructions.

## **CUSTOMER SUPPORT**

Users of Microchip products can receive assistance through several channels:

- Distributor or Representative
- Local Sales Office
- Field Application Engineer (FAE)
- Technical Support
- Development Systems Information Line

Customers should contact their distributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document.

Technical support is available through the web site at: http://support.microchip.com

## **READER RESPONSE**

It is our intention to provide you with the best documentation possible to ensure successful use of your Microchip product. If you wish to provide your comments on organization, clarity, subject matter, and ways in which our documentation can better serve you, please FAX your comments to the Technical Publications Manager at (480) 792-4150.

Please list the following information, and use this outline to provide us with your comments about this document.

| To:  | Technical Publications Manager         | Total Pages Sent                                       |
|------|----------------------------------------|--------------------------------------------------------|
| RE:  | Reader Response                        |                                                        |
| Fron | n: Name                                |                                                        |
|      | Company                                |                                                        |
|      | Address                                |                                                        |
|      | City / State / ZIP / Country           |                                                        |
|      | Telephone: ()                          | FAX: ()                                                |
| Appl | ication (optional):                    |                                                        |
| Wou  | ld you like a reply?YN                 |                                                        |
| Devi | ce: PIC16F688                          | Literature Number: DS41203E                            |
| Que  | stions:                                |                                                        |
| 1. \ | What are the best features of this do  | cument?                                                |
|      |                                        |                                                        |
| -    |                                        |                                                        |
| 2.   | How does this document meet your h     | nardware and software development needs?               |
|      |                                        |                                                        |
| _    |                                        |                                                        |
| 3.   | Do you find the organization of this d | ocument easy to follow? If not, why?                   |
| -    |                                        |                                                        |
| -    |                                        |                                                        |
| 4. \ | What additions to the document do y    | ou think would enhance the structure and subject?      |
| -    |                                        |                                                        |
| -    |                                        |                                                        |
| 5.   | What deletions from the document co    | ould be made without affecting the overall usefulness? |
| -    |                                        |                                                        |
| -    |                                        |                                                        |
| 6. I | s there any incorrect or misleading in | nformation (what and where)?                           |
| -    |                                        |                                                        |
| -    |                                        |                                                        |
| 7. I | How would you improve this docume      | nt?                                                    |
| -    |                                        |                                                        |
| -    |                                        |                                                        |