

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

E·XFI

| Product Status             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | PIC                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 32MHz                                                                     |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                 |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                     |
| Number of I/O              | 35                                                                        |
| Program Memory Size        | 28KB (16K x 14)                                                           |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 2K x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                               |
| Data Converters            | A/D 28x10b; D/A 1x5b, 1x8b                                                |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 40-UFQFN Exposed Pad                                                      |
| Supplier Device Package    | 40-UQFN (5x5)                                                             |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f1719-e-mv |

Email: info@E-XFL.COM

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

|                  | 2. 0000              |                                    |                   |                 |                  |                |              |
|------------------|----------------------|------------------------------------|-------------------|-----------------|------------------|----------------|--------------|
| R-1/q            | R-0/q                | R-q/q                              | R-0/q             | R-0/q           | R-q/q            | R-0/0          | R-0/q        |
| SOSCR            | PLLR                 | OSTS                               | HFIOFR            | HFIOFL          | MFIOFR           | LFIOFR         | HFIOFS       |
| bit 7            | -                    | ·                                  |                   |                 |                  |                | bit 0        |
|                  |                      |                                    |                   |                 |                  |                |              |
| Legend:          |                      |                                    |                   |                 |                  |                |              |
| R = Readable     | bit                  | W = Writable                       | bit               | U = Unimplei    | mented bit, read | d as '0'       |              |
| u = Bit is unch  | nanged               | x = Bit is unkr                    | nown              | -n/n = Value    | at POR and BC    | R/Value at all | other Resets |
| '1' = Bit is set |                      | '0' = Bit is cle                   | ared              | q = Condition   | nal              |                |              |
|                  |                      |                                    |                   |                 |                  |                |              |
| bit 7            | SOSCR: Sec           | ondary Oscilla                     | tor Ready bit     |                 |                  |                |              |
|                  | If T1OSCEN           | <u>= 1</u> :                       |                   |                 |                  |                |              |
|                  | 1 = Second           | ary oscillator is                  | ready             |                 |                  |                |              |
|                  | 0 = Seconda          | ary oscillator is                  | not ready         |                 |                  |                |              |
|                  | <u>If I10SCEN</u>    | <u>= 0</u> :<br>arv.clock.sourc    | e is always rea   | adv             |                  |                |              |
| bit 6            |                      | Doody bit                          | e is always lea   | luy             |                  |                |              |
| DILO             | $1 = 4 \times PLL i$ | is ready bit                       |                   |                 |                  |                |              |
|                  | $0 = 4 \times PLL i$ | is not ready                       |                   |                 |                  |                |              |
| bit 5            | OSTS: Oscill         | ator Start-up Ti                   | mer Status bit    |                 |                  |                |              |
|                  | 1 = Running          | g from the clock                   | defined by the    | e FOSC<2:0>     | bits of the Conf | iguration Word | s            |
|                  | 0 = Running          | g from an intern                   | al oscillator (F  | OSC<2:0> = 1    | 00)              |                |              |
| bit 4            | HFIOFR: Hig          | h-Frequency Ir                     | nternal Oscillate | or Ready bit    |                  |                |              |
|                  | 1 = HFINTO           | SC is ready                        |                   |                 |                  |                |              |
| 1.11.0           |                      | SC is not ready                    | /                 |                 |                  |                |              |
| DIT 3            |                      | n-Frequency in                     |                   | or Locked bit   |                  |                |              |
|                  | 1 = HFINTO           | SC is at least 2<br>SC is not 2% a | ccurate           |                 |                  |                |              |
| hit 2            | MFIOFR: Me           | dium Frequenc                      | v Internal Osci   | illator Ready b | it               |                |              |
| Sit 2            | 1 = MFINTO           | SC is ready                        | y memai eee       |                 | it.              |                |              |
|                  | 0 = MFINTO           | SC is not read                     | y                 |                 |                  |                |              |
| bit 1            | LFIOFR: Low          | v-Frequency In                     | ternal Oscillato  | r Ready bit     |                  |                |              |
|                  | 1 = LFINTOS          | SC is ready                        |                   |                 |                  |                |              |
|                  | 0 = LFINTOS          | SC is not ready                    |                   |                 |                  |                |              |
| bit 0            | HFIOFS: Hig          | h-Frequency Ir                     | ternal Oscillato  | or Stable bit   |                  |                |              |
|                  | 1 = HFINTO           | SC is at least 0                   | .5% accurate      |                 |                  |                |              |
|                  | 0 = HFINTO           | SC is not 0.5%                     | accurate          |                 |                  |                |              |
|                  |                      |                                    |                   |                 |                  |                |              |

# REGISTER 6-2: OSCSTAT: OSCILLATOR STATUS REGISTER

### FIGURE 10-6: FLASH PROGRAM MEMORY WRITE FLOWCHART



| R/W-1/1          | R/W-1/1 | R/W-1/1           | R/W-1/1 | R/W-1/1                                       | R/W-1/1          | R/W-1/1  | R/W-1/1     |
|------------------|---------|-------------------|---------|-----------------------------------------------|------------------|----------|-------------|
| WPUA7            | WPUA6   | WPUA5             | WPUA4   | WPUA3                                         | WPUA2            | WPUA1    | WPUA0       |
| bit 7            |         |                   |         |                                               |                  |          | bit 0       |
|                  |         |                   |         |                                               |                  |          |             |
| Legend:          |         |                   |         |                                               |                  |          |             |
| R = Readable b   | oit     | W = Writable I    | bit     | U = Unimpler                                  | mented bit, read | l as '0' |             |
| u = Bit is uncha | anged   | x = Bit is unkn   | iown    | -n/n = Value at POR and BOR/Value at all othe |                  |          | ther Resets |
| '1' = Bit is set |         | '0' = Bit is clea | ared    |                                               |                  |          |             |

# REGISTER 11-5: WPUA: WEAK PULL-UP PORTA REGISTER<sup>(1,2)</sup>

| bit 7-0 | WPUA<7:0>: Weak Pull-up Register bits |
|---------|---------------------------------------|
|         | 1 = Pull-up enabled                   |
|         | 0 = Pull-up disabled                  |

Note 1: Global WPUEN bit of the OPTION REG register must be cleared for individual pull-ups to be enabled.

2: The weak pull-up device is automatically disabled if the pin is configured as an output.

#### REGISTER 11-6: **ODCONA: PORTA OPEN-DRAIN CONTROL REGISTER**

| R/W-0/0 |
|---------|---------|---------|---------|---------|---------|---------|---------|
| ODA7    | ODA6    | ODA5    | ODA4    | ODA3    | ODA2    | ODA1    | ODA0    |
| 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 ODA<7:0>: PORTA Open-Drain Enable bits

For RA<7:0> pins, respectively

- 1 = Port pin operates as open-drain drive (sink current only)
- 0 = Port pin operates as standard push-pull drive (source and sink current)

| Name    | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   | Register<br>on Page |
|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------------------|
| ANSELD  | ANSD7   | ANSD6   | ANSD5   | ANSD4   | ANSD3   | ANSD2   | ANSD1   | ANSD0   | 141                 |
| INLVLD  | INLVLD7 | INLVLD6 | INLVLD5 | INLVLD4 | INLVLD3 | INLVLD2 | INLVLD1 | INLVLD0 | 142                 |
| LATD    | LATD7   | LATD6   | LATD5   | LATD4   | LATD3   | LATD2   | LATD1   | LATD0   | 140                 |
| ODCOND  | ODD7    | ODD6    | ODD5    | ODD4    | ODD3    | ODD2    | ODD1    | ODD0    | 142                 |
| PORTD   | RD7     | RD6     | RD5     | RD4     | RD3     | RD2     | RD1     | RD0     | 140                 |
| SLRCOND | SLRD7   | SLRD6   | SLRD5   | SLRD4   | SLRD3   | SLRD2   | SLRD1   | SLRD0   | 142                 |
| TRISD   | TRISD7  | TRISD6  | TRISD5  | TRISD4  | TRISD3  | TRISD2  | TRISD1  | TRISD0  | 140                 |
| WPUD    | WPUD7   | WPUD6   | WPUD5   | WPUD4   | WPUD3   | WPUD2   | WPUD1   | WPUD0   | 141                 |

| TABLE 11-6: | SUMMARY OF REGISTERS ASSOCIATED WITH PORTD |
|-------------|--------------------------------------------|
|-------------|--------------------------------------------|

**Legend:** x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by PORTD.

| 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     | R/W-0/0 |
|------------------|---------|-------------------|---------|-------------------------------------------------|------------------|-------------|---------|
| IOCCP7           | IOCCP6  | IOCCP5            | IOCCP4  | IOCCP3                                          | IOCCP2           | IOCCP1      | IOCCP0  |
| bit 7            |         |                   |         |                                                 |                  |             | bit 0   |
|                  |         |                   |         |                                                 |                  |             |         |
| Legend:          |         |                   |         |                                                 |                  |             |         |
| R = Readable     | bit     | W = Writable      | bit     | U = Unimpler                                    | mented bit, read | as '0'      |         |
| u = Bit is unch  | anged   | x = Bit is unkr   | nown    | n -n/n = Value at POR and BOR/Value at all othe |                  | ther Resets |         |
| '1' = Bit is set |         | '0' = Bit is clea | ared    |                                                 |                  |             |         |

#### REGISTER 13-7: IOCCP: INTERRUPT-ON-CHANGE PORTC POSITIVE EDGE REGISTER

bit 7-0

bit 7-0

**IOCCP<7:0>:** Interrupt-on-Change PORTC Positive Edge Enable bits

1 = Interrupt-on-Change enabled on the pin for a positive going edge. IOCCFx bit and IOCIF flag will be set upon detecting an edge.

0 = Interrupt-on-Change disabled for the associated pin.

#### REGISTER 13-8: IOCCN: INTERRUPT-ON-CHANGE PORTC NEGATIVE EDGE REGISTER

| R/W-0/0 |
|---------|---------|---------|---------|---------|---------|---------|---------|
| IOCCN7  | IOCCN6  | IOCCN5  | IOCCN4  | IOCCN3  | IOCCN2  | IOCCN1  | IOCCN0  |
| 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 |                                                       |

IOCCN<7:0>: Interrupt-on-Change PORTC Negative Edge Enable bits

1 = Interrupt-on-Change enabled on the pin for a negative going edge. IOCCFx bit and IOCIF flag will be set upon detecting an edge.

0 = Interrupt-on-Change disabled for the associated pin.

#### REGISTER 13-9: IOCCF: INTERRUPT-ON-CHANGE PORTC FLAG REGISTER

| R/W/HS-0/0 |
|------------|------------|------------|------------|------------|------------|------------|------------|
| IOCCF7     | IOCCF6     | IOCCF5     | IOCCF4     | IOCCF3     | IOCCF2     | IOCCF1     | IOCCF0     |
| 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 | HS - Bit is set in hardware                           |

bit 7-0

IOCCF<7:0>: Interrupt-on-Change PORTC Flag bits

- 1 = An enabled change was detected on the associated pin.
  - Set when IOCCPx = 1 and a rising edge was detected on RCx, or when IOCCNx = 1 and a falling edge was detected on RCx.
- 0 = No change was detected, or the user cleared the detected change.





#### 30.2.1 SPI MODE REGISTERS

The MSSP module has five registers for SPI mode operation. These are:

- MSSP STATUS register (SSP1STAT)
- MSSP Control register 1 (SSP1CON1)
- MSSP Control register 3 (SSP1CON3)
- MSSP Data Buffer register (SSP1BUF)
- MSSP Address register (SSP1ADD)
- MSSP Shift register (SSP1SR)
- (Not directly accessible)

SSP1CON1 and SSP1STAT are the control and STA-TUS registers in SPI mode operation. The SSP1CON1 register is readable and writable. The lower six bits of the SSP1STAT are read-only. The upper two bits of the SSP1STAT are read/write.

In one SPI master mode, SSP1ADD can be loaded with a value used in the Baud Rate Generator. More information on the Baud Rate Generator is available in **Section 30.7 "Baud Rate Generator"**.

SSP1SR is the shift register used for shifting data in and out. SSP1BUF provides indirect access to the SSP1SR register. SSP1BUF is the buffer register to which data bytes are written, and from which data bytes are read.

In receive operations, SSP1SR and SSP1BUF together create a buffered receiver. When SSP1SR receives a complete byte, it is transferred to SSP1BUF and the SSP1IF interrupt is set.

During transmission, the SSP1BUF is not buffered. A write to SSP1BUF will write to both SSP1BUF and SSP1SR.

# 30.2.2 SPI MODE OPERATION

When initializing the SPI, several options need to be specified. This is done by programming the appropriate control bits (SSP1CON1<5:0> and SSP1STAT<7:6>). These control bits allow the following to be specified:

- Master mode (SCK is the clock output)
- Slave mode (SCK is the clock input)
- Clock Polarity (Idle state of SCK)
- Data Input Sample Phase (middle or end of data output time)
- Clock Edge (output data on rising/falling edge of SCK)
- Clock Rate (Master mode only)
- · Slave Select mode (Slave mode only)

To enable the serial port, SSP Enable bit, SSPEN of the SSP1CON1 register, must be set. To reset or reconfigure SPI mode, clear the SSPEN bit, re-initialize the SSP1CONx registers and then set the <u>SSPEN</u> bit. This configures the SDI, SDO, SCK and <u>SS</u> pins as serial port pins. For the pins to behave as the serial port function, some must have their data direction bits (in the TRIS register) appropriately programmed as follows:

- · SDI must have corresponding TRIS bit set
- SDO must have corresponding TRIS bit cleared
  SCK (Master mode) must have corresponding
- TRIS bit cleared
- SCK (Slave mode) must have corresponding <u>TRIS</u> bit set
- SS must have corresponding TRIS bit set

Any serial port function that is not desired may be overridden by programming the corresponding data direction (TRIS) register to the opposite value. When one device is transmitting a logical one, or letting the line float, and a second device is transmitting a logical zero, or holding the line low, the first device can detect that the line is not a logical one. This detection, when used on the SCL line, is called clock stretching. Clock stretching gives slave devices a mechanism to control the flow of data. When this detection is used on the SDA line, it is called arbitration. Arbitration ensures that there is only one master device communicating at any single time.

### 30.3.1 CLOCK STRETCHING

When a slave device has not completed processing data, it can delay the transfer of more data through the process of clock stretching. An addressed slave device may hold the SCL clock line low after receiving or sending a bit, indicating that it is not yet ready to continue. The master that is communicating with the slave will attempt to raise the SCL line in order to transfer the next bit, but will detect that the clock line has not yet been released. Because the SCL connection is open-drain, the slave has the ability to hold that line low until it is ready to continue communicating.

Clock stretching allows receivers that cannot keep up with a transmitter to control the flow of incoming data.

# 30.3.2 ARBITRATION

Each master device must monitor the bus for Start and Stop bits. If the device detects that the bus is busy, it cannot begin a new message until the bus returns to an Idle state.

However, two master devices may try to initiate a transmission on or about the same time. When this occurs, the process of arbitration begins. Each transmitter checks the level of the SDA data line and compares it to the level that it expects to find. The first transmitter to observe that the two levels do not match, loses arbitration, and must stop transmitting on the SDA line.

For example, if one transmitter holds the SDA line to a logical one (lets it float) and a second transmitter holds it to a logical zero (pulls it low), the result is that the SDA line will be low. The first transmitter then observes that the level of the line is different than expected and concludes that another transmitter is communicating.

The first transmitter to notice this difference is the one that loses arbitration and must stop driving the SDA line. If this transmitter is also a master device, it also must stop driving the SCL line. It then can monitor the lines for a Stop condition before trying to reissue its transmission. In the meantime, the other device that has not noticed any difference between the expected and actual levels on the SDA line continues with its original transmission. It can do so without any complications, because so far, the transmission appears exactly as expected with no other transmitter disturbing the message.

Slave Transmit mode can also be arbitrated, when a master addresses multiple slaves, but this is less common.

If two master devices are sending a message to two different slave devices at the address stage, the master sending the lower slave address always wins arbitration. When two master devices send messages to the same slave address, and addresses can sometimes refer to multiple slaves, the arbitration process must continue into the data stage.

Arbitration usually occurs very rarely, but it is a necessary process for proper multi-master support.

#### 30.4.5 START CONDITION

The  $I^2C$  specification defines a Start condition as a transition of SDA from a high to a low state while SCL line is high. A Start condition is always generated by the master and signifies the transition of the bus from an Idle to an Active state. Figure 30-12 shows wave forms for Start and Stop conditions.

A bus collision can occur on a Start condition if the module samples the SDA line low before asserting it low. This does not conform to the  $I^2C$  Specification that states no bus collision can occur on a Start.

#### 30.4.6 STOP CONDITION

A Stop condition is a transition of the SDA line from low-to-high state while the SCL line is high.

Note: At least one SCL low time must appear before a Stop is valid, therefore, if the SDA line goes low then high again while the SCL line stays high, only the Start condition is detected.

#### 30.4.7 RESTART CONDITION

A Restart is valid any time that a Stop would be valid. A master can issue a Restart if it wishes to hold the bus after terminating the current transfer. A Restart has the same effect on the slave that a Start would, resetting all slave logic and preparing it to clock in an address. The master may want to address the same or another slave. Figure 30-13 shows the wave form for a Restart condition.

In 10-bit Addressing Slave mode a Restart is required for the master to clock data out of the addressed slave. Once a slave has been fully addressed, matching both high and low address bytes, the master can issue a Restart and the high address byte with the R/W bit set. The slave logic will then hold the clock and prepare to clock out data.

After a full match with  $R/\overline{W}$  clear in 10-bit mode, a prior match flag is set and maintained until a Stop condition, a high address with  $R/\overline{W}$  clear, or high address match fails.

#### 30.4.8 START/STOP CONDITION INTERRUPT MASKING

The SCIE and PCIE bits of the SSP1CON3 register can enable the generation of an interrupt in Slave modes that do not typically support this function. Slave modes where interrupt on Start and Stop detect are already enabled, these bits will have no effect.

#### FIGURE 30-12: I<sup>2</sup>C START AND STOP CONDITIONS



#### FIGURE 30-13: I<sup>2</sup>C RESTART CONDITION



#### 30.5.3.2 7-Bit Transmission

A master device can transmit a read request to a slave, and then clock data out of the slave. The list below outlines what software for a slave will need to do to accomplish a standard transmission. Figure 30-18 can be used as a reference to this list.

- 1. Master sends a Start condition on SDA and SCL.
- 2. S bit of SSP1STAT is set; SSP1IF is set if interrupt on Start detect is enabled.
- Matching address with R/W bit set is received by the Slave setting SSP1IF bit.
- 4. Slave hardware generates an ACK and sets SSP1IF.
- 5. SSP1IF bit is cleared by user.
- 6. Software reads the received address from SSP1BUF, clearing BF.
- 7.  $R/\overline{W}$  is set so CKP was automatically cleared after the ACK.
- 8. The slave software loads the transmit data into SSP1BUF.
- 9. CKP bit is set releasing SCL, allowing the master to clock the data out of the slave.
- 10. SSP1IF is set after the ACK response from the master is loaded into the ACKSTAT register.
- 11. SSP1IF bit is cleared.
- 12. The slave software checks the ACKSTAT bit to see if the master wants to clock out more data.

Note 1: If the master ACKs the clock will be stretched.

- 2: ACKSTAT is the only bit updated on the rising edge of SCL (9th) rather than the falling.
- 13. Steps 9-13 are repeated for each transmitted byte.
- 14. If the master sends a not ACK; the clock is not held, but SSP1IF is still set.
- 15. The master sends a Restart condition or a Stop.
- 16. The slave is no longer addressed.



© 2014-2015 Microchip Technology Inc.

#### 30.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 30-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 SSP1STAT is set; SSP1IF 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 SSP1STAT register is set.
- 4. Slave sends ACK and SSP1IF is set.
- 5. Software clears the SSP1IF bit.
- 6. Software reads received address from SSP1BUF clearing the BF flag.
- 7. Slave loads low address into SSP1ADD, releasing SCL.
- 8. Master sends matching low address byte to the slave; UA bit is set.

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

- 9. Slave sends ACK and SSP1IF is set.
- **Note:** If the low address does not match, SSP1IF and UA are still set so that the slave software can set SSP1ADD back to the high address. BF is not set because there is no match. CKP is unaffected.
- 10. Slave clears SSP1IF.
- 11. Slave reads the received matching address from SSP1BUF clearing BF.
- 12. Slave loads high address into SSP1ADD.
- Master clocks a data byte to the slave and clocks out the slaves ACK on the 9th SCL pulse; SSP1IF is set.
- 14. If SEN bit of SSP1CON2 is set, CKP is cleared by hardware and the clock is stretched.
- 15. Slave clears SSP1IF.
- 16. Slave reads the received byte from SSP1BUF clearing BF.
- 17. If SEN is set the slave sets CKP to release the SCL.
- 18. Steps 13-17 repeat for each received byte.
- 19. Master sends Stop to end the transmission.

# 30.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 SSP1ADD register using the UA bit. All functionality, specifically when the CKP bit is cleared and SCL line is held low are the same. Figure 30-21 can be used as a reference of a slave in 10-bit addressing with AHEN set.

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

PIC16(L)F1717/8/9



# PIC16(L)F1717/8/9



| Name      | Bit 7     | Bit 6        | Bit 5       | Bit 4                      | Bit 3                  | Bit 2       | Bit 1  | Bit 0  | Reset<br>Values on<br>Page |
|-----------|-----------|--------------|-------------|----------------------------|------------------------|-------------|--------|--------|----------------------------|
| ANSELB    | —         | —            | ANSB5       | ANSB4                      | ANSB3                  | ANSB2 ANSB1 |        | ANSB0  | 131                        |
| ANSELC    | ANSC7     | ANSC6        | ANSC5       | ANSC4                      | ANSC3                  | ANSC2       | —      | —      | 136                        |
| INTCON    | GIE       | PEIE         | TMR0IE      | INTE                       | IOCIE                  | TMR0IF      | INTF   | IOCIF  | 90                         |
| PIE1      | TMR1GIE   | ADIE         | RCIE        | TXIE                       | SSP1IE                 | CCP1IE      | TMR2IE | TMR1IE | 91                         |
| PIE2      | OSFIE     | C2IE         | C1IE        | _                          | BCL1IE                 | TMR6IE      | TMR4IE | CCP2IE | 92                         |
| PIR1      | TMR1GIF   | ADIF         | RCIF        | TXIF                       | SSP1IF                 | CCP1IF      | TMR2IF | TMR1IF | 94                         |
| PIR2      | OSFIF     | C2IF         | C1IF        | _                          | — BCL1IF TMR6IF TMR4IF |             |        |        | 95                         |
| RxyPPS    | _         | _            | _           |                            | F                      | RxyPPS<4:   | 0>     |        | 153                        |
| SSPCLKPPS | —         | —            | —           |                            | SS                     | PCLKPPS<    | 4:0>   |        | 152                        |
| SSPDATPPS | —         | —            |             |                            | SS                     | PDATPPS<    | :4:0>  |        | 152                        |
| SSP1ADD   |           |              |             | ADD<                       | <7:0>                  |             |        |        | 350                        |
| SSP1BUF   | Synchrono | us Serial Po | ort Receive | Buffer/Tran                | ismit Regis            | ter         |        |        | 299*                       |
| SSP1CON1  | WCOL      | SSPOV        | SSPEN       | CKP                        |                        | SSPN        | /<3:0> |        | 346                        |
| SSP1CON2  | GCEN      | ACKSTAT      | ACKDT       | ACKEN                      | RCEN                   | PEN         | RSEN   | SEN    | 348                        |
| SSP1CON3  | ACKTIM    | PCIE         | SCIE        | BOEN SDAHT SBCDE AHEN DHEN |                        |             |        | 349    |                            |
| SSP1MSK   |           |              |             | MSK<                       | 350                    |             |        |        |                            |
| SSP1STAT  | SMP       | CKE          | D/A         | Р                          | S                      | R/W         | UA     | BF     | 345                        |
| TRISB     | TRISB7    | TRISB6       | TRISB5      | TRISB4                     | TRISB3                 | TRISB2      | TRISB1 | TRISB0 | 130                        |
| TRISC     | TRISC7    | TRISC6       | TRISC5      | TRISC4                     | TRISC3                 | TRISC2      | TRISC1 | TRISC0 | 135                        |

| TABLE 30-3: | SUMMARY OF REGISTERS ASSOCIATED WITH I <sup>2</sup> C OPERATION |
|-------------|-----------------------------------------------------------------|
|             |                                                                 |

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

### 31.1 EUSART Asynchronous Mode

The EUSART transmits and receives data using the standard non-return-to-zero (NRZ) format. NRZ is implemented with two levels: a VOH Mark state which represents a '1' data bit, and a VoL Space state which represents a '0' data bit. NRZ refers to the fact that consecutively transmitted data bits of the same value stay at the output level of that bit without returning to a neutral level between each bit transmission. An NRZ transmission port idles in the Mark state. Each character transmission consists of one Start bit followed by eight or nine data bits and is always terminated by one or more Stop bits. The Start bit is always a space and the Stop bits are always marks. The most common data format is eight bits. Each transmitted bit persists for a period of 1/(Baud Rate). An on-chip dedicated 8-bit/16-bit Baud Rate Generator is used to derive standard baud rate frequencies from the system oscillator. See Table 31-5 for examples of baud rate configurations.

The EUSART transmits and receives the LSb first. The EUSART's transmitter and receiver are functionally independent, but share the same data format and baud rate. Parity is not supported by the hardware, but can be implemented in software and stored as the ninth data bit.

#### 31.1.1 EUSART ASYNCHRONOUS TRANSMITTER

The EUSART transmitter block diagram is shown in Figure 31-1. The heart of the transmitter is the serial Transmit Shift Register (TSR), which is not directly accessible by software. The TSR obtains its data from the transmit buffer, which is the TX1REG register.

#### 31.1.1.1 Enabling the Transmitter

The EUSART transmitter is enabled for asynchronous operations by configuring the following three control bits:

- TXEN = 1
- SYNC = 0
- SPEN = 1

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

Setting the TXEN bit of the TX1STA register enables the transmitter circuitry of the EUSART. Clearing the SYNC bit of the TX1STA register configures the EUSART for asynchronous operation. Setting the SPEN bit of the RC1STA register enables the EUSART and automatically configures the TX/CK I/O pin as an output. If the TX/CK pin is shared with an analog peripheral, the analog I/O function must be disabled by clearing the corresponding ANSEL bit.

Note: The TXIF Transmitter Interrupt flag is set when the TXEN enable bit is set.

#### 31.1.1.2 Transmitting Data

A transmission is initiated by writing a character to the TX1REG register. If this is the first character, or the previous character has been completely flushed from the TSR, the data in the TX1REG is immediately transferred to the TSR register. If the TSR still contains all or part of a previous character, the new character data is held in the TX1REG until the Stop bit of the previous character has been transmitted. The pending character in the TX1REG is then transferred to the TSR in one TcY immediately following the Stop bit sequence commences immediately following the transfer of the data to the TSR from the TX1REG.

#### 31.1.1.3 Transmit Data Polarity

The polarity of the transmit data can be controlled with the SCKP bit of the BAUD1CON register. The default state of this bit is '0' which selects high true transmit idle and data bits. Setting the SCKP bit to '1' will invert the transmit data resulting in low true idle and data bits. The SCKP bit controls transmit data polarity in Asynchronous mode only. In Synchronous mode, the SCKP bit has a different function. See **Section 31.5.1.2 "Clock Polarity"**.

#### 31.1.1.4 Transmit Interrupt Flag

The TXIF interrupt flag bit of the PIR1 register is set whenever the EUSART transmitter is enabled and no character is being held for transmission in the TX1REG. In other words, the TXIF bit is only clear when the TSR is busy with a character and a new character has been queued for transmission in the TX1REG. The TXIF flag bit is not cleared immediately upon writing TX1REG. TXIF becomes valid in the second instruction cycle following the write execution. Polling TXIF immediately following the TX1REG write will return invalid results. The TXIF bit is read-only, it cannot be set or cleared by software.

The TXIF interrupt can be enabled by setting the TXIE interrupt enable bit of the PIE1 register. However, the TXIF flag bit will be set whenever the TX1REG is empty, regardless of the state of TXIE enable bit.

To use interrupts when transmitting data, set the TXIE bit only when there is more data to send. Clear the TXIE interrupt enable bit upon writing the last character of the transmission to the TX1REG.

| С    | Configuration Bits |      |                     | Pourd Poto Formula |  |  |
|------|--------------------|------|---------------------|--------------------|--|--|
| SYNC | BRG16              | BRGH | BRG/EUSART Mode     | Bauu Kale Formula  |  |  |
| 0    | 0                  | 0    | 8-bit/Asynchronous  | Fosc/[64 (n+1)]    |  |  |
| 0    | 0                  | 1    | 8-bit/Asynchronous  | F000/[40 (n+4)]    |  |  |
| 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  |                    |  |  |

### TABLE 31-3: BAUD RATE FORMULAS

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

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

| Name     | Bit 7        | Bit 6 | Bit 5 | Bit 4 | Bit 3 Bit 2 |            | Bit 3 Bit 2 |           | Bit 1 | Bit 0 | Register<br>on Page |
|----------|--------------|-------|-------|-------|-------------|------------|-------------|-----------|-------|-------|---------------------|
| BAUD1CON | ABDOVF       | RCIDL |       | SCKP  | BRG16 —     |            | WUE         | ABDEN     | 362   |       |                     |
| RC1STA   | SPEN         | RX9   | SREN  | CREN  | ADDEN       | ADDEN FERR |             | FERR OERR |       | RX9D  | 361                 |
| SP1BRGL  | SP1BRG<7:0>  |       |       |       |             |            |             |           | 363   |       |                     |
| SP1BRGH  | SP1BRG<15:8> |       |       |       |             |            | 363         |           |       |       |                     |
| TX1STA   | CSRC         | TX9   | TXEN  | SYNC  | SENDB       | BRGH       | TRMT        | TX9D      | 360   |       |                     |

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

\* Page provides register information.

| Name     | Bit 7   | Bit 6  | Bit 5  | Bit 4      | Bit 3      | Bit 3 Bit 2   |        | Bit 0  | Register<br>on Page |  |
|----------|---------|--------|--------|------------|------------|---------------|--------|--------|---------------------|--|
| ANSELB   | _       | _      | ANSB5  | ANSB4      | ANSB3      | ANSB2         | ANSB1  | ANSB0  | 131                 |  |
| ANSELC   | ANSC7   | ANSC6  | ANSC5  | ANSC4      | ANSC3      | ANSC2         | —      | —      | 136                 |  |
| BAUD1CON | ABDOVF  | RCIDL  | _      | SCKP       | BRG16      | _             | WUE    | ABDEN  | 362                 |  |
| CKPPS    | -       | -      | —      |            | CKPPS<4:0> |               |        |        |                     |  |
| INTCON   | GIE     | PEIE   | TMR0IE | INTE       | IOCIE      | IOCIE TMR0IF  |        | IOCIF  | 90                  |  |
| PIE1     | TMR1GIE | ADIE   | RCIE   | TXIE       | SSP1IE     | CCP1IE TMR2IE |        | TMR1IE | 91                  |  |
| PIR1     | TMR1GIF | ADIF   | RCIF   | TXIF       | SSP1IF     | CCP1IF TMR2IF |        | TMR1IF | 94                  |  |
| RC1REG   |         |        | EUSA   | ART Receiv | e Data Reg | ister         |        |        | 356*                |  |
| RC1STA   | SPEN    | RX9    | SREN   | CREN       | ADDEN      | FERR          | OERR   | RX9D   | 361                 |  |
| RXPPS    | -       |        | —      |            | 152        |               |        |        |                     |  |
| TRISB    | TRISB7  | TRISB6 | TRISB5 | TRISB4     | TRISB3     | TRISB2        | TRISB1 | TRISB0 | 130                 |  |
| TRISC    | TRISC7  | TRISC6 | TRISC5 | TRISC4     | TRISC3     | TRISC2        | TRISC1 | TRISC0 | 135                 |  |
| TX1STA   | CSRC    | TX9    | TXEN   | SYNC       | SENDB      | BRGH          | TRMT   | TX9D   | 360                 |  |

# TABLE 31-10: SUMMARY OF REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE RECEPTION

Legend: — = unimplemented location, read as '0'. Shaded cells are not used for synchronous slave reception. \* Page provides register information.

# PIC16(L)F1717/8/9

| RETFIE           | Return from Interrupt                                                                                                                                                                                          |  |  |  |  |  |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] RETFIE k                                                                                                                                                                                      |  |  |  |  |  |  |
| Operands:        | None                                                                                                                                                                                                           |  |  |  |  |  |  |
| Operation:       | $TOS \rightarrow PC, \\ 1 \rightarrow GIE$                                                                                                                                                                     |  |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                                           |  |  |  |  |  |  |
| Description:     | Return from Interrupt. Stack is POPed<br>and Top-of-Stack (TOS) is loaded in<br>the PC. Interrupts are enabled by<br>setting Global Interrupt Enable bit,<br>GIE (INTCON<7>). This is a 2-cycle<br>instruction |  |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                                                              |  |  |  |  |  |  |
| Cycles:          | 2                                                                                                                                                                                                              |  |  |  |  |  |  |
| Example:         | RETFIE                                                                                                                                                                                                         |  |  |  |  |  |  |
|                  | After Interrupt<br>PC = TOS<br>GIE = 1                                                                                                                                                                         |  |  |  |  |  |  |

| RETURN           | Return from Subroutine                                                                                                                                |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [label] RETURN                                                                                                                                        |  |  |  |  |  |
| Operands:        | None                                                                                                                                                  |  |  |  |  |  |
| Operation:       | $TOS\toPC$                                                                                                                                            |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                  |  |  |  |  |  |
| Description:     | Return from subroutine. The stack is<br>POPed and the top of the stack (TOS)<br>is loaded into the program counter.<br>This is a 2-cycle instruction. |  |  |  |  |  |

| RETLW            | Return with literal in W                                                                                                                                                      | RLF              | Rotate Left f through Carry                                                                                                                                                                                       |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] RETLW k                                                                                                                                                      | Syntax:          | [ <i>label</i> ] RLF f,d                                                                                                                                                                                          |
| Operands:        | $0 \le k \le 255$                                                                                                                                                             | Operands:        | $0 \le f \le 127$                                                                                                                                                                                                 |
| Operation:       | $k \rightarrow (W);$                                                                                                                                                          |                  | $d \in [0,1]$                                                                                                                                                                                                     |
|                  | $TOS \rightarrow PC$                                                                                                                                                          | Operation:       | See description below                                                                                                                                                                                             |
| Status Affected: | None                                                                                                                                                                          | Status Affected: | C                                                                                                                                                                                                                 |
| Description:     | The W register is loaded with the 8-bit<br>literal 'k'. The program counter is<br>loaded from the top of the stack (the<br>return address). This is a 2-cycle<br>instruction. | Description:     | The contents of register 'f' are rotated<br>one bit to the left through the Carry<br>flag. If 'd' is '0', the result is placed in<br>the W register. If 'd' is '1', the result is<br>stored back in register 'f'. |
| Words:           | 1                                                                                                                                                                             |                  | C Register f                                                                                                                                                                                                      |
| Cycles:          | 2                                                                                                                                                                             |                  |                                                                                                                                                                                                                   |
| Example:         | CALL TABLE;W contains table                                                                                                                                                   | Words:           | 1                                                                                                                                                                                                                 |
|                  | ;offset value                                                                                                                                                                 | Cycles:          | 1                                                                                                                                                                                                                 |
|                  | • ;W now has table value                                                                                                                                                      | Example:         | RLF REG1,0                                                                                                                                                                                                        |
| TABLE            | •                                                                                                                                                                             |                  | Before Instruction                                                                                                                                                                                                |
|                  | ADDWF PC ; $W = offset$                                                                                                                                                       |                  | REG1 = 1110 0110                                                                                                                                                                                                  |
|                  | RETLW k1 ;Begin table                                                                                                                                                         |                  | C = 0                                                                                                                                                                                                             |
|                  | RETLW k2 ;                                                                                                                                                                    |                  | REG1 = 1110 0110                                                                                                                                                                                                  |
|                  | •                                                                                                                                                                             |                  | W = 1100 1100                                                                                                                                                                                                     |
|                  | •                                                                                                                                                                             |                  | C = 1                                                                                                                                                                                                             |
|                  | RETLW kn ; End of table                                                                                                                                                       |                  |                                                                                                                                                                                                                   |
|                  | Before Instruction<br>W = 0x07<br>After Instruction<br>W = value of k8                                                                                                        |                  |                                                                                                                                                                                                                   |

# TABLE 34-15: ANALOG-TO-DIGITAL CONVERTER (ADC) CHARACTERISTICS<sup>(1,2,3,4)</sup>

Standard Operating Conditions (unless otherwise stated)

 $201/T_{1} - 25^{\circ}C$ Cinala 2 0 - \/oo

| $VDD = 3.0V$ , $IA = 25$ C, Single-ended, 2 $\mu$ S IAD, VREFT = 5V, VREFT = VSS |      |                                                   |      |       |      |       |                                                                           |  |
|----------------------------------------------------------------------------------|------|---------------------------------------------------|------|-------|------|-------|---------------------------------------------------------------------------|--|
| Param.<br>No.                                                                    | Sym. | Characteristic                                    | Min. | Тур.† | Max. | Units | Conditions                                                                |  |
| AD01                                                                             | NR   | Resolution                                        | —    |       | 10   | bit   |                                                                           |  |
| AD02                                                                             | EIL  | Integral Error                                    | _    |       | ±1.7 | LSb   | VREF = 3.0V                                                               |  |
| AD03                                                                             | Edl  | Differential Error                                | _    |       | ±1   | LSb   | No missing codes, VREF = 3.0V                                             |  |
| AD04                                                                             | EOFF | Offset Error                                      | _    |       | ±2.5 | LSb   | VREF = 3.0V                                                               |  |
| AD05                                                                             | Egn  | Gain Error                                        | _    |       | ±2.0 | LSb   | VREF = 3.0V                                                               |  |
| AD06                                                                             | VREF | Reference Voltage                                 | 1.8  |       | Vdd  | V     | VREF = (VREF+ minus VREF-)                                                |  |
| AD07                                                                             | VAIN | Full-Scale Range                                  | Vss  | _     | VREF | V     |                                                                           |  |
| AD08                                                                             | Zain | Recommended Impedance of<br>Analog Voltage Source |      |       | 10   | kΩ    | Can go higher if external $0.01 \mu F$ capacitor is present on input pin. |  |

These parameters are characterized but not tested.

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

Note 1: Total Absolute Error includes integral, differential, offset and gain errors.

2: The ADC conversion result never decreases with an increase in the input voltage and has no missing codes.

3: ADC VREF is from external VREF+ pin, VDD pin or FVR, whichever is selected as reference input.

4: See Section 35.0 "DC and AC Characteristics Graphs and Charts" for operating characterization.

#### TABLE 34-16: ADC CONVERSION REQUIREMENTS

| Standard Operating Conditions (unless otherwise stated) |      |                                                                 |     |                |      |       |                                           |  |  |
|---------------------------------------------------------|------|-----------------------------------------------------------------|-----|----------------|------|-------|-------------------------------------------|--|--|
| Param.<br>No.                                           | Sym. | Characteristic                                                  |     | Тур.†          | Max. | Units | Conditions                                |  |  |
| AD130*                                                  | TAD  | ADC Clock Period (TADC)                                         |     | —              | 9.0  | μS    | Fosc-based                                |  |  |
|                                                         |      | ADC Internal FRC Oscillator<br>Period (TFRC)                    | 1.0 | 2              | 6.0  | μS    | ADCS<1:0> = 11 (ADC FRC mode)             |  |  |
| AD131                                                   | TCNV | Conversion Time (not including Acquisition Time) <sup>(1)</sup> |     | 11             | —    | Tad   | Set GO/DONE bit to conversion<br>complete |  |  |
| AD132*                                                  | TACQ | Acquisition Time                                                | _   | 5.0            |      | μS    |                                           |  |  |
| AD133*                                                  | THCD | Holding Capacitor Disconnect                                    |     | 1/2 Tad        |      |       | ADCS<2:0> $\neq$ x11 (Fosc-based)         |  |  |
|                                                         |      | Time                                                            | —   | 1/2 TAD + 1TCY | _    |       | ADCS<2:0> = x11 (FRC-based)               |  |  |

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 t are not tested.

Note 1: The ADRES register may be read on the following TCY cycle.

# THE MICROCHIP WEBSITE

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

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

# CUSTOMER CHANGE NOTIFICATION SERVICE

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

To register, access the Microchip website at www.microchip.com. Under "Support", click on "Customer Change Notification" and follow the registration instructions.

# **CUSTOMER SUPPORT**

Users of Microchip products can receive assistance through several channels:

- Distributor or Representative
- · Local Sales Office
- Field Application Engineer (FAE)
- Technical Support

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

Technical support is available through the website at: http://www.microchip.com/support