



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Obsolete                                                                |
|----------------------------|-------------------------------------------------------------------------|
| Core Processor             | PIC                                                                     |
| Core Size                  | 8-Bit                                                                   |
| Speed                      | 20MHz                                                                   |
| Connectivity               | I²C, SPI, UART/USART                                                    |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                   |
| Number of I/O              | 33                                                                      |
| Program Memory Size        | 14KB (8K x 14)                                                          |
| Program Memory Type        | ROM                                                                     |
| EEPROM Size                |                                                                         |
| RAM Size                   | 368 x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                               |
| Data Converters            | A/D 8x8b                                                                |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                       |
| Mounting Type              | Through Hole                                                            |
| Package / Case             | 40-DIP (0.600", 15.24mm)                                                |
| Supplier Device Package    | 40-PDIP                                                                 |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16cr77-i-p |

Email: info@E-XFL.COM

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

#### **Pin Diagrams**



#### FIGURE 2-2: PIC16CR77/76 REGISTER FILE MAP

| P                                          | File<br>Address | F                                          | File<br>Address |                                            | File<br>Address |                                            | File<br>Address |
|--------------------------------------------|-----------------|--------------------------------------------|-----------------|--------------------------------------------|-----------------|--------------------------------------------|-----------------|
| Indirect addr.(*)                          | 00h             | Indirect addr.(*)                          | 80h             | Indirect addr.(*)                          | 100h            | Indirect addr.(*)                          | 180h            |
| TMR0                                       | 01h             | OPTION REG                                 | 81h             | TMR0                                       | 101h            | OPTION_REG                                 | 181h            |
| PCL                                        | 02h             | PCL                                        | 82h             | PCL                                        | 102h            | PCL                                        | 182h            |
| STATUS                                     | 03h             | STATUS                                     | 83h             | STATUS                                     | 103h            | STATUS                                     | 183h            |
| FSR                                        | 04h             | FSR                                        | 84h             | FSR                                        | 104h            | FSR                                        | 184h            |
| PORTA                                      | 05h             | TRISA                                      | 85h             |                                            | 105h            |                                            | 185h            |
| PORTB                                      | 06h             | TRISB                                      | 86h             | PORTB                                      | 106h            | TRISB                                      | 186h            |
| PORTC                                      | 07h             | TRISC                                      | 87h             |                                            | 107h            |                                            | 187h            |
| PORTD <sup>(1)</sup>                       | 08h             | TRISD <sup>(1)</sup>                       | 88h             |                                            | 108h            |                                            | 188h            |
| PORTE <sup>(1)</sup>                       | 09h             | TRISE <sup>(1)</sup>                       | 89h             |                                            | 109h            |                                            | 189h            |
| PCLATH                                     | 0Ah             | PCLATH                                     | 8Ah             | PCLATH                                     | 10Ah            | PCLATH                                     | 18Ah            |
| INTCON                                     | 0Bh             | INTCON                                     | 8Bh             | INTCON                                     | 10Bh            | INTCON                                     | 18Bh            |
| PIR1                                       | 0Ch             | PIE1                                       | 8Ch             | PMDATA                                     | 10Ch            | PMCON1                                     | 18Ch            |
| PIR2                                       | 0Dh             | PIE2                                       | 8Dh             | PMADR                                      | 10Dh            |                                            | 18Dh            |
| TMR1L                                      | 0Eh             | PCON                                       | 8Eh             | PMDATH                                     | 10Eh            |                                            | 18Eh            |
| TMR1H                                      | 0Fh             |                                            | 8Fh             | PMADRH                                     | 10Fh            |                                            | 18Fh            |
| T1CON                                      | 10h             |                                            | 90h             |                                            | 110h            |                                            | 190h            |
| TMR2                                       | 11h             |                                            | 91h             |                                            | 111h            |                                            | 191h            |
| T2CON                                      | 12h             | PR2                                        | 92h             |                                            | 112h            |                                            | 192h            |
| SSPBUF                                     | 13h             | SSPADD                                     | 93h             |                                            | 113h            |                                            | 193h            |
| SSPCON                                     | 14h             | SSPSTAT                                    | 94h             |                                            | 114h            |                                            | 194h            |
| CCPR1L                                     | 15h             |                                            | 95h             |                                            | 115h            |                                            | 195h            |
| CCPR1H                                     | 16h             |                                            | 96h             |                                            | 116h            |                                            | 196h            |
| CCP1CON                                    | 17h             |                                            | 97h             | General                                    | 117h            | Burpose                                    | 197h            |
| RCSTA                                      | 18h             | TXSTA                                      | 98h             | Register                                   | 118h            | Register                                   | 198h            |
| TXREG                                      | 19h             | SPBRG                                      | 99h             | 16 Bytes                                   | 119h            | 16 Bytes                                   | 199h            |
| RCREG                                      | 1Ah             |                                            | 9Ah             |                                            | 11Ah            |                                            | 19Ah            |
| CCPR2L                                     | 1Bh             |                                            | 9Bh             |                                            | 11Bh            |                                            | 19Bh            |
| CCPR2H                                     | 1Ch             |                                            | 9Ch             |                                            | 11Ch            |                                            | 19Ch            |
| CCP2CON                                    | 1Dh             |                                            | 9Dh             |                                            | 11Dh            |                                            | 19Dh            |
| ADRES                                      | 1Eh             |                                            | 9Eh             |                                            | 11Eh            |                                            | 19Eh            |
| ADCON0                                     | 1Fh             | ADCON1                                     | 9Fh             |                                            | 11Fh            |                                            | 19Fh            |
|                                            | 20h             |                                            | A0h             |                                            | 120h            |                                            | 1A0h            |
| General<br>Purpose<br>Register<br>96 Bytes |                 | General<br>Purpose<br>Register<br>80 Bytes | FFh             | General<br>Purpose<br>Register<br>80 Bytes | 16Fh            | General<br>Purpose<br>Register<br>80 Bytes | 1EFh            |
| ,                                          | 7Eb             | accesses<br>70h-7Fh                        | F0h             | accesses<br>70h-7Fh                        | 170h            | accesses<br>70h-7Fh                        | 1F0h            |
| Bank 0                                     |                 | Bank 1                                     |                 | Bank 2                                     |                 | Bank 3                                     |                 |

Unimplemented data memory locations, read as '0'.

\* Not a physical register.

**Note 1:** These registers are not implemented on 28-pin devices.

#### 2.2.2.1 STATUS Register

The STATUS register contains the arithmetic status of the ALU, the Reset status and the bank select bits for data memory.

The STATUS register can be the destination for any instruction, as with any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the TO and PD bits are not writable, therefore, the result of an instruction with the STATUS register as destination may be different than intended.

For example, CLRF STATUS will clear the upper three bits and set the Z bit. This leaves the STATUS register as `000u u1uu' (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions are used to alter the STATUS register, because these instructions do not affect the Z, C or DC bits from the STATUS register. For other instructions not affecting any Status bits, see the "Instruction Set Summary."

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

| R/W-       | 0 R/W-0                                                                                         | R/W-0                                                                                                                                                                                                                 | R-1                                       | R-1                                                               | R/W-x                              | R/W-x                               | R/W-x                              |  |  |  |
|------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-------------------------------------------------------------------|------------------------------------|-------------------------------------|------------------------------------|--|--|--|
| IRP        | RP1                                                                                             | RP0                                                                                                                                                                                                                   | TO                                        | PD                                                                | Z                                  | DC                                  | С                                  |  |  |  |
| bit 7      | ·                                                                                               |                                                                                                                                                                                                                       |                                           | ·                                                                 |                                    | ·                                   | bit 0                              |  |  |  |
| Legend:    |                                                                                                 |                                                                                                                                                                                                                       |                                           |                                                                   |                                    |                                     |                                    |  |  |  |
| R = Read   | lable bit                                                                                       | W = Writable b                                                                                                                                                                                                        | oit                                       | U = Unimple                                                       | emented bit, rea                   | ad as '0'                           |                                    |  |  |  |
| -n = Value | e at POR                                                                                        | '1' = Bit is set                                                                                                                                                                                                      |                                           | '0' = Bit is cl                                                   | eared                              | x = Bit is unk                      | nown                               |  |  |  |
| bit 7      | <b>IRP:</b> Register<br>1 = Bank 2, 3<br>0 = Bank 0, 1                                          | r Bank Select bit<br>3 (100h-1FFh)<br>(00h-FFh)                                                                                                                                                                       | t (used for ir                            | direct address                                                    | ing)                               |                                     |                                    |  |  |  |
| bit 6-5    | <b>RP1:RP0</b> : Re<br>11 = Bank 3<br>10 = Bank 2<br>01 = Bank 1<br>00 = Bank 0<br>Each bank is | egister Bank Sel<br>(180h-1FFh)<br>(100h-17Fh)<br>(80h-FFh)<br>(00h-7Fh)<br>128 bytes                                                                                                                                 | ect bits (use                             | d for direct ad                                                   | dressing)                          |                                     |                                    |  |  |  |
| bit 4      | <b>TO</b> : Time-out<br>1 = After pow<br>0 = A WDT ti                                           | bit<br>ver-up, CLRWDT<br>me-out occurred                                                                                                                                                                              | instruction o                             | r SLEEP instru                                                    | ction                              |                                     |                                    |  |  |  |
| bit 3      | <b>PD</b> : Power-do<br>1 = After pow<br>0 = By execu                                           | own bit<br>/er-up or by the<br>tion of the SLEE                                                                                                                                                                       | CLRWDT insi                               | truction                                                          |                                    |                                     |                                    |  |  |  |
| bit 2      | z: Zero bit<br>1 = The resul<br>0 = The resul                                                   | lt of an arithmeti<br>It of an arithmeti                                                                                                                                                                              | c or logic op<br>c or logic op            | peration is zero                                                  | zero                               |                                     |                                    |  |  |  |
| bit 1      | DC: Digit carr<br>1 = A carry-o<br>0 = No carry-                                                | ry/borrow bit (AI<br>ut from the 4th I<br>out from the 4th                                                                                                                                                            | DWF, ADDLW<br>ow order bit<br>low order b | of the result of the result                                       | UBWF instruction                   | ns)                                 |                                    |  |  |  |
| bit 0      | <b>C</b> : Carry/borr<br>1 = A carry-o<br>0 = No carry-o                                        | <b>C:</b> Carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions)<br>1 = A carry-out from the Most Significant bit of the result occurred<br>0 = No carry-out from the Most Significant bit of the result occurred |                                           |                                                                   |                                    |                                     |                                    |  |  |  |
| Note:      | For borrow, the p<br>second operand. I<br>of the source regis                                   | olarity is revers<br>For rotate (RRF,<br>ster.                                                                                                                                                                        | ed. A subtra<br>RLF) instru               | action is execture execture execture the sector actions, this bit | uted by adding<br>t is loaded with | the two's comp<br>either the high o | blement of the<br>or low order bit |  |  |  |

#### REGISTER 2-1: STATUS: (ADDRESS 03h, 83h, 103h, 183h)

# 2.3 PCL and PCLATH

The Program Counter (PC) is 13 bits wide. The low byte comes from the PCL register, which is a readable and writable register. The upper bits (PC<12:8>) are not readable, but are indirectly writable through the PCLATH register. On any Reset, the upper bits of the PC will be cleared. Figure 2-1 shows the two situations for the loading of the PC. The upper example in the figure shows how the PC is loaded on a write to PCL (PCLATH<4:0>  $\rightarrow$  PCH). The lower example in the figure shows how the PC is loaded during a CALL or GOTO instruction (PCLATH<4:3>  $\rightarrow$  PCH).

#### FIGURE 2-4: LOADING OF PC IN DIFFERENT SITUATIONS



## 2.3.1 COMPUTED GOTO

A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). When doing a table read using a computed GOTO method, care should be exercised if the table location crosses a PCL memory boundary (each 256 byte block). Refer to the Application Note, *"Implementing a Table Read"* (AN556).

#### 2.3.2 STACK

The PIC16CR7X family has an 8-level deep x 13-bit wide hardware stack. The stack space is not part of either program or data space and the Stack Pointer is not readable or writable. The PC is PUSHed onto the stack when a CALL instruction is executed, or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE instruction execution. PCLATH is not affected by a PUSH or POP operation.

The stack operates as a circular buffer. This means that after the stack has been PUSHed eight times, the ninth push overwrites the value that was stored from the first push. The tenth push overwrites the second push (and so on).

Note 1: There are no Status bits to indicate stack overflow or stack underflow conditions.

2: There are no instructions/mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, RETURN, RETLW and RETFIE instructions, or the vectoring to an interrupt address.

# 2.4 Program Memory Paging

PIC16CR7X devices are capable of addressing a continuous 8K word block of program memory. The CALL and GOTO instructions provide only 11 bits of address to allow branching within any 2K program memory page. When doing a CALL or GOTO instruction, the upper 2 bits of the address are provided by PCLATH<4:3>. When doing a CALL or GOTO instruction, the user must ensure that the page select bits are programmed so that the desired program memory page is addressed. If a return from a CALL instruction (or interrupt) is executed, the entire 13-bit PC is popped off the stack. Therefore, manipulation of the PCLATH<4:3> bits are not required for the RETURN instructions (which POPs the address from the stack).

| Note: | The                                    | cont   | ents   | of  | the | PC  | CLA | TΗ   | are   |
|-------|----------------------------------------|--------|--------|-----|-----|-----|-----|------|-------|
|       | uncha                                  | angeo  | l afte | ra  | REI | URN | or  | RE   | FFIE  |
|       | instruction is executed. The user must |        |        |     |     |     |     |      |       |
|       | setup                                  | the    | PCL/   | ATH | for | any | sub | osec | quent |
|       | CALL                                   | s or c | SOTOS  | 5.  |     |     |     |      |       |

Example 2-1 shows the calling of a subroutine in page 1 of the program memory. This example assumes that PCLATH is saved and restored by the Interrupt Service Routine (if interrupts are used).

#### EXAMPLE 2-1: CALL OF A SUBROUTINE IN PAGE 1 FROM PAGE 0

|         | ORG  | 0x500    |                       |
|---------|------|----------|-----------------------|
|         | BCF  | PCLATH,4 |                       |
|         | BSF  | PCLATH,3 | ;Select page 1        |
|         |      |          | ;(800h-FFFh)          |
|         | CALL | SUB1_P1  | ;Call subroutine in   |
|         | :    |          | ;page 1 (800h-FFFh)   |
|         | :    |          |                       |
|         | ORG  | 0x900    | ;page 1 (800h-FFFh)   |
| SUB1_P1 |      |          |                       |
|         | :    |          | ;called subroutine    |
|         | :    |          | ;page 1 (800h-FFFh)   |
|         | :    |          |                       |
| RETURN  |      |          | ;return to Call       |
|         |      |          | ;subroutine in page 0 |
|         |      |          | ;(000h-7FFh)          |

# 4.0 I/O PORTS

Some pins for these I/O ports are multiplexed with an alternate function for the peripheral features on the device. In general, when a peripheral is enabled, that pin may not be used as a general purpose I/O pin.

Additional information on I/O ports may be found in the "*PIC*<sup>®</sup> *Mid-Range MCU Family Reference Manual*" (DS33023).

## 4.1 PORTA and the TRISA Register

PORTA is a 6-bit wide, bidirectional port. The corresponding data direction register is TRISA. Setting a TRISA bit (= 1) will make the corresponding PORTA pin an input (i.e., put the corresponding output driver in a High-Impendance mode). Clearing a TRISA bit (= 0) will make the corresponding PORTA pin an output (i.e., put the contents of the output latch on the selected pin).

Reading the PORTA register reads the status of the pins, whereas writing to it will write to the PORT latch. All write operations are read-modify-write operations. Therefore, a write to a port implies that the port pins are read, the value is modified and then written to the PORT data latch.

Pin RA4 is multiplexed with the Timer0 module clock input to become the RA4/T0CKI pin. The RA4/T0CKI pin is a Schmitt Trigger input and an open drain output. All other PORTA pins have TTL input levels and full CMOS output drivers.

Other PORTA pins are multiplexed with analog inputs and analog VREF input. The operation of each pin is selected by clearing/setting the control bits in the ADCON1 register (A/D Control Register1).

| Note: | On a Power-on Reset, these pins are     |
|-------|-----------------------------------------|
|       | configured as analog inputs and read as |
|       | ʻ0'.                                    |

The TRISA register controls the direction of the RA pins, even when they are being used as analog inputs. The user must ensure the bits in the TRISA register are maintained set, when using them as analog inputs.

| EXAMPLE 4-1: | <b>INITIALIZING PORTA</b> |
|--------------|---------------------------|
|--------------|---------------------------|

| BCF   | STATUS, | RP0 | ;   |                       |
|-------|---------|-----|-----|-----------------------|
| BCF   | STATUS, | RP1 | ; E | Bank0                 |
| CLRF  | PORTA   |     | ; ] | Initialize PORTA by   |
|       |         |     | ; ( | clearing output       |
|       |         |     | ; ċ | lata latches          |
| BSF   | STATUS, | RP0 | ; 5 | Select Bank 1         |
| MOVLW | 0x06    |     | ; ( | Configure all pins    |
| MOVWF | ADCON1  |     | ; a | as digital inputs     |
| MOVLW | 0xCF    |     | ; \ | <i>V</i> alue used to |
|       |         |     | ; i | initialize data       |
|       |         |     | ; ċ | lirection             |
| MOVWF | TRISA   |     | ; 5 | Set RA<3:0> as inputs |
|       |         |     | ; F | RA<5:4> as outputs    |
|       |         |     | ; ] | TRISA<7:6>are always  |
|       |         |     | ; 1 | read as `0'.          |

#### FIGURE 4-1:

#### BLOCK DIAGRAM OF RA3:RA0 AND RA5 PINS



FIGURE 4-2:

BLOCK DIAGRAM OF RA4/T0CKI PIN



#### 4.5 PORTE and TRISE Register

This section is not applicable to the PIC16CR73 or PIC16CR76.

PORTE has three pins, RE0/RD/AN5, RE1/WR/AN6 and RE2/CS/AN7, which are individually configureable as inputs or outputs. These pins have Schmitt Trigger input buffers.

I/O PORTE becomes control inputs for the microprocessor port when bit PSPMODE (TRISE<4>) is set. In this mode, the user must make sure that the TRISE<2:0> bits are set (pins are configured as digital inputs). Ensure ADCON1 is configured for digital I/O. In this mode, the input buffers are TTL.

Register 4-1 shows the TRISE register, which also controls the Parallel Slave Port operation.

PORTE pins are multiplexed with analog inputs. When selected as an analog input, these pins will read as '0's.

TRISE controls the direction of the RE pins, even when they are being used as analog inputs. The user must make sure to keep the pins configured as inputs when using them as analog inputs.

Note: On a Power-on Reset, these pins are configured as analog inputs and read as '0'.

#### FIGURE 4-7:

#### PORTE BLOCK DIAGRAM (IN I/O PORT MODE)



# PIC16CR7X

NOTES:

## 6.1 Timer1 Operation in Timer Mode

Timer mode is selected by clearing the TMR1CS (T1CON<1>) bit. In this mode, the input clock to the timer is FOSC/4. The synchronize control bit T1SYNC (T1CON<2>) has no effect, since the internal clock is always in sync.

## 6.2 Timer1 Counter Operation

Timer1 may operate in Asynchronous or Synchronous mode, depending on the setting of the TMR1CS bit.

When Timer1 is being incremented via an external source, increments occur on a rising edge. After Timer1 is enabled in Counter mode, the module must first have a falling edge before the counter begins to increment.



#### 6.3 Timer1 Operation in Synchronized Counter Mode

Counter mode is selected by setting bit TMR1CS. In this mode, the timer increments on every rising edge of clock input on pin RC1/T1OSI/CCP2, when bit T1OSCEN is set, or on pin RC0/T1OSO/T1CKI, when bit T1OSCEN is cleared.



In this configuration, during Sleep mode, Timer1 will not increment even if the external clock is present, since the synchronization circuit is shut-off. The prescaler, however, will continue to increment.



## FIGURE 6-2: TIMER1 BLOCK DIAGRAM

| R/W-0                                                                                                                                                          | R/W-0                                                                                                              | R/W-0                                               | R/W-0                   | U-0              | R-0              | R-0               | R-x   |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-------------------------|------------------|------------------|-------------------|-------|--|--|
| SPEN                                                                                                                                                           | RX9                                                                                                                | SREN                                                | CREN                    | _                | FERR             | OERR              | RX9D  |  |  |
| bit 7                                                                                                                                                          | •<br>•                                                                                                             |                                                     |                         |                  |                  |                   | bit 0 |  |  |
|                                                                                                                                                                |                                                                                                                    |                                                     |                         |                  |                  |                   |       |  |  |
| Legend:                                                                                                                                                        |                                                                                                                    |                                                     |                         |                  |                  |                   |       |  |  |
| R = Readable                                                                                                                                                   | bit                                                                                                                | W = Writable                                        | bit                     | U = Unimpler     | mented bit, read | 1 as '0'          |       |  |  |
| -n = Value at F                                                                                                                                                | POR                                                                                                                | '1' = Bit is set                                    |                         | '0' = Bit is cle | ared             | x = Bit is unkr   | nown  |  |  |
| bit 7 <b>SPEN:</b> Serial Port Enable bit<br>1 = Serial port enabled (configures RC7/RX/DT and RC6/TX/CK pins as serial port pins)<br>0 = Serial port disabled |                                                                                                                    |                                                     |                         |                  |                  |                   |       |  |  |
| bit 6                                                                                                                                                          | <b>RX9</b> : 9-bit Re<br>1 = Selects 9-<br>0 = Selects 8-                                                          | ceive Enable t<br>-bit reception<br>-bit reception  | bit                     |                  |                  |                   |       |  |  |
| bit 5                                                                                                                                                          | SREN: Single                                                                                                       | Receive Enat                                        | ole bit                 |                  |                  |                   |       |  |  |
|                                                                                                                                                                | Asynchronous<br>Don't care                                                                                         | <u>s mode:</u>                                      |                         |                  |                  |                   |       |  |  |
|                                                                                                                                                                | <u>Synchronous</u><br>1 = Enables s                                                                                | mode – Maste                                        | <u>er:</u>              |                  |                  |                   |       |  |  |
|                                                                                                                                                                | 0 = Disables s<br>This bit is clea                                                                                 | single receive<br>ared after rece                   | ption is compl          | ete.             |                  |                   |       |  |  |
|                                                                                                                                                                | <u>Synchronous</u><br>Don't care                                                                                   | mode – Slave                                        | <u>.</u>                |                  |                  |                   |       |  |  |
| bit 4                                                                                                                                                          | CREN: Contir                                                                                                       | nuous Receive                                       | Enable bit              |                  |                  |                   |       |  |  |
|                                                                                                                                                                | Asynchronous<br>1 = Enables o<br>0 = Disables o                                                                    | <u>s mode:</u><br>continuous rece<br>continuous rec | eive<br>eive            |                  |                  |                   |       |  |  |
|                                                                                                                                                                | <u>Synchronous</u><br>1 = Enables o<br>0 = Disables o                                                              | <u>mode:</u><br>continuous reco<br>continuous rec   | eive until enab<br>eive | le bit CREN is   | cleared (CREN    | l overrides SRE   | EN)   |  |  |
| bit 3                                                                                                                                                          | Unimplemen                                                                                                         | ted: Read as '                                      | 0'                      |                  |                  |                   |       |  |  |
| bit 2                                                                                                                                                          | FERR: Framin<br>1 = Framing e<br>0 = No framin                                                                     | ng Error bit<br>error (can be u<br>ig error         | pdated by rea           | ding RCREG r     | egister and rece | eive next valid l | byte) |  |  |
| bit 1                                                                                                                                                          | <b>OERR</b> : Overrun Error bit<br>1 = Overrun error (can be cleared by clearing bit CREN)<br>0 = No overrun error |                                                     |                         |                  |                  |                   |       |  |  |
| bit 0                                                                                                                                                          | <b>RX9D:</b> 9th bit<br>Can be parity                                                                              | of Received E<br>bit (parity to b                   | )ata<br>e calculated b  | y firmware)      |                  |                   |       |  |  |

# REGISTER 10-2: RCSTA: RECEIVE STATUS AND CONTROL (ADDRESS 18h)

# 11.0 ANALOG-TO-DIGITAL CONVERTER (A/D) MODULE

The 8-bit Analog-to-Digital (A/D) converter module has five inputs for the PIC16CR73/76 and eight for the PIC16CR74/77.

The A/D allows conversion of an analog input signal to a corresponding 8-bit digital number. The output of the sample and hold is the input into the converter, which generates the result via successive approximation. The analog reference voltage is software selectable to either the device's positive supply voltage (VDD), or the voltage level on the RA3/AN3/VREF pin.

The A/D converter has a unique feature of being able to operate while the device is in Sleep mode. To operate in Sleep, the A/D conversion clock must be derived from the A/D's internal RC oscillator. The A/D module has three registers. These registers are:

- A/D Result Register ((ADRES)
- A/D Control Register 0 (ADCON0)
- A/D Control Register 1 ((ADCON1)

The ADCON0 register, shown in Register 11-1, controls the operation of the A/D module. The ADCON1 register, shown in Register 11-2, configures the functions of the port pins. The port pins can be configured as analog inputs (RA3 can also be a voltage reference), or as digital I/O.

Additional information on using the A/D module can be found in the "*PIC*<sup>®</sup> *Mid-Range MCU Family Reference Manual*" (DS33023) and in Application Note AN546, "*Using The Analog-to-Digital Converter*" (DS00546).

| R/W-0                              | R/W-0 | R/W-0 | R/W-0                              | R/W-0                                   | R/W-0   | U-0 | R/W-0 |
|------------------------------------|-------|-------|------------------------------------|-----------------------------------------|---------|-----|-------|
| ADCS1                              | ADCS0 | CHS2  | CHS1                               | CHS0                                    | GO/DONE | _   | ADON  |
| bit 7                              |       |       |                                    |                                         |         |     | bit 0 |
|                                    |       |       |                                    |                                         |         |     |       |
| Legend:                            |       |       |                                    |                                         |         |     |       |
| R = Readable bit W = Writable bit  |       |       | U = Unimplemented bit, read as '0' |                                         |         |     |       |
| -n = Value at POR '1' = Bit is set |       |       |                                    | '0' = Bit is cleared x = Bit is unknown |         |     | nown  |

| bit 7-6 | ADCS1:ADCS0: A/D Conversion Clock Select bits                                                                                                  |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 00 = FOSC/2 $01 = FOSC/8$                                                                                                                      |
|         | 10 = Fosc/32                                                                                                                                   |
|         | 11 = FRC (clock derived from the internal A/D module RC oscillator)                                                                            |
| bit 5-3 | CHS2:CHS0: Analog Channel Select bits                                                                                                          |
|         | 000 = Channel 0 (RA0/AN0)                                                                                                                      |
|         | 001 = Channel 1 (RA1/AN1)                                                                                                                      |
|         | 010 = Channel 2 (RA2/AN2)                                                                                                                      |
|         | 011 = Channel 4 (RA5/AN3)                                                                                                                      |
|         | $101 = \text{Channel 5 (RE0/AN5)}^{(1)}$                                                                                                       |
|         | 110 = Channel 6 (RE1/AN6) <sup>(1)</sup>                                                                                                       |
|         | 111 = Channel 7 (RE2/AN7) <sup>(1)</sup>                                                                                                       |
| bit 2   | GO/DONE: A/D Conversion Status bit                                                                                                             |
|         | <u>If ADON = 1:</u>                                                                                                                            |
|         | 1 = A/D conversion in progress (setting this bit starts the A/D conversion)                                                                    |
|         | <ul> <li>a) =A/D conversion not in progress (this bit is automatically cleared by hardware when the<br/>A/D conversion is complete)</li> </ul> |
| bit 1   | Unimplemented: Read as '0'                                                                                                                     |
| bit 0   | ADON: A/D On bit                                                                                                                               |
|         | 1 = A/D converter module is operating                                                                                                          |
|         | 0 = A/D converter module is shut-off and consumes no operating current                                                                         |
|         | Note: A/D channels 5, 6 and 7 are implemented on the PIC16CR74/77 only.                                                                        |
|         |                                                                                                                                                |

#### REGISTER 11-1: ADCON0: (ADDRESS 1Fh)

## 11.2 Selecting the A/D Conversion Clock

The A/D conversion time per bit is defined as TAD. The A/D conversion requires 9.0 TAD per 8-bit conversion. The source of the A/D conversion clock is software selectable. The four possible options for TAD are:

- 2 Tosc (Fosc/2)
- 8 Tosc (Fosc/8)
- 32 Tosc (Fosc/32)
- Internal RC oscillator (2-6 μs)

For correct A/D conversions, the A/D conversion clock (TAD) must be selected to ensure a minimum TAD time as small as possible, but no less than  $1.6 \,\mu$ s.

# 11.3 Configuring Analog Port Pins

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

The A/D operation is independent of the state of the CHS2:CHS0 bits and the TRIS bits.

- Note 1: When reading the PORT register, all pins configured as analog input channels will read as cleared (a low level). Pins configured as digital inputs will convert an analog input. Analog levels on a digitally configured input will not affect the conversion accuracy.
  - 2: Analog levels on any pin that is defined as a digital input, but not as an analog input, may cause the digital input buffer to consume current that is out of the device's specification.

# 11.4 A/D Conversions

Note: The GO/DONE bit should **NOT** be set in the same instruction that turns on the A/D.

Setting the GO/DONE bit begins an A/D conversion. When the conversion completes, the 8-bit result is placed in the ADRES register, the GO/DONE bit is cleared, and the ADIF flag (PIR<6>) is set.

If both the A/D interrupt bit ADIE (PIE1<6>) and the peripheral interrupt enable bit PEIE (INTCON<6>) are set, the device will wake from Sleep whenever ADIF is set by hardware. In addition, an interrupt will also occur if the Global Interrupt bit GIE (INTCON<7>) is set.

Clearing the GO/DONE bit during a conversion will abort the current conversion. The ADRES register will NOT be changed and the ADIF flag will not be set.

After the GO/DONE bit is cleared at either the end of a conversion, or by firmware, another conversion can be initiated by setting the GO/DONE bit. Users must still take into account the appropriate acquisition time for the application.

# 11.5 A/D Operation During Sleep

The A/D module can operate during Sleep mode. This requires that the A/D clock source be set to RC (ADCS1:ADCS0 = 11). When the RC clock source is selected, the A/D module waits one instruction cycle before starting the conversion. This allows the SLEEP instruction to be executed, which eliminates all digital switching noise from the conversion. When the conversion is completed, the GO/DONE bit will be cleared, and the result loaded into the ADRES register. If the A/D interrupt is enabled, the device will wake-up from Sleep. If the A/D interrupt is not enabled, the ADON bit will remain set.

When the A/D clock source is another clock option (not RC), a SLEEP instruction will cause the present conversion to be aborted and the A/D module to be turned off, though the ADON bit will remain set.

Turning off the A/D places the A/D module in its lowest current consumption state.

Note: For the A/D module to operate in Sleep, the A/D clock source must be set to RC (ADCS1:ADCS0 = 11). To perform an A/D conversion in Sleep, ensure the SLEEP instruction immediately follows the instruction that sets the GO/DONE bit.

# 11.6 Effects of a Reset

A device Reset forces all registers to their Reset state. The A/D module is disabled and any conversion in progress is aborted. All A/D input pins are configured as analog inputs.

The ADRES register will contain unknown data after a Power-on Reset.

# 12.4 MCLR

PIC16CR7X devices have a noise filter in the  $\overline{\text{MCLR}}$ Reset path. The filter will detect and ignore small pulses.

It should be noted that a WDT Reset does not drive MCLR pin low.

The behavior of the ESD protection on the  $\overline{\text{MCLR}}$  pin has been altered from previous devices of this family. Voltages applied to the pin that exceed its specification can result in both  $\overline{\text{MCLR}}$  Resets and excessive current beyond the device specification during the ESD event. For this reason, Microchip recommends that the  $\overline{\text{MCLR}}$ pin no longer be tied directly to VDD. The use of an RC network, as shown in Figure 12-5, is suggested.

FIGURE 12-5: RECOMMENDED MCLR CIRCUIT



# 12.5 Power-on Reset (POR)

A Power-on Reset pulse is generated on-chip when VDD rise is detected (in the range of 1.2V-1.7V). To take advantage of the POR, tie the  $\overline{\text{MCLR}}$  pin to VDD as described in **Section 12.4 "MCLR**". A maximum rise time for VDD is specified. See the Electrical Specifications for details.

When the device starts normal operation (exits the Reset condition), device operating parameters (voltage, frequency, temperature,...) must be met to ensure operation. If these conditions are not met, the device must be held in Reset until the operating conditions are met. For additional information, refer to Application Note AN607, "*Power-up Trouble Shooting*" (DS00607).

# 12.6 Power-up Timer (PWRT)

The Power-up Timer provides a fixed 72 ms nominal time-out on power-up only from the POR. The Power-up Timer operates on an internal RC oscillator. The chip is kept in Reset as long as the PWRT is active. The PWRT's time delay allows VDD to rise to an acceptable level. A Configuration bit is provided to enable/disable the PWRT.

The power-up time delay will vary from chip-to-chip, due to VDD, temperature and process variation. See DC parameters for details (TPWRT, parameter #33).

# 12.7 Oscillator Start-up Timer (OST)

The Oscillator Start-up Timer (OST) provides 1024 oscillator cycles (from OSC1 input) delay after the PWRT delay is over (if enabled). This helps to ensure that the crystal oscillator or resonator has started and stabilized.

The OST time-out is invoked only for XT, LP and HS modes and only on Power-on Reset, or wake-up from Sleep.

## 12.8 Brown-out Reset (BOR)

The Configuration bit, BODEN, can enable or disable the Brown-out Reset circuit. If VDD falls below VBOR (parameter D005, about 4V) for longer than TBOR (parameter #35, about 100  $\mu$ S), the brown-out situation will reset the device. If VDD falls below VBOR for less than TBOR, a Reset may not occur.

Once the brown-out occurs, the device will remain in Brown-out Reset until VDD rises above VBOR. The Power-up Timer then keeps the device in Reset for TPWRT (parameter #33, about 72 mS). If VDD should fall below VBOR during TPWRT, the Brown-out Reset process will restart when VDD rises above VBOR, with the Power-up Timer Reset. The Power-up Timer is always enabled when the Brown-out Reset circuit is enabled, regardless of the state of the PWRT Configuration bit.

## 12.9 Time-out Sequence

On power-up, the time-out sequence is as follows: the PWRT delay starts (if enabled) when a POR Reset occurs. Then, OST starts counting 1024 oscillator cycles when PWRT ends (LP, XT, HS). When the OST ends, the device comes out of Reset.

If MCLR is kept low long enough, all delays will expire. Bringing MCLR high will begin execution immediately. This is useful for testing purposes or to synchronize more than one PIC16CR7X device operating in parallel.

Table 12-5 shows the Reset conditions for the STATUS, PCON and PC registers, while Table 12-6 shows the Reset conditions for all the registers.

| Register   | Devices |    | Devices Po<br>Bro |    | Power-on Reset,<br>Brown-out Reset | MCLR Reset,<br>WDT Reset | Wake-up via WDT or<br>Interrupt |
|------------|---------|----|-------------------|----|------------------------------------|--------------------------|---------------------------------|
| W          | 73      | 74 | 76                | 77 | XXXX XXXX                          | uuuu uuuu                | uuuu uuuu                       |
| INDF       | 73      | 74 | 76                | 77 | N/A                                | N/A                      | N/A                             |
| TMR0       | 73      | 74 | 76                | 77 | XXXX XXXX                          | uuuu uuuu                | uuuu uuuu                       |
| PCL        | 73      | 74 | 76                | 77 | 0000h                              | 0000h                    | PC + 1 <sup>(2)</sup>           |
| STATUS     | 73      | 74 | 76                | 77 | 0001 1xxx                          | 000q quuu <b>(3)</b>     | uuuq quuu <b>(3)</b>            |
| FSR        | 73      | 74 | 76                | 77 | XXXX XXXX                          | uuuu uuuu                | uuuu uuuu                       |
| PORTA      | 73      | 74 | 76                | 77 | 0x 0000                            | 0u 0000                  | uu uuuu                         |
| PORTB      | 73      | 74 | 76                | 77 | xxxx xxxx                          | uuuu uuuu                | uuuu uuuu                       |
| PORTC      | 73      | 74 | 76                | 77 | xxxx xxxx                          | uuuu uuuu                | uuuu uuuu                       |
| PORTD      | 73      | 74 | 76                | 77 | XXXX XXXX                          | uuuu uuuu                | uuuu uuuu                       |
| PORTE      | 73      | 74 | 76                | 77 | xxx                                | uuu                      | uuu                             |
| PCLATH     | 73      | 74 | 76                | 77 | 0 0000                             | 0 0000                   | u uuuu                          |
| INTCON     | 73      | 74 | 76                | 77 | 0000 000x                          | 0000 000u                | uuuu uuuu <b>(1)</b>            |
| PIR1       | 73      | 74 | 76                | 77 | r000 0000                          | r000 0000                | ruuu uuuu <b>(1)</b>            |
|            | 73      | 74 | 76                | 77 | 0000 0000                          | 0000 0000                | uuuu uuuu <b>(1)</b>            |
| PIR2       | 73      | 74 | 76                | 77 | 0                                  | 0                        | (1)                             |
| TMR1L      | 73      | 74 | 76                | 77 | xxxx xxxx                          | uuuu uuuu                | uuuu uuuu                       |
| TMR1H      | 73      | 74 | 76                | 77 | xxxx xxxx                          | uuuu uuuu                | uuuu uuuu                       |
| T1CON      | 73      | 74 | 76                | 77 | 00 0000                            | uu uuuu                  | uu uuuu                         |
| TMR2       | 73      | 74 | 76                | 77 | 0000 0000                          | 0000 0000                | uuuu uuuu                       |
| T2CON      | 73      | 74 | 76                | 77 | -000 0000                          | -000 0000                | -uuu uuuu                       |
| SSPBUF     | 73      | 74 | 76                | 77 | xxxx xxxx                          | uuuu uuuu                | uuuu uuuu                       |
| SSPCON     | 73      | 74 | 76                | 77 | 0000 0000                          | 0000 0000                | uuuu uuuu                       |
| CCPR1L     | 73      | 74 | 76                | 77 | XXXX XXXX                          | uuuu uuuu                | uuuu uuuu                       |
| CCPR1H     | 73      | 74 | 76                | 77 | XXXX XXXX                          | uuuu uuuu                | uuuu uuuu                       |
| CCP1CON    | 73      | 74 | 76                | 77 | 00 0000                            | 00 0000                  | uu uuuu                         |
| RCSTA      | 73      | 74 | 76                | 77 | 0000 -00x                          | 0000 -00x                | uuuu -uuu                       |
| TXREG      | 73      | 74 | 76                | 77 | 0000 0000                          | 0000 0000                | uuuu uuuu                       |
| RCREG      | 73      | 74 | 76                | 77 | 0000 0000                          | 0000 0000                | uuuu uuuu                       |
| CCPR2L     | 73      | 74 | 76                | 77 | XXXX XXXX                          | uuuu uuuu                | uuuu uuuu                       |
| CCPR2H     | 73      | 74 | 76                | 77 | XXXX XXXX                          | uuuu uuuu                | uuuu uuuu                       |
| CCP2CON    | 73      | 74 | 76                | 77 | 0000 0000                          | 0000 0000                | uuuu uuuu                       |
| ADRES      | 73      | 74 | 76                | 77 | XXXX XXXX                          | uuuu uuuu                | uuuu uuuu                       |
| ADCON0     | 73      | 74 | 76                | 77 | 0000 00-0                          | 0000 00-0                | uuuu uu-u                       |
| OPTION_REG | 73      | 74 | 76                | 77 | 1111 1111                          | 1111 1111                | uuuu uuuu                       |
| TRISA      | 73      | 74 | 76                | 77 | 11 1111                            | 11 1111                  | uu uuuu                         |
| TRISB      | 73      | 74 | 76                | 77 | 1111 1111                          | 1111 1111                | uuuu uuuu                       |
| TRISC      | 73      | 74 | 76                | 77 | 1111 1111                          | 1111 1111                | uuuu uuuu                       |
| TRISD      | 73      | 74 | 76                | 77 | 1111 1111                          | 1111 1111                | uuuu uuuu                       |
| TRISE      | 73      | 74 | 76                | 77 | 0000 -111                          | 0000 -111                | uuuu -uuu                       |

#### TABLE 12-6: INITIALIZATION CONDITIONS FOR ALL REGISTERS

**Legend:** u = unchanged, x = unknown, - = unimplemented bit, read as '0', q = value depends on condition, r = reserved, maintain clear

Note 1: One or more bits in INTCON, PIR1 and/or PIR2 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 12-5 for Reset value for specific condition.

#### 12.11 Interrupts

The PIC16CR7X family has up to 12 sources of interrupt. The Interrupt Control register (INTCON) records individual interrupt requests in flag bits. It also has individual and global interrupt enable bits.

| Note: | Individual                        | interrupt |     | t flag | bits | are  | set,   |
|-------|-----------------------------------|-----------|-----|--------|------|------|--------|
|       | regardless                        | of        | the | status | of t | neir | corre- |
|       | sponding mask bit or the GIE bit. |           |     |        |      |      |        |

A Global Interrupt Enable bit, GIE (INTCON<7>) enables (if set) all unmasked interrupts, or disables (if cleared) all interrupts. When bit GIE is enabled and an interrupt's flag bit and mask bit are set, the interrupt will vector immediately. Individual interrupts can be disabled through their corresponding enable bits in various registers. Individual interrupt bits are set, regardless of the status of the GIE bit. The GIE bit is cleared on Reset.

The "return from interrupt" instruction, RETFIE, exits the interrupt routine, as well as sets the GIE bit, which re-enables interrupts.

The RB0/INT pin interrupt, the RB port change interrupt and the TMR0 overflow interrupt flags are contained in the INTCON register.

The peripheral interrupt flags are contained in the Special Function Registers, PIR1 and PIR2. The corresponding interrupt enable bits are contained in Special Function Registers, PIE1 and PIE2, and the peripheral interrupt enable bit is contained in Special Function Register, INTCON.

When an interrupt is responded to, the GIE bit is cleared to disable any further interrupt, the return address is pushed onto the stack and the PC is loaded with 0004h. Once in the Interrupt Service Routine, the source(s) of the interrupt can be determined by polling the interrupt flag bits. The interrupt flag bit(s) must be cleared in software before re-enabling interrupts to avoid recursive interrupts.

For external interrupt events, such as the INT pin or PORTB change interrupt, the interrupt latency will be three or four instruction cycles. The exact latency depends when the interrupt event occurs, relative to the current Q cycle. The latency is the same for one or two-cycle instructions. Individual interrupt flag bits are set, regardless of the status of their corresponding mask bit, PEIE bit or the GIE bit.



#### FIGURE 12-10: INTERRUPT LOGIC

FIGURE 15-7: TIMER0 AND TIMER1 EXTERNAL CLOCK TIMINGS



| Param<br>No.                   | Symbol    | Characteristic                             |                                        |                                           | Min                                       | Тур† | Max    | Units                              | Conditions                         |  |
|--------------------------------|-----------|--------------------------------------------|----------------------------------------|-------------------------------------------|-------------------------------------------|------|--------|------------------------------------|------------------------------------|--|
| 40*                            | Tt0H      | T0CKI High Pulse Width                     |                                        | No Prescaler                              | aler 0.5TCY + 20                          |      | _      | ns                                 | Must also meet                     |  |
|                                |           |                                            |                                        | With Prescaler                            | 10                                        | —    | —      | ns                                 | parameter 42                       |  |
| 41*                            | Tt0L      | T0CKI Low Pulse                            | Width                                  | No Prescaler                              | 0.5TCY + 20                               | —    | —      | ns                                 | Must also meet                     |  |
|                                |           |                                            |                                        | With Prescaler                            | 10                                        | —    | —      | ns                                 | parameter 42                       |  |
| 42*                            | Tt0P      | T0CKI Period                               |                                        | No Prescaler                              | Tcy + 40                                  |      | _      | ns                                 |                                    |  |
|                                |           |                                            |                                        | With Prescaler                            | Greater of:                               | —    | —      | ns                                 | N = prescale                       |  |
|                                |           |                                            |                                        |                                           | 20 or <u>Tcy + 40</u><br>N                |      |        |                                    | value (2, 4,,<br>256)              |  |
| 45*                            | Tt1H      | T1CKI High Time                            | Synchronous, Pr                        | escaler = 1                               | 0.5Tcy + 20                               |      | —      | ns                                 | Must also meet                     |  |
|                                |           |                                            | Synchronous,                           | Standard(5V)                              | 15                                        | _    | —      | ns                                 | parameter 47                       |  |
|                                |           |                                            | Prescaler = $2,4,8$                    | Extended(3V)                              | 25                                        | —    | —      | ns                                 |                                    |  |
|                                |           |                                            | Asynchronous                           | Standard(5V)                              | 30                                        | —    | —      | ns                                 |                                    |  |
|                                |           |                                            | Extended(3V)                           | 50                                        | —                                         | —    | ns     |                                    |                                    |  |
| 46*                            | Tt1L      | T1CKI Low Time Synchronous, Pr             |                                        | escaler = 1                               | 0.5Tcy + 20                               | —    | —      | ns                                 | Must also meet                     |  |
|                                |           |                                            | Synchronous,                           | Standard(5V)                              | 15                                        | —    | —      | ns                                 | parameter 47                       |  |
|                                |           |                                            | Prescaler = 2,4,8<br>Asynchronous      | Extended(3V)                              | 25                                        | —    | —      | ns                                 |                                    |  |
|                                |           |                                            |                                        | Standard(5V)                              | 30                                        | —    | —      | ns                                 |                                    |  |
|                                |           |                                            |                                        | Extended(3V)                              | 50                                        | —    | —      | ns                                 |                                    |  |
| 47* Tt1P T1CKI Input<br>Period |           | Synchronous                                | Standard( <b>5V</b> )                  | Greater of:<br>30 or <u>Tcʏ + 40</u><br>N | _                                         | —    | ns     | N = prescale<br>value (1, 2, 4, 8) |                                    |  |
|                                |           |                                            |                                        | Extended(3V)                              | Greater of:<br>50 or <u>Tcʏ + 40</u><br>N |      |        |                                    | N = prescale<br>value (1, 2, 4, 8) |  |
|                                |           |                                            | Asynchronous                           | Standard(5V)                              | 60                                        | -    | —      | ns                                 |                                    |  |
|                                |           |                                            |                                        | Extended(3V)                              | 100                                       | —    | —      | ns                                 |                                    |  |
|                                | Ft1       | Timer1 Oscillator I<br>(oscillator enabled | nput Frequency R<br>by setting bit T10 | DC                                        | _                                         | 200  | kHz    |                                    |                                    |  |
| 48                             | TCKEZtmr1 | Delay from Extern                          | al Clock Edge to T                     | Timer Increment                           | 2 Tosc                                    | —    | 7 Tosc | —                                  |                                    |  |

\* These parameters are characterized but not tested.

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



#### FIGURE 15-10: SPI MASTER MODE TIMING (CKE = 0, SMP = 0)





| Param<br>No. | Symbol  | Characteristic  |              | Min  | Тур | Max | Units | 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 |
|              |         | Hold time       | 400 kHz mode | 600  | _   | —   |       | clock 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  |     | —   |       |                              |

| TABLE 15-8: | I <sup>2</sup> C <sup>™</sup> BUS | START/STOP | P BITS REQUIREME | ENTS |
|-------------|-----------------------------------|------------|------------------|------|
|-------------|-----------------------------------|------------|------------------|------|

\* These parameters are characterized but not tested.





# 17.1 Package Marking Information (continued)





28-Lead SOIC (.300")



#### 28-Lead SSOP



## 44-Lead TQFP



Example



Example



## Example



#### Example



# 28-Lead Plastic Quad Flat, No Lead Package (ML) – 6x6 mm Body [QFN] with 0.55 mm Contact Length

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



|                        | Units            |              |      | MILLIMETERS |  |  |  |
|------------------------|------------------|--------------|------|-------------|--|--|--|
| Dimensi                | Dimension Limits |              |      | MAX         |  |  |  |
| Number of Pins         | 28               |              |      |             |  |  |  |
| Pitch                  | е                | 0.65 BSC     |      |             |  |  |  |
| Overall Height         | А                | 0.80 0.90 1. |      |             |  |  |  |
| Standoff               |                  | 0.00         | 0.02 | 0.05        |  |  |  |
| Contact Thickness      |                  | 0.20 REF     |      |             |  |  |  |
| Overall Width          | E                | 6.00 BSC     |      |             |  |  |  |
| Exposed Pad Width      |                  | 3.65         | 3.70 | 4.20        |  |  |  |
| Overall Length         |                  | 6.00 BSC     |      |             |  |  |  |
| Exposed Pad Length     | D2               | 3.65         | 3.70 | 4.20        |  |  |  |
| Contact Width          | b                | 0.23         | 0.30 | 0.35        |  |  |  |
| Contact Length         |                  | 0.50         | 0.55 | 0.70        |  |  |  |
| Contact-to-Exposed Pad |                  | 0.20         | -    | -           |  |  |  |

#### Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. Package is saw singulated.

3. Dimensioning and tolerancing per ASME Y14.5M.

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-105B

## 28-Lead Plastic Small Outline (SO) – Wide, 7.50 mm Body [SOIC]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging









|                          | Units         | MILLMETERS  |     |      |  |
|--------------------------|---------------|-------------|-----|------|--|
| Dime                     | ension Limits | MIN         | NOM | MAX  |  |
| Number of Pins           | Ν             | 28          |     |      |  |
| Pitch                    | е             | 1.27 BSC    |     |      |  |
| Overall Height           | А             | _           | _   | 2.65 |  |
| Molded Package Thickness | A2            | 2.05        | -   | 1    |  |
| Standoff §               | A1            | 0.10        | -   | 0.30 |  |
| Overall Width            | E             | 10.30 BSC   |     |      |  |
| Molded Package Width     | E1            | 7.50 BSC    |     |      |  |
| Overall Length           | D             | 17.90 BSC   |     |      |  |
| Chamfer (optional)       | h             | 0.25 – 0.75 |     |      |  |
| Foot Length              | L             | 0.40        | -   | 1.27 |  |
| Footprint L1             |               | 1.40 REF    |     |      |  |
| Foot Angle Top           | φ             | 0°          | _   | 8°   |  |
| Lead Thickness           | С             | 0.18        | _   | 0.33 |  |
| Lead Width               | b             | 0.31        | _   | 0.51 |  |
| Mold Draft Angle Top     |               | 5°          | _   | 15°  |  |
| Mold Draft Angle Bottom  |               | 5°          | _   | 15°  |  |

Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. § Significant Characteristic.

3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.15 mm per side.

4. Dimensioning and tolerancing per ASME Y14.5M.

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-052B