

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

EXF

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 20MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, SPI                                                      |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 11                                                                         |
| Program Memory Size        | 3.5KB (2K x 14)                                                            |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                |                                                                            |
| RAM Size                   | 128 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                |
| Data Converters            | A/D 8x10b                                                                  |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 14-TSSOP (0.173", 4.40mm Width)                                            |
| Supplier Device Package    | 14-TSSOP                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf1503-e-st |

Email: info@E-XFL.COM

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

# 3.0 MEMORY ORGANIZATION

These devices contain the following types of memory:

- Program Memory
  - Configuration Words
  - Device ID
  - User ID
  - Flash Program Memory
- Data Memory
  - Core Registers
  - Special Function Registers
  - General Purpose RAM
  - Common RAM

The following features are associated with access and control of program memory and data memory:

- PCL and PCLATH
- Stack
- · Indirect Addressing

# 3.1 Program Memory Organization

The enhanced mid-range core has a 15-bit program counter capable of addressing a  $32K \times 14$  program memory space. Table 3-1 shows the memory sizes implemented. Accessing a location above these boundaries will cause a wrap-around within the implemented memory space. The Reset vector is at 0000h and the interrupt vector is at 0004h (See Figure 3-1).

# 3.2 High-Endurance Flash

This device has a 128 byte section of high-endurance program Flash memory (PFM) in lieu of data EEPROM. This area is especially well suited for nonvolatile data storage that is expected to be updated frequently over the life of the end product. See Section 10.2 "Flash **Program Memory Overview**" for more information on writing data to PFM. See Section 3.2.1.2 "Indirect **Read with FSR**" for more information about using the FSR registers to read byte data stored in PFM.

#### TABLE 3-1:DEVICE SIZES AND ADDRESSES

| Device                    | Program Memory | Last Program Memory | High-Endurance Flash                |
|---------------------------|----------------|---------------------|-------------------------------------|
|                           | Space (Words)  | Address             | Memory Address Range <sup>(1)</sup> |
| PIC16LF1503<br>PIC16F1503 | 2,048          | 07FFh               | 0780h-07FFh                         |

Note 1: High-endurance Flash applies to low byte of each address in the range.

| R/W-0/0          | R/W-0/0                                        | U-0               | U-0                    | R/W-0/0         | U-0              | R/W-0/0          | R/W-0/0     |  |
|------------------|------------------------------------------------|-------------------|------------------------|-----------------|------------------|------------------|-------------|--|
| TMR1GIE          | ADIE                                           | —                 | _                      | SSP1IE          | _                | TMR2IE           | TMR1IE      |  |
| bit 7            |                                                |                   |                        |                 | ·                |                  | bit 0       |  |
|                  |                                                |                   |                        |                 |                  |                  |             |  |
| Legend:          |                                                |                   |                        |                 |                  |                  |             |  |
| R = Readable     | bit                                            | W = Writable      | bit                    | U = Unimple     | mented bit, read | as '0'           |             |  |
| u = Bit is uncha | anged                                          | x = Bit is unkr   | nown                   | -n/n = Value    | at POR and BOI   | R/Value at all o | ther Resets |  |
| '1' = Bit is set |                                                | '0' = Bit is clea | ared                   |                 |                  |                  |             |  |
|                  |                                                |                   |                        |                 |                  |                  |             |  |
| bit 7            | TMR1GIE: Ti                                    | mer1 Gate Inte    | rrupt Enable b         | pit             |                  |                  |             |  |
|                  | 1 = Enables t                                  | he Timer1 gate    | acquisition in         | iterrupt        |                  |                  |             |  |
|                  | 0 = Disables                                   | the Timer1 gate   | e acquisition ir       | nterrupt        |                  |                  |             |  |
| bit 6            | ADIE: Analog                                   | J-to-Digital Con  | verter (ADC) I         | Interrupt Enab  | le bit           |                  |             |  |
|                  | 1 = Enables t                                  | he ADC interru    | pt                     |                 |                  |                  |             |  |
| hit E 1          |                                                |                   | ιρι                    |                 |                  |                  |             |  |
| DIL 3-4          |                                                | teu: Reau as      |                        | Interrupt Eng   | hla hit          |                  |             |  |
| DIL 3            | 1 - Englos                                     | chronous Sena     | i Port (NISSP)<br>runt | ) interrupt Ena |                  |                  |             |  |
|                  | 0 = Disables f                                 | the MSSP inter    | rupt                   |                 |                  |                  |             |  |
| bit 2            | Unimplemen                                     | ted: Read as '    | 0'                     |                 |                  |                  |             |  |
| bit 1            | TMR2IE: TMF                                    | R2 to PR2 Mate    | ch Interrupt Er        | nable bit       |                  |                  |             |  |
|                  | 1 = Enables the Timer2 to PR2 match interrupt  |                   |                        |                 |                  |                  |             |  |
|                  | 0 = Disables the Timer2 to PR2 match interrupt |                   |                        |                 |                  |                  |             |  |
| bit 0            | TMR1IE: Timer1 Overflow Interrupt Enable bit   |                   |                        |                 |                  |                  |             |  |
|                  | 1 = Enables the Timer1 overflow interrupt      |                   |                        |                 |                  |                  |             |  |
|                  | 0 = Disables the Timer1 overflow interrupt     |                   |                        |                 |                  |                  |             |  |
|                  |                                                |                   |                        |                 |                  |                  |             |  |
| Note: Bit        | PEIE of the IN                                 | TCON register     | must be                |                 |                  |                  |             |  |

# REGISTER 7-2: PIE1: PERIPHERAL INTERRUPT ENABLE REGISTER 1

**Note:** Bit PEIE of the INTCON register must be set to enable any peripheral interrupt.

| U-0                                   | U-0                             | U-0             | U-0           | U-0             | U-0              | R/W-0/0          | R/W-0/0     |
|---------------------------------------|---------------------------------|-----------------|---------------|-----------------|------------------|------------------|-------------|
|                                       |                                 | _               |               | —               |                  | CLC2IE           | CLC1IE      |
| bit 7                                 |                                 |                 |               |                 |                  |                  | bit 0       |
|                                       |                                 |                 |               |                 |                  |                  |             |
| Legend:                               |                                 |                 |               |                 |                  |                  |             |
| R = Reada                             | ıble bit                        | W = Writable    | bit           | U = Unimpler    | mented bit, read | as '0'           |             |
| u = Bit is u                          | nchanged                        | x = Bit is unkr | nown          | -n/n = Value    | at POR and BOI   | R/Value at all o | ther Resets |
| '1' = Bit is set '0' = Bit is cleared |                                 |                 |               |                 |                  |                  |             |
|                                       |                                 |                 |               |                 |                  |                  |             |
| bit 7-2                               | Unimplemen                      | ted: Read as '  | 0'            |                 |                  |                  |             |
| bit 1                                 | CLC2IE: Con                     | figurable Logic | Block 2 Inter | rupt Enable bit |                  |                  |             |
|                                       | 1 = Enables                     | the CLC 2 inter | rupt          |                 |                  |                  |             |
|                                       | 0 = Disables                    | the CLC 2 inte  | rrupt         |                 |                  |                  |             |
| bit 0                                 | CLC1IE: Con                     | figurable Logic | Block 1 Inter | rupt Enable bit |                  |                  |             |
|                                       | 1 = Enables the CLC 1 interrupt |                 |               |                 |                  |                  |             |
|                                       | 0 = Disables                    | the CLC 1 inte  | rrupt         |                 |                  |                  |             |
|                                       |                                 |                 |               |                 |                  |                  |             |
| Note:                                 | Bit PEIE of the IN              | TCON register   | must be       |                 |                  |                  |             |

REGISTER 7-4: PIE3: PERIPHERAL INTERRUPT ENABLE REGISTER 3

**Note:** Bit PEIE of the INICON register must be set to enable any peripheral interrupt.

| Name       | Bit 7   | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1   | Bit 0  | Register<br>on Page |
|------------|---------|--------|--------|--------|--------|--------|---------|--------|---------------------|
| INTCON     | GIE     | PEIE   | TMR0IE | INTE   | IOCIE  | TMR0IF | INTF    | IOCIF  | 64                  |
| OPTION_REG | WPUEN   | INTEDG | TMR0CS | TMR0SE | PSA    |        | PS<2:0> |        | 139                 |
| PIE1       | TMR1GIE | ADIE   | _      | —      | SSP1IE | _      | TMR2IE  | TMR1IE | 65                  |
| PIE2       | —       | C2IE   | C1IE   | _      | BCL1IE | NCO1IE | _       | —      | 66                  |
| PIE3       | —       | _      | _      | _      | _      | _      | CLC2IE  | CLC1IE | 67                  |
| PIR1       | TMR1GIF | ADIF   |        | _      | SSP1IF |        | TMR2IF  | TMR1IF | 68                  |
| PIR2       | —       | C2IF   | C1IF   | —      | BCL1IF | NCO1IF | _       | —      | 69                  |
| PIR3       | _       | _      |        | _      | _      |        | CLC2IF  | CLC1IF | 70                  |

TABLE 7-1: SUMMARY OF REGISTERS ASSOCIATED WITH INTERRUPTS

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

# 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



# 10.6 Register Definitions: Flash Program Memory Control

# REGISTER 10-1: PMDATL: PROGRAM MEMORY DATA LOW BYTE REGISTER

| 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 |
|----------------------|---------|----------------------|---------|-------------------|----------------------|---------------------|---------|
|                      |         |                      | PMDA    | AT<7:0>           |                      |                     |         |
| bit 7                |         |                      |         |                   |                      |                     | bit 0   |
|                      |         |                      |         |                   |                      |                     |         |
| Legend:              |         |                      |         |                   |                      |                     |         |
| R = Readable bit     |         | W = Writable bit     |         | U = Unimpleme     | nted bit, read as '0 | ,                   |         |
| u = Bit is unchanged | b       | x = Bit is unknown   |         | -n/n = Value at f | POR and BOR/Valu     | ue at all other Res | sets    |
| '1' = Bit is set     |         | '0' = Bit is cleared |         |                   |                      |                     |         |

bit 7-0

PMDAT<7:0>: Read/write value for Least Significant bits of program memory

# REGISTER 10-2: PMDATH: PROGRAM MEMORY DATA HIGH BYTE REGISTER

| U-0   | U-0 | R/W-x/u | R/W-x/u | R/W-x/u | R/W-x/u  | R/W-x/u | R/W-x/u |
|-------|-----|---------|---------|---------|----------|---------|---------|
| —     | —   |         |         | PMDA    | \T<13:8> |         |         |
| bit 7 |     |         |         |         |          |         | bit 0   |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | 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 Unimplemented: Read as '0'

bit 5-0 PMDAT<13:8>: Read/write value for Most Significant bits of program memory

#### REGISTER 10-3: PMADRL: PROGRAM MEMORY ADDRESS LOW BYTE REGISTER

| R/W-0/0 |
|---------|---------|---------|---------|---------|---------|---------|---------|
|         |         |         | PMAD    | R<7:0>  |         |         |         |
| bit 7   |         |         |         |         |         |         | bit 0   |
|         |         |         |         |         |         |         |         |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | 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-0

PMADR<7:0>: Specifies the Least Significant bits for program memory address

#### REGISTER 10-4: PMADRH: PROGRAM MEMORY ADDRESS HIGH BYTE REGISTER

| U-1   | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0     | R/W-0/0 | R/W-0/0 | R/W-0/0 |
|-------|---------|---------|---------|-------------|---------|---------|---------|
| (1)   |         |         |         | PMADR<14:8> | >       |         |         |
| bit 7 |         |         |         |             |         |         | bit 0   |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | 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 Unimplemented: Read as '1'

bit 6-0 PMADR<14:8>: Specifies the Most Significant bits for program memory address

Note 1: Unimplemented, read as '1'.

# 15.1 ADC Configuration

When configuring and using the ADC the following functions must be considered:

- · Port configuration
- · Channel selection
- ADC voltage reference selection
- ADC conversion clock source
- · Interrupt control
- Result formatting

#### 15.1.1 PORT CONFIGURATION

The ADC can be used to convert both analog and digital signals. When converting analog signals, the I/O pin should be configured for analog by setting the associated TRIS and ANSEL bits. Refer to **Section 11.0 "I/O Ports"** for more information.

| Note: | Analog voltages on any pin that is defined |
|-------|--------------------------------------------|
|       | as a digital input may cause the input     |
|       | buffer to conduct excess current.          |

#### 15.1.2 CHANNEL SELECTION

There are 11 channel selections available:

- AN<7:0> pins
- · Temperature Indicator
- FVR\_buffer1

The CHS bits of the ADCON0 register determine which channel is connected to the sample and hold circuit.

When changing channels, a delay (TACQ) is required before starting the next conversion. Refer to **Section 15.2.6 "ADC Conversion Procedure"** for more information.

#### 15.1.3 ADC VOLTAGE REFERENCE

The ADC module uses a positive and a negative voltage reference. The positive reference is labeled ref+ and the negative reference is labeled ref-.

The positive voltage reference (ref+) is selected by the ADPREF bits in the ADCON1 register. The positive voltage reference source can be:

- VREF+ pin
- Vdd

The negative voltage reference (ref-) source is:

Vss

#### 15.1.4 CONVERSION CLOCK

The source of the conversion clock is software selectable via the ADCS bits of the ADCON1 register. There are seven possible clock options:

- Fosc/2
- · Fosc/4
- Fosc/8
- Fosc/16
- Fosc/32
- Fosc/64
- FRC (internal RC oscillator)

The time to complete one bit conversion is defined as TAD. One full 10-bit conversion requires 11.5 TAD periods as shown in Figure 15-2.

For correct conversion, the appropriate TAD specification must be met. Refer to the ADC conversion requirements in **Section 28.0 "Electrical Specifications"** for more information. Table 15-1 gives examples of appropriate ADC clock selections.

| Note: | Unless using the FRC, any changes in the |
|-------|------------------------------------------|
|       | system clock frequency will change the   |
|       | ADC clock frequency, which may           |
|       | adversely affect the ADC result.         |

| ADC Clock              | Period (TAD) | Device Frequency (Fosc) |            |              |            |            |  |  |  |  |
|------------------------|--------------|-------------------------|------------|--------------|------------|------------|--|--|--|--|
| ADC<br>Clock<br>Source | ADCS<2:0     | 20 MHz                  | 16 MHz     | 16 MHz 8 MHz |            | 1 MHz      |  |  |  |  |
| Fosc/2                 | 000          | 100 ns                  | 125 ns     | 250 ns       | 500 ns     | 2.0 μs     |  |  |  |  |
| Fosc/4                 | 100          | 200 ns                  | 250 ns     | 500 ns       | 1.0 μs     | 4.0 μs     |  |  |  |  |
| Fosc/8                 | 001          | 400 ns                  | 500 ns     | 1.0 μs       | 2.0 μs     | 8.0 μs     |  |  |  |  |
| Fosc/16                | 101          | 800 ns                  | 1.0 μs     | 2.0 μs       | 4.0 μs     | 16.0 μs    |  |  |  |  |
| Fosc/32                | 010          | 1.6 μs                  | 2.0 μs     | 4.0 μs       | 8.0 μs     | 32.0 μs    |  |  |  |  |
| Fosc/64                | 110          | 3.2 μs                  | 4.0 μs     | 8.0 μs       | 16.0 μs    | 64.0 μs    |  |  |  |  |
| FRC                    | x11          | 1.0-6.0 μs              | 1.0-6.0 μs | 1.0-6.0 μs   | 1.0-6.0 μs | 1.0-6.0 μs |  |  |  |  |

#### TABLE 15-1: ADC CLOCK PERIOD (TAD) Vs. DEVICE OPERATING FREQUENCIES

**Legend:** Shaded cells are outside of recommended range.

**Note:** The TAD period when using the FRC clock source can fall within a specified range, (see TAD parameter). The TAD period when using the FOSC-based clock source can be configured for a more precise TAD period. However, the FRC clock source must be used when conversions are to be performed with the device in Sleep mode.



#### FIGURE 15-2: ANALOG-TO-DIGITAL CONVERSION TAD CYCLES

# **15.4 ADC Acquisition Requirements**

For the ADC to meet its specified accuracy, the charge holding capacitor (CHOLD) must be allowed to fully charge to the input channel voltage level. The Analog Input model is shown in Figure 15-4. The source impedance (Rs) and the internal sampling switch (Rss) impedance directly affect the time required to charge the capacitor CHOLD. The sampling switch (Rss) impedance varies over the device voltage (VDD), refer to Figure 15-4. **The maximum recommended impedance for analog sources is 10 k** $\Omega$ . As the source impedance is decreased, the acquisition time may be decreased. After the analog input channel is selected (or changed), an ADC acquisition must be done before the conversion can be started. To calculate the minimum acquisition time, Equation 15-1 may be used. This equation assumes that 1/2 LSb error is used (1,024 steps for the ADC). The 1/2 LSb error is the maximum error allowed for the ADC to meet its specified resolution.

#### EQUATION 15-1: ACQUISITION TIME EXAMPLE

Assumptions: Temperature =  $50^{\circ}C$  and external impedance of  $10k\Omega$  5.0V VDD TACQ = Amplifier Settling Time + Hold Capacitor Charging Time + Temperature Coefficient = TAMP + TC + TCOFF  $= 2\mu s + TC + [(Temperature - 25^{\circ}C)(0.05\mu s/^{\circ}C)]$ 

*The value for Tc can be approximated with the following equations:* 

$$V_{APPLIED}\left(1 - \frac{1}{(2^{n+1}) - 1}\right) = V_{CHOLD} ; [1] V_{CHOLD} charged to within 1/2 lsb$$

$$V_{APPLIED}\left(1 - e^{\frac{-TC}{RC}}\right) = V_{CHOLD} ; [2] V_{CHOLD} charge response to V_{APPLIED} (1 - e^{\frac{-TC}{RC}}) = V_{APPLIED}\left(1 - \frac{1}{(2^{n+1}) - 1}\right) ; combining [1] and [2]$$

*Note:* Where n = number of bits of the ADC.

Solving for TC:

$$Tc = -C_{HOLD}(RIC + RSS + RS) \ln(1/2047)$$
  
= -12.5pF(1k\Omega + 7k\Omega + 10k\Omega) \ln(0.0004885)  
= 1.72\mu s

Therefore:

$$TACQ = 2\mu s + 1.72\mu s + [(50^{\circ}C - 25^{\circ}C)(0.05\mu s/^{\circ}C)]$$
  
= 4.97\mu s

Note 1: The reference voltage (VRPOS) has no effect on the equation, since it cancels itself out.

- 2: The charge holding capacitor (CHOLD) is not discharged after each conversion.
- **3:** The maximum recommended impedance for analog sources is  $10 \text{ k}\Omega$ . This is required to meet the pin leakage specification.

#### 21.2 SPI Mode Overview

The Serial Peripheral Interface (SPI) bus is a synchronous serial data communication bus that operates in Full-Duplex mode. Devices communicate in a master/slave environment where the master device initiates the communication. A slave device is controlled through a Chip Select known as Slave Select.

The SPI bus specifies four signal connections:

- Serial Clock (SCKx)
- Serial Data Out (SDOx)
- Serial Data In (SDIx)
- Slave Select (SSx)

Figure 21-1 shows the block diagram of the MSSP module when operating in SPI mode.

The SPI bus operates with a single master device and one or more slave devices. When multiple slave devices are used, an independent Slave Select connection is required from the master device to each slave device.

Figure 21-4 shows a typical connection between a master device and multiple slave devices.

The master selects only one slave at a time. Most slave devices have tri-state outputs so their output signal appears disconnected from the bus when they are not selected.

Transmissions involve two shift registers, eight bits in size, one in the master and one in the slave. With either the master or the slave device, data is always shifted out one bit at a time, with the Most Significant bit (MSb) shifted out first. At the same time, a new Least Significant bit (LSb) is shifted into the same register.

Figure 21-5 shows a typical connection between two processors configured as master and slave devices.

Data is shifted out of both shift registers on the programmed clock edge and latched on the opposite edge of the clock.

The master device transmits information out on its SDOx output pin which is connected to, and received by, the slave's SDIx input pin. The slave device transmits information out on its SDOx output pin, which is connected to, and received by, the master's SDIx input pin.

To begin communication, the master device first sends out the clock signal. Both the master and the slave devices should be configured for the same clock polarity.

The master device starts a transmission by sending out the MSb from its shift register. The slave device reads this bit from that same line and saves it into the LSb position of its shift register. During each SPI clock cycle, a full-duplex data transmission occurs. This means that while the master device is sending out the MSb from its shift register (on its SDOx pin) and the slave device is reading this bit and saving it as the LSb of its shift register, that the slave device is also sending out the MSb from its shift register (on its SDOx pin) and the master device is reading this bit and saving it as the LSb of its shift register.

After eight bits have been shifted out, the master and slave have exchanged register values.

If there is more data to exchange, the shift registers are loaded with new data and the process repeats itself.

Whether the data is meaningful or not (dummy data), depends on the application software. This leads to three scenarios for data transmission:

- Master sends useful data and slave sends dummy data.
- Master sends useful data and slave sends useful data.
- Master sends dummy data and slave sends useful data.

Transmissions may involve any number of clock cycles. When there is no more data to be transmitted, the master stops sending the clock signal and it deselects the slave.

Every slave device connected to the bus that has not been selected through its slave select line must disregard the clock and transmission signals and must not transmit out any data of its own.

| Name     | Bit 7     | Bit 6          | Bit 5         | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Reset<br>Values on<br>Page: |
|----------|-----------|----------------|---------------|--------|--------|--------|--------|--------|-----------------------------|
| INTCON   | GIE       | PEIE           | TMR0IE        | INTE   | IOCIE  | TMR0IF | INTF   | IOCIF  | 64                          |
| PIE1     | TMR1GIE   | ADIE           | _             | _      | SSP1IE | —      | TMR2IE | TMR1IE | 65                          |
| PIE2     | —         | C2IE           | C1IE          | _      | BCL1IE | NCO1IE | —      | _      | 66                          |
| PIR1     | TMR1GIF   | ADIF           | _             | _      | SSP1IF | —      | TMR2IF | TMR1IF | 68                          |
| PIR2     | _         | C2IF           | C1IF          | _      | BCL1IF | NCO1IF | —      | _      | 69                          |
| TRISA    | _         | _              | TRISA5        | TRISA4 | _(1)   | TRISA2 | TRISA1 | TRISA0 | 98                          |
| SSP1ADD  |           |                |               | ADD<   | <7:0>  |        |        |        | 207                         |
| SSP1BUF  | MSSP Rece | ive Buffer/Tra | nsmit Registe | r      |        |        |        |        | 158*                        |
| SSP1CON1 | WCOL      | SSPOV          | SSPEN         | CKP    |        | SSPM   | <3:0>  |        | 204                         |
| SSP1CON2 | GCEN      | ACKSTAT        | ACKDT         | ACKEN  | RCEN   | PEN    | RSEN   | SEN    | 205                         |
| SSP1CON3 | ACKTIM    | PCIE           | SCIE          | BOEN   | SDAHT  | SBCDE  | AHEN   | DHEN   | 206                         |
| SSP1MSK  | MSK<7:0>  |                |               |        |        |        |        |        |                             |
| SSP1STAT | SMP       | CKE            | D/A           | Р      | S      | R/W    | UA     | BF     | 203                         |

# TABLE 21-3: SUMMARY OF REGISTERS ASSOCIATED WITH I<sup>2</sup>C<sup>™</sup> OPERATION

Legend: — = unimplemented location, read as '0'. Shaded cells are not used by the MSSP module in I<sup>2</sup>C<sup>™</sup> mode. \* Page provides register information.

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

#### REGISTER 21-2: SSPxCON1: SSP CONTROL REGISTER 1

| B/C/HS-0/0                 | R/C/HS-0/0                                                                                                                                                                                                                                                                                                                                                                             | R/W-0/0                                                                                                                                                                                                                                                                                                                                         | R/W-0/0                                                                                                                                                                                                                         | R/W-0/0                                                                                                                                                     | R/W-0/0                                                                                                           | R/W-0/0                                                                                      | R/W-0/0                                                                          |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| WCOL                       | SSPOV <sup>(1)</sup>                                                                                                                                                                                                                                                                                                                                                                   | SSPEN                                                                                                                                                                                                                                                                                                                                           | CKP                                                                                                                                                                                                                             |                                                                                                                                                             | SSPM<3:                                                                                                           | 0>                                                                                           |                                                                                  |
| bit 7                      | 001.01                                                                                                                                                                                                                                                                                                                                                                                 | 001 2.1                                                                                                                                                                                                                                                                                                                                         | 0.4                                                                                                                                                                                                                             |                                                                                                                                                             |                                                                                                                   | <u> </u>                                                                                     | bit 0                                                                            |
|                            |                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                 |                                                                                                                                                             |                                                                                                                   |                                                                                              |                                                                                  |
| Legend:                    |                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                 |                                                                                                                                                             |                                                                                                                   |                                                                                              |                                                                                  |
| R = Readable b             | vit                                                                                                                                                                                                                                                                                                                                                                                    | W = Writable bit                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                 | U = Unimplemer                                                                                                                                              | ted bit, read as '0'                                                                                              |                                                                                              |                                                                                  |
| u = Bit is uncha           | nged                                                                                                                                                                                                                                                                                                                                                                                   | x = Bit is unknown                                                                                                                                                                                                                                                                                                                              | า                                                                                                                                                                                                                               | -n/n = Value at P                                                                                                                                           | OR and BOR/Value at a                                                                                             | II other Resets                                                                              |                                                                                  |
| '1' = Bit is set           |                                                                                                                                                                                                                                                                                                                                                                                        | '0' = Bit is cleared                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                 | HS = Bit is set by                                                                                                                                          | / hardware C                                                                                                      | = User cleared                                                                               |                                                                                  |
| bit 7                      | WCOL: Write Co<br><u>Master mode:</u><br>1 = A write to th<br>0 = No collision<br><u>Slave mode:</u><br>The SCOUD                                                                                                                                                                                                                                                                      | Illision Detect bit<br>he SSPxBUF registe                                                                                                                                                                                                                                                                                                       | er was attempted                                                                                                                                                                                                                | I while the I <sup>2</sup> C cond                                                                                                                           | itions were not valid for                                                                                         | a transmission to                                                                            | be started                                                                       |
|                            | 1 = The SSPXB<br>0 = No collision                                                                                                                                                                                                                                                                                                                                                      | i<br>1<br>1                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                 | smitting the previous                                                                                                                                       | word (must be cleared in                                                                                          | sonware)                                                                                     |                                                                                  |
| bit 6                      | SSPOV: Receive<br>In SPI mode:<br>1 = A new byte<br>Overflow ca<br>setting over<br>SSPxBUF r<br>0 = No overflow<br>In I <sup>2</sup> C mode:<br>1 = A byte is re<br>(must be cl<br>0 = No overflow                                                                                                                                                                                     | Overflow Indicator<br>is received while the<br>an only occur in Slav<br>flow. In Master mode<br>register (must be clear<br>v<br>ecceived while the St<br>eared in software).<br>v                                                                                                                                                               | bit <sup>(1)</sup><br>SSPxBUF registe<br>e mode. In Slave<br>e, the overflow bit i<br>ared in software).<br>SPxBUF register                                                                                                     | er is still holding the p<br>mode, the user mus<br>s not set since each<br>is still holding the p                                                           | revious data. In case of or<br>t read the SSPxBUF, eve<br>new reception (and transmore<br>previous byte. SSPOV is | verflow, the data ir<br>n if only transmitti<br>nission) is initiated<br>s a "don't care" ir | n SSPxSR is lost.<br>ng data, to avoid<br>d by writing to the<br>n Transmit mode |
| bit 5                      | SSPEN: Synchro<br>In both modes, w<br><u>In SPI mode:</u><br>1 = Enables set<br>0 = Disables set<br><u>In I<sup>2</sup>C mode:</u><br>1 = Enables the<br>0 = Disables set                                                                                                                                                                                                              | nous Serial Port Er<br>hen enabled, these<br>rial port and configur<br>erial port and config<br>e serial port and config<br>erial port and config                                                                                                                                                                                               | able bit<br>pins must be pro-<br>es SCKx, SDOx,<br>ures these pins a<br>gures the SDAx a<br>ures these pins a                                                                                                                   | operly configured as<br>SDIx and SSx as the<br>as I/O port pins<br>Ind SCLx pins as the<br>as I/O port pins                                                 | s input or output<br>e source of the serial port<br>source of the serial port p                                   | pins <sup>(2)</sup><br>pins <sup>(3)</sup>                                                   |                                                                                  |
| bit 4                      | <b>CKP:</b> Clock Pola<br>In <u>SPI mode:</u><br>1 = Idle state for<br>0 = Idle state for<br>In $I^2C$ Slave mod<br>SCLx release co<br>1 = Enable clock k<br>0 = Holds clock k<br>In $I^2C$ Master mod<br>Unused in this m                                                                                                                                                             | rity Select bit<br>clock is a high level<br>clock is a low level<br><u>le:</u><br>ntrol<br>ow (clock stretch). (<br><u>de:</u><br>ode                                                                                                                                                                                                           | Used to ensure o                                                                                                                                                                                                                | lata setup time.)                                                                                                                                           |                                                                                                                   |                                                                                              |                                                                                  |
| bit 3-0                    | SSPM<3:0>: Syr<br>0000 = SPI Masi<br>0010 = SPI Masi<br>0010 = SPI Masi<br>0100 = SPI Masi<br>0100 = SPI Slav<br>0101 = SPI Slav<br>0101 = I <sup>2</sup> C Slave<br>0111 = I <sup>2</sup> C Slave<br>1001 = Reserved<br>1001 = Reserved<br>1010 = SPI Masi<br>1011 = I <sup>2</sup> C firmw<br>1100 = Reserved<br>1101 = Reserved<br>1101 = Reserved<br>1101 = I <sup>2</sup> C Slave | ter mode, clock = Fe<br>ter mode, clock = Fe<br>ter mode, clock = Fe<br>ter mode, clock = Fe<br>ter mode, clock = T2<br>e mode, clock = SC<br>e mode, clock = SC<br>e mode, clock = SC<br>e mode, 10-bit addres<br>e mode, clock = Fe<br>d<br>ter mode, clock = Fe<br>vare controlled Mast<br>d<br>e mode, 7-bit addres<br>e mode, 7-bit addres | ort Mode Select b<br>DSC/4<br>DSC/16<br>DSC/64<br>2_match/2<br>Kx pin, <u>SS</u> pin co<br>Kx pin, <u>SS</u> pin co<br>SS<br>DSC/(4 * (SSPxAI<br>DSC/(4 * (SSPxAI<br>er mode (Slave i<br>SS with Start and<br>SS with Start and | its<br>ontrol enabled<br>ontrol disabled, SSA<br>DD+1)) <sup>(4)</sup><br>DD+1)) <sup>(5)</sup><br>dle)<br>Stop bit interrupts e<br>d Stop bit interrupts e | can be used as I/O pin                                                                                            |                                                                                              |                                                                                  |
| Note 1: In<br>2: W<br>3: W | Master mode, the ov<br>/hen enabled, these p<br>/hen enabled, the SD/                                                                                                                                                                                                                                                                                                                  | erflow bit is not set<br>ins must be properl<br>Ax and SCLx pins m                                                                                                                                                                                                                                                                              | since each new r<br>y configured as in<br>nust be configure                                                                                                                                                                     | eception (and trans<br>nput or output.<br>d as inputs.                                                                                                      | mission) is initiated by v                                                                                        | vriting to the SSP                                                                           | xBUF register.                                                                   |

- SSPxADD values of 0, 1 or 2 are not supported for I<sup>2</sup>C mode.
   SSPxADD value of '0' is not supported. Use SSPM = 0000 instead.

#### 22.1.5 PWM RESOLUTION

The resolution determines the number of available duty cycles for a given period. For example, a 10-bit resolution will result in 1024 discrete duty cycles, whereas an 8-bit resolution will result in 256 discrete duty cycles.

The maximum PWM resolution is ten bits when PR2 is 255. The resolution is a function of the PR2 register value as shown by Equation 22-4.

#### EQUATION 22-4: PWM RESOLUTION

Resolution = 
$$\frac{\log[4(PR2 + I)]}{\log(2)}$$
 bits

**Note:** If the pulse width value is greater than the period the assigned PWM pin(s) will remain unchanged.

| TABLE 22-1: | EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (Fosc = 20 MHz) |
|-------------|---------------------------------------------------------|
|-------------|---------------------------------------------------------|

| PWM Frequency             | 0.31 kHz | 4.88 kHz | 19.53 kHz | 78.12 kHz | 156.3 kHz | 208.3 kHz |
|---------------------------|----------|----------|-----------|-----------|-----------|-----------|
| Timer Prescale            | 64       | 4        | 1         | 1         | 1         | 1         |
| PR2 Value                 | 0xFF     | 0xFF     | 0xFF      | 0x3F      | 0x1F      | 0x17      |
| Maximum Resolution (bits) | 10       | 10       | 10        | 8         | 7         | 6.6       |

# TABLE 22-2: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (Fosc = 8 MHz)

| PWM Frequency             | 0.31 kHz | 4.90 kHz | 19.61 kHz | 76.92 kHz | 153.85 kHz | 200.0 kHz |
|---------------------------|----------|----------|-----------|-----------|------------|-----------|
| Timer Prescale            | 64       | 4        | 1         | 1         | 1          | 1         |
| PR2 Value                 | 0x65     | 0x65     | 0x65      | 0x19      | 0x0C       | 0x09      |
| Maximum Resolution (bits) | 8        | 8        | 8         | 6         | 5          | 5         |

#### 22.1.6 OPERATION IN SLEEP MODE

In Sleep mode, the TMR2 register will not increment and the state of the module will not change. If the PWMx pin is driving a value, it will continue to drive that value. When the device wakes up, TMR2 will continue from its previous state.

#### 22.1.7 CHANGES IN SYSTEM CLOCK FREQUENCY

The PWM frequency is derived from the system clock frequency (Fosc). Any changes in the system clock frequency will result in changes to the PWM frequency. Refer to **Section 5.0 "Oscillator Module"** for additional details.

#### 22.1.8 EFFECTS OF RESET

Any Reset will force all ports to Input mode and the PWM registers to their Reset states.

# 23.1 CLCx Setup

Programming the CLCx module is performed by configuring the four stages in the logic signal flow. The four stages are:

- Data selection
- Data gating
- Logic function selection
- Output polarity

Each stage is setup at run time by writing to the corresponding CLCx Special Function Registers. This has the added advantage of permitting logic reconfiguration on-the-fly during program execution.

#### 23.1.1 DATA SELECTION

There are 16 signals available as inputs to the configurable logic. Four 8-input multiplexers are used to select the inputs to pass on to the next stage. The 16 inputs to the multiplexers are arranged in groups of four. Each group is available to two of the four multiplexers, in each case, paired with a different group. This arrangement makes possible selection of up to two from a group without precluding a selection from another group.

Data selection is through four multiplexers as indicated on the left side of Figure 23-2. Data inputs in the figure are identified by a generic numbered input name.

Table 23-1 correlates the generic input name to the actual signal for each CLC module. The columns labeled lcxd1 through lcxd4 indicate the MUX output for the selected data input. D1S through D4S are abbreviations for the MUX select input codes: LCxD1S<2:0> through LCxD4S<2:0>, respectively. Selecting a data input in a column excludes all other inputs in that column.

Data inputs are selected with CLCxSEL0 and CLCxSEL1 registers (Register 23-3 and Register 23-5, respectively).

Note: Data selections are undefined at power-up.

| Data Input | lcxd1<br>D1S | lcxd2<br>D2S | lcxd3<br>D3S | lcxd4<br>D4S | CLC 1       | CLC 2       |
|------------|--------------|--------------|--------------|--------------|-------------|-------------|
| LCx_in[0]  | 000          | _            | —            | 100          | CLC1IN0     | CLC2IN0     |
| LCx_in[1]  | 001          | _            | _            | 101          | CLC1IN1     | CLC2IN1     |
| LCx_in[2]  | 010          | _            | _            | 110          | C1OUT_sync  | C1OUT_sync  |
| LCx_in[3]  | 011          | _            | _            | 111          | C2OUT_sync  | C2OUT_sync  |
| LCx_in[4]  | 100          | 000          | _            | —            | Fosc        | Fosc        |
| LCx_in[5]  | 101          | 001          | _            | —            | T0_overflow | T0_overflow |
| LCx_in[6]  | 110          | 010          | _            | —            | T1_overflow | T1_overflow |
| LCx_in[7]  | 111          | 011          | _            | —            | T2_match    | T2_match    |
| LCx_in[8]  | _            | 100          | 000          | —            | LC1_out     | LC1_out     |
| LCx_in[9]  | _            | 101          | 001          | _            | LC2_out     | LC2_out     |
| LCx_in[10] | _            | 110          | 010          | —            | Reserved    | Reserved    |
| LCx_in[11] | _            | 111          | 011          | —            | Reserved    | Reserved    |
| LCx_in[12] | _            | _            | 100          | 000          | NCO1_out    | LFINTOSC    |
| LCx_in[13] | —            | _            | 101          | 001          | HFINTOSC    | FRC         |
| LCx_in[14] | _            | _            | 110          | 010          | PWM3_out    | PWM1_out    |
| LCx_in[15] | _            | _            | 111          | 011          | PWM4_out    | PWM2_out    |

TABLE 23-1: CLCx DATA INPUT SELECTION



PIC16(L)F1503

DS40001607D-page 243

Status

© 2011-2015 Microchip Technology Inc

# TABLE 28-10:RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER<br/>AND BROWN-OUT RESET PARAMETERS

| Standard Operating Conditions (unless otherwise stated) |        |                                                          |      |      |      |       |                                          |  |  |
|---------------------------------------------------------|--------|----------------------------------------------------------|------|------|------|-------|------------------------------------------|--|--|
| Param.<br>No.                                           | Sym.   | Characteristic                                           | Min. | Тур† | Max. | Units | Conditions                               |  |  |
| 30                                                      | TMCL   | MCLR Pulse Width (low)                                   | 2    |      |      | μS    |                                          |  |  |
| 31                                                      | TWDTLP | Low-Power Watchdog Timer<br>Time-out Period              | 10   | 16   | 27   | ms    | VDD = 3.3V-5V,<br>1:512 Prescaler used   |  |  |
| 33*                                                     | TPWRT  | Power-up Timer Period                                    | 40   | 65   | 140  | ms    | PWRTE = 0                                |  |  |
| 34*                                                     | Tioz   | I/O high-impedance from MCLR Low or Watchdog Timer Reset |      |      | 2.0  | μS    |                                          |  |  |
| 35                                                      | VBOR   | Brown-out Reset Voltage <sup>(1)</sup>                   | 2.55 | 2.70 | 2.85 | V     | BORV = 0                                 |  |  |
|                                                         |        |                                                          | 2.35 | 2.45 | 2.58 | V     | BORV = 1 (PIC16F1503)                    |  |  |
|                                                         |        |                                                          | 1.80 | 1.90 | 2.05 | V     | BORV = 1 (PIC16LF1503)                   |  |  |
| 36*                                                     | VHYST  | Brown-out Reset Hysteresis                               | 0    | 25   | 75   | mV    | $-40^{\circ}C \leq TA \leq +85^{\circ}C$ |  |  |
| 37*                                                     | TBORDC | Brown-out Reset DC Response Time                         | 1    | 16   | 35   | μS    | $VDD \leq VBOR$                          |  |  |
| 38                                                      | VLPBOR | Low-Power Brown-Out Reset Voltage                        | 1.8  | 2.1  | 2.5  | V     | LPBOR = 1                                |  |  |

These parameters are characterized but not tested.

\*

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

#### FIGURE 28-9: BROWN-OUT RESET TIMING AND CHARACTERISTICS



Note 1: To ensure these voltage tolerances, VDD and VSS must be capacitively decoupled as close to the device as possible. 0.1  $\mu$ F and 0.01  $\mu$ F values in parallel are recommended.

# 29.0 DC AND AC CHARACTERISTICS GRAPHS AND CHARTS

The graphs and tables provided in this section are for design guidance and are not tested.

In some graphs or tables, the data presented are **outside specified operating range** (i.e., outside specified VDD range). This is for **information only** and devices are ensured to operate properly only within the specified range.

**Note:** The graphs and tables provided following this note are a statistical summary based on a limited number of samples and are provided for informational purposes only. The performance characteristics listed herein are not tested or guaranteed. In some graphs or tables, the data presented may be outside the specified operating range (e.g., outside specified power supply range) and therefore, outside the warranted range.

"Typical" represents the mean of the distribution at 25°C. "MAXIMUM", "Max.", "MINIMUM" or "Min." represents (mean +  $3\sigma$ ) or (mean -  $3\sigma$ ) respectively, where  $\sigma$  is a standard deviation, over each temperature range.

FIGURE 29-3: IDD, EXTERNAL CLOCK (ECL), LOW-POWER MODE, Fosc = 500 kHz, PIC16LF1503 ONLY



FIGURE 29-4: IDD, EXTERNAL CLOCK (ECL), LOW-POWER MODE, Fosc = 500 kHz, PIC16F1503 ONLY











# PIC16(L)F1503



FIGURE 29-56: COMPARATOR RESPONSE TIME OVER TEMPERATURE, NORMAL POWER MODE (CxSP = 1)

