

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

| Details                    |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                    |
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 16MHz                                                                       |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                           |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                       |
| Number of I/O              | 50                                                                          |
| Program Memory Size        | 16KB (8K x 16)                                                              |
| Program Memory Type        | ОТР                                                                         |
| EEPROM Size                | -                                                                           |
| RAM Size                   | 454 x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                                 |
| Data Converters            | A/D 12x10b                                                                  |
| Oscillator Type            | External                                                                    |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 64-TQFP                                                                     |
| Supplier Device Package    | 64-TQFP (10x10)                                                             |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic17c752t-16e-pt |
|                            |                                                                             |

Email: info@E-XFL.COM

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

# 2.0 DEVICE VARIETIES

Each device has a variety of frequency ranges and packaging options. Depending on application and production requirements, the proper device option can be selected using the information in the PIC17C7XX Product Selection System section at the end of this data sheet. When placing orders, please use the "PIC17C7XX Product Identification System" at the back of this data sheet to specify the correct part number. When discussing the functionality of the device, memory technology and voltage range does not matter.

There are two memory type options. These are specified in the middle characters of the part number.

- 1. **C**, as in PIC17**C**756A. These devices have EPROM type memory.
- 2. **CR**, as in PIC17**CR**756A. These devices have ROM type memory.

All these devices operate over the standard voltage range. Devices are also offered which operate over an extended voltage range (and reduced frequency range). Table 2-1 shows all possible memory types and voltage range designators for a particular device. These designators are in **bold** typeface.

| Memory Type                                                              | Voltage Range      |             |  |  |  |
|--------------------------------------------------------------------------|--------------------|-------------|--|--|--|
| memory type                                                              | Standard           | Extended    |  |  |  |
| EPROM                                                                    | PIC17 <b>C</b> XXX | PIC17LCXXX  |  |  |  |
| ROM                                                                      | PIC17CRXXX         | PIC17LCRXXX |  |  |  |
| Note: Not all memory technologies are available for a particular device. |                    |             |  |  |  |

# 2.1 UV Erasable Devices

The UV erasable version, offered in CERQUAD package, is optimal for prototype development and pilot programs.

The UV erasable version can be erased and reprogrammed to any of the configuration modes. Third party programmers also are available; refer to the *Third Party Guide* for a list of sources.

# 2.2 One-Time-Programmable (OTP) Devices

The availability of OTP devices is especially useful for customers expecting frequent code changes and updates.

The OTP devices, packaged in plastic packages, permit the user to program them once. In addition to the program memory, the configuration bits must be programmed.

# 2.3 Quick-Turnaround-Production (QTP) Devices

Microchip offers a QTP Programming Service for factory production orders. This service is made available for users who choose not to program a medium to high quantity of units and whose code patterns have stabilized. The devices are identical to the OTP devices but with all EPROM locations and configuration options already programmed by the factory. Certain code and prototype verification procedures apply before production shipments are available. Please contact your local Microchip Technology sales office for more details.

# 2.4 Serialized Quick-Turnaround Production (SQTP<sup>sm</sup>) Devices

Microchip offers a unique programming service, where a few user defined locations in each device are programmed with different serial numbers. The serial numbers may be random, pseudo-random or sequential.

Serial programming allows each device to have a unique number which can serve as an entry code, password or ID number.

# 2.5 Read Only Memory (ROM) Devices

Microchip offers masked ROM versions of several of the highest volume parts, thus giving customers a low cost option for high volume, mature products.

ROM devices do not allow serialization information in the program memory space.

For information on submitting ROM code, please contact your regional sales office.

Note: Presently, NO ROM versions of the PIC17C7XX devices are available.

## EXAMPLE 6-2: SAVING STATUS AND WREG IN RAM (NESTED)

; The addresses that are used to store the CPUSTA and WREG values must be in the data memory ; address range of 1Ah - 1Fh. Up to 6 locations can be saved and restored using the MOVFP ; instruction. This instruction neither affects the status bits, nor corrupts the WREG register. ; This routine uses the FRSO, so it controls the FS1 and FSO bits in the ALUSTA register. Nobank FSR EOU 0x40 Bank FSR EQU 0x41 ALU\_Temp EQU 0x42 0x43 WREG TEMP EQU BSR S1 EQU 0x01A ; 1st location to save BSR 0x01B BSR S2 EQU ; 2nd location to save BSR (Label Not used in program) BSR S3 EQU 0x01C ; 3rd location to save BSR (Label Not used in program) BSR S4 EQU 0x01D ; 4th location to save BSR (Label Not used in program) 0x01E BSR\_S5 EQU ; 5th location to save BSR (Label Not used in program) 0x01F ; 6th location to save BSR (Label Not used in program) BSR\_S6 EOU INITIALIZATION CALL CLEAR RAM ; Must Clear all Data RAM INIT\_POINTERS ; Must Initialize the pointers for POP and PUSH CLRF BSR, F ; Set All banks to 0 CLRF ALUSTA, F ; FSR0 post increment BSF ALUSTA, FS1 CLRF WREG, F ; Clear WREG MOVLW BSR S1 ; Load FSR0 with 1st address to save BSR MOVWF FSR0 MOVWF Nobank FSR MOVLW 0x20 MOVWF Bank\_FSR : ; Your code : : ; At Interrupt Vector Address PUSH BSF ALUSTA, FSO ; FSR0 has auto-increment, does not affect status bits BCF ALUSTA, FS1 ; does not affect status bits MOVFP BSR, INDF0 ; No Status bits are affected CLRF BSR, F ; Peripheral and Data RAM Bank 0 No Status bits are affected MOVPF ALUSTA, ALU\_Temp ; MOVPF FSR0, Nobank\_FSR ; Save the FSR for BSR values WREG, WREG TEMP MOVPF ; ; Restore FSR value for other values MOVFP Bank\_FSR, FSR0 MOVFP ALU\_Temp, INDF0 ; Push ALUSTA value MOVFP WREG TEMP, INDFO ; Push WREG value MOVFP PCLATH, INDF0 ; Push PCLATH value MOVPF FSR0, Bank FSR ; Restore FSR value for other values MOVFP Nobank FSR, FSR0 ; ; ; Interrupt Service Routine (ISR) code : ; POP CLRF ALUSTA, F ; FSR0 has auto-decrement, does not affect status bits MOVFP Bank FSR, FSR0 ; Restore FSR value for other values FSR0, F DECF ; ; Pop PCLATH value MOVFP INDF0, PCLATH ; Pop WREG value MOVFP INDF0, WREG ; FSR0 does not change BSF ALUSTA, FS1 MOVPF INDF0, ALU Temp ; Pop ALUSTA value MOVPF FSR0, Bank FSR ; Restore FSR value for other values Nobank\_FSR, F DECF ; MOVFP Nobank FSR, FSR0 ; Save the FSR for BSR values ALU Temp, ALUSTA MOVFP ; MOVFP INDF0, BSR ; No Status bits are affected RETFIE ; Return from interrupt (enable interrupts)

## 7.2.2.1 ALU Status Register (ALUSTA)

The ALUSTA register contains the status bits of the Arithmetic and Logic Unit and the mode control bits for the indirect addressing register.

As with all the other registers, the ALUSTA register can be the destination for any instruction. If the ALUSTA register is the destination for an instruction that affects the Z, DC, C, or OV bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Therefore, the result of an instruction with the ALUSTA register as destination may be different than intended.

For example, the CLRF ALUSTA, F instruction will clear the upper four bits and set the Z bit. This leaves the ALUSTA register as 0000u1uu (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions be used to alter the ALUSTA register, because these instructions do not affect any status bits. To see how other instructions affect the status bits, see the "Instruction Set Summary."

| Note 1: The C and DC bits operate as a borrow and |
|---------------------------------------------------|
| digit borrow bit, respectively, in subtraction.   |
| See the SUBLW and SUBWF instructions for          |
| examples.                                         |

2: The overflow bit will be set if the 2's complement result exceeds +127, or is less than -128.

The Arithmetic and Logic Unit (ALU) is capable of carrying out arithmetic or logical operations on two operands, or a single operand. All single operand instructions operate either on the WREG register, or the given file register. For two operand instructions, one of the operands is the WREG register and the other is either a file register, or an 8-bit immediate constant.

# REGISTER 7-1: ALUSTA REGISTER (ADDRESS: 04h, UNBANKED)

|         | R/W-1                                                                                                                                                                                                                                                                                                                                                                                                                               | R/W-1                              | R/W-1          | R/W-1       | R/W-x    | R/W-x         | R/W-x        | R/W-x |  |  |  |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|----------------|-------------|----------|---------------|--------------|-------|--|--|--|
|         | FS3                                                                                                                                                                                                                                                                                                                                                                                                                                 | FS2                                | FS1            | FS0         | OV       | Z             | DC           | С     |  |  |  |
|         | bit 7                                                                                                                                                                                                                                                                                                                                                                                                                               |                                    |                |             |          |               |              | bit 0 |  |  |  |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                    |                |             |          |               |              |       |  |  |  |
| bit 7-6 | FS3:FS2: FSR1 Mode Select bits<br>00 = Post auto-decrement FSR1 value<br>01 = Post auto-increment FSR1 value<br>1x = FSR1 value does not change                                                                                                                                                                                                                                                                                     |                                    |                |             |          |               |              |       |  |  |  |
| bit 5-4 | FS1:FS0: FSR0 Mode Select bits<br>00 = Post auto-decrement FSR0 value<br>01 = Post auto-increment FSR0 value<br>1x = FSR0 value does not change                                                                                                                                                                                                                                                                                     |                                    |                |             |          |               |              |       |  |  |  |
| bit 3   | <b>OV</b> : Overflow bit<br>This bit is used for signed arithmetic (2's complement). It indicates an overflow of the 7-bit<br>magnitude, which causes the sign bit (bit7) to change state.<br>1 = Overflow occurred for signed arithmetic (in this arithmetic operation)<br>0 = No overflow occurred                                                                                                                                |                                    |                |             |          |               |              |       |  |  |  |
| bit 2   |                                                                                                                                                                                                                                                                                                                                                                                                                                     | sult of an arit<br>sult of an arit |                |             |          |               |              |       |  |  |  |
| bit 1   | <b>DC</b> : Digit carry/borrow bit<br>For ADDWF and ADDLW instructions.<br>1 = A carry-out from the 4th low order bit of the result occurred<br>0 = No carry-out from the 4th low order bit of the result                                                                                                                                                                                                                           |                                    |                |             |          |               |              |       |  |  |  |
|         | Note:                                                                                                                                                                                                                                                                                                                                                                                                                               | For borrow,                        | the polarity i | s reversed. |          |               |              |       |  |  |  |
| bit 0   | C: Carry/bo                                                                                                                                                                                                                                                                                                                                                                                                                         | orrow bit                          |                |             |          |               |              |       |  |  |  |
|         | <ul> <li>For ADDWF and ADDLW instructions. Note that a subtraction is executed by adding the two's complement of the second operand.</li> <li>For rotate (RRCF, RLCF) instructions, this bit is loaded with either the high or low order bit of the source register.</li> <li>1 = A carry-out from the Most Significant bit of the result occurred</li> <li>0 = No carry-out from the Most Significant bit of the result</li> </ul> |                                    |                |             |          |               |              |       |  |  |  |
|         | Note:                                                                                                                                                                                                                                                                                                                                                                                                                               | For borrow,                        | the polarity i | s reversed. |          |               |              |       |  |  |  |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                    |                |             |          |               |              |       |  |  |  |
|         | Legend:                                                                                                                                                                                                                                                                                                                                                                                                                             |                                    |                |             |          |               |              |       |  |  |  |
|         | R = Reada                                                                                                                                                                                                                                                                                                                                                                                                                           | ble bit                            | W = W          | ritable bit | U = Unim | plemented bit | , read as '0 | ,     |  |  |  |

'1' = Bit is set

- n = Value at POR Reset

x = Bit is unknown

'0' = Bit is cleared



## FIGURE 10-7: BLOCK DIAGRAM OF RB6 PORT PIN



# FIGURE 10-8: BLOCK DIAGRAM OF RB7 PORT PIN











|       | R-0                                                                                                                                                                                                                                                                                                                                             | R-0                                                                   | R/W-0                                                                            | R/W-0                                                                       | R/W-0                        | R/W-0                                                            | R/W-0                         | R/W-0                       |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------|------------------------------|------------------------------------------------------------------|-------------------------------|-----------------------------|
|       | CA2OVF                                                                                                                                                                                                                                                                                                                                          | CA10VF                                                                | PWM2ON                                                                           | PWM10N                                                                      | CA1/PR3                      | TMR3ON                                                           | TMR2ON                        | TMR10N                      |
|       | bit 7                                                                                                                                                                                                                                                                                                                                           |                                                                       |                                                                                  |                                                                             |                              |                                                                  |                               | bit 0                       |
| bit 7 | This bit in<br>(CA2H:CA<br>unread cap<br>the capture<br>1 = Overflo                                                                                                                                                                                                                                                                             | 2L) before th<br>oture value (l                                       | the capture<br>ne next capt<br>ast capture<br>h the TMR3<br>on Capture2          | e value had<br>ure event oc<br>before overfle<br>value until th<br>register | curred. The ow). Subseq      | ead from the<br>capture regi<br>uent capture<br>gister has be    | ster retains<br>events will r | the oldest<br>not update    |
| bit 6 | This bit ind<br>CA1H:PR3<br>est unread<br>update the<br>bytes).<br>1 = Overflo                                                                                                                                                                                                                                                                  | BL/CA1L), be<br>I capture va                                          | ne capture va<br>fore the next<br>lue (last cap<br>ister with the<br>on Capture1 | alue had not l<br>capture even<br>oture before<br>TMR3 value<br>register    | nt occurred.<br>overflow). S | om the captur<br>The capture r<br>subsequent c<br>apture registe | egister retai<br>apture even  | ns the old-<br>its will not |
| bit 5 | <b>PWM2ON</b> :<br>1 = PWM2<br>(The R<br>0 = PWM2                                                                                                                                                                                                                                                                                               | PWM2 On I<br>is enabled<br>B3/PWM2 pi<br>is disabled                  | bit<br>n ignores the                                                             | e state of the                                                              |                              | oit.)<br>for data direc                                          | tion.)                        |                             |
| bit 4 | PWM1ON: PWM1 On bit<br>1 = PWM1 is enabled<br>(The RB2/PWM1 pin ignores the state of the DDRB<2> bit.)<br>0 = PWM1 is disabled<br>(The RB2/PWM1 pin uses the state of the DDRB<2> bit for data direction.)                                                                                                                                      |                                                                       |                                                                                  |                                                                             |                              |                                                                  |                               |                             |
| bit 3 | <ul> <li>CA1/PR3: CA1/PR3 Register Mode Select bit</li> <li>1 = Enables Capture1         (PR3H/CA1H:PR3L/CA1L is the Capture1 register. Timer3 runs without a period register.)</li> <li>0 = Enables the Period register         (PR3H/CA1H:PR3L/CA1L is the Period register for Timer3.)</li> </ul>                                            |                                                                       |                                                                                  |                                                                             |                              |                                                                  |                               | egister.)                   |
| bit 2 | -                                                                                                                                                                                                                                                                                                                                               | Timer3 On b<br>Timer3                                                 |                                                                                  |                                                                             |                              | ,                                                                |                               |                             |
| bit 1 | <ul> <li>TMR2ON: Timer2 On bit</li> <li>This bit controls the incrementing of the TMR2 register. When TMR2:TMR1 form the 16-bit timer (T16 is set), TMR2ON must be set. This allows the MSB of the timer to increment.</li> <li>1 = Starts Timer2 (must be enabled if the T16 bit (TCON1&lt;3&gt;) is set)</li> <li>0 = Stops Timer2</li> </ul> |                                                                       |                                                                                  |                                                                             |                              |                                                                  |                               |                             |
| bit 0 | •                                                                                                                                                                                                                                                                                                                                               | Timer1 On b                                                           | oit                                                                              |                                                                             |                              |                                                                  |                               |                             |
|       | <u>When T16</u><br>1 = Starts 7<br>0 = Stops 7                                                                                                                                                                                                                                                                                                  | <u>is set (in 16</u><br>16-bit TMR2<br>16-bit TMR2:<br>is clear (in 8 | bit Timer mo<br>TMR1<br>TMR1                                                     |                                                                             |                              |                                                                  |                               |                             |

# REGISTER 13-2: TCON2 REGISTER (ADDRESS: 17h, BANK 3)

## 13.1.3 USING PULSE WIDTH MODULATION (PWM) OUTPUTS WITH TIMER1 AND TIMER2

Three high speed pulse width modulation (PWM) outputs are provided. The PWM1 output uses Timer1 as its time base, while PWM2 and PWM3 may independently be software configured to use either Timer1 or Timer2 as the time base. The PWM outputs are on the RB2/PWM1, RB3/PWM2 and RG5/PWM3 pins.

Each PWM output has a maximum resolution of 10bits. At 10-bit resolution, the PWM output frequency is 32.2 kHz (@ 32 MHz clock) and at 8-bit resolution the PWM output frequency is 128.9 kHz. The duty cycle of the output can vary from 0% to 100%.

Figure 13-3 shows a simplified block diagram of a PWM module.

The duty cycle registers are double buffered for glitch free operation. Figure 13-4 shows how a glitch could occur if the duty cycle registers were not double buffered.

The user needs to set the PWM1ON bit (TCON2<4>) to enable the PWM1 output. When the PWM1ON bit is set, the RB2/PWM1 pin is configured as PWM1 output and forced as an output, irrespective of the data direction bit (DDRB<2>). When the PWM1ON bit is clear, the pin behaves as a port pin and its direction is controlled by its data direction bit (DDRB<2>). Similarly, the PWM2ON (TCON2<5>) bit controls the configuration of the RB3/PWM2 pin and the PWM3ON (TCON3<0>) bit controls the configuration of the RG5/PWM3 pin.

## FIGURE 13-3: SIMPLIFIED PWM BLOCK DIAGRAM





## 13.2.4 EXTERNAL CLOCK INPUT FOR TIMER3

When TMR3CS is set, the 16-bit TMR3 increments on the falling edge of clock input TCLK3. The input on the RB5/TCLK3 pin is sampled and synchronized by the internal phase clocks, twice every instruction cycle. This causes a delay from the time a falling edge appears on TCLK3 to the time TMR3 is actually incremented. For the external clock input timing requirements, see the Electrical Specification section. Figure 13-7 shows the timing diagram when operating from an external clock.

# 13.2.5 READING/WRITING TIMER3

Since Timer3 is a 16-bit timer and only 8-bits at a time can be read or written, care should be taken when reading or writing while the timer is running. The best method is to stop the timer, perform any read or write operation and then restart Timer3 (using the TMR3ON bit). However, if it is necessary to keep Timer3 freerunning, care must be taken. For writing to the 16-bit TMR3, Example 13-2 may be used. For reading the 16bit TMR3, Example 13-3 may be used. Interrupts must be disabled during this routine.

## EXAMPLE 13-2: WRITING TO TMR3

| BSF   | CPUSTA, | GLINTD | ; Disable interrupts      |
|-------|---------|--------|---------------------------|
| MOVFP | RAM_L,  | TMR3L  | i                         |
| MOVFP | RAM_H,  | TMR3H  | i                         |
| BCF   | CPUSTA, | GLINTD | ; Done, enable interrupts |

## EXAMPLE 13-3: READING FROM TMR3

| MOVPF<br>MOVPF | TMR3L,<br>TMR3H, |       | ; read low TMR3<br>; read high TMR3 |
|----------------|------------------|-------|-------------------------------------|
| MOVFP          | TMPLO,           | WREG  | ; tmplo -> wreg                     |
| CPFSLT         | TMR3L            |       | ; TMR3L < wreg?                     |
| RETURN         |                  |       | ; no then return                    |
| MOVPF          | TMR3L,           | TMPLO | ; read low TMR3                     |
| MOVPF          | TMR3H,           | TMPHI | ; read high TMR3                    |
| RETURN         |                  |       | ; return                            |
|                |                  |       |                                     |





| TABLE 14-5: BAUD R | ATES FOR ASYNCHRONOUS MODE |
|--------------------|----------------------------|
|--------------------|----------------------------|

| BAUD        | Fosc = | = 33 MHz                                                                                    | SPBRG              | FOSC = 25      | MHz    | SPBRG              | FOSC = 2 | FOSC = 20 MHz  |                    | SPBRG FOSC = 16 MHz |        | SPBRG              |
|-------------|--------|---------------------------------------------------------------------------------------------|--------------------|----------------|--------|--------------------|----------|----------------|--------------------|---------------------|--------|--------------------|
| RATE<br>(K) | KBAU   | D %ERROR                                                                                    | VALUE<br>(DECIMAL) | KBAUD 9        | %ERROR | VALUE<br>(DECIMAL) | KBAUD    | %ERROR         | VALUE<br>(DECIMAL) | KBAUD               | %ERROR | VALUE<br>(DECIMAL) |
| 0.3         | NA     |                                                                                             |                    | NA             | _      |                    | NA       | _              |                    | NA                  | _      |                    |
| 1.2         | NA     | _                                                                                           | _                  | NA             | _      | _                  | 1.221    | +1.73          | 255                | 1.202               | +0.16  | 207                |
| 2.4         | 2.398  | -0.07                                                                                       | 214                | 2.396          | 0.14   | 162                | 2.404    | +0.16          | 129                | 2.404               | +0.16  | 103                |
| 9.6         | 9.548  |                                                                                             | 53                 | 9.53           | -0.76  | 40                 | 9.469    | -1.36          | 32                 | 9.615               | +0.16  | 25                 |
| 19.2        | 19.09  |                                                                                             | 26                 | 19.53          | +1.73  | 19                 | 19.53    | +1.73          | 15                 | 19.23               | +0.16  | 12                 |
| 76.8        | 73.66  | 6 -4.09                                                                                     | 6                  | 78.13          | +1.73  | 4                  | 78.13    | +1.73          | 3                  | 83.33               | +8.51  | 2                  |
| 96          | 103.1  | 2 +7.42                                                                                     | 4                  | 97.65          | +1.73  | 3                  | 104.2    | +8.51          | 2                  | NA                  | _      | _                  |
| 300         | 257.8  | 1 -14.06                                                                                    | 1                  | 390.63         | +30.21 | 0                  | 312.5    | +4.17          | 0                  | NA                  | _      | _                  |
| 500         | 515.6  | 2 +3.13                                                                                     | 0                  | NA             | _      | _                  | NA       | _              | _                  | NA                  | _      | _                  |
| HIGH        | 515.6  | 2 —                                                                                         | 0                  | _              | _      | 0                  | 312.5    | _              | 0                  | 250                 | _      | 0                  |
| LOW         | 2.014  | 4 <u> </u>                                                                                  | 255                | 1.53           | _      | 255                | 1.221    | _              | 255                | 0.977               | _      | 255                |
| I           | F      | Fosc = 10 MHz                                                                               |                    |                | Fosc   | = 7.159 MH         | 7        |                | FOSC = 5           | .068 MHz            |        |                    |
| BAU<br>RAT  | ID     |                                                                                             |                    | SPBRG<br>VALUE |        | - 1.100 1011       |          | SPBRG<br>VALUE | 1 000 - 0          |                     |        | SPBRG<br>VALUE     |
| (K)         | )      | KBAUD                                                                                       | %ERROR             | (DECIMA        | L) KE  | BAUD %             | ERROR    | (DECIMAL       | ) KBAU             | D %I                | ERROR  | (DECIMAL)          |
| 0.3         | 3      | NA                                                                                          | —                  | _              |        | NA                 | _        | —              | 0.31               |                     | +3.13  | 255                |
| 1.2         | 2      | 1.202                                                                                       | +0.16              | 129            | 1      | .203               | _0.23    | 92             | 1.2                |                     | 0      | 65                 |
| 2.4         | Ļ      | 2.404                                                                                       | +0.16              | 64             | 2      | .380               | -0.83    | 46             | 2.4                |                     | 0      | 32                 |
| 9.6         | 6      | 9.766                                                                                       | +1.73              | 15             | 9      | .322               | -2.90    | 11             | 9.9                |                     | -3.13  | 7                  |
| 19.3        | 2      | 19.53                                                                                       | +1.73              | 7              | 1      | 8.64               | -2.90    | 5              | 19.8               |                     | +3.13  | 3                  |
| 76.         | 8      | 78.13                                                                                       | +1.73              | 1              |        | NA                 | —        |                | 79.2               |                     | +3.13  | 0                  |
| 96          | ;      | NA                                                                                          | —                  | —              |        | NA                 | —        |                | NA                 |                     | —      | —                  |
| 300         | C      | NA                                                                                          | —                  | _              |        | NA                 | _        | —              | NA                 |                     | _      | -                  |
| 500         |        | NA                                                                                          | —                  | _              |        | NA                 | _        | —              | NA                 |                     | _      | -                  |
| HIG         |        | 156.3                                                                                       | —                  | 0              |        | 11.9               | _        | 0              | 79.2               |                     | _      | 0                  |
| LO          | N      | 0.610                                                                                       | —                  | 255            | 0      | .437               | —        | 255            | 0.309              | )                   | —      | 2 <b>55</b>        |
|             | F      | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- | Hz                 |                | Fosc   | = 1 MHz            |          |                | Fosc = 3           | 2.768 kHz           |        |                    |
| BAU<br>RAT  | ID     |                                                                                             |                    | SPBRG<br>VALUE | i      |                    |          | SPBRG<br>VALUE |                    |                     |        | SPBRG<br>VALUE     |
| (K)         |        | KBAUD                                                                                       | %ERROR             | (DECIMA        | L) KE  | AUD %              | ERROR    | (DECIMAL       | ) KBAU             | D %I                | ERROR  | (DECIMAL)          |
| 0.3         | 3      | 0.301                                                                                       | +0.23              | 185            | 0      | .300               | +0.16    | 51             | 0.256              | ; -                 | 14.67  | 1                  |
| 1.2         | 2      | 1.190                                                                                       | -0.83              | 46             | 1      | .202               | +0.16    | 12             | NA                 |                     | _      | _                  |
| 2.4         | Ļ      | 2.432                                                                                       | +1.32              | 22             | 2      | .232               | -6.99    | 6              | NA                 |                     | _      | _                  |
| 9.6         | 6      | 9.322                                                                                       | -2.90              | 5              |        | NA                 | _        | _              | NA                 |                     | _      | _                  |
| 19.3        | 2      | 18.64                                                                                       | -2.90              | 2              |        | NA                 | _        | _              | NA                 |                     | _      | _                  |
| 76.         | 8      | NA                                                                                          | _                  | _              |        | NA                 | _        | _              | NA                 |                     | _      | _                  |
| 96          | ;      | NA                                                                                          | _                  | _              |        | NA                 | _        | _              | NA                 |                     | _      | _                  |
| 300         | C      | NA                                                                                          | _                  | _              |        | NA                 | _        | _              | NA                 |                     | _      | _                  |
| 500         | D      | NA                                                                                          | _                  | _              |        | NA                 | _        | _              | NA                 |                     | _      | _                  |
| HIG         | н      | 55.93                                                                                       | _                  | 0              | 1      | 5.63               | _        | 0              | 0.512              | 2                   | _      | 0                  |
| LOV         | N      | 0.218                                                                                       | _                  | 255            | 0      | .061               | _        | 255            | 0.002              | 2                   | _      | 255                |

#### REGISTER 15-1: SSPSTAT: SYNC SERIAL PORT STATUS REGISTER (ADDRESS: 13h, BANK 6) R/W-0 R/W-0 R-0 R-0 R-0 R-0 R-0 R-0 SMP CKE D/A Р S R/W UA BF bit 7 bit 0 bit 7 SMP: Sample bit SPI Master mode: 1 = Input data sampled at end of data output time 0 = Input data sampled at middle of data output time SPI Slave mode: SMP must be cleared when SPI is used in Slave mode In I<sup>2</sup>C Master or Slave mode: 1 = Slew rate control disabled for Standard Speed mode (100 kHz and 1 MHz) 0 = Slew rate control enabled for High Speed mode (400 kHz) bit 6 CKE: SPI Clock Edge Select (Figure 15-6, Figure 15-8 and Figure 15-9) CKP = 0: 1 = Data transmitted on rising edge of SCK 0 = Data transmitted on falling edge of SCK CKP = 1: 1 = Data transmitted on falling edge of SCK 0 = Data transmitted on rising edge of SCK bit 5 D/A: Data/Address bit (I<sup>2</sup>C mode only) 1 = Indicates that the last byte received or transmitted was data 0 = Indicates that the last byte received or transmitted was address P: STOP bit bit 4 $(l^2C \text{ mode only})$ . This bit is cleared when the MSSP module is disabled, SSPEN is cleared.) 1 = Indicates that a STOP bit has been detected last (this bit is '0' on RESET) 0 = STOP bit was not detected last bit 3 S: START bit (I<sup>2</sup>C mode only. This bit is cleared when the MSSP module is disabled, SSPEN is cleared.) 1 = Indicates that a START bit has been detected last (this bit is '0' on RESET) 0 = START bit was not detected last **R/W**: Read/Write bit Information (I<sup>2</sup>C mode only) bit 2 This bit holds the R/W bit information following the last address match. This bit is only valid from the address match to the next START bit, STOP bit, or not ACK bit. In I<sup>2</sup>C Slave mode: 1 = Read 0 = WriteIn I<sup>2</sup>C Master mode: 1 = Transmit is in progress 0 = Transmit is not in progress Or'ing this bit with SEN, RSEN, PEN, RCEN, or ACKEN will indicate if the MSSP is in IDLE mode. bit 1 **UA**: Update Address (10-bit I<sup>2</sup>C mode only) 1 = Indicates that the user needs to update the address in the SSPADD register 0 = Address does not need to be updated bit 0 BF: Buffer Full Status bit Receive (SPI and I<sup>2</sup>C modes) 1 = Receive complete, SSPBUF is full 0 = Receive not complete, SSPBUF is empty Transmit (I<sup>2</sup>C mode only) 1 = Data transmit in progress (does not include the ACK and STOP bits), SSPBUF is full 0 = Data transmit complete (does not include the $\overline{ACK}$ and STOP bits), SSPBUF is empty Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

# 15.2.9 I<sup>2</sup>C MASTER MODE START CONDITION TIMING

To initiate a START condition, the user sets the START condition enable bit, SEN (SSPCON2<0>). If the SDA and SCL pins are sampled high, the baud rate generator is reloaded with the contents of SSPADD<6:0> and starts its count. If SCL and SDA are both sampled high when the baud rate generator times out (TBRG), the SDA pin is driven low. The action of the SDA being driven low while SCL is high is the START condition and causes the S bit (SSPSTAT<3>) to be set. Following this, the baud rate generator is reloaded with the contents of SSPADD<6:0> and resumes its count. When the baud rate generator times out (TBRG), the SEN bit (SSPCON2<0>) will be automatically cleared by hardware, the baud rate generator is suspended, leaving the SDA line held low and the START condition is complete.

Note: If at the beginning of START condition, the SDA and SCL pins are already sampled low, or if during the START condition, the SCL line is sampled low before the SDA line is driven low, a bus collision occurs. The Bus Collision Interrupt Flag (BCLIF) is set, the START condition is aborted and the I<sup>2</sup>C module is reset into its IDLE state.

# FIGURE 15-20: FIRST START BIT TIMING



If the user writes the SSPBUF when a START sequence is in progress, then WCOL is set and the contents of the buffer are unchanged (the write doesn't occur).

**Note:** Because queueing of events is not allowed, writing to the lower 5 bits of SSPCON2 is disabled until the START condition is complete.



# 15.2.12 I<sup>2</sup>C MASTER MODE RECEPTION

Master mode reception is enabled by programming the receive enable bit, RCEN (SSPCON2<3>).

| Note: | The SSP Module must be in an IDLE        |
|-------|------------------------------------------|
|       | STATE before the RCEN bit is set, or the |
|       | RCEN bit will be disregarded.            |

The baud rate generator begins counting and on each rollover, the state of the SCL pin changes (high to low/ low to high) and data is shifted into the SSPSR. After the falling edge of the eighth clock, the receive enable flag is automatically cleared, the contents of the SSPSR are loaded into the SSPBUF, the BF flag is set, the SSPIF is set and the baud rate generator is suspended from counting, holding SCL low. The SSP is now in IDLE state, awaiting the next command. When the buffer is read by the CPU, the BF flag is automatically cleared. The user can then send an acknowledge bit at the end of reception, by setting the acknowledge sequence enable bit, ACKEN (SSPCON2<4>).

# 15.2.12.1 BF Status Flag

In receive operation, BF is set when an address or data byte is loaded into SSPBUF from SSPSR. It is cleared when SSPBUF is read.

## 15.2.12.2 SSPOV Status Flag

In receive operation, SSPOV is set when 8 bits are received into the SSPSR, and the BF flag is already set from a previous reception.

## 15.2.12.3 WCOL Status Flag

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



## FIGURE 15-36: BUS COLLISION DURING START CONDITION (SCL = 0)

# FIGURE 15-37: BRG RESET DUE TO SDA COLLISION DURING START CONDITION



# 16.7 A/D Accuracy/Error

In systems where the device frequency is low, use of the A/D RC clock is preferred. At moderate to high frequencies, TAD should be derived from the device oscillator.

The absolute accuracy specified for the A/D converter includes the sum of all contributions for quantization error, integral error, differential error, full scale error, offset error, and monotonicity. It is defined as the maximum deviation from an actual transition versus an ideal transition for any code. The absolute error of the A/D converter is specified at <  $\pm$ 1 LSb for VDD = VREF (over the device's specified operating range). However, the accuracy of the A/D converter will degrade as VREF diverges from VDD.

For a given range of analog inputs, the output digital code will be the same. This is due to the quantization of the analog input to a digital code. Quantization error is typically  $\pm$  1/2 LSb and is inherent in the analog to digital conversion process. The only way to reduce quantization error is to increase the resolution of the A/D converter or oversample.

Offset error measures the first actual transition of a code versus the first ideal transition of a code. Offset error shifts the entire transfer function. Offset error can be calibrated out of a system or introduced into a system through the interaction of the total leakage current and source impedance at the analog input.

Gain error measures the maximum deviation of the last actual transition and the last ideal transition adjusted for offset error. This error appears as a change in slope of the transfer function. The difference in gain error to full scale error is that full scale does not take offset error into account. Gain error can be calibrated out in software.

Linearity error refers to the uniformity of the code changes. Linearity errors cannot be calibrated out of the system. Integral non-linearity error measures the actual code transition versus the ideal code transition, adjusted by the gain error for each code.

Differential non-linearity measures the maximum actual code width versus the ideal code width. This measure is unadjusted.

The maximum pin leakage current is specified in the Device Data Sheet electrical specification (Table 20-2, parameter #D060).

In systems where the device frequency is low, use of the A/D RC clock is preferred. At moderate to high frequencies, TAD should be derived from the device oscillator. TAD must not violate the minimum and should be minimized to reduce inaccuracies due to noise and sampling capacitor bleed off. In systems where the device will enter SLEEP mode after the start of the A/D conversion, the RC clock source selection is required. In this mode, the digital noise from the modules in SLEEP are stopped. This method gives high accuracy.

# 16.8 Connection Considerations

If the input voltage exceeds the rail values (VSS or VDD) by greater than 0.3V, then the accuracy of the conversion is out of specification.

An external RC filter is sometimes added for antialiasing of the input signal. The R component should be selected to ensure that the total source impedance is kept under the 10 k $\Omega$  recommended specification. Any external components connected (via hi-impedance) to an analog input pin (capacitor, zener diode, etc.) should have very little leakage current at the pin.

# 16.9 Transfer Function

The transfer function of the A/D converter is as follows: the first transition occurs when the analog input voltage (VAIN) equals Analog VREF / 1024 (Figure 16-7).

## FIGURE 16-7: A/D TRANSFER FUNCTION



#### 17.4 Power-down Mode (SLEEP)

The Power-down mode is entered by executing a SLEEP instruction. This clears the Watchdog Timer and postscaler (if enabled). The PD bit is cleared and the TO bit is set (in the CPUSTA register). In SLEEP mode, the oscillator driver is turned off. The I/O ports maintain their status (driving high, low, or hi-impedance input).

The MCLR/VPP pin must be at a logic high level (VIHMC). A WDT time-out RESET does not drive the MCLR/VPP pin low.

#### 17.4.1 WAKE-UP FROM SLEEP

The device can wake-up from SLEEP through one of the following events:

- Power-on Reset
- · Brown-out Reset
- External RESET input on MCLR/VPP pin
- WDT Reset (if WDT was enabled)
- Interrupt from RA0/INT pin, RB port change, T0CKI interrupt, or some peripheral interrupts

The following peripheral interrupts can wake the device from SLEEP:

- Capture interrupts
- · USART synchronous slave transmit interrupts
- · USART synchronous slave receive interrupts
- A/D conversion complete
- · SPI slave transmit/receive complete
- I<sup>2</sup>C slave receive

Other peripherals cannot generate interrupts since during SLEEP, no on-chip Q clocks are present.

Any RESET event will cause a device RESET. Any interrupt event is considered a continuation of program execution. The TO and PD bits in the CPUSTA register can be used to determine the cause of a device RESET. The PD bit, which is set on power-up, is cleared when SLEEP is invoked. The TO bit is cleared if WDT time-out occurred (and caused a RESET).

When the SLEEP instruction is being executed, the next instruction (PC + 1) is pre-fetched. For the device to wake-up through an interrupt event, the corresponding interrupt enable bit must be set (enabled). Wake-up is regardless of the state of the GLINTD bit. If the GLINTD bit is set (disabled), the device continues execution at the instruction after the SLEEP instruction. If the GLINTD bit is clear (enabled), the device executes the instruction after the SLEEP instruction and then branches to the interrupt vector address. In cases where the execution of the instruction following SLEEP is not desirable, the user should have a NOP after the SLEEP instruction.

| Note: | If the global interrupt is disabled (GLINTD            |
|-------|--------------------------------------------------------|
|       | is set), but any interrupt source has both its         |
|       | interrupt enable bit and the corresponding             |
|       | interrupt flag bit set, the device will imme-          |
|       | diately wake-up from SLEEP. The $\overline{TO}$ bit is |
|       | set and the $\overline{PD}$ bit is cleared.            |

The WDT is cleared when the device wakes from SLEEP, regardless of the source of wake-up.

#### 17.4.1.1 Wake-up Delay

When the oscillator type is configured in XT or LF mode, the Oscillator Start-up Timer (OST) is activated on wake-up. The OST will keep the device in RESET for 1024Tosc. This needs to be taken into account when considering the interrupt response time when coming out of SLEEP.

0004h

Inst (PC+2)

Inst (PC+1)

Q4

0005h

Dummy Cycle

#### Q1 | Q2 | Q3 | Q4 | Q1 Q2 Q3 OSC1 MMM Tost(2) CLKOUT<sup>(4)</sup> '0' or '1 INT (RA0/INT pin) Interrupt Latency(2) **INTF Flag** GLINTD bit Processor in SLEEP INSTRUCTION FLOW

#### **FIGURE 17-2:** WAKE-UP FROM SLEEP THROUGH INTERRUPT

Note 1: XT or LF oscillator mode assumed.

Inst (PC) = SLEEP

Inst (PC-1)

2: TOST = 1024TOSC (drawing not to scale). This delay will not be there for RC osc mode.

PC+1

Inst (PC+1)

SLEEP

3: When GLINTD = 0, processor jumps to interrupt routine after wake-up. If GLINTD = 1, execution will continue in line. 4: CLKOUT is not available in these osc modes, but shown here for timing reference.

PC+2

PC

Instruction

Fetched Instruction

Executed

# PIC17C7XX

| RETURN            |                 | Return from Subroutine |                                                                                                                      |      |                |  |  |  |
|-------------------|-----------------|------------------------|----------------------------------------------------------------------------------------------------------------------|------|----------------|--|--|--|
| Syntax:           |                 | [ label ]              | [label] RETURN                                                                                                       |      |                |  |  |  |
| Operands:         |                 | None                   | None                                                                                                                 |      |                |  |  |  |
| Operation:        |                 | $TOS\toF$              | $TOS \rightarrow PC;$                                                                                                |      |                |  |  |  |
| Status Affected:  |                 | None                   | None                                                                                                                 |      |                |  |  |  |
| Encoding:         |                 | 0000                   | 0000                                                                                                                 | 0000 | 0010           |  |  |  |
| Description:      |                 | popped an              | Return from subroutine. The stack is<br>popped and the top of the stack (TOS)<br>is loaded into the program counter. |      |                |  |  |  |
| Words:            |                 | 1                      | 1                                                                                                                    |      |                |  |  |  |
| Cycles:           |                 | 2                      | 2                                                                                                                    |      |                |  |  |  |
| Q Cycle Activity: |                 |                        |                                                                                                                      |      |                |  |  |  |
| Q1                |                 | Q2                     | Q                                                                                                                    | 3    | Q4             |  |  |  |
|                   | Decode          | No<br>operation        | Proce<br>Dat                                                                                                         |      | POP PC         |  |  |  |
|                   | No<br>operation | No<br>operation        | No<br>opera                                                                                                          |      | No<br>peration |  |  |  |
|                   |                 |                        | •                                                                                                                    |      |                |  |  |  |

Example: RETURN

After Interrupt PC = TOS

| Syntax:                            | [ label ]                                                                   | RLCF f                      | .d   | -       |
|------------------------------------|-----------------------------------------------------------------------------|-----------------------------|------|---------|
| Operands:                          | 0 ≤ f ≤ 25<br>d ∈ [0,1]                                                     |                             | ,    |         |
| Operation:                         | $f < n > \rightarrow d$<br>$f < 7 > \rightarrow C$<br>$C \rightarrow d < 0$ | ;                           |      |         |
| Status Affected:                   | С                                                                           |                             |      |         |
| Encoding:                          | 0001                                                                        | 101d                        | ffff | ffff    |
|                                    | Flag. If 'd'<br>WREG. If '<br>back in ree                                   | d' is 1, the<br>gister 'f'. | •    |         |
| Words:                             | 1                                                                           |                             |      |         |
| Cycles:                            | 1<br>1                                                                      |                             |      |         |
|                                    | •                                                                           | Q3                          |      | Q4      |
| Cycles:<br>Q Cycle Activity:       | 1                                                                           | Q3<br>Proces<br>Data        | s W  | rite to |
| Cycles:<br>Q Cycle Activity:<br>Q1 | 1<br>Q2<br>Read<br>register 'f'                                             | Proces                      | s W  |         |

After Instruction

| tter Instruction |   |      |      |  |  |  |
|------------------|---|------|------|--|--|--|
| REG              | = | 1110 | 0110 |  |  |  |
| WREG             | = | 1100 | 1100 |  |  |  |
| С                | = | 1    |      |  |  |  |

| RLNCF                     | Rotate L                                           | Rotate Left f (no carry)                                                                                                                                                  |       |                     |             |  |
|---------------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------------------|-------------|--|
| Syntax:                   | [ label ]                                          | RLNCF                                                                                                                                                                     | f,d   |                     | Synt        |  |
| Operands:                 | 0 ≤ f ≤ 25<br>d ∈ [0,1]                            | 0 ≤ f ≤ 255<br>d ∈ [0,1]                                                                                                                                                  |       |                     |             |  |
| Operation:                | $f < n > \rightarrow d$<br>$f < 7 > \rightarrow d$ | ,                                                                                                                                                                         |       |                     | Ope         |  |
| Status Affected:          | None                                               | None                                                                                                                                                                      |       |                     |             |  |
| Encoding:                 | 0010                                               | 001d                                                                                                                                                                      | ffff  | ffff                | Statu       |  |
| Description:              | one bit to t<br>placed in \                        | The contents of register 'f' are rotated<br>one bit to the left. If 'd' is 0, the result is<br>placed in WREG. If 'd' is 1, the result is<br>stored back in register 'f'. |       |                     |             |  |
|                           |                                                    | regist                                                                                                                                                                    | ter f | ]•                  |             |  |
| Words:                    | 1                                                  |                                                                                                                                                                           |       |                     |             |  |
| Cycles:                   | 1                                                  |                                                                                                                                                                           |       |                     |             |  |
| Q Cycle Activity:         |                                                    |                                                                                                                                                                           |       |                     | Wor         |  |
| Q1                        | Q2                                                 | Q3                                                                                                                                                                        |       | Q4                  | Cycl        |  |
| Decode                    | Read<br>register 'f'                               | Process<br>Data                                                                                                                                                           |       | rite to<br>tination | QC          |  |
|                           |                                                    |                                                                                                                                                                           |       |                     |             |  |
| Example:                  | RLNCF                                              | REG,                                                                                                                                                                      | 1     |                     |             |  |
| Before Instr              | uction                                             |                                                                                                                                                                           |       |                     | E.e.        |  |
| C<br>REG                  | = 0<br>= 1110 1                                    | .011                                                                                                                                                                      |       |                     | <u>Exar</u> |  |
| After Instruc<br>C<br>REG | tion<br>=<br>= 1101 0                              | 111                                                                                                                                                                       |       |                     |             |  |

| RCF                                                                                                                                                      | Rotate Ri                                                         | ght f th     | rough C | arry                   |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--------------|---------|------------------------|--|--|
| Syntax:                                                                                                                                                  | [ label ]                                                         | RRCF         | f,d     |                        |  |  |
| )perands:                                                                                                                                                | $\begin{array}{l} 0 \leq f \leq 255 \\ d  \in  [0,1] \end{array}$ |              |         |                        |  |  |
| $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                     |                                                                   |              |         |                        |  |  |
| Status Affected:                                                                                                                                         | С                                                                 |              |         |                        |  |  |
| ncoding:                                                                                                                                                 | 0001                                                              | 100d         | ffff    | ffff                   |  |  |
| one bit to the right through the Carry<br>Flag. If 'd' is 0, the result is placed in<br>WREG. If 'd' is 1, the result is placed<br>back in register 'f'. |                                                                   |              |         |                        |  |  |
| Cycles:                                                                                                                                                  |                                                                   | 1            |         |                        |  |  |
| Cycle Activity:                                                                                                                                          | ·                                                                 |              |         |                        |  |  |
| Q1                                                                                                                                                       | Q2                                                                | Q            | 3       | Q4                     |  |  |
| Decode                                                                                                                                                   | Read<br>register 'f'                                              | Proce<br>Dat |         | Write to<br>estination |  |  |
|                                                                                                                                                          |                                                                   |              |         |                        |  |  |
| xample:                                                                                                                                                  | RRCF REG                                                          | 1,0          |         |                        |  |  |
| Before Instru                                                                                                                                            | ction                                                             |              |         |                        |  |  |

REG1 = 1110 0110

WREG = 0111 0011

= 0

= 0

1110 0110

С

С

After Instruction REG1 =

| Param.<br>No. | Sym   | Characteristic                       |            | Min            | Тур†                      | Max            | Units | Conditions                                                                              |
|---------------|-------|--------------------------------------|------------|----------------|---------------------------|----------------|-------|-----------------------------------------------------------------------------------------|
| A01           | NR    | Resolution                           |            | _              | _                         | 10             | bit   | $\label{eq:VREF+} \begin{array}{l} VDD = 5.12V,\\ VSS \leq VAIN \leq VREF+ \end{array}$ |
|               |       |                                      |            | _              | _                         | 10             | bit   | $(VREF+ - VREF-) \ge 3.0V,$<br>$VREF- \le VAIN \le VREF+$                               |
| A02           | Eabs  | Absolute error                       |            | _              | _                         | < ±1           | LSb   | $\label{eq:VREF+} \begin{array}{l} VDD = 5.12V,\\ VSS \leq VAIN \leq VREF+ \end{array}$ |
|               |       |                                      |            | —              | —                         | < ±1           | LSb   | $(VREF+ - VREF-) \ge 3.0V,$<br>$VREF- \le VAIN \le VREF+$                               |
| A03           | EIL   | Integral linearity error             |            |                | -                         | < ±1           | LSb   | VREF+ = VDD = 5.12V,<br>$VSS \le VAIN \le VREF+$                                        |
|               |       |                                      |            | _              | -                         | < ±1           | LSb   | $(VREF+ - VREF-) \ge 3.0V,$<br>$VREF- \le VAIN \le VREF+$                               |
| A04           | Edl   | Differential linearity error         |            |                |                           | < ±1           | LSb   | VREF+ = VDD = 5.12V,<br>$VSS \le VAIN \le VREF+$                                        |
|               |       |                                      |            | _              | _                         | < ±1           | LSb   | $(VREF+ - VREF-) \ge 3.0V,$<br>$VREF- \le VAIN \le VREF+$                               |
| A05           | Efs   | Full scale error                     |            | _              | _                         | < ±1           | LSb   | $\label{eq:VREF+} \begin{array}{l} VDD = 5.12V,\\ VSS \leq VAIN \leq VREF+ \end{array}$ |
|               |       |                                      |            | _              | _                         | < ±1           | LSb   | $(VREF+ - VREF-) \ge 3.0V,$<br>$VREF- \le VAIN \le VREF+$                               |
| A06           | EOFF  | Offset error                         |            | _              | _                         | < ±1           | LSb   | $\label{eq:VREF+} \begin{array}{l} VDD = 5.12V,\\ VSS \leq VAIN \leq VREF+ \end{array}$ |
|               |       |                                      |            | _              | _                         | < ±1           | LSb   | $(VREF+ - VREF-) \ge 3.0V,$<br>$VREF- \le VAIN \le VREF+$                               |
| A10           | —     | Monotonicity                         |            | —              | guaranteed <sup>(3)</sup> | _              | —     | $VSS \leq VAIN \leq VREF$                                                               |
| A20           | Vref  | Reference voltage<br>(VREF+ — VREF-) |            | 0V             |                           | _              | V     | VREF delta when changing voltage levels on VREF inputs                                  |
| A20A          |       |                                      |            | 3V             | _                         | _              | V     | Absolute minimum electrical spec.<br>to ensure 10-bit accuracy                          |
| A21           | VREF+ | Reference voltage high               |            | Avss<br>+ 3.0V | —                         | AVDD +<br>0.3V | V     |                                                                                         |
| A22           | VREF- | Reference voltag                     | ge low     | Avss -<br>0.3V | _                         | Avdd -<br>3.0V | V     |                                                                                         |
| A25           | VAIN  | Analog input volt                    | age        | Avss -<br>0.3V |                           | Vref +<br>0.3V | V     |                                                                                         |
| A30           | Zain  | Recommended i analog voltage s       |            | —              | _                         | 10.0           | kΩ    |                                                                                         |
| A40           | IAD   | A/D conversion                       | PIC17CXXX  | _              | 180                       |                | μΑ    | Average current consumption when                                                        |
|               |       | current (VDD)                        | PIC17LCXXX | _              | 90                        | _              | μΑ    | A/D is on <b>(Note 1)</b>                                                               |
| A50           | IREF  | VREF input current (Note 2)          |            | 10             | —                         | 1000           | μΑ    | During VAIN acquisition.<br>Based on differential of VHOLD to<br>VAIN                   |
|               |       |                                      |            | _              | _                         | 10             | μΑ    | During A/D conversion cycle                                                             |

| TABLE 20-18: A/D C | ONVERTER CHARACTERISTICS |
|--------------------|--------------------------|
|--------------------|--------------------------|

† Data in "Typ" column is at 5V, 25°C unless otherwise stated.

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

2: VREF current is from RG0 and RG1 pins or AVDD and AVSS pins, 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.



