# Microchip Technology - PIC16C770/SO Datasheet





Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                 |
|----------------------------|------------------------------------------------------------------------|
| Core Processor             | PIC                                                                    |
| Core Size                  | 8-Bit                                                                  |
| Speed                      | 20MHz                                                                  |
| Connectivity               | I <sup>2</sup> C, SPI                                                  |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                  |
| Number of I/O              | 15                                                                     |
| Program Memory Size        | 3.5KB (2K x 14)                                                        |
| Program Memory Type        | ОТР                                                                    |
| EEPROM Size                | -                                                                      |
| RAM Size                   | 256 x 8                                                                |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V                                                              |
| Data Converters            | A/D 6x12b                                                              |
| Oscillator Type            | Internal                                                               |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                          |
| Package / Case             | 20-SOIC (0.295", 7.50mm Width)                                         |
| Supplier Device Package    | 20-SOIC                                                                |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c770-so |

Email: info@E-XFL.COM

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

# PIC16C717/770/771

NOTES:

#### 2.2.2.6 PIE2 REGISTER

This register contains the individual enable bits for the SSP bus collision and low voltage detect interrupts.

# REGISTER 2-6: PERIPHERAL INTERRUPT ENABLE REGISTER 2 (PIE2: 8Dh)

|         | R/W-0                                                                                                       | U-0           | U-0           | U-0           | R/W-0        | U-0       | U-0          | U-0    |  |
|---------|-------------------------------------------------------------------------------------------------------------|---------------|---------------|---------------|--------------|-----------|--------------|--------|--|
|         | LVDIE                                                                                                       | —             | —             | _             | BCLIE        | _         | —            | —      |  |
|         | bit 7                                                                                                       |               |               |               |              |           |              | bit 0  |  |
| bit 7   | LVDIE: Lov                                                                                                  | v Voltage D   | etect Interru | pt Enable bit | I            |           |              |        |  |
|         | 1 = LVD Interrupt is enabled<br>0 = LVD Interrupt is disabled                                               |               |               |               |              |           |              |        |  |
| bit 6-4 | Unimplem                                                                                                    | ented: Rea    | d as '0'      |               |              |           |              |        |  |
| bit 3   | BCLIE: Bus                                                                                                  | s Collision I | nterrupt Ena  | ble bit       |              |           |              |        |  |
|         | <ul> <li>1 = Bus Collision interrupt is enabled</li> <li>0 = Bus Collision interrupt is disabled</li> </ul> |               |               |               |              |           |              |        |  |
| bit 2-0 | Unimplemented: Read as '0'                                                                                  |               |               |               |              |           |              |        |  |
|         |                                                                                                             |               |               |               |              |           |              |        |  |
|         | Legend:                                                                                                     |               |               |               |              |           |              |        |  |
|         | R = Reada                                                                                                   | ble bit       | W = W         | ritable bit   | U = Unim     | plemented | bit, read as | 0'     |  |
|         | - n = Value                                                                                                 | at POR        | '1' = B       | it is set     | '0' = Bit is | s cleared | x = Bit is u | nknown |  |

The INDF register is not a physical register. Addressing INDF actually addresses the register whose address is contained in the FSR register (FSR is a *pointer*). This is indirect addressing.

Reading INDF itself indirectly (FSR = 0) will produce 00h. Writing to the INDF register indirectly results in a no-operation (although STATUS bits may be affected).

A simple program to clear RAM locations 20h-2Fh using indirect addressing is shown in Example 2-1.

### EXAMPLE 2-1: How to Clear RAM Using Indirect Addressing

|        |       |       | J                    |
|--------|-------|-------|----------------------|
|        | movlw | 0x20  | ;initialize pointer  |
|        | movwf | FSR   | ; to RAM             |
| NEXT   | clrf  | INDF  | ;clear INDF register |
|        | incf  | FSR   | ;inc pointer         |
|        | btfss | FSR,4 | ;all done?           |
|        | goto  | NEXT  | ;NO, clear next      |
| CONTIN | UE    |       |                      |
| :      |       |       | ;YES, continue       |
| 1      |       |       |                      |

An effective 9-bit address is obtained by concatenating the 8-bit FSR register and the IRP bit (STATUS<7>), as shown in Figure 2-5.



# FIGURE 2-5: DIRECT/INDIRECT ADDRESSING

## 8.3 PWM Mode

In Pulse Width Modulation (PWM) mode, the ECCP module produces up to a 10-bit resolution PWM output. Figure 8-3 shows the simplified PWM block diagram.



### FIGURE 8-3: SIMPLIFIED PWM BLOCK DIAGRAM

### 8.3.1 PWM PERIOD

The PWM period is specified by writing to the PR2 register. The PWM period can be calculated using the following formula:

 $PWM PERIOD = [(PR2) + 1] \cdot 4 \cdot TOSC \cdot (TMR2 PRESCALE VALUE)$ 

PWM frequency is defined as 1 / [PWM period].

When TMR2 is equal to PR2, the following three events occur on the next increment cycle:

- TMR2 is cleared
- The CCP1 pin is set (exception: if PWM duty cycle = 0%, the CCP1 pin will not be set)
- The PWM duty cycle is latched from CCPR1L into CCPR1H

**Note:** The Timer2 postscaler (see Section 7.0) is not used in the determination of the PWM frequency. The postscaler could be used to have a servo update rate at a different frequency than the PWM output.



FIGURE 8-7: EXAMPLE OF HALF-BRIDGE OUTPUT MODE APPLICATIONS

Note that in the Full-Bridge Output mode, the ECCP module does not provide any deadband delay. In general, since only one output is modulated at a time, deadband delay is not required. However, there is a situation where a deadband delay might be required. This situation occurs when all of the following conditions are true:

- 1. The direction of the PWM output changes when the duty cycle of the output is at or near 100%.
- 2. The turn off time of the power switch, including the power device and driver circuit, is greater than turn on time.

Figure 8-11 shows an example, where the PWM direction changes from forward to reverse at a near 100% duty cycle. At time t1, the output P1A and P1D become inactive, while output P1C becomes active. In this

example, since the turn off time of the power devices is longer than the turn on time, a shoot-through current flows through the power devices, QB and QD, for the duration of  $t = t_{off}-t_{on}$ . The same phenomenon will occur to power devices, QC and QB, for PWM direction change from reverse to forward.

If changing PWM direction at high duty cycle is required for the user's application, one of the following requirements must be met:

- 1. Avoid changing PWM output direction at or near 100% duty cycle.
- 2. Use switch drivers that compensate for the slow turn off of the power devices. The total turn off time  $(t_{off})$  of the power device and the driver must be less than the turn on time  $(t_{on})$ .





### 8.3.7 SYSTEM IMPLEMENTATION

When the ECCP module is used in the PWM mode, the application hardware must use the proper external pullup and/or pull-down resistors on the PWM output pins. When the microcontroller powers up, all of the I/O pins are in the high-impedance state. The external pull-up and pull-down resistors must keep the power switch devices in the off state until the microcontroller drives the I/O pins with the proper signal levels, or activates the PWM output(s).

### 8.3.8 START-UP CONSIDERATIONS

Prior to enabling the PWM outputs, the P1A, P1B, P1C and P1D latches may not be in the proper states. Enabling the TRISB bits for output at the same time with the CCP module may cause damage to the power switch devices. The CCP1 module must be enabled in the proper Output mode with the TRISB bits enabled as inputs. Once the CCP1 completes a full PWM cycle, the P1A, P1B, P1C and P1D output latches are properly initialized. At this time, the TRISB bits can be enabled for outputs to start driving the power switch devices. The completion of a full PWM cycle is indicated by the TMR2IF bit going from a '0' to a '1'.

### 8.3.9 SET UP FOR PWM OPERATION

The following steps should be taken when configuring the ECCP module for PWM operation:

- 1. Configure the PWM module:
  - a) Disable the CCP1/P1A, P1B, P1C and/or P1D outputs by setting the respective TRISB bits.
  - b) Set the PWM period by loading the PR2 register.
  - c) Set the PWM duty cycle by loading the CCPR1L register and CCP1CON<5:4> bits.
  - d) Configure the ECCP module for the desired PWM operation by loading the CCP1CON register. With the CCP1M<3:0> bits select the active high/low levels for each PWM output. With the PWM1M<1:0> bits select one of the available Output modes: Single, Half-Bridge, Full-Bridge, Forward or Full-Bridge Reverse.
  - e) For Half-Bridge Output mode, set the deadband delay by loading the P1DEL register.
- 2. Configure and start TMR2:
  - a) Clear the TMR2 interrupt flag bit by clearing the TMR2IF bit in the PIR1 register.
  - b) Set the TMR2 prescale value by loading the T2CKPS<1:0> bits in the T2CON register.
  - c) Enable Timer2 by setting the TMR2ON bit in the T2CON register.
- 3. Enable PWM outputs after a new cycle has started:
  - a) Wait until TMR2 overflows (TMR2IF bit becomes a '1'). The new PWM cycle begins here.
  - Enable the CCP1/P1A, P1B, P1C and/or P1D pin outputs by clearing the respective TRISB bits.

| Address                 | Name    | Bit 7                               | Bit 6                         | Bit 5   | Bit 4   | Bit 3   | Bit 2  | Bit 1     | Bit 0     | Value on<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|-------------------------|---------|-------------------------------------|-------------------------------|---------|---------|---------|--------|-----------|-----------|-------------------------|---------------------------------|
| 0Bh, 8Bh,<br>10Bh, 18Bh | INTCON  | GIE                                 | PEIE                          | TOIE    | INTE    | RBIE    | TOIF   | INTF      | RBIF      | 0000 000x               | 0000 000u                       |
| 0Ch                     | PIR1    | —                                   | ADIF                          |         | _       | SSPIF   | CCP1IF | TMR2IF    | TMR1IF    | -0 0000                 | -0 0000                         |
| 8Ch                     | PIE1    | —                                   | ADIE                          |         | _       | SSPIE   | CCP1IE | TMR2IE    | TMR1IE    | -0 0000                 | -0 0000                         |
| 86h, 186h               | TRISB   | PORTB Dat                           | PORTB Data Direction Register |         |         |         |        |           |           | 1111 1111               | 1111 1111                       |
| 11h                     | TMR2    | Timer2 register                     |                               |         |         |         |        |           | 0000 0000 | 0000 0000               |                                 |
| 92h                     | PR2     | Timer2 perio                        | od register                   |         |         |         |        |           |           | 1111 1111               | 1111 1111                       |
| 12h                     | T2CON   | -                                   | TOUTPS3                       | TOUTPS2 | TOUTPS1 | TOUTPS0 | TMR2ON | T2CKPS1   | T2CKPS0   | -000 0000               | -000 0000                       |
| 15h                     | CCPR1L  | Capture/Compare/PWM register1 (LSB) |                               |         |         |         |        | xxxx xxxx | uuuu uuuu |                         |                                 |
| 17h                     | CCP1CON | PWM1M1                              | PWM1M0                        | DC1B1   | DC1B0   | CCP1M3  | CCP1M2 | CCP1M1    | CCP1M0    | 0000 0000               | 0000 0000                       |
| 97h                     | P1DEL   | EL PWM1 Delay value                 |                               |         |         |         |        | 0000 0000 | 0000 0000 |                         |                                 |

# TABLE 8-3: REGISTERS ASSOCIATED WITH PWM

Legend: x = unknown, u = unchanged, - = unimplemented read as '0'. Shaded cells are not used by ECCP module in PWM mode.

# 9.0 MASTER SYNCHRONOUS SERIAL PORT (MSSP) MODULE

The Master Synchronous Serial Port (MSSP) module is a serial interface useful for communicating with other peripheral or microcontroller devices. These peripheral devices may be serial EEPROMs, shift registers, display drivers, etc. The MSSP module can operate in one of two modes:

- Serial Peripheral Interface (SPI™)
- Inter-Integrated Circuit (I<sup>2</sup>C<sup>™</sup>)

For more information about these SSP modes see Section 15 of the *PIC Mid-Range MCU Family Reference Manual (DS33023).* 

### 9.2.2 SLAVE MODE

When an address is matched or the data transfer after an address match is received, the hardware automatically will generate the Acknowledge ( $\overline{ACK}$ ) pulse. Then, it loads the SSPBUF register with the received value currently in the SSPSR register.

Any combination of the following conditions will cause the  $\underline{MSSP}$  module to generate a NACK pulse in lieu of the  $\overline{ACK}$  pulse:

- a) The buffer full bit BF (SSPSTAT<0>) is set before the transfer is received.
- b) The overflow bit SSPOV (SSPCON<6>) is set before the transfer is received.

If the BF bit is set, the SSPSR register value is not loaded into the SSPBUF. However, both the SSPIF and SSPOV bits are set. Table 9-2 shows what happens when a data transfer byte is received, given the status of bits BF and SSPOV. The shaded cells show the condition where user software did not properly clear the overflow condition. The BF flag bit is cleared by reading the SSPBUF register. The SSPOV flag bit is cleared through software.

The SCL clock input must have a minimum high and low time for proper operation. The high and low times of the  $I^2C$  specification as well as the requirements of the MSSP module are shown in timing parameters #100 and #101 of the Electrical Specifications.

### 9.2.2.1 7-BIT ADDRESSING

Once the MSSP module has been enabled (SSPEN=1), the slave module waits for a START condition to occur. Following the START condition, eight bits are shifted into the SSPSR register. All incoming bits are sampled on the rising edge of the clock (SCL) line. The received address (register SSPSR<7:1>) is compared to the stored address (register SSPADD<7:1>). SSPSR<0> is the R/W bit and is not considered in the comparison. Comparison is made on the falling edge of the eighth clock (SCL) pulse. If the addresses match, and the BF and SSPOV bits are clear, the following events occur:

- a) The SSPSR register value is transferred to the SSPBUF register on the falling edge of the eighth SCL pulse.
- b) The buffer full bit; BF is set on the falling edge of the eighth SCL pulse.
- c) An ACK pulse is generated during the ninth clock cycle.
- d) SSP interrupt flag bit; SSPIF (PIR1<3>) is set (interrupt is generated if enabled) - on the falling edge of the ninth SCL pulse.

### 9.2.2.2 10-BIT ADDRESSING

In 10-bit mode, the basic receive and transmit operations are the same as in the 7-bit mode. However, the criteria for address match are more complex.

Two address bytes need to be received by the slave. The five Most Significant bits (MSbs) of the first address byte specify that this is a 10-bit address. The LSb of the first received address byte is the R/W bit, which must be zero, specifying a write so the slave device will receive the second address byte. For a 10-bit address, the first byte equals '11110 A9 A8 0', where A9 and A8 are the two MSbs of the address. The sequence of events for a 10-bit address is as follows, with steps 7 through 9 applicable only to the slave-transmitter:

- 1. Receive first (high) byte of Address (bits SSPIF, BF, and bit UA (SSPSTAT<1>) are set).
- 2. Update the SSPADD register with second (low) byte of Address (clears bit UA and releases the SCL line).
- 3. Read the SSPBUF register (clears bit BF) and clear flag bit SSPIF.
- 4. Receive second (low) byte of Address (bits SSPIF, BF, and UA are set).
- 5. Update the SSPADD register with the first (high) byte of Address. This will clear bit UA and release the SCL line.
- 6. Read the SSPBUF register (clears bit BF) and clear flag bit SSPIF.
- 7. Receive Repeated START condition.
- Receive first (high) byte of Address with R/W bit set to 1 (bits SSPIF and BF are set). This also puts the MSSP module in the Slave-transmit mode.
- 9. Read the SSPBUF register (clears bit BF) and clear flag bit SSPIF.

**Note:** Following the Repeated START condition (step 7) in 10-bit mode, the user only needs to match the first 7-bit address. The user does not update the SSPADD for the second half of the address.

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

In Master-transmitter mode, serial data is output through SDA, while SCL outputs the serial clock. The first byte transmitted contains seven bits of address data and the Read/Write (R/W) bit. In this case, the R/W bit will be logic '0'. Subsequent serial data is transmitted eight bits at a time. After each byte is transmitted, an Acknowledge bit is received. START and STOP conditions are output to indicate the beginning and the end of a serial transfer.

Transmission of a data byte, a 7-bit address, or either half of a 10-bit address is accomplished by simply writing a value to the SSPBUF register. This action will set the buffer full flag (BF) and allow the baud rate generator to begin counting and start the next transmission. Each bit of address/data will be shifted out onto the SDA pin after the falling edge of SCL is asserted (see data hold time spec). SCL is held low for one baud rate generator roll over count (TBRG). Data should be valid before SCL is released high (see data setup time spec). When the SCL pin is released high, it is held that way for TBRG, the data on the SDA pin must remain stable for that duration and some hold time after the next falling edge of SCL. After the eighth bit is shifted out (the falling edge of the eighth clock), the BF flag is cleared and the master releases SDA. This allows the slave device being addressed to respond with an ACK bit during the ninth bit time. The status of ACK is read into the ACKDT on the rising edge of the ninth clock. If the master receives an Acknowledge, the Acknowledge status bit (ACKSTAT) is cleared. Otherwise, the bit is set. The SSPIF is set on the falling edge of the ninth clock, and the master clock (baud rate generator) is suspended until the next data byte is loaded into the SSPBUF leaving SCL low and SDA unchanged (Figure 9-18).

A typical transmit sequence would go as follows:

- a) The user generates a START Condition by setting the START enable bit (SEN) in SSPCON2.
- b) SSPIF is set at the completion of the START sequence.
- c) The user resets the SSPIF bit and loads the SSPBUF with seven bits of address plus R/W bit to transmit.
- d) Address and R/W is shifted out the SDA pin until all eight bits are transmitted.
- e) The MSSP Module shifts in the ACK bit from the slave device, and writes its value into the SSPCON2 register (SSPCON2<6>).
- f) The module generates an interrupt at the end of the ninth clock cycle by setting SSPIF.
- g) The user resets the SSPIF bit and loads the SSPBUF with eight bits of data.
- h) DATA is shifted out the SDA pin until all eight bits are transmitted.
- The MSSP Module shifts in the ACK bit from the slave device and writes its value into the SSPCON2 register (SSPCON2<6>).
- j) The MSSP module generates an interrupt at the end of the ninth clock cycle by setting the SSPIF bit.
- k) The user resets the SSPIF bit and generates a STOP condition by setting the STOP enable bit PEN in SSPCON2.
- I) SSPIF is set when the STOP condition is complete.

9.2.12.1 BF STATUS FLAG

In Transmit mode, the BF bit (SSPSTAT<0>) is set when the CPU writes to SSPBUF and is cleared when all eight bits are shifted out.

9.2.12.2 WCOL STATUS FLAG

If the user writes the SSPBUF when a transmit is already in progress (i.e. SSPSR is still shifting out a data byte), then WCOL is set and the contents of the buffer are unchanged (the write doesn't occur).

WCOL must be cleared in software.

9.2.12.3 ACKSTAT STATUS FLAG

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

# PIC16C717/770/771



# PIC16C717/770/771

# REGISTER 11-1: A/D CONTROL REGISTER 0 (ADCON0: 1Fh).

| 1. 11-1.  |                                                       |                                               |                                              |                                             | ••••                          |                            |                            |                      |
|-----------|-------------------------------------------------------|-----------------------------------------------|----------------------------------------------|---------------------------------------------|-------------------------------|----------------------------|----------------------------|----------------------|
|           | R/W-0                                                 | R/W-0                                         | R/W-0                                        | R/W-0                                       | R/W-0                         | R/W-0                      | R/W-0                      | R/W-0                |
|           | ADCS1                                                 | ADCS0                                         | CHS2                                         | CHS1                                        | CHS0                          | GO/DONE                    | CHS3                       | ADON                 |
|           | bit 7                                                 |                                               |                                              |                                             |                               |                            |                            | bit 0                |
| bit 7-6   | ADCS<1:0                                              | >: A/D Conv                                   | ersion Cloc                                  | k Select bits                               | ;                             |                            |                            |                      |
|           | If internal V<br>or 101):<br>00 = Fosc/<br>01 = Fosc/ | 'RL and/or V<br>'2<br>'8                      | /RH are not                                  | used for A/I                                | D reference                   | (VCFG<2:0>                 | = 000, 0                   | 01, 011              |
|           | 10 = Fosc/                                            | 32                                            |                                              |                                             |                               |                            |                            |                      |
|           | 11 = FRC (                                            | clock derived                                 | d from a dec                                 | dicated RC of                               | oscillator)                   | <b>C</b> (2)() 01          | 0 1 0 0 1                  | 1001111).            |
|           | 0.0 = Fosc/                                           | '16                                           | RH are used                                  | a for A/D refe                              | erence (VCF                   | G<2:0>=01                  | 0, 100, 1                  | .10 <b>O</b> f 111): |
|           | 01 = FOSC/                                            | 64                                            |                                              |                                             |                               |                            |                            |                      |
|           | 10 = Fosc/                                            | 256                                           |                                              |                                             |                               |                            |                            |                      |
|           | 11 = FRC/8                                            |                                               |                                              |                                             |                               |                            |                            |                      |
| bit 5-3,1 | CHS:<3:0>                                             | : Analog Ch                                   | annel Seleo                                  | ct bits                                     |                               |                            |                            |                      |
|           | 0000 = cha                                            | annel 00 (AN                                  | 10)<br>14)                                   |                                             |                               |                            |                            |                      |
|           | 0001 = cha                                            | annei 01 (AN<br>annei 02 (AN                  | 11)<br>12)                                   |                                             |                               |                            |                            |                      |
|           | 0010 = cha                                            | annel 02 (AN                                  | 12)<br>13)                                   |                                             |                               |                            |                            |                      |
|           | 0100 = cha                                            | annel 04 (AN                                  | 14)                                          |                                             |                               |                            |                            |                      |
|           | 0101 = cha                                            | annel 05 (AN                                  | 15)                                          |                                             |                               |                            |                            |                      |
|           | 0110 = res                                            | erved, do no                                  | ot select                                    |                                             |                               |                            |                            |                      |
|           | 0111 = res                                            | erved, do no                                  | ot select                                    |                                             |                               |                            |                            |                      |
|           | 1000 = res                                            | erved, do no                                  | ot select                                    |                                             |                               |                            |                            |                      |
|           | 1001 = res                                            | erved do no                                   | nt select                                    |                                             |                               |                            |                            |                      |
|           | 1011 = res                                            | erved, do no                                  | ot select                                    |                                             |                               |                            |                            |                      |
|           | 1100 = res                                            | erved, do no                                  | ot select                                    |                                             |                               |                            |                            |                      |
|           | 1101 = res                                            | erved, do no                                  | ot select                                    |                                             |                               |                            |                            |                      |
|           | 1110 = res                                            | erved, do no                                  | ot select                                    |                                             |                               |                            |                            |                      |
|           | 1111 = res                                            | erved, do no                                  | ot select                                    |                                             |                               |                            |                            |                      |
| bit 2     | GO/DONE:                                              | : A/D Conve                                   | rsion Status                                 | bit                                         |                               |                            |                            |                      |
|           | 1 = A/D co<br>This bit<br>0 = A/D co                  | nversion cyc<br>is automation<br>nversion con | le in progre<br>cally cleared<br>npleted/not | ss. Setting t<br>d by hardwa<br>in progress | his bit starts<br>re when the | an A/D conv<br>A/D convers | ersion cycl<br>ion has cor | e.<br>npleted.       |
| bit 0     | ADON: A/D                                             | ) On bit                                      |                                              |                                             |                               |                            |                            |                      |
|           | 1 = A/D coi                                           | nverter modu                                  | ule is opera                                 | ting                                        |                               |                            |                            |                      |
|           | 0 = A/D cor                                           | nverter is sh                                 | utoff and co                                 | nsumes no                                   | operating c                   | urrent                     |                            |                      |
|           |                                                       |                                               |                                              |                                             |                               |                            |                            |                      |

| Legend:            |                  |                      |                    |
|--------------------|------------------|----------------------|--------------------|
| R = Readable bit   | W = Writable bit | U = Unimplemented    | bit, read as '0'   |
| - n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown |

### FIGURE 11-2: PIC16C717 10-BIT A/D RESULT FORMAT



After the A/D module has been configured as desired, the selected channel must be acquired before the conversion is started. The analog input channels must have their corresponding TRIS and ANSEL bits selected as an input. To determine acquisition time, see Section 11.6. After this acquisition time has elapsed, the A/D conversion can be started. The following steps should be followed for doing an A/D conversion:

### 11.2 Configuring the A/D Module

### 11.2.1 CONFIGURING ANALOG PORT PINS

The ANSEL and TRIS registers control the operation of the A/D port pins. The port pins that are desired as analog inputs must have their corresponding TRIS bit set (input). If the TRIS bit is cleared (output), the digital output level (VOH or VOL) will be converted. The proper ANSEL bits must be set (analog input) to disable the digital input buffer.

The A/D operation is independent of the state of the TRIS bits and the ANSEL bits.

- Note 1: When reading the PORTA register, all pins configured as analog input channels will read as '0'.
  - 2: When reading the PORTB register, all pins configured as analog pins on PORTB will be read as '1'.
  - 3: Analog levels on any pin that is defined as a digital input, including the ANx pins, may cause the input buffer to consume current that is out of the devices specification.

# 11.2.2 CONFIGURING THE REFERENCE VOLTAGES

The VCFG bits in the ADCON1 register configure the A/D module reference inputs. The reference high input can come from an internal reference (VRH) or (VRL), an external reference (VREF+), or AVDD. The low reference input can come from an internal reference (VRL), an external reference (VREF-), or AVss. If an external reference is chosen for the reference high or reference low inputs, the port pin that multiplexes the incoming external references is configured as an analog input, regardless of the values contained in the A/D port configuration bits (PCFG<3:0>).

# 12.8 Time-out Sequence

On power-up, the time-out sequence is as follows: First PWRT time-out is invoked by the POR pulse. When the PWRT delay expires, the Oscillator Start-up Timer is activated. The total time-out will vary based on oscillator configuration and the status of the PWRT. For example, in RC mode with the PWRT disabled, there will be no time-out at all. Figure 12-6, Figure 12-7, Figure 12-8 and Figure 12-9 depict time-out sequences on power-up.

Since the time-outs occur from the POR pulse, if MCLR is kept low long enough, the time-outs will expire. Then bringing MCLR high will begin execution immediately (Figure 12-8). This is useful for testing purposes or to synchronize more than one PIC<sup>®</sup> microcontroller operating in parallel.

Table 12-5 shows the RESET conditions for some special function registers, while Table 12-6 shows the RESET conditions for all the registers.

### 12.9 Power Control/STATUS Register (PCON)

The Power Control/STATUS Register, PCON, has two status bits that provide indication of which power-up type RESET occurred.

Bit0 is Brown-out Reset Status bit, BOR. The BOR bit is unknown upon a POR. BOR must be set by the user and checked on subsequent RESETS to see if bit BOR cleared, indicating a BOR occurred.

Bit1 is POR (Power-on Reset Status bit). It is cleared on a Power-on Reset and unaffected otherwise. The user must set this bit following a Power-on Reset.

| Occillator Configuration | Power            | -up       | Prown out        | Wake-up from<br>SLEEP |  |
|--------------------------|------------------|-----------|------------------|-----------------------|--|
|                          | PWRTE = 0        | PWRTE = 1 | Brown-out        |                       |  |
| XT, HS, LP               | TPWRT + 1024Tosc | 1024Tosc  | TPWRT + 1024Tosc | 1024Tosc              |  |
| EC, ER, INTRC            | TPWRT            | _         | TPWRT            | _                     |  |

### TABLE 12-3: TIME-OUT IN VARIOUS SITUATIONS

### TABLE 12-4: STATUS BITS AND THEIR SIGNIFICANCE

| POR | BOR | то | PD |                                                         |
|-----|-----|----|----|---------------------------------------------------------|
| 0   | x   | 1  | 1  | Power-on Reset                                          |
| 0   | х   | 0  | x  | Illegal, TO is set on POR                               |
| 0   | x   | x  | 0  | Illegal, PD is set on POR                               |
| 1   | 0   | 1  | 1  | Brown-out Reset                                         |
| 1   | 1   | 0  | 1  | WDT Reset                                               |
| 1   | 1   | 0  | 0  | WDT Wake-up                                             |
| 1   | 1   | u  | u  | MCLR Reset during normal operation                      |
| 1   | 1   | 1  | 0  | MCLR Reset during SLEEP or interrupt wake-up from SLEEP |

### TABLE 12-5: RESET CONDITION FOR SPECIAL REGISTERS

| Condition                             | Program<br>Counter | STATUS<br>Register | PCON<br>Register |
|---------------------------------------|--------------------|--------------------|------------------|
| Power-on Reset                        | 000h               | 0001 1xxx          | 1-0x             |
| MCLR Reset during normal operation    | 000h               | 000u uuuu          | 1-uu             |
| MCLR Reset during SLEEP               | 000h               | 0001 0uuu          | 1-uu             |
| WDT Reset                             | 000h               | 0000 luuu          | 1-uu             |
| WDT Wake-up                           | PC + 1             | uuu0 0uuu          | u-uu             |
| Brown-out Reset                       | 000h               | 0001 luuu          | 1-u0             |
| Interrupt wake-up from SLEEP, GIE = 0 | PC + 1             | uuul 0uuu          | u-uu             |
| Interrupt wake-up from SLEEP, GIE = 1 | 0004h              | uuul 0uuu          | u-uu             |

Legend: u = unchanged, x = unknown, - = unimplemented bit read as '0'.





# FIGURE 12-8: TIME-OUT SEQUENCE ON POWER-UP (MCLR NOT TIED TO VDD): CASE 2



### FIGURE 12-9: SLOW VDD RISE TIME (MCLR TIED TO VDD)



| RETFIE           | Return from Interrupt  | RLF              | Rotate Left f through Carry                                                                                                                                                                                      |  |  |
|------------------|------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:          | [label] RETFIE         | Syntax:          | [ <i>label</i> ] RLF f,d                                                                                                                                                                                         |  |  |
| Operands:        | None                   | Operands:        | $0 \leq f \leq 127$                                                                                                                                                                                              |  |  |
| Operation:       | $TOS \rightarrow PC$ , |                  | d ∈ [0,1]                                                                                                                                                                                                        |  |  |
| -                | $1 \rightarrow GIE$    | Operation:       | See description below                                                                                                                                                                                            |  |  |
| Status Affected: | None                   | Status Affected: | С                                                                                                                                                                                                                |  |  |
|                  |                        | Description:     | The contents of register 'f' are<br>rotated one bit to the left through<br>the Carry Flag. If 'd' is 0, the<br>result is placed in the W register.<br>If 'd' is 1, the result is stored back<br>in register 'f'. |  |  |

| RETLW            | Return with Literal in W                                                                                                                                                            | RRF              | Rotate Right f through Carry                                                                                                                                                                                        |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] RETLW k                                                                                                                                                            | Syntax:          | [ <i>label</i> ] RRF f,d                                                                                                                                                                                            |
| Operands:        | $0 \le k \le 255$                                                                                                                                                                   | Operands:        | $0 \le f \le 127$                                                                                                                                                                                                   |
| Operation:       | $k \rightarrow (W);$                                                                                                                                                                |                  | d ∈ [0,1]                                                                                                                                                                                                           |
| •                | $TOS \rightarrow PC$                                                                                                                                                                | Operation:       | See description below                                                                                                                                                                                               |
| Status Affected: | None                                                                                                                                                                                | Status Affected: | С                                                                                                                                                                                                                   |
| Description:     | The W register is loaded with the<br>eight bit literal 'k'. The program<br>counter is loaded from the top of<br>the stack (the return address).<br>This is a two cycle instruction. | Description:     | The contents of register 'f' are<br>rotated one bit to the right through<br>the Carry Flag. If 'd' is 0, the result<br>is placed in the W register. If 'd' is<br>1, the result is placed back in reg-<br>ister 'f'. |
|                  |                                                                                                                                                                                     |                  | C Register f                                                                                                                                                                                                        |

| RETURN           | Return from Subroutine                                                                                     | SLEEP            |                                                                                                                                                                                                          |  |
|------------------|------------------------------------------------------------------------------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax:          | [label] RETURN                                                                                             | Syntax:          | [ label SLEEP                                                                                                                                                                                            |  |
| Operands:        | None                                                                                                       |                  | ]                                                                                                                                                                                                        |  |
| Operation:       | $TOS \rightarrow PC$                                                                                       | Operands:        | None                                                                                                                                                                                                     |  |
| Status Affected: | None                                                                                                       | Operation:       | $\begin{array}{l} 00h \rightarrow WDT, \\ 0 \rightarrow WDT \ prescaler, \\ 1 \rightarrow \overline{TO}, \\ 0 \rightarrow \overline{PD} \\ \overline{TO}, \ \overline{PD} \end{array}$                   |  |
| Description:     | Return from subroutine. The stack<br>is POPed and the top of the stack<br>(TOS) is loaded into the program |                  |                                                                                                                                                                                                          |  |
|                  | counter. This is a two cycle                                                                               | Status Affected: |                                                                                                                                                                                                          |  |
|                  | instruction.                                                                                               | Description:     | The power-down status bit, PD<br>is cleared. Time-out status bit,<br>TO is set. Watchdog Timer and<br>its prescaler are cleared.<br>The processor is put into SLEEP<br>mode with the oscillator stopped. |  |

See Section 12.8 for more

details.

# TABLE 15-4:RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER,<br/>AND BROWN-OUT RESET REQUIREMENTS

| Parameter | Sym   | Characteristic                                            | Min | Тур†      | Max | Units | Conditions                                        |
|-----------|-------|-----------------------------------------------------------|-----|-----------|-----|-------|---------------------------------------------------|
| NO.       |       |                                                           |     |           |     |       |                                                   |
| 30*       | TMCL  | MCLR Pulse Width (low)                                    | 2   | —         | _   | μS    | VDD = 5V, -40°C to +85°C                          |
| 31*       | Twdt  | Watchdog Timer Time-out Period (No Prescaler)             | 7   | 18        | 33  | ms    | VDD = 5V, -40°C to +85°C                          |
| 32*       | Tost  | Oscillation Start-up Timer Period                         | _   | 1024 Tosc | _   | —     | Tosc = OSC1 period                                |
| 33*       | TPWRT | Power up Timer Period                                     | 28  | 72        | 132 | ms    | $VDD = 5V, -40^{\circ}C \text{ to } +85^{\circ}C$ |
| 34*       | TIOZ  | I/O Hi-impedance from MCLR Low<br>or Watchdog Timer Reset | _   | _         | 2.1 | μS    |                                                   |
| 35*       | TBOR  | Brown-out Reset pulse width                               | 100 | —         | _   | μS    | $VDD \le VBOR (D005)$                             |

These parameters are characterized but not tested.

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

### FIGURE 15-9: BROWN-OUT RESET CHARACTERISTICS



### FIGURE 15-10: TIMER0 AND TIMER1 EXTERNAL CLOCK TIMINGS



#### 15.4.2 LOW VOLTAGE DETECT MODULE (LVD)





| TABLE 15-8: | ELECTRICAL CHARACTERISTICS: LVD |
|-------------|---------------------------------|
|-------------|---------------------------------|

| Standard Operating Conditions (unless otherwise stated)                   |                  |                                                                                 |                                                       |     |      |      |       |            |  |  |  |  |
|---------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------|-------------------------------------------------------|-----|------|------|-------|------------|--|--|--|--|
|                                                                           |                  | Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial and |                                                       |     |      |      |       |            |  |  |  |  |
| DC CHAI                                                                   | ACTERISTICS      |                                                                                 | $0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial |     |      |      |       |            |  |  |  |  |
| Operating voltage VDD range as described in DC Characteristics Section 15 |                  |                                                                                 |                                                       |     |      |      |       |            |  |  |  |  |
| Param.<br>No.                                                             | Charac           | teristic                                                                        | Symbol                                                | Min | Тур† | Max  | Units | Conditions |  |  |  |  |
| D420*                                                                     | LVD Voltage      | LVV = 0100                                                                      |                                                       | 2.5 | 2.58 | 2.66 | V     |            |  |  |  |  |
|                                                                           |                  | LVV = 0101                                                                      |                                                       | 2.7 | 2.78 | 2.86 | V     |            |  |  |  |  |
|                                                                           |                  | LVV = 0110                                                                      |                                                       | 2.8 | 2.89 | 2.98 | V     |            |  |  |  |  |
|                                                                           |                  | LVV = 0111                                                                      |                                                       | 3.0 | 3.1  | 3.2  | V     |            |  |  |  |  |
|                                                                           |                  | LVV = 1000                                                                      |                                                       | 3.3 | 3.41 | 3.52 | V     |            |  |  |  |  |
|                                                                           |                  | LVV = 1001                                                                      | Vlvd                                                  | 3.5 | 3.61 | 3.72 | V     |            |  |  |  |  |
|                                                                           |                  | LVV = 1010                                                                      |                                                       | 3.6 | 3.72 | 3.84 | V     |            |  |  |  |  |
|                                                                           |                  | LVV = 1011                                                                      |                                                       | 3.8 | 3.92 | 4.04 | V     |            |  |  |  |  |
|                                                                           |                  | LVV = 1100                                                                      |                                                       | 4.0 | 4.13 | 4.26 | V     |            |  |  |  |  |
|                                                                           |                  | LVV = 1101                                                                      |                                                       | 4.2 | 4.33 | 4.46 | V     |            |  |  |  |  |
|                                                                           |                  | LVV = 1110                                                                      |                                                       | 4.5 | 4.64 | 4.78 | V     |            |  |  |  |  |
| *                                                                         | These parameters | are characterized h                                                             | out not tester                                        | 1   |      |      |       |            |  |  |  |  |

These parameters are characterized but not tested.

**Note 1:** Production tested at Tamb = 25°C. Specifications over temperature limits ensured by characterization.

| TABLE 15-14: PIC16C717 AND PIC16LC717 A/D CONVERTER CHARACTERISTI | CS: |
|-------------------------------------------------------------------|-----|
|-------------------------------------------------------------------|-----|

| Param.<br>No. | Sym   | Characteristic                                       | Min   | Тур†   | Max       | Units | Conditions                                                                                                                               |
|---------------|-------|------------------------------------------------------|-------|--------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------|
| A01           | NR    | Resolution                                           |       | _      | 10 bits   | bit   | Min. resolution for A/D is 4.1 mV,<br>VREF+ = AVDD = 4.096V,<br>VREF- = AVSS = 0V,<br>VREF- $\leq$ VAIN $\leq$ VREF+                     |
| A03           | EIL   | Integral error                                       |       | _      | ±1        | LSb   | VREF+ = AVDD = 4.096V,<br>VREF- = AVSS = 0V,<br>$VREF- \leq VAIN \leq VREF+$                                                             |
| A04           | Edl   | Differential error                                   | _     | _      | ±1        | LSb   | No missing codes to 10 bits<br>VREF+ = AVDD = 4.096V,<br>VREF- = AVSS = 0V,<br>$VREF- \le VAIN \le VREF+$                                |
| A06           | EOFF  | Offset error                                         | —     | _      | ±2        | LSb   | VREF+ = AVDD = 4.096V,<br>VREF- = AVSS = 0V,<br>VREF- ≤ VAIN ≤ VREF+                                                                     |
| A07           | Egn   | Gain Error                                           | —     | _      | ±1        | LSb   | VREF+ = AVDD = 4.096V,<br>VREF- = AVSS = 0V,<br>VREF- ≤ VAIN ≤ VREF+                                                                     |
| A10           | —     | Monotonicity                                         |       | Note 3 | —         |       | $AVSS \leq VAIN \leq VREF+$                                                                                                              |
| A20*          | Vref  | Reference voltage<br>(VREF+ - VREF-)                 | 4.096 | _      | VDD +0.3V | V     | Absolute minimum electrical spec to ensure 10-bit accuracy.                                                                              |
| A21*          | VREF+ | Reference V High<br>(AVDD or VREF+)                  | VREF- | _      | AVdd      | V     | Min. resolution for A/D is 4.1 mV                                                                                                        |
| A22*          | VREF- | Reference V Low<br>(Avss or VREF-)                   | AVss  | _      | VREF+     | V     | Min. resolution for A/D is 4.1 mV                                                                                                        |
| A25*          | VAIN  | Analog input voltage                                 | Vrefl | _      | Vrefh     | V     |                                                                                                                                          |
| A30*          | ZAIN  | Recommended<br>impedance of analog<br>voltage source | _     | _      | 2.5       | kΩ    |                                                                                                                                          |
| A50*          | IREF  | VREF input current<br>(Note 2)                       | _     | _      | 10        | μA    | During VAIN acquisition.<br>Based on differential of VHOLD to VAIN.<br>To charge CHOLD see Section 11.0.<br>During A/D conversion cycle. |

These parameters are characterized but not tested.

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

Note 1: When A/D is off, it will not consume any current other than leakage current. The power-down current spec includes any such leakage from the A/D module.

2: VREF current is from External VREF+, or VREF-, or AVSS, or AVDD pin, whichever is selected as reference input.

3: The A/D conversion result never decreases with an increase in the input voltage and has no missing codes.

t



### TABLE 15-15: PIC16C717 AND PIC16LC717 A/D CONVERSION REQUIREMENT (NORMAL MODE)

| Parameter<br>No.    | Sym  | Characteristic                                                     | Min      | Тур†   | Max | Units | Conditions                                                                                                                                                                                                               |
|---------------------|------|--------------------------------------------------------------------|----------|--------|-----|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 130* <sup>(3)</sup> | TAD  | A/D clock period                                                   | 1.6      | _      | _   | μs    | Tosc based, VREF $\geq$ 2.5V                                                                                                                                                                                             |
|                     |      |                                                                    | 3.0      | —      | —   | μs    | Tosc based, VREF full range                                                                                                                                                                                              |
|                     |      |                                                                    | 3.0      | 6.0    | 9.0 | μs    | ADCS<1:0> = 11 (A/D RC mode)<br>At VDD = 2.5V                                                                                                                                                                            |
|                     |      |                                                                    | 2.0      | 4.0    | 6.0 | μs    | At VDD = 5.0V                                                                                                                                                                                                            |
| 131*                | ТСNV | Conversion time (not<br>including<br>acquisition time)<br>(Note 1) |          | 11Tad  | _   | Tad   |                                                                                                                                                                                                                          |
| 132*                | TACQ | Acquisition Time                                                   | (Note 2) | 11.5   | —   | μs    |                                                                                                                                                                                                                          |
|                     |      |                                                                    | 5*       | _      | _   | μs    | The minimum time is the amplifier<br>settling time. This may be used if<br>the "new" input voltage has not<br>changed by more than 1LSb (i.e.,<br>1mV @ 4.096V) from the last sam-<br>pled voltage (as stated on CHOLD). |
| 134*                | TGO  | Q4 to A/D clock start                                              | —        | Tosc/2 | _   | _     |                                                                                                                                                                                                                          |

\* These parameters are characterized but not tested.

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

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

2: See Section 11.6 for minimum conditions.

**3:** These numbers multiplied by 8 if VRH or VRL is selected as A/D reference.