



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             | 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              | 22                                                                         |
| Program Memory Size        | 3.5KB (2K x 14)                                                            |
| Program Memory Type        | OTP                                                                        |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 128 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V                                                                  |
| Data Converters            | -                                                                          |
| Oscillator Type            | External                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                             |
| Supplier Device Package    | 28-SOIC                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c62b-20i-so |
|                            |                                                                            |

Email: info@E-XFL.COM

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

#### 2.2.2.2 OPTION\_REG REGISTER

Г

The OPTION\_REG register is a readable and writable register, which contains various control bits to configure the TMR0 prescaler/WDT postscaler (single assignable register known as the prescaler), the External INT Interrupt, TMR0 and the weak pull-ups on PORTB.

Note: To achieve a 1:1 prescaler assignment for the TMR0 register, assign the prescaler to the Watchdog Timer.

## REGISTER 2-2: OPTION\_REG REGISTER (ADDRESS 81h)

| R/W-1    | R/W-1       | R/W-1                          | R/W-1    | R/W-1        | R/W-1     | R/W-1   | R/W-1 |                          |
|----------|-------------|--------------------------------|----------|--------------|-----------|---------|-------|--------------------------|
| RBPU     | INTEDG      | TOCS                           | T0SE     | PSA          | PS2       | PS1     | PS0   | R = Readable bit         |
| bit7     |             |                                |          |              |           |         | bit0  | W = Writable bit         |
|          |             |                                |          |              |           |         |       | - n = Value at POR reset |
| bit 7:   | RBPU: PC    |                                |          |              |           |         |       |                          |
|          |             | B pull-ups a                   |          |              |           | _       |       |                          |
|          | 0 = PORTI   | B pull-ups a                   | are enat | oled for all | PORTB inp | outs    |       |                          |
| bit 6:   | INTEDG: I   | nterrupt Ed                    | lge Sele | ct bit       |           |         |       |                          |
|          | 1 = Interru | pt on rising                   | edge o   | f RB0/INT    | pin       |         |       |                          |
|          | 0 = Interru | pt on falling                  | g edge o | f RB0/INT    | - pin     |         |       |                          |
| bit 5:   | TOCS: TM    | R0 Clock S                     | ource S  | elect bit    |           |         |       |                          |
|          | 1 = Transit | ion on RA4                     | /T0CKI   | pin          |           |         |       |                          |
|          |             | al instruction                 |          | •            | (OUT)     |         |       |                          |
| bit 4:   | TOSE: TMI   |                                | -        | •            | ,         |         |       |                          |
| Dit 4.   |             |                                |          |              | on RA4/T0 | CKI nin |       |                          |
|          |             | •                              |          |              | on RA4/T0 | •       |       |                          |
| hit 0.   |             |                                | •        |              |           | o p     |       |                          |
| bit 3:   | PSA: Pres   | •                              |          |              |           |         |       |                          |
|          |             | tler is assig<br>tler is assig |          |              | modulo    |         |       |                          |
|          |             | 0                              |          |              | module    |         |       |                          |
| bit 2-0: | PS2:PS0:    | Prescaler F                    | Rate Sel | ect bits     |           |         |       |                          |
|          | Bit Value   | TMR0 Rat                       | e WD     | Г Rate       |           |         |       |                          |
|          | 000         | 1:2                            | 1:       | 1            |           |         |       |                          |
|          | 001         | 1:4                            | 1 :      |              |           |         |       |                          |
|          | 010         | 1:8                            | 1:       |              |           |         |       |                          |
|          | 011         | 1:16                           | 1:       | -            |           |         |       |                          |
|          | 100         | 1:32                           |          | 16           |           |         |       |                          |
|          | 101         | 1:64                           |          | 32<br>64     |           |         |       |                          |
|          | 110         | 1:128                          |          | 64<br>128    |           |         |       |                          |
|          | 111         | 1:256                          |          | 120          |           |         |       |                          |

## 5.0 TIMER1 MODULE

The Timer1 module timer/counter has the following features:

- 16-bit timer/counter
- Readable and writable
- Internal or external clock select
- Interrupt on overflow from FFFFh to 0000h
- Reset from CCP module trigger

Timer1 has a control register, shown in Register 5-1. Timer1 can be enabled/disabled by setting/clearing control bit TMR1ON (T1CON<0>).

Figure 5-1 is a simplified block diagram of the Timer1 module.

Additional information on timer modules is available in the PIC<sup>®</sup> MCU Mid-Range Reference Manual, (DS33023).

## 5.1 <u>Timer1 Operation</u>

Timer1 can operate in one of these modes:

- As a timer
- As a synchronous counter
- As an asynchronous counter

The operating mode is determined by the clock select bit, TMR1CS (T1CON<1>).

In timer mode, Timer1 increments every instruction cycle. In counter mode, it increments on every rising edge of the external clock input.

When the Timer1 oscillator is enabled (T1OSCEN is set), the RC1/T1OSI and RC0/T1OSO/T1CKI pins become inputs. That is, the TRISC<1:0> value is ignored.

Timer1 also has an internal "reset input". This reset can be generated by the CCP module as a special event trigger (Section 7.0).

## REGISTER 5-1:T1CON: TIMER1 CONTROL REGISTER (ADDRESS 10h)

| U-0      | U-0                                                                                                                                                                                                                 | R/W-0                                                                                                                                                                                                                                                             | R/W-0       | R/W-0   | R/W-0  | R/W-0        | R/W-0   |                                                                                       |  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------|--------|--------------|---------|---------------------------------------------------------------------------------------|--|
|          | _                                                                                                                                                                                                                   | T1CKPS1                                                                                                                                                                                                                                                           | T1CKPS0     | T1OSCEN | T1SYNC | TMR1CS       | TMR1ON  | R = Readable bit                                                                      |  |
| bit7     |                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                   |             |         |        |              | bitO    | W = Writable bit<br>U = Unimplemented bit,<br>read as '0'<br>- n = Value at POR reset |  |
| bit 7-6: | Unimple                                                                                                                                                                                                             | mented: F                                                                                                                                                                                                                                                         | lead as '0' |         |        |              |         |                                                                                       |  |
| bit 5-4: | <ul> <li>4: T1CKPS1:T1CKPS0: Timer1 Input Clock Prescale Select bits</li> <li>11 = 1:8 Prescale value</li> <li>10 = 1:4 Prescale value</li> <li>01 = 1:2 Prescale value</li> <li>00 = 1:1 Prescale value</li> </ul> |                                                                                                                                                                                                                                                                   |             |         |        |              |         |                                                                                       |  |
| bit 3:   | 1 = Oscill<br>0 = Oscill                                                                                                                                                                                            | <b>T1OSCEN</b> : Timer1 Oscillator Enable Control bit<br>1 = Oscillator is enabled (TRISC<1:0> ignored)<br>0 = Oscillator is shut off<br>(The oscillator is turned off to reduce power drain                                                                      |             |         |        |              |         |                                                                                       |  |
| bit 2:   | <u>TMR1CS</u><br>1 = Do no<br>0 = Syncl<br><u>TMR1CS</u>                                                                                                                                                            | TISYNC: Timer1 External Clock Input Synchronization Control bit <u>TMR1CS = 1</u> 1 = Do not synchronize external clock input         0 = Synchronize external clock input <u>TMR1CS = 0</u> This bit is ignored. Timer1 uses the internal clock when TMR1CS = 0. |             |         |        |              |         |                                                                                       |  |
| bit 1:   | 1 = Exter                                                                                                                                                                                                           | : Timer1 C<br>mal clock fi<br>nal clock (F                                                                                                                                                                                                                        | rom pin R   |         |        | n the rising | ı edge) |                                                                                       |  |
| bit 0:   |                                                                                                                                                                                                                     | I: Timer1 C<br>les Timer1<br>s Timer1                                                                                                                                                                                                                             | )n bit      |         |        |              |         |                                                                                       |  |

NOTES:

## 8.0 SYNCHRONOUS SERIAL PORT (SSP) MODULE

#### 8.1 SSP Module Overview

The Synchronous Serial Port (SSP) 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, A/D converters, etc. The SSP module can operate in one of two modes:

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

For more information on SSP operation (including an I<sup>2</sup>C Overview), refer to the PIC<sup>®</sup> MCU Mid-Range Reference Manual, (DS33023). Also, refer to Application Note AN578, *"Use of the SSP Module in the I<sup>2</sup>C Multi-Master Environment."* 

## 8.2 SPI Mode

This section contains register definitions and operational characteristics of the SPI module.

Additional information on SPI operation may be found in the PIC<sup>®</sup> MCU Mid-Range Reference Manual, (DS33023).

8.2.1 OPERATION OF SSP MODULE IN SPI MODE

A block diagram of the SSP Module in SPI Mode is shown in Figure 8-1.

The SPI mode allows 8-bits of data to be synchronously transmitted and received simultaneously. To accomplish communication, three pins are used:

- Serial Data Out (SDO)RC5/SDO
- Serial Data In (SDI)RC4/SDI/SDA
- Serial Clock (SCK)RC3/SCK/SCL

Additionally, a fourth pin may be used when in a slave mode of operation:

Slave Select (SS)RA5/SS/AN4

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

- Master Operation (SCK is the clock output)
- Slave Mode (SCK is the clock input)
- Clock Polarity (Idle state of SCK)
- Clock Edge (Output data on rising/falling edge of SCK)
- Clock Rate (master operation only)
- Slave Select Mode (Slave mode only)

To enable the serial port, SSP Enable bit, SSPEN (SSPCON<5>) must be set. To reset or reconfigure SPI mode, clear bit SSPEN, re-initialize the SSPCON reg-

ister, and then set bit SSPEN. This configures the SDI, SDO, SCK and  $\overline{SS}$  pins as serial port pins. For the pins to behave as the serial port function, they must have their data direction bits (in the TRISC register) appropriately programmed. That is:

- SDI must have TRISC<4> set
- SDO must have TRISC<5> cleared
- SCK (master operation) must have TRISC<3> cleared
- SCK (Slave mode) must have TRISC<3> set
- SS must have TRISA<5> set (if used)

Note: When the SPI is in Slave Mode with  $\overline{SS}$  pin control enabled, (SSPCON<3:0> = 0100) the SPI module will reset if the  $\overline{SS}$  pin is set to VDD.

**Note:** If the SPI is used in Slave Mode with CKE = '1', then the  $\overline{SS}$  pin control must be enabled.

#### FIGURE 8-1: SSP BLOCK DIAGRAM (SPI MODE)



## 8.3 <u>SSP I<sup>2</sup>C Operation</u>

The SSP module in I<sup>2</sup>C mode fully implements all slave functions, except general call support, and provides interrupts on start and stop bits in hardware to support firmware implementations of the master functions. The SSP module implements the standard mode specifications, as well as 7-bit and 10-bit addressing.

Two pins are used for data transfer. These are the RC3/SCK/SCL pin, which is the clock (SCL), and the RC4/SDI/SDA pin, which is the data (SDA). The user must configure these pins as inputs or outputs through the TRISC<4:3> bits.

The SSP module functions are enabled by setting SSP Enable bit SSPEN (SSPCON<5>).

FIGURE 8-2: SSP BLOCK DIAGRAM (I<sup>2</sup>C MODE)



The SSP module has five registers for  $I^2C$  operation. These are the:

- SSP Control Register (SSPCON)
- SSP Status Register (SSPSTAT)
- Serial Receive/Transmit Buffer (SSPBUF)
- SSP Shift Register (SSPSR) Not accessible
- SSP Address Register (SSPADD)

The SSPCON register allows control of the  $I^2C$  operation. Four mode selection bits (SSPCON<3:0>) allow one of the following  $I^2C$  modes to be selected:

- I<sup>2</sup>C Slave mode (7-bit address)
- I<sup>2</sup>C Slave mode (10-bit address)
- I<sup>2</sup>C Slave mode (7-bit address), with start and stop bit interrupts enabled for firmware master mode support
- I<sup>2</sup>C Slave mode (10-bit address), with start and stop bit interrupts enabled for firmware master mode support
- I<sup>2</sup>C start and stop bit interrupts enabled for firmware master mode support, slave mode idle

Selection of any  $I^2C$  mode, with the SSPEN bit set, forces the SCL and SDA pins to be operated as open drain outputs, provided these pins are programmed to inputs by setting the appropriate TRISC bits.

Additional information on SSP I<sup>2</sup>C operation may be found in the PIC<sup>®</sup> MCU Mid-Range Reference Manual, (DS33023).

#### 8.3.1 SLAVE MODE

In slave mode, the SCL and SDA pins must be configured as inputs (TRISC<4:3> set). The SSP module will override the input state with the output data when required (slave-transmitter).

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, and load the SSPBUF register with the received value in the SSPSR register.

There are certain conditions that will cause the SSP module not to give this  $\overline{ACK}$  pulse. This happens if either of the following conditions occur:

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

In this case, the SSPSR register value is not loaded into the SSPBUF, but bit SSPIF (PIR1<3>) is set. Table 8-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. Flag bit BF is cleared by reading the SSPBUF register, while bit SSPOV is cleared through software.

The SCL clock input must have a minimum high and low for proper operation. The high and low times of the  $I^2C$  specification, as well as the requirement of the SSP module, is shown in timing parameter #100, THIGH, and parameter #101, TLOW.

#### 8.3.1.3 TRANSMISSION

When the  $R/\overline{W}$  bit of the incoming address byte is set and an address match occurs, the  $R/\overline{W}$  bit of the SSPSTAT register is set. The received address is loaded into the SSPBUF register. The ACK pulse will be sent on the ninth bit and the CKP will be cleared by hardware, holding SCL low. Slave devices cause the master to wait by holding the SCL line low. The transmit data is loaded into the SSPBUF register, which in turn loads the SSPSR register. When bit CKP (SSP-CON<4>) is set, pin RC3/SCK/SCL releases SCL. When the SCL line goes high, the master may resume operating the SCL line and receiving data. The master must monitor the SCL pin prior to asserting another clock pulse. The slave devices may be holding off the master by stretching the clock. The eight data bits are shifted out on the falling edge of the SCL input. This ensures that the SDA signal is valid during the SCL high time (Figure 8-4).

An SSP interrupt is generated for each data transfer byte. Flag bit SSPIF must be cleared in software, and the SSPSTAT register used to determine the status of the byte. Flag bit SSPIF is set on the falling edge of the ninth clock pulse.

As a slave-transmitter, the  $\overline{ACK}$  pulse from the masterreceiver is latched on the rising edge of the ninth SCL input pulse. If the SDA line was high (not  $\overline{ACK}$ ), then the data transfer is complete. When the  $\overline{ACK}$  is latched by the slave, the slave logic is reset (resets SSPSTAT register) and the slave then monitors for another occurrence of the START bit. If the SDA line was low ( $\overline{ACK}$ ), the transmit data must be loaded into the SSPBUF register, which also loads the SSPSR register. Then pin RC3/SCK/SCL should be enabled by setting bit CKP.



FIGURE 8-4: I<sup>2</sup>C WAVEFORMS FOR TRANSMISSION (7-BIT ADDRESS)

## 10.0 SPECIAL FEATURES OF THE CPU

The PIC16C62B/72A devices have a host of features intended to maximize system reliability, minimize cost through elimination of external components, provide power saving operating modes and offer code protection. These are:

- Oscillator Mode Selection
- Reset
  - Power-on Reset (POR)
  - Power-up Timer (PWRT)
  - Oscillator Start-up Timer (OST)
  - Brown-out Reset (BOR)
- Interrupts
- Watchdog Timer (WDT)
- SLEEP
- Code protection
- ID locations
- In-circuit serial programming<sup>™</sup> (ICSP)

These devices have a Watchdog Timer, which can be shut off only through configuration bits. It runs off its own RC oscillator for added reliability. There are two timers that offer necessary delays on power-up. One is the Oscillator Start-up Timer (OST), intended to keep the chip in reset until the crystal oscillator is stable. The

#### FIGURE 10-1: CONFIGURATION WORD

other is the Power-up Timer (PWRT), which provides a fixed delay on power-up only and is designed to keep the part in reset while the power supply stabilizes. With these two timers on-chip, most applications need no external reset circuitry.

SLEEP mode is designed to offer a very low current power-down mode. The user can wake-up from SLEEP through external reset, Watchdog Timer Wake-up, or through an interrupt. Several oscillator options are also made available to allow the part to fit the application. The RC oscillator option saves system cost while the LP crystal option saves power. A set of configuration bits are used to select various options.

Additional information on special features is available in the PIC<sup>®</sup> MCU Mid-Range Reference Manual, (DS33023).

## 10.1 Configuration Bits

The configuration bits can be programmed (read as '0') or left unprogrammed (read as '1') to select various device configurations. These bits are mapped in program memory location 2007h.

The user will note that address 2007h is beyond the user program memory space. In fact, it belongs to the special test/configuration memory space (2000h - 3FFFh), which can be accessed only during programming.

| CP1          | CP0                                                                                                                                                                                                                     | CP1                                                                                                                                                                                                                                    | CP0  | CP1    | CP0    | _     | BODEN | CP1 | CP0 | PWRTE | WDTE  | FOSC1 | FOSC0 | Register: | CONFIG |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|--------|-------|-------|-----|-----|-------|-------|-------|-------|-----------|--------|
| bit13        |                                                                                                                                                                                                                         | bit0 Address: 2007h                                                                                                                                                                                                                    |      |        |        |       |       |     |     |       | 2007h |       |       |           |        |
| bit 13<br>5- | <ul> <li>CP1:CP0: Code Protection bits <sup>(2)</sup></li> <li>11 = Code protection off</li> <li>10 = Upper half of program memory code protected</li> <li>01 = Upper 3/4th of program memory code protected</li> </ul> |                                                                                                                                                                                                                                        |      |        |        |       |       |     |     |       |       |       |       |           |        |
|              |                                                                                                                                                                                                                         | 00 = AII                                                                                                                                                                                                                               |      |        |        |       |       |     |     |       |       |       |       |           |        |
| bit 7:       | I                                                                                                                                                                                                                       | Jnimpl                                                                                                                                                                                                                                 | emen | ted: R | ead as | s '1' |       |     |     |       |       |       |       |           |        |
| bit 6:       |                                                                                                                                                                                                                         | BODEN: Brown-out Reset Enable bit <sup>(1)</sup><br>1 = BOR enabled<br>0 = BOR disabled                                                                                                                                                |      |        |        |       |       |     |     |       |       |       |       |           |        |
| bit 3:       |                                                                                                                                                                                                                         | <b>PWRTE</b> : Power-up Timer Enable bit <sup>(1)</sup><br>1 = PWRT disabled<br>0 = PWRT enabled                                                                                                                                       |      |        |        |       |       |     |     |       |       |       |       |           |        |
| bit 2:       | :                                                                                                                                                                                                                       | WDTE: Watchdog Timer Enable bit<br>1 = WDT enabled<br>0 = WDT disabled                                                                                                                                                                 |      |        |        |       |       |     |     |       |       |       |       |           |        |
| bit 1-       |                                                                                                                                                                                                                         | FOSC1:FOSC0: Oscillator Selection bits<br>11 = RC oscillator<br>10 = HS oscillator<br>01 = XT oscillator<br>00 = LP oscillator                                                                                                         |      |        |        |       |       |     |     |       |       |       |       |           |        |
| Note         |                                                                                                                                                                                                                         | Enabling Brown-out Reset automatically enables Power-up Timer (PWRT), regardless of the value of bit $\overline{\text{PWRTE}}$ .<br>All of the CP1:CP0 pairs must be given the same value to enable the code protection scheme listed. |      |        |        |       |       |     |     |       |       |       |       |           |        |

| TABLE 10-6           | ABLE 10-6 INITIALIZATION CONDITIONS FOR ALL REGISTERS |                                                 |           |                          |                                 |  |  |
|----------------------|-------------------------------------------------------|-------------------------------------------------|-----------|--------------------------|---------------------------------|--|--|
| Register             |                                                       | Applicable Power-on Res<br>Devices Brown-out Re |           | MCLR Resets<br>WDT Reset | Wake-up via WDT or<br>Interrupt |  |  |
| W                    | 62B                                                   | 72A                                             | XXXX XXXX | uuuu uuuu                | սսսս սսսս                       |  |  |
| INDF                 | 62B                                                   | 72A                                             | N/A       | N/A                      | N/A                             |  |  |
| TMR0                 | 62B                                                   | 72A                                             | xxxx xxxx | uuuu uuuu                | uuuu uuuu                       |  |  |
| PCL                  | 62B                                                   | 72A                                             | 0000h     | 0000h                    | PC + 1 <sup>(2)</sup>           |  |  |
| STATUS               | 62B                                                   | 72A                                             | 0001 1xxx | 000q quuu <b>(3)</b>     | uuuq quuu <b>(3)</b>            |  |  |
| FSR                  | 62B                                                   | 72A                                             | XXXX XXXX | uuuu uuuu                | uuuu uuuu                       |  |  |
| PORTA <sup>(4)</sup> | 62B                                                   | 72A                                             | 0x 0000   | 0u 0000                  | uu uuuu                         |  |  |
| PORTB <sup>(5)</sup> | 62B                                                   | 72A                                             | xxxx xxxx | uuuu uuuu                | սսսս սսսս                       |  |  |
| PORTC <sup>(5)</sup> | 62B                                                   | 72A                                             | xxxx xxxx | uuuu uuuu                | uuuu uuuu                       |  |  |
| PCLATH               | 62B                                                   | 72A                                             | 0 0000    | 0 0000                   | u uuuu                          |  |  |
| INTCON               | 62B                                                   | 72A                                             | 0000 000x | 0000 000u                | uuuu uuuu <b>(1)</b>            |  |  |
|                      | 62B                                                   | 72A                                             | 0000      | 0000                     | uuuu <b>(1)</b>                 |  |  |
| PIR1                 | 62B                                                   | 72A                                             | -0 0000   | -0 0000                  | -u uuuu <b>(1)</b>              |  |  |
| TMR1L                | 62B                                                   | 72A                                             | xxxx xxxx | uuuu uuuu                | uuuu uuuu                       |  |  |
| TMR1H                | 62B                                                   | 72A                                             | XXXX XXXX | uuuu uuuu                | uuuu uuuu                       |  |  |
| T1CON                | 62B                                                   | 72A                                             | 00 0000   | uu uuuu                  | uu uuuu                         |  |  |
| TMR2                 | 62B                                                   | 72A                                             | 0000 0000 | 0000 0000                | uuuu uuuu                       |  |  |
| T2CON                | 62B                                                   | 72A                                             | -000 0000 | -000 0000                | -uuu uuuu                       |  |  |
| SSPBUF               | 62B                                                   | 72A                                             | XXXX XXXX | uuuu uuuu                | uuuu uuuu                       |  |  |
| SSPCON               | 62B                                                   | 72A                                             | 0000 0000 | 0000 0000                | uuuu uuuu                       |  |  |
| CCPR1L               | 62B                                                   | 72A                                             | XXXX XXXX | uuuu uuuu                | uuuu uuuu                       |  |  |
| CCPR1H               | 62B                                                   | 72A                                             | XXXX XXXX | uuuu uuuu                | uuuu uuuu                       |  |  |
| CCP1CON              | 62B                                                   | 72A                                             | 00 0000   | 00 0000                  | uu uuuu                         |  |  |
| ADRES                | 62B                                                   | 72A                                             | XXXX XXXX | uuuu uuuu                | uuuu uuuu                       |  |  |
| ADCON0               | 62B                                                   | 72A                                             | 0000 00-0 | 0000 00-0                | uuuu uu-u                       |  |  |
| OPTION_REG           | 62B                                                   | 72A                                             | 1111 1111 | 1111 1111                | uuuu uuuu                       |  |  |
| TRISA                | 62B                                                   | 72A                                             | 11 1111   | 11 1111                  | uu uuuu                         |  |  |
| TRISB                | 62B                                                   | 72A                                             | 1111 1111 | 1111 1111                | uuuu uuuu                       |  |  |
| TRISC                | 62B                                                   | 72A                                             | 1111 1111 | 1111 1111                | uuuu uuuu                       |  |  |
| PIE1                 | 62B                                                   | 72A                                             | 0000      | 0000                     | uuuu                            |  |  |
|                      | 62B                                                   | 72A                                             | -0 0000   | -0 0000                  | -u uuuu                         |  |  |
| PCON                 | 62B                                                   | 72A                                             | 0q        | uq                       | uq                              |  |  |
| PR2                  | 62B                                                   | 72A                                             | 1111 1111 | 1111 1111                | 1111 1111                       |  |  |
| SSPADD               | 62B                                                   | 72A                                             | 0000 0000 | 0000 0000                | uuuu uuuu                       |  |  |
| SSPSTAT              | 62B                                                   | 72A                                             | 0000 0000 | 0000 0000                | սսսս սսսս                       |  |  |
| ADCON1               | 62B                                                   | 72A                                             | 000       | 000                      | uuu                             |  |  |

| TABLE 10-6 | INITIALIZATION CONDITIONS FOR ALL REGISTERS |
|------------|---------------------------------------------|
|            |                                             |

Legend: u = unchanged, x = unknown, - = unimplemented bit, read as '0', <math>q = value depends on condition

Note 1: One or more bits in INTCON and/or PIR1 will be affected (to cause wake-up).

2: When the wake-up is due to an interrupt and the GIE bit is set, the PC is loaded with the interrupt vector (0004h).

**3:** See Table 10-5 for reset value for specific condition.

4: On any device reset, these pins are configured as inputs.

5: This is the value that will be in the port output latch.

## 10.12 Watchdog Timer (WDT)

The Watchdog Timer is a free running on-chip RC oscillator which does not require any external components. This RC oscillator is separate from the RC oscillator of the OSC1/CLKIN pin. The WDT will run, even if the clock on the OSC1/CLKIN and OSC2/CLKOUT pins of the device has been stopped, for example, by execution of a SLEEP instruction.

During normal operation, a WDT time-out generates a device RESET (Watchdog Timer Reset). If the device is in SLEEP mode, a WDT time-out causes the device to wake-up and continue with normal operation (Watchdog Timer Wake-up). The  $\overline{\text{TO}}$  bit in the STATUS register will be cleared upon a Watchdog Timer time-out.

The WDT can be permanently disabled by clearing configuration bit WDTE (Section 10.1).

The WDT time-out period (TWDT, parameter #31) is multiplied by the prescaler ratio, when the prescaler is assigned to the WDT. The prescaler assignment (assigned to either the WDT or Timer0) and prescaler ratio are set in the OPTION\_REG register.

Note: The CLRWDT and SLEEP instructions clear the WDT and the postscaler, if assigned to the WDT, and prevent it from timing out and generating a device RESET condition.

**Note:** When a CLRWDT instruction is executed and the prescaler is assigned to the WDT, the prescaler count will be cleared, but the prescaler assignment is not changed.



## FIGURE 10-9: SUMMARY OF WATCHDOG TIMER REGISTERS

| Address | Name         | Bit 7 | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|--------------|-------|--------|-------|-------|-------|-------|-------|-------|
| 2007h   | Config. bits |       | BODEN  | CP1   | CP0   | PWRTE | WDTE  | FOSC1 | FOSC0 |
| 81h     | OPTION_REG   | RBPU  | INTEDG | TOCS  | TOSE  | PSA   | PS2   | PS1   | PS0   |

Legend: Shaded cells are not used by the Watchdog Timer.

## FIGURE 10-10: WAKE-UP FROM SLEEP THROUGH INTERRUPT

| ; a1   a2   a3   a4 ; (<br>osc1 /~//        | 21   Q2   Q3   Q4 ;<br>\/ |                       | 01 02 03 04  | a1 a2 a3 a4                   | a1 a2 a3 a4      | 01 02 03 04 |
|---------------------------------------------|---------------------------|-----------------------|--------------|-------------------------------|------------------|-------------|
| CLKOUT(4)                                   |                           | Tost(2)               | /            | /                             | //               |             |
| INTF flag<br>(INTCON<1>)                    |                           |                       |              | Interrupt Latency<br>(Note 2) | -<br> <br> <br>  |             |
| GIE bit<br>(INTCON<7>)                      | <br> <br> +<br> <br>      | Processor in<br>SLEEP |              |                               | 1<br>1<br>1<br>1 |             |
| INSTRUCTION FLOW                            | 1                         |                       |              |                               |                  | · · · ·     |
| PC <u>X PC X</u>                            | PC+1                      | PC+2                  | PC+2         | X PC + 2                      | X 0004h          | X 0005h     |
| Instruction {<br>fetched { Inst(PC) = SLEEP | Inst(PC + 1)              | ,<br>,<br>,           | Inst(PC + 2) |                               | Inst(0004h)      | Inst(0005h) |
| Instruction<br>executed Inst(PC - 1)        | SLEEP                     | 1<br>1<br>1           | Inst(PC + 1) | Dummy cycle                   | Dummy cycle      | Inst(0004h) |

**Note 1:** XT, HS or LP oscillator mode assumed.

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

3: GIE = '1' assumed. In this case after wake- up, the processor jumps to the interrupt routine. If GIE = '0', execution will continue in-line.

4: CLKOUT is not available in these osc modes, but shown here for timing reference.

#### 10.14 Program Verification/Code Protection

If the code protection bits have not been programmed, the on-chip program memory can be read out for verification purposes.

| Note: | Microchip does not recommend code pro- |
|-------|----------------------------------------|
|       | tecting windowed devices.              |

#### 10.15 ID Locations

Four memory locations (2000h - 2003h) are designated as ID locations where the user can store checksum or other code-identification numbers. These locations are not accessible during normal execution, but are readable and writable during program/verify. It is recommended that only the 4 least significant bits of the ID location are used.

For ROM devices, these values are submitted along with the ROM code.

#### 10.16 In-Circuit Serial Programming™

PIC16CXXX microcontrollers can be serially programmed while in the end application circuit. This is simply done with two lines for clock and data, and three more lines for power, ground and the programming voltage. This allows customers to manufacture boards with unprogrammed devices, and then program the microcontroller just before shipping the product. This also allows the most recent firmware or a custom firmware to be programmed.

For complete details of serial programming, please refer to the In-Circuit Serial Programming (ICSP™) Guide, DS30277.

# PIC16C62B/72A

| IORLW            | Inclusive OR Literal with W                                                                                           |
|------------------|-----------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] IORLW k                                                                                                     |
| Operands:        | $0 \le k \le 255$                                                                                                     |
| Operation:       | (W) .OR. $k \rightarrow$ (W)                                                                                          |
| Status Affected: | Z                                                                                                                     |
| Description:     | The contents of the W register is<br>OR'ed with the eight bit literal 'k'. The<br>result is placed in the W register. |

| MOVLW            | Move Literal to W                                                                          |  |  |  |  |  |
|------------------|--------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] MOVLW k                                                                   |  |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                          |  |  |  |  |  |
| Operation:       | $k \rightarrow (W)$                                                                        |  |  |  |  |  |
| Status Affected: | None                                                                                       |  |  |  |  |  |
| Description:     | The eight bit literal 'k' is loaded into W register. The don't cares will assemble as 0's. |  |  |  |  |  |

| IORWF            | Inclusive OR W with f                                                                                                                                                  |  |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [label] IORWF f,d                                                                                                                                                      |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                        |  |  |  |  |  |
| Operation:       | (W) .OR. (f) $\rightarrow$ (destination)                                                                                                                               |  |  |  |  |  |
| Status Affected: | Z                                                                                                                                                                      |  |  |  |  |  |
| Description:     | Inclusive OR the W register with regis-<br>ter 'f'. If 'd' is 0, the result is placed in<br>the W register. If 'd' is 1, the result is<br>placed back in register 'f'. |  |  |  |  |  |

| MOVWF            | Move W to f                           |  |  |  |  |  |  |  |  |
|------------------|---------------------------------------|--|--|--|--|--|--|--|--|
| Syntax:          | [label] MOVWF f                       |  |  |  |  |  |  |  |  |
| Operands:        | $0 \leq f \leq 127$                   |  |  |  |  |  |  |  |  |
| Operation:       | $(W) \rightarrow (f)$                 |  |  |  |  |  |  |  |  |
| Status Affected: | None                                  |  |  |  |  |  |  |  |  |
| Description:     | Move data from W register to register |  |  |  |  |  |  |  |  |

| MOVF             | Move f                                                                                                                                                                                                                                                                                |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] MOVF f,d                                                                                                                                                                                                                                                             |
| Operands:        | $\begin{array}{l} 0\leq f\leq 127\\ d\in [0,1] \end{array}$                                                                                                                                                                                                                           |
| Operation:       | (f) $\rightarrow$ (destination)                                                                                                                                                                                                                                                       |
| Status Affected: | Z                                                                                                                                                                                                                                                                                     |
| Description:     | The contents of register f is moved to<br>a destination dependant upon the sta-<br>tus of d. If $d = 0$ , destination is W reg-<br>ister. If $d = 1$ , the destination is file<br>register f itself. $d = 1$ is useful to test a<br>file register since status flag Z is<br>affected. |

| NOP              | No Operation  |
|------------------|---------------|
| Syntax:          | [label] NOP   |
| Operands:        | None          |
| Operation:       | No operation  |
| Status Affected: | None          |
| Description:     | No operation. |





#### 13.1 DC Characteristics: PIC16C62B/72A-04 (Commercial, Industrial, Extended) PIC16C62B/72A-20 (Commercial, Industrial, Extended)

|              |               |                                                                         |          |         |         |                                      | ns (unless otherwise stated)                                   |
|--------------|---------------|-------------------------------------------------------------------------|----------|---------|---------|--------------------------------------|----------------------------------------------------------------|
| DC CHA       |               | DISTICS                                                                 | Operatir | ng temp | erature | e 0°C                                | $\leq TA \leq +70^{\circ}C$ for commercial                     |
| DC CHA       | NACIE         |                                                                         |          |         |         | -40°C                                | $\leq$ TA $\leq$ +85°C for industrial                          |
|              |               |                                                                         |          |         | -40°C   | $\leq$ TA $\leq$ +125°C for extended |                                                                |
| Param<br>No. | Sym           | Characteristic                                                          | Min      | Тур†    | Max     | Units                                | Conditions                                                     |
| -            |               |                                                                         |          |         |         |                                      |                                                                |
| D001         | Vdd           | Supply Voltage                                                          | 4.0      | -       | 5.5     | V                                    | XT, RC and LP osc mode                                         |
| D001A        |               |                                                                         | 4.5      | -       | 5.5     | V                                    | HS osc mode                                                    |
|              |               |                                                                         | VBOR*    | -       | 5.5     | V                                    | BOR enabled (Note 7)                                           |
| D002*        | Vdr           | RAM Data Retention<br>Voltage (Note 1)                                  | -        | 1.5     | -       | V                                    |                                                                |
| D003         | VPOR          | <b>VDD Start Voltage</b> to<br>ensure internal<br>Power-on Reset signal | -        | Vss     | -       | V                                    | See section on Power-on Reset for details                      |
| D004*        | SVDD          | VDD Rise Rate to                                                        | 0.05     | -       | -       | V/ms                                 |                                                                |
| D004A*       |               | ensure internal                                                         | TBD      | -       | -       |                                      | PWRT disabled (PWRTE bit set)                                  |
|              |               | Power-on Reset signal                                                   |          |         |         |                                      | See section on Power-on Reset for details                      |
| D005         | VBOR          | Brown-out Reset<br>voltage trip point                                   | 3.65     | -       | 4.35    | V                                    | BODEN bit set                                                  |
| D010         | IDD           | Supply Current                                                          | -        | 2.7     | 5       | mA                                   | XT, RC osc modes                                               |
|              |               | (Note 2, 5)                                                             |          |         |         |                                      | Fosc = 4 MHz, VDD = 5.5V (Note 4)                              |
| D013         |               |                                                                         | -        | 10      | 20      | mA                                   | HS osc mode                                                    |
| 2010         |               |                                                                         |          |         | 20      |                                      | Fosc = 20  MHz,  VDD = 5.5  V                                  |
| D020         | IPD           | Power-down Current                                                      | -        | 10.5    | 42      | μA                                   | VDD = 4.0V, WDT enabled,-40°C to +85°C                         |
|              |               | (Note 3, 5)                                                             | -        | 1.5     | 16      | μA                                   | VDD = $4.0V$ , WDT disabled, 0°C to +70°C                      |
| D021         |               |                                                                         | -        | 1.5     | 19      | μ <b>Α</b>                           | VDD = 4.0V, WDT disabled, -40°C to +85°C                       |
| D021B        |               |                                                                         | -        | 2.5     | 19      | μΑ                                   | VDD = $4.0V$ , WDT disabled, $-40^{\circ}C$ to $+125^{\circ}C$ |
|              |               | Module Differential                                                     |          |         |         |                                      |                                                                |
|              |               | Current (Note 6)                                                        |          |         |         |                                      |                                                                |
| D022*        | $\Delta IWDT$ | Watchdog Timer                                                          | -        | 6.0     | 20      | μA                                   | WDTE BIT SET, VDD = 4.0V                                       |
| D022A*       | $\Delta IBOR$ | Brown-out Reset                                                         | -        | TBD     | 200     | μA                                   | BODEN bit set, VDD = 5.0V                                      |

\* 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: This is the limit to which VDD can be lowered without losing RAM data.

2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an impact on the current consumption.

The test conditions for all IDD measurements in active operation mode are:

OSC1 = external square wave, from rail to rail; all I/O pins tristated, pulled to VDD,

 $\overline{MCLR} = VDD$ ; WDT enabled/disabled as specified.

- **3:** The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and Vss.
- 4: For RC osc mode, current through Rext is not included. The current through the resistor can be estimated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm.
- 5: Timer1 oscillator (when enabled) adds approximately 20 μA to the specification. This value is from characterization and is for design guidance only. This is not tested.
- 6: The ∆ current is the additional current consumed when this peripheral is enabled. This current should be added to the base IDD or IPD measurement.
- 7: This is the voltage where the device enters the Brown-out Reset. When BOR is enabled, the device will perform a brown-out reset when VDD falls below VBOR.

#### 13.4.2 TIMING CONDITIONS

The temperature and voltages specified in Table 13-1 apply to all timing specifications unless otherwise noted. Figure 13-4 specifies the load conditions for the timing specifications.

## TABLE 13-1: TEMPERATURE AND VOLTAGE SPECIFICATIONS - AC

| AC CHARACTERISTICS | Standard Operating Conditions (unless otherwise stated)                            |  |  |  |  |  |  |  |
|--------------------|------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|                    | Operating temperature $0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial        |  |  |  |  |  |  |  |
|                    | $-40^{\circ}C \leq TA \leq +85^{\circ}C$ for industrial                            |  |  |  |  |  |  |  |
|                    | -40°C $\leq$ TA $\leq$ +125°C for extended                                         |  |  |  |  |  |  |  |
|                    | Operating voltage VDD range as described in DC spec Section 13.1 and Section 13.2. |  |  |  |  |  |  |  |
|                    | LC parts operate for commercial/industrial temp's only.                            |  |  |  |  |  |  |  |

#### FIGURE 13-4: LOAD CONDITIONS FOR DEVICE TIMING SPECIFICATIONS



## FIGURE 13-10: CAPTURE/COMPARE/PWM TIMINGS



#### TABLE 13-6: CAPTURE/COMPARE/PWM REQUIREMENTS

| Param<br>No. | Sym                              |                       | Characteristi  | с           | Min                   | Тур† | Max | Units | Conditions                         |
|--------------|----------------------------------|-----------------------|----------------|-------------|-----------------------|------|-----|-------|------------------------------------|
| 50*          | TccL CCP1 input low No Prescaler |                       |                | 0.5Tcy + 20 | —                     | —    | ns  |       |                                    |
|              |                                  | time                  | With Prescaler | PIC16CXX    | 10                    | _    | _   | ns    |                                    |
|              |                                  |                       |                | PIC16LCXX   | 20                    | _    | _   | ns    |                                    |
| 51*          | TccH                             | CCP1 input high time  | No Prescaler   |             | 0.5TCY + 20           | _    | _   | ns    |                                    |
|              |                                  |                       | With Prescaler | PIC16CXX    | 10                    | -    | —   | ns    |                                    |
|              |                                  |                       |                | PIC16LCXX   | 20                    | _    | _   | ns    |                                    |
| 52*          | TccP                             | CCP1 input perior     | d              |             | <u>3Tcy + 40</u><br>N | -    | —   | ns    | N = prescale<br>value (1,4, or 16) |
| 53*          | TccR                             | CCP1 output rise      | time           | PIC16CXX    | —                     | 10   | 25  | ns    |                                    |
|              |                                  |                       |                | PIC16LCXX   | —                     | 25   | 45  | ns    |                                    |
| 54*          | TccF                             | CCP1 output fall time |                | PIC16CXX    | —                     | 10   | 25  | ns    |                                    |
|              |                                  |                       |                | PIC16LCXX   | —                     | 25   | 45  | ns    |                                    |

\* 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 13-15: I<sup>2</sup>C BUS START/STOP BITS TIMING



# TABLE 13-11: I<sup>2</sup>C BUS START/STOP BITS REQUIREMENTS

| Parameter<br>No. | Sym     | Characteristic  |              | Min  | Ту<br>р | Max | Unit<br>s | Conditions                        |  |
|------------------|---------|-----------------|--------------|------|---------|-----|-----------|-----------------------------------|--|
| 90*              | TSU:STA | START condition | 100 kHz mode | 4700 |         | —   | ns        | Only relevant for repeated        |  |
|                  |         | Setup time      | 400 kHz mode | 600  | _       | —   |           | START condition                   |  |
| 91*              | THD:STA | START condition | 100 kHz mode | 4000 |         | —   | ns        | After this period the first clock |  |
|                  |         | Hold time       | 400 kHz mode | 600  |         | —   |           | pulse is generated                |  |
| 92*              | TSU:STO | STOP condition  | 100 kHz mode | 4700 |         | —   | ns        |                                   |  |
|                  |         | Setup time      | 400 kHz mode | 600  |         | —   |           |                                   |  |
| 93               | THD:STO | STOP condition  | 100 kHz mode | 4000 | —       | —   | ns        |                                   |  |
|                  |         | Hold time       | 400 kHz mode | 600  | _       | —   |           |                                   |  |

These parameters are characterized but not tested.

# PIC16C62B/72A

## FIGURE 13-16: I<sup>2</sup>C BUS DATA TIMING



#### TABLE 13-12: I<sup>2</sup>C BUS DATA REQUIREMENTS

| Param.<br>No. | Sym     | Characte                   | eristic      | Min        | Max  | Units | Conditions                                       |
|---------------|---------|----------------------------|--------------|------------|------|-------|--------------------------------------------------|
| 100*          | Thigh   | Clock high time            | 100 kHz mode | 4.0        | —    | μS    | Device must operate at a min-<br>imum of 1.5 MHz |
|               |         |                            | 400 kHz mode | 0.6        | _    | μS    | Device must operate at a min-<br>imum of 10 MHz  |
|               |         |                            | SSP Module   | 1.5TCY     | —    |       |                                                  |
| 101*          | TLOW    | Clock low time             | 100 kHz mode | 4.7        | -    | μS    | Device must operate at a min-<br>imum of 1.5 MHz |
|               |         |                            | 400 kHz mode | 1.3        | —    | μs    | Device must operate at a min-<br>imum of 10 MHz  |
|               |         |                            | SSP Module   | 1.5TCY     | —    |       |                                                  |
| 102*          | TR      | SDA and SCL rise           | 100 kHz mode | —          | 1000 | ns    |                                                  |
|               |         | time                       | 400 kHz mode | 20 + 0.1Cb | 300  | ns    | Cb is specified to be from 10-400 pF             |
| 103*          | TF      | SDA and SCL fall time      | 100 kHz mode | —          | 300  | ns    |                                                  |
|               |         |                            | 400 kHz mode | 20 + 0.1Cb | 300  | ns    | Cb is specified to be from 10-400 pF             |
| 90*           | TSU:STA | START condition setup time | 100 kHz mode | 4.7        | —    | μs    | Only relevant for repeated                       |
|               |         |                            | 400 kHz mode | 0.6        | —    | μs    | START condition                                  |
| 91*           | THD:STA | START condition hold       | 100 kHz mode | 4.0        | —    | μs    | After this period the first clock                |
|               |         | time                       | 400 kHz mode | 0.6        | —    | μS    | pulse is generated                               |
| 106*          | THD:DAT | Data input hold time       | 100 kHz mode | 0          | —    | ns    |                                                  |
|               |         |                            | 400 kHz mode | 0          | 0.9  | μs    |                                                  |
| 107*          | TSU:DAT | Data input setup time      | 100 kHz mode | 250        | —    | ns    | Note 2                                           |
|               |         |                            | 400 kHz mode | 100        | —    | ns    |                                                  |
| 92*           | TSU:STO | STOP condition setup       | 100 kHz mode | 4.7        | —    | μs    |                                                  |
|               |         | time                       | 400 kHz mode | 0.6        | _    | μS    |                                                  |
| 109*          | ΤΑΑ     | Output valid from          | 100 kHz mode | —          | 3500 | ns    | Note 1                                           |
|               |         | clock                      | 400 kHz mode | —          | —    | ns    |                                                  |
| 110*          | TBUF    | Bus free time              | 100 kHz mode | 4.7        | _    | μS    | Time the bus must be free                        |
|               |         |                            | 400 kHz mode | 1.3        | —    | μs    | before a new transmission<br>can start           |
|               | Cb      | Bus capacitive loading     |              | —          | 400  | pF    |                                                  |

\* These parameters are characterized but not tested.

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

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

## FIGURE 13-17: A/D CONVERSION TIMING



**Note 1:** If the A/D clock source is selected as RC, a time of TCY is added before the A/D clock starts. This allows the SLEEP instruction to be executed.

| Param | Sym  | Characteristic                                    |                         | Min    | Typ†   | Max | Unit | Conditions                                                                                                                                                                                                                         |
|-------|------|---------------------------------------------------|-------------------------|--------|--------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| No.   |      |                                                   |                         |        |        |     | S    |                                                                                                                                                                                                                                    |
| 130   | Tad  | A/D clock period                                  | PIC16CXX                | 1.6    |        |     | μs   | Tosc based, VREF $\geq 3.0V$                                                                                                                                                                                                       |
|       |      |                                                   | PIC16LCXX               | 2.0    |        | -   | μs   | Tosc based, VREF full range                                                                                                                                                                                                        |
|       |      |                                                   | PIC16CXX                | 2.0    | 4.0    | 6.0 | μS   | A/D RC Mode                                                                                                                                                                                                                        |
|       |      |                                                   | PIC16LCXX               | 3.0    | 6.0    | 9.0 | μS   | A/D RC Mode                                                                                                                                                                                                                        |
| 131   | TCNV | Conversion time (not including S/H time) (Note 1) |                         | 11     | _      | 11  | TAD  |                                                                                                                                                                                                                                    |
| 132   | TACQ | Acquisition time                                  |                         | Note 2 | 20     |     | μS   |                                                                                                                                                                                                                                    |
|       |      |                                                   |                         | 5*     | _      | _   | μs   | The minimum time is the<br>amplifier settling time. This<br>may be used if the "new" input<br>voltage has not changed by<br>more than 1 LSb (i.e., 20.0 mV<br>@ 5.12V) from the last sam-<br>pled voltage (as stated on<br>CHOLD). |
| 134   | TGO  | Q4 to A/D clo                                     | ck start                |        | Tosc/2 |     |      | If the A/D clock source is<br>selected as RC, a time of TCY<br>is added before the A/D clock<br>starts. This allows the SLEEP<br>instruction to be executed.                                                                       |
| 135   | Tswc | Switching from conve<br>time                      | $rt \rightarrow sample$ | 1.5    |        |     | Tad  |                                                                                                                                                                                                                                    |

## TABLE 13-14: A/D CONVERSION REQUIREMENTS

\* 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 9.1 for min conditions.

## 14.0 DC AND AC CHARACTERISTICS GRAPHS AND TABLES

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

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

The data presented in this section is a **statistical summary** of data collected on units from different lots over a period of time and matrix samples. 'Typical' represents the mean of the distribution at 25°C. 'Max' or 'min' represents (mean +  $3\sigma$ ) or (mean -  $3\sigma$ ) respectively, where  $\sigma$  is standard deviation, over the whole temperature range.

## Graphs and Tables not available at this time.

Data is not available at this time but you may reference the *PIC16C72 Series Data Sheet* (DS39016,) DC and AC characteristic section, which contains data similar to what is expected.