



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

Email: info@E-XFL.COM

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

#### FIGURE 5-3: QUARTZ CRYSTAL OPERATION (LP, XT OR HS MODE)



- Note 1: Quartz crystal characteristics vary according to type, package and manufacturer. The user should consult the manufacturer data sheets for specifications and recommended application.
  - 2: Always verify oscillator performance over the VDD and temperature range that is expected for the application.
  - **3:** For oscillator design assistance, reference the following Microchip Applications Notes:
    - AN826, "Crystal Oscillator Basics and Crystal Selection for rfPIC<sup>®</sup> and PIC<sup>®</sup> Devices" (DS00826)
    - AN849, "Basic PIC<sup>®</sup> Oscillator Design" (DS00849)
    - AN943, "Practical PIC<sup>®</sup> Oscillator Analysis and Design" (DS00943)
    - AN949, "Making Your Oscillator Work" (DS00949)

FIGURE 5-4:

#### CERAMIC RESONATOR OPERATION (XT OR HS MODE)



# 5.2.1.3 Oscillator Start-up Timer (OST)

If the oscillator module is configured for LP, XT or HS modes, the Oscillator Start-up Timer (OST) counts 1024 oscillations from OSC1. This occurs following a Power-on Reset (POR) and when the Power-up Timer (PWRT) has expired (if configured), or a wake-up from Sleep. During this time, the program counter does not increment and program execution is suspended, unless either FSCM or Two-Speed Start-Up are enabled. In this case, code will continue to execute at the selected INTOSC frequency while the OST is counting. The OST ensures that the oscillator circuit, using a quartz crystal resonator or ceramic resonator, has started and is providing a stable system clock to the oscillator module.

In order to minimize latency between external oscillator start-up and code execution, the Two-Speed Clock Start-up mode can be selected (see **Section 5.4 "Two-Speed Clock Start-up Mode"**).

#### 6.4 Low-Power Brown-Out Reset (LPBOR)

The Low-Power Brown-out Reset (LPBOR) operates like the BOR to detect low voltage conditions on the VDD pin. When too low of a voltage is detected, the device is held in Reset. When this occurs, a register bit (BOR) is changed to indicate that a BOR Reset has occurred. The BOR bit in PCON is used for both BOR and the LPBOR. Refer to Register 6-2.

The LPBOR voltage threshold (Lapboard) has a wider tolerance than the BOR (Vpor), but requires much less current (LPBOR current) to operate. The LPBOR is intended for use when the BOR is configured as disabled (BOREN = 00) or disabled in Sleep mode (BOREN = 10).

Refer to Figure 6-1 to see how the LPBOR interacts with other modules.

#### 6.4.1 ENABLING LPBOR

The LPBOR is controlled by the LPBOR bit of Configuration Words. When the device is erased, the LPBOR module defaults to disabled.

# 6.5 MCLR

The  $\overline{\text{MCLR}}$  is an optional external input that can reset the device. The  $\overline{\text{MCLR}}$  function is controlled by the MCLRE bit of Configuration Words and the LVP bit of Configuration Words (Table 6-2).

# TABLE 6-2: MCLR CONFIGURATION

| MCLRE | LVP | MCLR     |
|-------|-----|----------|
| 0     | 0   | Disabled |
| 1     | 0   | Enabled  |
| x     | 1   | Enabled  |

# 6.5.1 MCLR ENABLED

When  $\overline{\text{MCLR}}$  is enabled and the pin is held low, the device is held in Reset. The  $\overline{\text{MCLR}}$  pin is connected to VDD through an internal weak pull-up.

The device has a noise filter in the  $\overline{\text{MCLR}}$  Reset path. The filter will detect and ignore small pulses.

# **Note:** A Reset does not drive the MCLR pin low.

# 6.5.2 MCLR DISABLED

When MCLR is disabled, the pin functions as a general purpose input and the internal weak pull-up is under software control. See **Section 11.3 "PORTA Registers"** for more information.

### 6.6 Watchdog Timer (WDT) Reset

The Watchdog Timer generates a Reset if the firmware does not issue a CLRWDT instruction within the time-out period. The TO and PD bits in the STATUS register are changed to indicate the WDT Reset. See **Section 9.0 "Watchdog Timer (WDT)"** for more information.

### 6.7 RESET Instruction

A RESET instruction will cause a device Reset. The  $\overline{RI}$  bit in the PCON register will be set to '0'. See Table 6-4 for default conditions after a RESET instruction has occurred.

# 6.8 Stack Overflow/Underflow Reset

The device can reset when the Stack Overflows or Underflows. The STKOVF or STKUNF bits of the PCON register indicate the Reset condition. These Resets are enabled by setting the STVREN bit in Configuration Words. See **Section 3.5.2 "Overflow/Underflow Reset"** for more information.

# 6.9 Programming Mode Exit

Upon exit of Programming mode, the device will behave as if a POR had just occurred.

# 6.10 Power-Up Timer

The Power-up Timer optionally delays device execution after a BOR or POR event. This timer is typically used to allow VDD to stabilize before allowing the device to start running.

The Power-up Timer is controlled by the  $\overrightarrow{\mathsf{PWRTE}}$  bit of Configuration Words.

# 6.11 Start-up Sequence

Upon the release of a POR or BOR, the following must occur before the device will begin executing:

- 1. Power-up Timer runs to completion (if enabled).
- 2. MCLR must be released (if enabled).

The total time-out will vary based on oscillator configuration and Power-up Timer configuration. See **Section 5.0 "Oscillator Module (With Fail-Safe Clock Monitor)"** for more information.

The Power-up Timer runs independently of MCLR Reset. If MCLR is kept low long enough, the Power-up Timer will expire. Upon bringing MCLR high, the device will begin execution after 10 Foss cycles (see Figure 6-3). This is useful for testing purposes or to synchronize more than one device operating in parallel.

### 7.3 Interrupts During Sleep

Some interrupts can be used to wake from Sleep. To wake from Sleep, the peripheral must be able to operate without the system clock. The interrupt source must have the appropriate Interrupt Enable bit(s) set prior to entering Sleep.

On waking from Sleep, if the GIE bit is also set, the processor will branch to the interrupt vector. Otherwise, the processor will continue executing instructions after the SLEEP instruction. The instruction directly after the SLEEP instruction will always be executed before branching to the ISR. Refer to **Section 8.0 "Power-Down Mode (Sleep)"** for more details.

# 7.4 INT Pin

The INT pin can be used to generate an asynchronous edge-triggered interrupt. This interrupt is enabled by setting the INTE bit of the INTCON register. The INTEDG bit of the OPTION\_REG register determines on which edge the interrupt will occur. When the INTEDG bit is set, the rising edge will cause the interrupt. When the INTEDG bit is clear, the falling edge will cause the interrupt. The INTF bit of the INTCON register will be set when a valid edge appears on the INT pin. If the GIE and INTE bits are also set, the processor will redirect program execution to the interrupt vector.

# 7.5 Automatic Context Saving

Upon entering an interrupt, the return PC address is saved on the stack. Additionally, the following registers are automatically saved in the shadow registers:

- W register
- STATUS register (except for TO and PD)
- BSR register
- FSR registers
- PCLATH register

Upon exiting the Interrupt Service Routine, these registers are automatically restored. Any modifications to these registers during the ISR will be lost. If modifications to any of these registers are desired, the corresponding shadow register should be modified and the value will be restored when exiting the ISR. The shadow registers are available in Bank 31 and are readable and writable. Depending on the user's application, other registers may also need to be saved.

# 10.3 Modifying Flash Program Memory

When modifying existing data in a program memory row, and data within that row must be preserved, it must first be read and saved in a RAM image. Program memory is modified using the following steps:

- 1. Load the starting address of the row to be modified.
- 2. Read the existing data from the row into a RAM image.
- 3. Modify the RAM image to contain the new data to be written into program memory.
- 4. Load the starting address of the row to be rewritten.
- 5. Erase the program memory row.
- 6. Load the write latches with data from the RAM image.
- 7. Initiate a programming operation.

#### FIGURE 10-7: FLASH PROGRAM MEMORY MODIFY FLOWCHART



### 13.3 Register Definitions: FVR Control

| R/W-0/0                                                                                                                                                    | R-q/q                                                                                                                                                                                                                                                                                                                                                                                                                            | R/W-0/0                                                                            | R/W-0/0                                                                 | R/W-0/0                                                                            | R/W-0/0                                              | R/W-0/0                                                        | R/W-0/0                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------------------------|-----------------------------------------|
| FVREN <sup>(1)</sup>                                                                                                                                       | ) FVRRDY <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                                                                          | TSEN <sup>(3)</sup>                                                                | TSRNG <sup>(3)</sup>                                                    | CDAFV                                                                              | ′R<1:0> <b>(1)</b>                                   | ADFVR                                                          | <1:0> <sup>(1)</sup>                    |
| bit 7                                                                                                                                                      | ÷                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                    |                                                                         |                                                                                    |                                                      |                                                                | bit (                                   |
|                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                    |                                                                         |                                                                                    |                                                      |                                                                |                                         |
| Legend:                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                    |                                                                         |                                                                                    |                                                      |                                                                |                                         |
| R = Readab                                                                                                                                                 | ole bit                                                                                                                                                                                                                                                                                                                                                                                                                          | W = Writable                                                                       | bit                                                                     | U = Unimplei                                                                       | mented bit, read                                     | as '0'                                                         |                                         |
| u = Bit is un                                                                                                                                              | nchanged                                                                                                                                                                                                                                                                                                                                                                                                                         | x = Bit is unki                                                                    | nown                                                                    | -n/n = Value                                                                       | at POR and BOI                                       | R/Value at all c                                               | other Resets                            |
| '1' = Bit is s                                                                                                                                             | et                                                                                                                                                                                                                                                                                                                                                                                                                               | '0' = Bit is cle                                                                   | ared                                                                    | q = Value de                                                                       | pends on condit                                      | ion                                                            |                                         |
| bit 7 <b>FVREN:</b> Fixed Voltage Reference Enable bit <sup>(1)</sup><br>1 = Fixed Voltage Reference is enabled<br>0 = Fixed Voltage Reference is disabled |                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                    |                                                                         |                                                                                    |                                                      |                                                                |                                         |
| bit 6                                                                                                                                                      | bit 6 <b>FVRRDY:</b> Fixed Voltage Reference Ready Flag bit <sup>(2)</sup><br>1 = Fixed Voltage Reference output is ready for use<br>0 = Fixed Voltage Reference output is not ready or not enabled                                                                                                                                                                                                                              |                                                                                    |                                                                         |                                                                                    |                                                      |                                                                |                                         |
| bit 5                                                                                                                                                      | <b>TSEN:</b> Temperat<br>1 = Temperat<br>0 = Temperat                                                                                                                                                                                                                                                                                                                                                                            | erature Indicato<br>ture Indicator is<br>ture Indicator is                         | or Enable bit <sup>(3)</sup><br>s enabled<br>s disabled                 | )                                                                                  |                                                      |                                                                |                                         |
| bit 4                                                                                                                                                      | <b>TSRNG:</b> Tem<br>1 = VOUT = V<br>0 = VOUT = V                                                                                                                                                                                                                                                                                                                                                                                | perature Indica<br>′DD - 4V⊤ (High<br>′DD - 2V⊤ (Low                               | ator Range Se<br>Range)<br>Range)                                       | lection bit <sup>(3)</sup>                                                         |                                                      |                                                                |                                         |
| bit 3-2                                                                                                                                                    | <b>CDAFVR&lt;1:0&gt;:</b> Comparator FVR Buffer Gain Selection bits <sup>(1)</sup><br>11 = Comparator FVR Buffer Gain is 4x, with output voltage = 4x VFVR (4.096V nominal) <sup>(4)</sup><br>10 = Comparator FVR Buffer Gain is 2x, with output voltage = 2x VFVR (2.048V nominal) <sup>(4)</sup><br>01 = Comparator FVR Buffer Gain is 1x, with output voltage = 1x VFVR (1.024V nominal)<br>00 = Comparator FVR Buffer is off |                                                                                    |                                                                         |                                                                                    |                                                      |                                                                | al) <b>(4)</b><br>al)( <b>4)</b><br>al) |
| bit 1-0                                                                                                                                                    | <b>ADFVR&lt;1:0&gt;</b><br>11 = ADC FV<br>10 = ADC FV<br>01 = ADC FV<br>00 = ADC FV                                                                                                                                                                                                                                                                                                                                              | : ADC FVR Bu<br>R Buffer Gain<br>R Buffer Gain<br>R Buffer Gain<br>R Buffer is off | ffer Gain Sele<br>is 4x, with out<br>is 2x, with out<br>is 1x, with out | ection bit <sup>(1)</sup><br>put voltage = 4<br>put voltage = 2<br>put voltage = 1 | lx Vfvr (4.096V<br>2x Vfvr (2.048V<br>x Vfvr (1.024V | nominal) <sup>(4)</sup><br>nominal) <sup>(4)</sup><br>nominal) |                                         |
| Note 1: 7                                                                                                                                                  | To minimize current consumption when the FVR is disabled, the FVR buffers should be turned off by ing the Buffer Gain Selection bits.                                                                                                                                                                                                                                                                                            |                                                                                    |                                                                         |                                                                                    |                                                      |                                                                | ed off by clear                         |

#### **REGISTER 13-1: FVRCON: FIXED VOLTAGE REFERENCE CONTROL REGISTER**

- 2: FVRRDY is always '1' for the PIC16F1508/9 devices.
- 3: See Section 14.0 "Temperature Indicator Module" for additional information.
- 4: Fixed Voltage Reference output cannot exceed VDD.

#### TABLE 13-2: SUMMARY OF REGISTERS ASSOCIATED WITH THE FIXED VOLTAGE REFERENCE

| Name   | Bit 7 | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2   | Bit 1 | Bit 0  | Register<br>on page |
|--------|-------|--------|-------|-------|-------|---------|-------|--------|---------------------|
| FVRCON | FVREN | FVRRDY | TSEN  | TSRNG | CDAFV | ′R>1:0> | ADFV  | R<1:0> | 125                 |

**Legend:** Shaded cells are unused by the Fixed Voltage Reference module.

| REGISTER 15-3: | ADCON2: ADC CONTROL REGISTER 2 |
|----------------|--------------------------------|
|----------------|--------------------------------|

| R/\\/_0/0                          | R/\/_0 | 0 R/M_0/0           | R/M/-0/0          | 11-0                         | 11-0             | 11-0             | 11-0         |
|------------------------------------|--------|---------------------|-------------------|------------------------------|------------------|------------------|--------------|
| 10,00-0/0                          |        |                     | 11/00-0/0         | 0-0                          | 0-0              | 0-0              | 0-0          |
|                                    | IRIC   | 38EL<3:0>(1)        |                   |                              | _                |                  |              |
| bit 7                              |        |                     |                   |                              |                  |                  | bit 0        |
|                                    |        |                     |                   |                              |                  |                  |              |
| Legend:                            |        |                     |                   |                              |                  |                  |              |
| R = Readable                       | bit    | W = Writable b      | oit               | U = Unimpler                 | mented bit, read | 1 as '0'         |              |
| u = Bit is unch                    | anged  | x = Bit is unkn     | own               | -n/n = Value a               | at POR and BO    | R/Value at all o | other Resets |
| '1' = Bit is set                   |        | '0' = Bit is clea   | ared              |                              |                  |                  |              |
|                                    |        |                     |                   |                              |                  |                  |              |
| bit 7-4                            | TRIGSE | I <3:0>: Auto-Conve | ersion Trigger    | Selection bits <sup>(1</sup> | )                |                  |              |
|                                    | 0000 - |                     | trigger selec     | ted                          |                  |                  |              |
|                                    | 0000 - | Reserved            | r ingger selee    | icu                          |                  |                  |              |
|                                    | 0010 = | Reserved            |                   |                              |                  |                  |              |
|                                    | 0011 = | Timer0 – T0 overfl  | <sub>OW</sub> (2) |                              |                  |                  |              |
|                                    | 0100 = | Timer1 – T1 overfl  | <sub>OW</sub> (2) |                              |                  |                  |              |
|                                    | 0101 = | Timer2 – T2 match   | 1                 |                              |                  |                  |              |
|                                    | 0110 = | Comparator C1 – C   | C1OUT svnc        |                              |                  |                  |              |
|                                    | 0111 = | Comparator C2 – C   | 20UT sync         |                              |                  |                  |              |
|                                    | 1000 = | CLC1 – LC1 out      | _ /               |                              |                  |                  |              |
|                                    | 1001 = | CLC2 – LC2 out      |                   |                              |                  |                  |              |
|                                    | 1010 = | CLC3 – LC3_out      |                   |                              |                  |                  |              |
|                                    | 1011 = | CLC4 – LC4_out      |                   |                              |                  |                  |              |
|                                    | 1100 = | Reserved            |                   |                              |                  |                  |              |
|                                    | 1101 = | Reserved            |                   |                              |                  |                  |              |
|                                    | 1110 = | Reserved            |                   |                              |                  |                  |              |
|                                    | 1111 = | Reserved            |                   |                              |                  |                  |              |
| bit 3-0 Unimplemented: Read as '0' |        |                     |                   |                              |                  |                  |              |

- Note 1: This is a rising edge sensitive input for all sources.
  - 2: Signal also sets its corresponding interrupt flag.

| R/W-0/u                                                                                                                                                                                 | R/W-0/u                                                                                                                                                                                                                                                                                                            | R/W-0/u                                            | R/W-0/u                                           | R/W/HC-0/u                         | R-x/x                          | R/W-0/u          | R/W-0/u     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|---------------------------------------------------|------------------------------------|--------------------------------|------------------|-------------|
| TMR1GE                                                                                                                                                                                  | T1GPOL                                                                                                                                                                                                                                                                                                             | T1GTM                                              | T1GSPM                                            | T1GGO/<br>DONE                     | T1GVAL                         | T1GSS            | <1:0>       |
| bit 7                                                                                                                                                                                   | •                                                                                                                                                                                                                                                                                                                  | •                                                  |                                                   |                                    |                                |                  | bit 0       |
|                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                    |                                                    |                                                   |                                    |                                |                  |             |
| Legend:                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                    |                                                    |                                                   |                                    |                                |                  |             |
| R = Readable                                                                                                                                                                            | bit                                                                                                                                                                                                                                                                                                                | W = Writable                                       | bit                                               | U = Unimplem                       | nented bit, read               | d as '0'         |             |
| u = Bit is uncha                                                                                                                                                                        | anged                                                                                                                                                                                                                                                                                                              | x = Bit is unkr                                    | nown                                              | -n/n = Value a                     | t POR and BO                   | R/Value at all o | ther Resets |
| '1' = Bit is set                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                    | '0' = Bit is clea                                  | ared                                              | HC = Bit is cle                    | eared by hardw                 | are              |             |
| bit 7 <b>TMR1GE:</b> Timer1 Gate Enable bit<br><u>If TMR1ON = 0</u> :<br>This bit is ignored<br><u>If TMR1ON = 1</u> :<br>1 = Timer1 counting is controlled by the Timer1 gate function |                                                                                                                                                                                                                                                                                                                    |                                                    |                                                   |                                    |                                |                  |             |
| bit 6                                                                                                                                                                                   | T1GPOL: Tim                                                                                                                                                                                                                                                                                                        | ner1 Gate Pola                                     | rity bit                                          |                                    |                                |                  |             |
|                                                                                                                                                                                         | 1 = Timer1 g<br>0 = Timer1 g                                                                                                                                                                                                                                                                                       | ate is active-hi<br>ate is active-lo               | gh (Timer1 cou<br>w (Timer1 cou                   | unts when gate<br>nts when gate is | is high)<br>s low)             |                  |             |
| bit 5                                                                                                                                                                                   | T1GTM: Time                                                                                                                                                                                                                                                                                                        | er1 Gate Toggle                                    | e Mode bit                                        |                                    |                                |                  |             |
|                                                                                                                                                                                         | 1 = Timer1 G<br>0 = Timer1 G<br>Timer1 gate fl                                                                                                                                                                                                                                                                     | ate Toggle mo<br>ate Toggle mo<br>lip-flop toggles | de is enabled<br>de is disabled<br>on every risin | and toggle flip-<br>g edge.        | flop is cleared                |                  |             |
| bit 4                                                                                                                                                                                   | T1GSPM: Tin                                                                                                                                                                                                                                                                                                        | ner1 Gate Sing                                     | le-Pulse Mode                                     | e bit                              |                                |                  |             |
|                                                                                                                                                                                         | 1 = Timer1 ga<br>0 = Timer1 ga                                                                                                                                                                                                                                                                                     | ate Single-Puls<br>ate Single-Puls                 | se mode is ena<br>se mode is dis                  | abled and is cor<br>abled          | ntrolling Timer1               | gate             |             |
| bit 3                                                                                                                                                                                   | T1GGO/DON                                                                                                                                                                                                                                                                                                          | E: Timer1 Gate                                     | e Single-Pulse                                    | Acquisition Sta                    | itus bit                       |                  |             |
|                                                                                                                                                                                         | 1 = Timer1 ga<br>0 = Timer1 ga                                                                                                                                                                                                                                                                                     | ate single-puls<br>ate single-puls                 | e acquisition is<br>e acquisition h               | s ready, waiting<br>as completed o | for an edge<br>or has not been | started          |             |
| bit 2                                                                                                                                                                                   | <b>T1GVAL:</b> Timer1 Gate Value Status bit<br>Indicates the current state of the Timer1 gate that could be provided to TMR1H:TMR1L.                                                                                                                                                                               |                                                    |                                                   |                                    |                                |                  |             |
| bit 1-0                                                                                                                                                                                 | Unaffected by Timer1 Gate Enable (TMR1GE).<br><b>T1GSS&lt;1:0&gt;:</b> Timer1 Gate Source Select bits<br>11 = Comparator 2 optionally synchronized output (C2OUT_sync)<br>10 = Comparator 1 optionally synchronized output (C1OUT_sync)<br>01 = Timer0 overflow output (T0_overflow)<br>00 = Timer1 gate pin (T1G) |                                                    |                                                   |                                    |                                |                  |             |

# REGISTER 19-2: T1GCON: TIMER1 GATE CONTROL REGISTER

#### 20.1 Timer2 Operation

The clock input to the Timer2 module is the system instruction clock (Fosc/4).

TMR2 increments from 00h on each clock edge.

A 4-bit counter/prescaler on the clock input allows direct input, divide-by-4 and divide-by-16 prescale options. These options are selected by the prescaler control bits, T2CKPS<1:0> of the T2CON register. The value of TMR2 is compared to that of the Period register, PR2, on each clock cycle. When the two values match, the comparator generates a match signal as the timer output. This signal also resets the value of TMR2 to 00h on the next cycle and drives the output counter/ postscaler (see **Section 20.2 "Timer2 Interrupt"**).

The TMR2 and PR2 registers are both directly readable and writable. The TMR2 register is cleared on any device Reset, whereas the PR2 register initializes to FFh. Both the prescaler and postscaler counters are cleared on the following events:

- a write to the TMR2 register
- · a write to the T2CON register
- Power-on Reset (POR)
- Brown-out Reset (BOR)
- MCLR Reset
- Watchdog Timer (WDT) Reset
- Stack Overflow Reset
- Stack Underflow Reset
- RESET Instruction

Note: TMR2 is not cleared when T2CON is written.

# 20.2 Timer2 Interrupt

Timer2 can also generate an optional device interrupt. The Timer2 output signal (T2\_match) provides the input for the 4-bit counter/postscaler. This counter generates the TMR2 match interrupt flag which is latched in TMR2IF of the PIR1 register. The interrupt is enabled by setting the TMR2 Match Interrupt Enable bit, TMR2IE of the PIE1 register.

A range of 16 postscale options (from 1:1 through 1:16 inclusive) can be selected with the postscaler control bits, T2OUTPS<3:0>, of the T2CON register.

### 20.3 Timer2 Output

The output of TMR2 is T2\_match. T2\_match is available to the following peripherals:

- Configurable Logic Cell (CLC)
- Master Synchronous Serial Port (MSSP)
- Numerically Controlled Oscillator (NCO)
- Pulse Width Modulator (PWM)

The T2\_match signal is synchronous with the system clock. Figure 20-3 shows two examples of the timing of the T2\_match signal relative to Fosc and prescale value, T2CKPS<1:0>. The upper diagram illustrates 1:1 prescale timing and the lower diagram, 1:X prescale timing.

# FIGURE 20-3: T2

T2\_MATCH TIMING DIAGRAM



# 20.4 Timer2 Operation During Sleep

Timer2 cannot be operated while the processor is in Sleep mode. The contents of the TMR2 and PR2 registers will remain unchanged while the processor is in Sleep mode.

#### 21.5.4 SLAVE MODE 10-BIT ADDRESS RECEPTION

This section describes a standard sequence of events for the MSSP module configured as an  $I^2C$  slave in 10-bit Addressing mode.

Figure 21-20 is used as a visual reference for this description.

This is a step by step process of what must be done by slave software to accomplish  $I^2C$  communication.

- 1. Bus starts idle.
- Master sends Start condition; S bit of SSPxSTAT is set; SSPxIF is set if interrupt on Start detect is enabled.
- 3. Master sends matching high address with  $R/\overline{W}$  bit clear; UA bit of the SSPxSTAT register is set.
- 4. Slave sends ACK and SSPxIF is set.
- 5. Software clears the SSPxIF bit.
- 6. Software reads received address from SSPxBUF clearing the BF flag.
- 7. Slave loads low address into SSPxADD, releasing SCLx.
- 8. Master sends matching low address byte to the slave; UA bit is set.

**Note:** Updates to the SSPxADD register are not allowed until after the ACK sequence.

9. Slave sends ACK and SSPxIF is set.

**Note:** If the low address does not match, SSPxIF and UA are still set so that the slave software can set SSPxADD back to the high address. BF is not set because there is no match. CKP is unaffected.

- 10. Slave clears SSPxIF.
- 11. Slave reads the received matching address from SSPxBUF clearing BF.
- 12. Slave loads high address into SSPxADD.
- 13. Master clocks a data byte to the slave and clocks out the slaves ACK on the ninth SCLx pulse; SSPxIF is set.
- 14. If SEN bit of SSPxCON2 is set, CKP is cleared by hardware and the clock is stretched.
- 15. Slave clears SSPxIF.
- 16. Slave reads the received byte from SSPxBUF clearing BF.
- 17. If SEN is set the slave sets CKP to release the SCLx.
- 18. Steps 13-17 repeat for each received byte.
- 19. Master sends Stop to end the transmission.

# 21.5.5 10-BIT ADDRESSING WITH ADDRESS OR DATA HOLD

Reception using 10-bit addressing with AHEN or DHEN set is the same as with 7-bit modes. The only difference is the need to update the SSPxADD register using the UA bit. All functionality, specifically when the CKP bit is cleared and SCLx line is held low are the same. Figure 21-21 can be used as a reference of a slave in 10-bit addressing with AHEN set.

Figure 21-22 shows a standard waveform for a slave transmitter in 10-bit Addressing mode.



#### 21.6.6 I<sup>2</sup>C MASTER MODE TRANSMISSION

Transmission of a data byte, a 7-bit address or the other half of a 10-bit address is accomplished by simply writing a value to the SSPxBUF register. This action will set the Buffer Full flag bit, BF, and allow the Baud Rate Generator to begin counting and start the next transmission. Each bit of address/data will be shifted out onto the SDAx pin after the falling edge of SCLx is asserted. SCLx is held low for one Baud Rate Generator rollover count (TBRG). Data should be valid before SCLx is released high. When the SCLx pin is released high, it is held that way for TBRG. The data on the SDAx pin must remain stable for that duration and some hold time after the next falling edge of SCLx. After the eighth bit is shifted out (the falling edge of the eighth clock), the BF flag is cleared and the master releases SDAx. This allows the slave device being addressed to respond with an ACK bit during the ninth bit time if an address match occurred, or if data was received properly. The status of ACK is written into the ACKSTAT bit on the rising edge of the ninth clock. If the master receives an Acknowledge, the Acknowledge Status bit, ACKSTAT, is cleared. If not, the bit is set. After the ninth clock, the SSPxIF bit is set and the master clock (Baud Rate Generator) is suspended until the next data byte is loaded into the SSPxBUF, leaving SCLx low and SDAx unchanged (Figure 21-28).

After the write to the SSPxBUF, each bit of the address will be shifted out on the falling edge of SCLx until all seven address bits and the R/W bit are completed. On the falling edge of the eighth clock, the master will release the SDAx pin, allowing the slave to respond with an Acknowledge. On the falling edge of the ninth clock, the master will sample the SDAx pin to see if the address was recognized by a slave. The status of the ACK bit is loaded into the ACKSTAT Status bit of the SSPxCON2 register. Following the falling edge of the ninth clock transmission of the address, the SSPxIF is set, the BF flag is cleared and the Baud Rate Generator is turned off until another write to the SSPxBUF takes place, holding SCLx low and allowing SDAx to float.

#### 21.6.6.1 BF Status Flag

In Transmit mode, the BF bit of the SSPxSTAT register is set when the CPU writes to SSPxBUF and is cleared when all eight bits are shifted out.

#### 21.6.6.2 WCOL Status Flag

If the user writes the SSPxBUF when a transmit is already in progress (i.e., SSPxSR is still shifting out a data byte), the WCOL bit is set and the contents of the buffer are unchanged (the write does not occur).

WCOL must be cleared by software before the next transmission.

#### 21.6.6.3 ACKSTAT Status Flag

In Transmit mode, the ACKSTAT bit of the SSPxCON2 register is cleared when the slave has sent an Acknowledge ( $\overline{ACK} = 0$ ) and is set when the slave does not Acknowledge ( $\overline{ACK} = 1$ ). A slave sends an Acknowledge when it has recognized its address (including a general call), or when the slave has properly received its data.

21.6.6.4 Typical transmit sequence:

- 1. The user generates a Start condition by setting the SEN bit of the SSPxCON2 register.
- 2. SSPxIF is set by hardware on completion of the Start.
- 3. SSPxIF is cleared by software.
- 4. The MSSPx module will wait the required start time before any other operation takes place.
- 5. The user loads the SSPxBUF with the slave address to transmit.
- 6. Address is shifted out the SDAx pin until all eight bits are transmitted. Transmission begins as soon as SSPxBUF is written to.
- The MSSPx module shifts in the ACK bit from the slave device and writes its value into the ACKSTAT bit of the SSPxCON2 register.
- The MSSPx module generates an interrupt at the end of the ninth clock cycle by setting the SSPxIF bit.
- 9. The user loads the SSPxBUF with eight bits of data.
- 10. Data is shifted out the SDAx pin until all eight bits are transmitted.
- 11. The MSSPx module shifts in the ACK bit from the slave device and writes its value into the ACKSTAT bit of the SSPxCON2 register.
- 12. Steps 8-11 are repeated for all transmitted data bytes.
- 13. The user generates a Stop or Restart condition by setting the PEN or RSEN bits of the SSPxCON2 register. Interrupt is generated once the Stop/Restart condition is complete.









#### TABLE 22-3: BAUD RATE FORMULAS

| (    | Configuration Bits |      |                     | Poud Poto Formula  |
|------|--------------------|------|---------------------|--------------------|
| SYNC | BRG16              | BRGH | BRG/EUSART Mode     | Bauu Kale Forniula |
| 0    | 0                  | 0    | 8-bit/Asynchronous  | Fosc/[64 (n+1)]    |
| 0    | 0                  | 1    | 8-bit/Asynchronous  |                    |
| 0    | 1                  | 0    | 16-bit/Asynchronous | FOSC/[16 (n+1)]    |
| 0    | 1                  | 1    | 16-bit/Asynchronous |                    |
| 1    | 0                  | x    | 8-bit/Synchronous   | Fosc/[4 (n+1)]     |
| 1    | 1                  | x    | 16-bit/Synchronous  |                    |

**Legend:** x = Don't care, n = value of SPBRGH, SPBRGL register pair.

#### TABLE 22-4: SUMMARY OF REGISTERS ASSOCIATED WITH THE BAUD RATE GENERATOR

| Name    | Bit 7     | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Register<br>on Page |
|---------|-----------|----------|-------|-------|-------|-------|-------|-------|---------------------|
| BAUDCON | ABDOVF    | RCIDL    | —     | SCKP  | BRG16 | _     | WUE   | ABDEN | 235                 |
| RCSTA   | SPEN      | RX9      | SREN  | CREN  | ADDEN | FERR  | OERR  | RX9D  | 234                 |
| SPBRGL  |           | BRG<7:0> |       |       |       |       |       | 236*  |                     |
| SPBRGH  | BRG<15:8> |          |       |       |       | 236*  |       |       |                     |
| TXSTA   | CSRC      | TX9      | TXEN  | SYNC  | SENDB | BRGH  | TRMT  | TX9D  | 233                 |

Legend: — = unimplemented location, read as '0'. Shaded cells are not used for the Baud Rate Generator.

\* Page provides register information.

#### REGISTER 23-2: PWMxDCH: PWM DUTY CYCLE HIGH BITS

| R/W-x/u          | R/W-x/u | R/W-x/u              | R/W-x/u | R/W-x/u         | R/W-x/u            | R/W-x/u             | R/W-x/u |
|------------------|---------|----------------------|---------|-----------------|--------------------|---------------------|---------|
|                  |         |                      | PWMxI   | DCH<7:0>        |                    |                     |         |
| bit 7            |         |                      |         |                 |                    |                     | bit 0   |
|                  |         |                      |         |                 |                    |                     |         |
| Legend:          |         |                      |         |                 |                    |                     |         |
| R = Readable b   | bit     | W = Writable bit     |         | U = Unimpleme   | ented bit, read as | '0'                 |         |
| u = Bit is uncha | nged    | x = Bit is unknown   | I       | -n/n = Value at | POR and BOR/V      | alue at all other f | Resets  |
| '1' = Bit is set |         | '0' = Bit is cleared |         |                 |                    |                     |         |

bit 7-0

PWMxDCH<7:0>: PWM Duty Cycle Most Significant bits These bits are the MSbs of the PWM duty cycle. The two LSbs are found in the PWMxDCL register.

#### REGISTER 23-3: PWMxDCL: PWM DUTY CYCLE LOW BITS

| R/W-x/u                                 | R/W-x/u | U-0 | U-0 | U-0 | U-0                | U-0 | U-0   |
|-----------------------------------------|---------|-----|-----|-----|--------------------|-----|-------|
| PWMxDCL<7:6>                            |         | —   | —   | —   | —                  | —   | —     |
| bit 7                                   |         |     |     |     |                    |     | bit 0 |
|                                         |         |     |     |     |                    |     |       |
| Legend:                                 |         |     |     |     |                    |     |       |
| R = Readable bit W = Writable bit U = V |         |     |     |     | ented bit, read as | ʻ0' |       |

| u = Bit is uncha | inged x = Bit is unknown             | -n/n = Value at POR and BOR/Value at all other Resets |
|------------------|--------------------------------------|-------------------------------------------------------|
| '1' = Bit is set | '0' = Bit is cleared                 |                                                       |
|                  |                                      |                                                       |
| bit 7-6          | PWMxDCL<7:6>: PWM Duty Cycle Least S | ignificant bits                                       |

These bits are the LSbs of the PWM duty cycle. The MSbs are found in the PWMxDCH register.

bit 5-0 Unimplemented: Read as '0'

#### TABLE 23-3: SUMMARY OF REGISTERS ASSOCIATED WITH PWM

| Name    | Bit 7                         | Bit 6                           | Bit 5   | Bit 4   | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Register<br>on Page |
|---------|-------------------------------|---------------------------------|---------|---------|--------|--------|--------|--------|---------------------|
| PR2     | Timer2 module Period Register |                                 |         |         |        |        |        |        |                     |
| PWM1CON | PWM1EN                        | PWM10E                          | PWM10UT | PWM1POL | _      | _      | _      | _      | 255                 |
| PWM1DCH | PWM1DCH<7:0>                  |                                 |         |         |        |        |        |        |                     |
| PWM1DCL | PWM1DCL<7:6>                  |                                 | _       | —       | _      | _      | _      | _      | 256                 |
| PWM2CON | PWM2EN                        | PWM2OE                          | PWM2OUT | PWM2POL | _      | _      | _      | _      | 255                 |
| PWM2DCH | PWM2DCH<7:0>                  |                                 |         |         |        |        |        |        | 256                 |
| PWM2DCL | PWM2D                         | PWM2DCL<7:6>                    |         | —       | _      | _      | _      | _      | 256                 |
| PWM3CON | PWM3EN                        | PWM3OE                          | PWM3OUT | PWM3POL | _      | _      | _      | _      | 255                 |
| PWM3DCH | PWM3DCH<7:0>                  |                                 |         |         |        |        |        |        | 256                 |
| PWM3DCL | PWM3D                         | CL<7:6>                         | _       | —       | _      | _      | _      | _      | 256                 |
| PWM4CON | PWM4EN                        | PWM4OE                          | PWM4OUT | PWM4POL | _      | _      | _      | _      | 255                 |
| PWM4DCH | PWM4DCH<7:0>                  |                                 |         |         |        |        |        |        | 256                 |
| PWM4DCL | PWM4D                         | PWM4DCL<7:6>                    |         | —       | _      | _      | _      | _      | 256                 |
| T2CON   | _                             | T2OUTPS<3:0> TMR2ON T2CKPS<1:0> |         |         |        |        |        | S<1:0> | 168                 |
| TMR2    | Timer2 module Register        |                                 |         |         |        |        |        | 166*   |                     |
| TRISA   | —                             | —                               | TRISA5  | TRISA4  | —(1)   | TRISA2 | TRISA1 | TRISA0 | 109                 |
| TRISC   | TRISC7                        | TRISC6                          | TRISC5  | TRISC4  | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 117                 |

- = Unimplemented locations, read as '0', u = unchanged, x = unknown. Shaded cells are not used by the PWM. Page provides register information. Legend:

Note 1: Unimplemented, read as '1'.

| U-0                                                                     | R/W-x/u                      | R/W-x/u           | R/W-x/u      | U-0                                                   | R/W-x/u | R/W-x/u                   | R/W-x/u |  |  |  |
|-------------------------------------------------------------------------|------------------------------|-------------------|--------------|-------------------------------------------------------|---------|---------------------------|---------|--|--|--|
|                                                                         | — LCxD2S<2:0> <sup>(1)</sup> |                   |              | —                                                     | L       | .CxD1S<2:0> <sup>(1</sup> | )       |  |  |  |
| bit 7                                                                   |                              |                   |              |                                                       |         |                           | bit 0   |  |  |  |
|                                                                         |                              |                   |              |                                                       |         |                           |         |  |  |  |
| Legend:                                                                 |                              |                   |              |                                                       |         |                           |         |  |  |  |
| R = Readable bit W = Writable bit                                       |                              |                   | bit          | U = Unimplemented bit, read as '0'                    |         |                           |         |  |  |  |
| u = Bit is unchanged                                                    |                              | x = Bit is unkr   | nown         | -n/n = Value at POR and BOR/Value at all other Resets |         |                           |         |  |  |  |
| '1' = Bit is set                                                        |                              | '0' = Bit is cle  | ared         |                                                       |         |                           |         |  |  |  |
| L                                                                       |                              |                   |              |                                                       |         |                           |         |  |  |  |
| bit 7                                                                   | Unimpleme                    | nted: Read as '   | 0'           |                                                       |         |                           |         |  |  |  |
| bit 6-4                                                                 | LCxD2S<2:                    | 0>: Input Data 2  | Selection Co | ntrol bits <sup>(1)</sup>                             |         |                           |         |  |  |  |
|                                                                         | 111 = LCx                    | in[11] is selecte | d for lcxd2  |                                                       |         |                           |         |  |  |  |
|                                                                         | 110 = LCx                    | in[10] is selecte | d for lcxd2  |                                                       |         |                           |         |  |  |  |
|                                                                         | 101 = LCx_                   | in[9] is selected | for lcxd2    |                                                       |         |                           |         |  |  |  |
|                                                                         | 100 = LCx_                   | in[8] is selected | for lcxd2    |                                                       |         |                           |         |  |  |  |
|                                                                         | 011 = LCx_                   | in[7] is selected | for lcxd2    |                                                       |         |                           |         |  |  |  |
|                                                                         | 010 = LCx_                   | in[6] is selected | for lcxd2    |                                                       |         |                           |         |  |  |  |
|                                                                         | 001 = LCx_                   | in[5] is selected | for lcxd2    |                                                       |         |                           |         |  |  |  |
|                                                                         | 000 = LCx_                   | in[4] is selected | for lcxd2    |                                                       |         |                           |         |  |  |  |
| bit 3                                                                   | Unimpleme                    | nted: Read as '   | 0'           |                                                       |         |                           |         |  |  |  |
| bit 2-0 LCxD1S<2:0>: Input Data 1 Selection Control bits <sup>(1)</sup> |                              |                   |              |                                                       |         |                           |         |  |  |  |
|                                                                         | 111 = LCx                    | in[7] is selected | for lcxd1    |                                                       |         |                           |         |  |  |  |
|                                                                         | 110 = LCx                    | in[6] is selected | for lcxd1    |                                                       |         |                           |         |  |  |  |
|                                                                         | 101 = LCx                    | in[5] is selected | for lcxd1    |                                                       |         |                           |         |  |  |  |
|                                                                         | 100 = LCx                    | in[4] is selected | for lcxd1    |                                                       |         |                           |         |  |  |  |
|                                                                         | 011 = LCx                    | in[3] is selected | for lcxd1    |                                                       |         |                           |         |  |  |  |
|                                                                         | 010 = LCx_                   | in[2] is selected | for lcxd1    |                                                       |         |                           |         |  |  |  |
|                                                                         | 001 = LCx_                   | in[1] is selected | for lcxd1    |                                                       |         |                           |         |  |  |  |
|                                                                         | 000 = LCx_                   | in[0] is selected | for lcxd1    |                                                       |         |                           |         |  |  |  |

# REGISTER 24-3: CLCxSEL0: MULTIPLEXER DATA 1 AND 2 SELECT REGISTER

**Note 1:** See Table 24-1 for signal names associated with inputs.

#### FIGURE 27-2: PICkit<sup>™</sup> PROGRAMMER STYLE CONNECTOR INTERFACE



For additional interface recommendations, refer to your specific device programmer manual prior to PCB design.

It is recommended that isolation devices be used to separate the programming pins from other circuitry. The type of isolation is highly dependent on the specific application and may include devices such as resistors, diodes, or even jumpers. See Figure 27-3 for more information.

#### FIGURE 27-3: TYPICAL CONNECTION FOR ICSP™ PROGRAMMING



NOTES:









Note 1:If the ADC clock source is selected as FRC, a time of TCY is added before the ADC clock starts. This allows the SLEEP instruction to be executed.

#### TABLE 29-21: I<sup>2</sup>C BUS DATA REQUIREMENTS

| Standard Operating Conditions (unless otherwise stated) |         |                            |              |            |       |            |                                             |  |  |
|---------------------------------------------------------|---------|----------------------------|--------------|------------|-------|------------|---------------------------------------------|--|--|
| Param.<br>No.                                           | Symbol  | Characte                   | Min.         | Max.       | Units | Conditions |                                             |  |  |
| SP100*                                                  | Тнідн   | Clock high time            | 100 kHz mode | 4.0        | _     | μS         | Device must operate at a minimum of 1.5 MHz |  |  |
|                                                         |         |                            | 400 kHz mode | 0.6        |       | μS         | Device must operate at a minimum of 10 MHz  |  |  |
|                                                         |         |                            | SSP module   | 1.5Tcy     | _     |            |                                             |  |  |
| SP101* TLOW                                             | TLOW    | Clock low time             | 100 kHz mode | 4.7        |       | μS         | Device must operate at a minimum of 1.5 MHz |  |  |
|                                                         |         |                            | 400 kHz mode | 1.3        |       | μS         | Device must operate at a minimum of 10 MHz  |  |  |
|                                                         |         |                            | SSP module   | 1.5Tcy     | _     |            |                                             |  |  |
| SP102* <sup>-</sup>                                     | TR      | SDA and SCL rise time      | 100 kHz mode | —          | 1000  | ns         |                                             |  |  |
|                                                         |         |                            | 400 kHz mode | 20 + 0.1Св | 300   | ns         | CB is specified to be from 10-400 pF        |  |  |
| SP103* Tr                                               | Tf      | SDA and SCL fall time      | 100 kHz mode | —          | 250   | ns         |                                             |  |  |
|                                                         |         |                            | 400 kHz mode | 20 + 0.1Св | 250   | ns         | CB is specified to be from 10-400 pF        |  |  |
| SP106* Thd:da                                           | THD:DAT | Data input hold time       | 100 kHz mode | 0          |       | ns         |                                             |  |  |
|                                                         |         |                            | 400 kHz mode | 0          | 0.9   | μS         |                                             |  |  |
| SP107*                                                  | TSU:DAT | Data input setup<br>time   | 100 kHz mode | 250        | _     | ns         | (Note 2)                                    |  |  |
|                                                         |         |                            | 400 kHz mode | 100        |       | ns         |                                             |  |  |
| SP109*                                                  | ΤΑΑ     | Output valid from<br>clock | 100 kHz mode | —          | 3500  | ns         | (Note 1)                                    |  |  |
|                                                         |         |                            | 400 kHz mode | —          | _     | ns         |                                             |  |  |
| SP110* TB                                               | TBUF    | Bus free time              | 100 kHz mode | 4.7        | _     | μS         | Time the bus must be fre                    |  |  |
|                                                         |         |                            | 400 kHz mode | 1.3        | _     | μS         | before a new transmission can start         |  |  |
| SP111                                                   | Св      | Bus capacitive loading     | _            | 400        | pF    |            |                                             |  |  |

\* These parameters are characterized but not tested.

Note 1: As a transmitter, the device must provide this internal minimum delay time to bridge the undefined region (min. 300 ns) of the falling edge of SCL to avoid unintended generation of Start or Stop conditions.

2: A Fast mode (400 kHz) I<sup>2</sup>C bus device can be used in a Standard mode (100 kHz) I<sup>2</sup>C bus system, but the requirement TSU:DAT  $\geq$  250 ns must then be met. This will automatically be the case if the device does not stretch the low period of the SCL signal. If such a device does stretch the low period of the SCL signal, it must output the next data bit to the SDA line TR max. + TSU:DAT = 1000 + 250 = 1250 ns (according to the Standard mode I<sup>2</sup>C bus specification), before the SCL line is released.

Example

**PIC16F1508** 

-E/SS @3

#### Package Marking Information (Continued)

20-Lead SSOP (5.30 mm)



20-Lead QFN (4x4x0.9 mm) 20-Lead UQFN (4x4x0.5 mm)





PIN 1-





• PIC16 F1508 E/ML @3

120123

