



Welcome to E-XFL.COM

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

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

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

#### Details

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

Email: info@E-XFL.COM

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

# 3.1 Power-on Reset (POR)

A Power-on Reset pulse is generated on-chip when VDD rise is detected. To take advantage of the POR circuitry, tie the MCLR pin through a 1 k $\Omega$  to 10 k $\Omega$  resistor to VDD. This will eliminate external RC components usually needed to create a Power-on Reset delay. A minimum rise rate for VDD is specified (parameter D004). For a slow rise time, see Figure 3-2.

When the device starts normal operation (i.e., exits the Reset condition), device operating parameters (voltage, frequency, temperature, etc.) 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.

FIGURE 3-2: EXTERNAL POWER-ON RESET CIRCUIT (FOR SLOW VDD POWER-UP)



# 3.2 Power-up Timer (PWRT)

The Power-up Timer provides a fixed nominal time-out (parameter 33) only on power-up 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 parameter 33 for details.

# 3.3 Oscillator Start-up Timer (OST)

The Oscillator Start-up Timer (OST) provides a 1024 oscillator cycle (from OSC1 input) delays after the PWRT delay is over (parameter 32). This ensures 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.

# 3.4 PLL Lock Time-out

With the PLL enabled, the time-out sequence following a Power-on Reset is different from other oscillator modes. A portion of the Power-up Timer is used to provide a fixed time-out that is sufficient for the PLL to lock to the main oscillator frequency. This PLL lock time-out (TPLL) is typically 2 ms and follows the oscillator start-up time-out.

# 3.5 Brown-out Reset (BOR)

A configuration bit, BOR, can disable (if clear/ programmed) or enable (if set) the Brown-out Reset circuitry. If VDD falls below parameter D005 for greater than parameter 35, the brown-out situation will reset the chip. A Reset may not occur if VDD falls below parameter D005 for less than parameter 35. The chip will remain in Brown-out Reset until VDD rises above BVDD. If the Power-up Timer is enabled, it will be invoked after VDD rises above BVDD; it then will keep the chip in Reset for an additional time delay (parameter 33). If VDD drops below BVDD while the Power-up Timer is running, the chip will go back into a Brown-out Reset and the Power-up Timer will be initialized. Once VDD rises above BVDD, the Power-up Timer will execute the additional time delay.

# 3.6 Time-out Sequence

On power-up, the time-out sequence is as follows: First, PWRT time-out is invoked after the POR time delay has expired. Then, OST is activated. The total time-out will vary based on oscillator configuration and the status of the PWRT. For example, in RC mode with the PWRT disabled, there will be no time-out at all. Figure 3-3, Figure 3-4, Figure 3-5, Figure 3-6 and Figure 3-7 depict time-out sequences on power-up.

Since the time-outs occur from the POR pulse, the time-outs will expire if MCLR is kept low long enough. Bringing MCLR high will begin execution immediately (Figure 3-5). This is useful for testing purposes or to synchronize more than one PIC18F6525/6621/8525/ 8621 device operating in parallel.

Table 3-2 shows the Reset conditions for some Special Function Registers, while Table 3-3 shows the Reset conditions for all of the registers.

| REGISTER 4-2: | STKPTR: S                                       | STACK POIN            | TER REG            | ISTER        |             |              |       |       |  |  |
|---------------|-------------------------------------------------|-----------------------|--------------------|--------------|-------------|--------------|-------|-------|--|--|
|               | R/C-0                                           | R/C-0                 | U-0                | R/W-0        | R/W-0       | R/W-0        | R/W-0 | R/W-0 |  |  |
|               | STKFUL <sup>(1)</sup>                           | STKUNF <sup>(1)</sup> | _                  | SP4          | SP3         | SP2          | SP1   | SP0   |  |  |
|               | bit 7                                           |                       |                    |              |             |              |       | bit 0 |  |  |
|               |                                                 |                       |                    |              |             |              |       |       |  |  |
| bit 7         | STKFUL: S                                       | tack Full Flag I      | oit <sup>(1)</sup> |              |             |              |       |       |  |  |
|               | 1 = Stack became full or overflowed             |                       |                    |              |             |              |       |       |  |  |
|               | 0 = Stack ha                                    | as not become         | full or over       | flowed       |             |              |       |       |  |  |
| bit 6         | STKUNF: Stack Underflow Flag bit <sup>(1)</sup> |                       |                    |              |             |              |       |       |  |  |
|               | 1 = Stack u                                     | nderflow occur        | red                |              |             |              |       |       |  |  |
|               | 0 = Stack u                                     | nderflow did no       | ot occur           |              |             |              |       |       |  |  |
| bit 5         | Unimpleme                                       | ented: Read as        | <b>6</b> '0'       |              |             |              |       |       |  |  |
| bit 4-0       | SP4:SP0: S                                      | Stack Pointer Lo      | ocation bits       | ;            |             |              |       |       |  |  |
|               | Note 1:                                         | Bit 7 and bit 6       | can only be        | e cleared in | user softwa | re or by a P | OR.   |       |  |  |
|               |                                                 |                       |                    |              |             |              |       |       |  |  |

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

# FIGURE 4-4: RETURN ADDRESS STACK AND ASSOCIATED REGISTERS



# 4.2.3 PUSH AND POP INSTRUCTIONS

Since the Top-of-Stack (TOS) is readable and writable, the ability to push values onto the stack and pull values off the stack, without disturbing normal program execution, is a desirable option. To push the current PC value onto the stack, a PUSH instruction can be executed. This will increment the Stack Pointer and load the current PC value onto the stack. TOSU, TOSH and TOSL can then be modified to place a return address on the stack.

The ability to pull the TOS value off of the stack and replace it with the value that was previously pushed onto the stack, without disturbing normal execution, is achieved by using the POP instruction. The POP instruction discards the current TOS by decrementing the Stack Pointer. The previous value pushed onto the stack then becomes the TOS value.

# 4.2.4 STACK FULL/UNDERFLOW RESETS

These Resets are enabled by programming the STVREN configuration bit. When the STVREN bit is disabled, a full or underflow condition will set the appropriate STKFUL or STKUNF bit, but not cause a device Reset. When the STVREN bit is enabled, a full or underflow condition will set the appropriate STKFUL or STKUNF bit and then cause a device Reset. The STKFUL or STKUNF bits are only cleared by the user software or a Power-on Reset.

© 2003-2013 Microchip Technology Inc.

bit bit

bit

bit

bit

|  | REGISTER 9-12: | <b>IPR3: PERIPHERAL INTERRUPT PRIORITY REGISTER 3</b> |
|--|----------------|-------------------------------------------------------|
|--|----------------|-------------------------------------------------------|

|   | U-0                                                                                     | U-0               | R/W-1           | R/W-1        | R/W-1  | R/W-1  | R/W-1  | R/W-1  |  |  |  |
|---|-----------------------------------------------------------------------------------------|-------------------|-----------------|--------------|--------|--------|--------|--------|--|--|--|
|   | _                                                                                       | —                 | RC2IP           | TX2IP        | TMR4IP | CCP5IP | CCP4IP | CCP3IP |  |  |  |
| - | bit 7                                                                                   |                   |                 |              |        |        |        | bit 0  |  |  |  |
|   | Unimplem                                                                                | ented: Read       | <b>l as</b> '0' |              |        |        |        |        |  |  |  |
|   | RC2IP: US                                                                               | ART2 Recei        | ve Interrupt    | Priority bit |        |        |        |        |  |  |  |
|   | 1 = High priority<br>0 = Low priority                                                   |                   |                 |              |        |        |        |        |  |  |  |
|   | TX2IP: USA                                                                              | ART2 Transı       | nit Interrupt   | Priority bit |        |        |        |        |  |  |  |
|   | 1 = High pi0 = Low pr                                                                   | riority<br>iority |                 |              |        |        |        |        |  |  |  |
|   | <b>TMR4IP</b> : TMR4 to PR4 Match Interrupt Priority bit 1 = High priority              |                   |                 |              |        |        |        |        |  |  |  |
|   | 0 = 1000 priority<br><b>CCPxIP</b> : CCPx Interrupt Priority bit (ECCP3, CCP4 and CCP5) |                   |                 |              |        |        |        |        |  |  |  |
|   | 1 = High p<br>0 = Low pr                                                                | riority<br>iority | <b>,</b>        | (, _         |        |        |        |        |  |  |  |
| [ | 1 = High p<br>0 = Low pr<br>Legend:                                                     | iority            |                 |              |        |        |        |        |  |  |  |

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

| Name          | Bit#  | Buffer | Function                                                                       |
|---------------|-------|--------|--------------------------------------------------------------------------------|
| RA0/AN0       | bit 0 | TTL    | Input/output or analog input.                                                  |
| RA1/AN1       | bit 1 | TTL    | Input/output or analog input.                                                  |
| RA2/AN2/VREF- | bit 2 | TTL    | Input/output, analog input or VREF                                             |
| RA3/AN3/VREF+ | bit 3 | TTL    | Input/output, analog input or VREF+.                                           |
| RA4/T0CKI     | bit 4 | ST     | Input/output or external clock input for Timer0.<br>Output is open-drain type. |
| RA5/AN4/LVDIN | bit 5 | TTL    | Input/output, analog input or Low-Voltage Detect input.                        |
| OSC2/CLKO/RA6 | bit 6 | TTL    | OSC2, clock output or I/O pin                                                  |

# TABLE 10-1: PORTA FUNCTIONS

Legend: TTL = TTL input, ST = Schmitt Trigger input

#### TABLE 10-2: SUMMARY OF REGISTERS ASSOCIATED WITH PORTA

| Name   | Bit 7 | Bit 6                 | Bit 5   | Bit 4                         | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|--------|-------|-----------------------|---------|-------------------------------|-------|-------|-------|-------|----------------------|---------------------------------|
| PORTA  | —     | RA6 <sup>(1)</sup>    | RA5     | RA4                           | RA3   | RA2   | RA1   | RA0   | -x0x 0000            | -u0u 0000                       |
| LATA   | —     | LATA6 <sup>(1)</sup>  | LATA Da | ATA Data Output Register      |       |       |       |       |                      | -uuu uuuu                       |
| TRISA  | _     | TRISA6 <sup>(1)</sup> | PORTA [ | PORTA Data Direction Register |       |       |       |       | -111 1111            | -111 1111                       |
| ADCON1 | _     | _                     | VCFG1   | VCFG0                         | PCFG3 | PCFG2 | PCFG1 | PCFG0 | 00 0000              | 00 0000                         |

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

**Note 1:** RA6 and associated bits are configured as port pins in RCIO and ECIO Oscillator modes only and read '0' in all other oscillator modes.

| Name    | Bit#  | Buffer Type | Function                                                                             |
|---------|-------|-------------|--------------------------------------------------------------------------------------|
| RJ0/ALE | bit 0 | ST          | Input/output port pin or address latch enable control for external memory interface. |
| RJ1/OE  | bit 1 | ST          | Input/output port pin or output enable control for external memory interface.        |
| RJ2/WRL | bit 2 | ST          | Input/output port pin or write low byte control for external memory interface.       |
| RJ3/WRH | bit 3 | ST          | Input/output port pin or write high byte control for external memory interface.      |
| RJ4/BA0 | bit 4 | ST          | Input/output port pin or byte address 0 control for external memory interface.       |
| RJ5/CE  | bit 5 | ST          | Input/output port pin or chip enable control for external memory interface.          |
| RJ6/LB  | bit 6 | ST          | Input/output port pin or lower byte select control for external memory interface.    |
| RJ7/UB  | bit 7 | ST          | Input/output port pin or upper byte select control for external memory interface.    |

# TABLE 10-17: PORTJ FUNCTIONS

**Legend:** ST = Schmitt Trigger input

# TABLE 10-18: SUMMARY OF REGISTERS ASSOCIATED WITH PORTJ

| Name  | Bit 7     | Bit 6                                     | Bit 5 | Bit 4     | Bit 3     | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|-------|-----------|-------------------------------------------|-------|-----------|-----------|-------|-------|-------|----------------------|---------------------------------|
| PORTJ | Read PC   | )RTJ pin/                                 |       | xxxx xxxx | uuuu uuuu |       |       |       |                      |                                 |
| LATJ  | LATJ Da   | LATJ Data Output Register                 |       |           |           |       |       |       | XXXX XXXX            | uuuu uuuu                       |
| TRISJ | Data Dire | Data Direction Control Register for PORTJ |       |           |           |       |       |       | 1111 1111            | 1111 1111                       |

**Legend:** x = unknown, u = unchanged

# 12.0 TIMER1 MODULE

The Timer1 module timer/counter has the following features:

- 16-bit timer/counter (two 8-bit registers: TMR1H and TMR1L)
- Readable and writable (both registers)
- Internal or external clock select
- Interrupt-on-overflow from FFFFh to 0000h
- Reset from ECCP module special event trigger

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

# REGISTER 12-1: T1CON: TIMER1 CONTROL REGISTER

| R/W-0 | U-0 | R/W-0   | R/W-0   | R/W-0   | R/W-0  | R/W-0  | R/W-0  |
|-------|-----|---------|---------|---------|--------|--------|--------|
| RD16  | _   | T1CKPS1 | T1CKPS0 | T1OSCEN | T1SYNC | TMR1CS | TMR1ON |
| bit 7 |     |         |         |         |        |        | bit 0  |

| bit 7   | RD16: 16-bit Read/Write N                                         | lode Enable bit        |                          |                    |  |  |  |  |  |
|---------|-------------------------------------------------------------------|------------------------|--------------------------|--------------------|--|--|--|--|--|
|         | 1 = Enables register read/v                                       | vrite of Timer1 in one | 16-bit operation         |                    |  |  |  |  |  |
|         | 0 = Enables register read/v                                       | vrite of Timer1 in two | 8-bit operations         |                    |  |  |  |  |  |
| bit 6   | Unimplemented: Read as                                            | '0'                    |                          |                    |  |  |  |  |  |
| bit 5-4 | 4 T1CKPS1:T1CKPS0: Timer1 Input Clock Prescale Select bits        |                        |                          |                    |  |  |  |  |  |
|         | 11 = 1:8 Prescale value                                           |                        |                          |                    |  |  |  |  |  |
|         | 10 = 1:4 Prescale value                                           |                        |                          |                    |  |  |  |  |  |
|         | 01 = 1:2 Prescale value                                           |                        |                          |                    |  |  |  |  |  |
|         | 00 = 1:1 Prescale value                                           |                        |                          |                    |  |  |  |  |  |
| bit 3   | T10SCEN: Timer1 Oscillat                                          | or Enable bit          |                          |                    |  |  |  |  |  |
|         | 1 = Timer1  oscillator is end                                     | abled                  |                          |                    |  |  |  |  |  |
|         | 0 = limer1 oscillator is shu                                      | ut off                 |                          |                    |  |  |  |  |  |
|         |                                                                   | and reedback resisto   | r are turned on to elimi | nate power drain.  |  |  |  |  |  |
| bit 2   | T1SYNC: Timer1 External Clock Input Synchronization Select bit    |                        |                          |                    |  |  |  |  |  |
|         | <u>When IMR1CS = 1:</u>                                           |                        |                          |                    |  |  |  |  |  |
|         | $\perp = D0 not synchronize external c$                           | lock input             |                          |                    |  |  |  |  |  |
|         | W hen TMP1CS = 0:                                                 |                        |                          |                    |  |  |  |  |  |
|         | This bit is ignored. Timer1                                       | uses the internal cloc | k when TMR1CS = 0.       |                    |  |  |  |  |  |
| bit 1   | TMR1CS: Timer1 Clock Sc                                           | ource Select bit       |                          |                    |  |  |  |  |  |
|         | 1 = External clock from pin RC0/T10S0/T13CKI (on the rising edge) |                        |                          |                    |  |  |  |  |  |
|         | 0 = Internal clock (Fosc/4)                                       |                        |                          |                    |  |  |  |  |  |
| bit 0   | TMR10N: Timer1 On bit                                             |                        |                          |                    |  |  |  |  |  |
|         | 1 = Enables Timer1                                                |                        |                          |                    |  |  |  |  |  |
|         | 0 = Stops Timer1                                                  |                        |                          |                    |  |  |  |  |  |
|         |                                                                   |                        |                          |                    |  |  |  |  |  |
|         | Legend:                                                           |                        |                          |                    |  |  |  |  |  |
|         | R = Readable bit                                                  | W = Writable bit       | U = Unimplemented        | l bit, read as '0' |  |  |  |  |  |
|         | -n = Value at POR                                                 | '1' = Bit is set       | '0' = Bit is cleared     | x = Bit is unknown |  |  |  |  |  |

Register 12-1 details the Timer1 Control register. This register controls the operating mode of the Timer1 module and contains the Timer1 oscillator enable bit (T10SCEN). Timer1 can be enabled or disabled by setting or clearing control bit, TMR10N (T1CON<0>).

Timer1 can also be used to provide Real-Time Clock (RTC) functionality to applications with only a minimal addition of external components and code overhead.

# 13.0 TIMER2 MODULE

The Timer2 module timer has the following features:

- 8-bit timer (TMR2 register)
- 8-bit period register (PR2)
- Readable and writable (both registers)
- Software programmable prescaler (1:1, 1:4, 1:16)
- Software programmable postscaler (1:1 to 1:16)
- Interrupt on TMR2 match of PR2
- MSSP module optional use of TMR2 output to generate clock shift

Timer2 has a control register shown in Register 13-1. Timer2 can be shut off by clearing control bit TMR2ON (T2CON<2>) to minimize power consumption. Figure 13-1 is a simplified block diagram of the Timer2 module. Register 13-1 shows the Timer2 Control register. The prescaler and postscaler selection of Timer2 are controlled by this register.

# 13.1 Timer2 Operation

Timer2 can be used as the PWM time base for the PWM mode of the ECCP module. The TMR2 register is readable and writable and is cleared on any device Reset. The input clock (FOSC/4) has a prescale option of 1:1, 1:4 or 1:16, selected by control bits T2CKPS1:T2CKPS0 (T2CON<1:0>). The match output of TMR2 goes through a 4-bit postscaler (which gives a 1:1 to 1:16 scaling inclusive) to generate a TMR2 interrupt, latched in flag bit TMR2IF (PIR1<1>).

The prescaler and postscaler counters are cleared when any of the following occurs:

- · a write to the TMR2 register
- a write to the T2CON register
- any device Reset (Power-on Reset, MCLR Reset, Watchdog Timer Reset, or Brown-out Reset)

TMR2 is not cleared when T2CON is written.

# REGISTER 13-1: T2CON: TIMER2 CONTROL REGISTER

| U-0   | R/W-0    | R/W-0    | R/W-0    | R/W-0    | R/W-0  | R/W-0   | R/W-0   |
|-------|----------|----------|----------|----------|--------|---------|---------|
|       | T2OUTPS3 | T2OUTPS2 | T2OUTPS1 | T2OUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 |
| bit 7 |          |          |          |          |        |         | bit 0   |

#### bit 7 Unimplemented: Read as '0'



|     | 0000 = 1:1 Postscale                               |
|-----|----------------------------------------------------|
|     | 0001 = 1:2 Postscale                               |
|     | •                                                  |
|     | •                                                  |
|     | •                                                  |
|     | 1111 = 1:16 Postscale                              |
| 2   | TMR2ON: Timer2 On bit                              |
|     | 1 = Timer2 is on                                   |
|     | 0 = Timer2 is off                                  |
| 1-0 | T2CKPS1:T2CKPS0: Timer2 Clock Prescale Select bits |

- 00 = Prescaler is 1
- 01 =Prescaler is 4
- 1x = Prescaler is 16

# Legend:

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

bit

bit

| ECCP Mode                                                            | CCP2CON<br>Configuration | RB3      | RC1       | RE7      | RE2    | RE1    | RE0    |  |  |
|----------------------------------------------------------------------|--------------------------|----------|-----------|----------|--------|--------|--------|--|--|
| All devices, CCP2MX = 1, Microcontroller mode:                       |                          |          |           |          |        |        |        |  |  |
| Compatible CCP                                                       | 00xx 11xx                | RB3/INT3 | ECCP2     | RE7      | RE2    | RE1    | RE0    |  |  |
| Dual PWM                                                             | 10xx 11xx                | RB3/INT3 | P2A       | RE7      | P2B    | RE1    | RE0    |  |  |
| Quad PWM                                                             | x1xx 11xx                | RB3/INT3 | P2A       | RE7      | P2B    | P2C    | P2D    |  |  |
| All devices, CCP2MX = 0, Microcontroller mode:                       |                          |          |           |          |        |        |        |  |  |
| Compatible CCP                                                       | 00xx 11xx                | RB3/INT3 | RC1/T1OS1 | ECCP2    | RE2    | RE1    | RE0    |  |  |
| Dual PWM                                                             | 10xx 11xx                | RB3/INT3 | RC1/T1OS1 | P2A      | P2B    | RE1    | RE0    |  |  |
| Quad PWM                                                             | x1xx 11xx                | RB3/INT3 | RC1/T1OS1 | P2A      | P2B    | P2C    | P2D    |  |  |
| PIC18F8525/8621 devices, CCP2MX = 0, all other Program Memory modes: |                          |          |           |          |        |        |        |  |  |
| Compatible CCP                                                       | 00xx 11xx                | ECCP2    | RC1/T1OS1 | RE7/AD15 | RE2/CS | RE1/WR | RE0/RD |  |  |
| Dual PWM                                                             | 10xx 11xx                | P2A      | RC1/T1OS1 | RE7/AD15 | P2B    | RE1/WR | RE0/RD |  |  |
| Quad PWM                                                             | x1xx 11xx                | P2A      | RC1/T1OS1 | RE7/AD15 | P2B    | P2C    | P2D    |  |  |

# TABLE 17-2: PIN CONFIGURATIONS FOR ECCP2

Legend: x = Don't care. Shaded cells indicate pin assignments not used by ECCP2 in a given mode.

## TABLE 17-3: PIN CONFIGURATIONS FOR ECCP3

| ECCP Mode                                                  | CCP3CON<br>Configuration | RG0          | RE4           | RE3            | RG3           | RH5      | RH4      |
|------------------------------------------------------------|--------------------------|--------------|---------------|----------------|---------------|----------|----------|
|                                                            |                          | All F        | PIC18F6525/66 | 21 devices:    |               |          |          |
| Compatible CCP                                             | 00xx 11xx                | ECCP3        | RE4           | RE3            | RG3/CCP4      | N/A      | N/A      |
| Dual PWM                                                   | 10xx 11xx                | P3A          | P3B           | RE3            | RG3/CCP4      | N/A      | N/A      |
| Quad PWM                                                   | x1xx 11xx                | P3A          | P3B           | P3C            | P3D           | N/A      | N/A      |
| PIC18F8525/8621 devices, ECCPMX = 1, Microcontroller mode: |                          |              |               |                |               |          |          |
| Compatible CCP                                             | 00xx 11xx                | ECCP3        | RE4/AD12      | RE3/AD11       | RG3/CCP4      | RH5/AN13 | RH4/AN12 |
| Dual PWM                                                   | 10xx 11xx                | P3A          | P3B           | RE3/AD11       | RG3/CCP4      | RH5/AN13 | RH4/AN12 |
| Quad PWM                                                   | x1xx 11xx                | P3A          | P3B           | P3C            | P3D           | RH5/AN13 | RH4/AN12 |
|                                                            | PIC18F8                  | 525/8621 dev | vices, ECCPM  | X = 0, Microc  | ontroller mod | le:      |          |
| Compatible CCP                                             | 00xx 11xx                | ECCP3        | RE6/AD14      | RE5/AD13       | RG3/CCP4      | RH7/AN15 | RH6/AN14 |
| Dual PWM                                                   | 10xx 11xx                | P3A          | RE6/AD14      | RE5/AD13       | RG3/CCP4      | P3B      | RH6/AN14 |
| Quad PWM                                                   | x1xx 11xx                | P3A          | RE6/AD14      | RE5/AD13       | P3D           | P3B      | P3C      |
|                                                            | PIC18F8525/86            | 621 devices, | ECCPMX = 1,   | all other Prog | gram Memory   | modes:   |          |
| Compatible CCP                                             | 00xx 11xx                | ECCP3        | RE6/AD14      | RE5/AD13       | RG3/CCP4      | RH7/AN15 | RH6/AN14 |

Legend: x = Don't care, N/A = Not available. Shaded cells indicate pin assignments not used by ECCP3 in a given mode.
 Note 1: With ECCP3 in Quad PWM mode, CCP4's output is overridden by P1D; otherwise CCP4 is fully operational.

## 18.4.6 MASTER MODE

Master mode is enabled by setting and clearing the appropriate SSPM bits in SSPCON1 and by setting the SSPEN bit. In Master mode, the SCL and SDA lines are manipulated by the MSSP hardware.

Master mode of operation is supported by interrupt generation on the detection of the Start and Stop conditions. The Stop (P) and Start (S) bits are cleared from a Reset or when the MSSP module is disabled. Control of the  $I^2C$  bus may be taken when the P bit is set or the bus is Idle, with both the S and P bits clear.

In Firmware Controlled Master mode, user code conducts all  ${\rm I}^2{\rm C}$  bus operations based on Start and Stop bit conditions.

Once Master mode is enabled, the user has six options.

- 1. Assert a Start condition on SDA and SCL.
- 2. Assert a Repeated Start condition on SDA and SCL.
- 3. Write to the SSPBUF register initiating transmission of data/address.
- 4. Configure the I<sup>2</sup>C port to receive data.
- 5. Generate an Acknowledge condition at the end of a received byte of data.
- 6. Generate a Stop condition on SDA and SCL.

# Note: The MSSP module, when configured in I<sup>2</sup>C Master mode, does not allow queueing of events. For instance, the user is not allowed to initiate a Start condition and immediately write the SSPBUF register to initiate transmission before the Start condition is complete. In this case, the SSPBUF will not be written to and the WCOL bit will be set, indicating that a write to the SSPBUF did not occur.

The following events will cause MSSP Interrupt Flag bit, SSPIF, to be set (MSSP interrupt, if enabled):

- Start condition
- Stop condition
- Data transfer byte transmitted/received
- Acknowledge transmit
- Repeated Start



# © 2003-2013 Microchip Technology Inc.

| TABLE 18-4: | <b>REGISTERS ASSOCIATED WITH I<sup>2</sup>C™ OPERATION</b> |  |
|-------------|------------------------------------------------------------|--|
|-------------|------------------------------------------------------------|--|

| Name    | Bit 7                                                                                                                  | Bit 6     | Bit 5     | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0       | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|---------|------------------------------------------------------------------------------------------------------------------------|-----------|-----------|--------|--------|--------|--------|-------------|----------------------|---------------------------------|
| INTCON  | GIE/GIEH                                                                                                               | PEIE/GIEL | TMR0IE    | INT0IE | RBIE   | TMR0IF | INT0IF | RBIF        | 0000 000x            | 0000 000u                       |
| PIR1    | PSPIF <sup>(1)</sup>                                                                                                   | ADIF      | RC1IF     | TX1IF  | SSPIF  | CCP1IF | TMR2IF | TMR1IF      | 0000 0000            | 0000 0000                       |
| PIE1    | PSPIE <sup>(1)</sup>                                                                                                   | ADIE      | RC1IE     | TX1IE  | SSPIE  | CCP1IE | TMR2IE | TMR1IE      | 0000 0000            | 0000 0000                       |
| IPR1    | PSPIP <sup>(1)</sup>                                                                                                   | ADIP      | RC1IP     | TX1IP  | SSPIP  | CCP1IP | TMR2IP | TMR1IP      | 1111 1111            | 1111 1111                       |
| TRISC   | PORTC Data                                                                                                             | 1111 1111 | 1111 1111 |        |        |        |        |             |                      |                                 |
| TRISF   | TRISF7                                                                                                                 | TRISF6    | TRISF5    | TRISF4 | TRISF3 | TRISF2 | TRISF1 | TRISF0      | 1111 1111            | 1111 1111                       |
| SSPBUF  | MSSP Receive Buffer/Transmit Register                                                                                  |           |           |        |        |        |        |             |                      | uuuu uuuu                       |
| SSPADD  | D MSSP Address Register in I <sup>2</sup> C Slave mode. MSSP Baud Rate Reload Register in I <sup>2</sup> C Master mode |           |           |        |        |        |        | aster mode. | 0000 0000            | 0000 0000                       |
| SSPCON1 | WCOL                                                                                                                   | SSPOV     | SSPEN     | CKP    | SSPM3  | SSPM2  | SSPM1  | SSPM0       | 0000 0000            | 0000 0000                       |
| SSPSTAT | SMP                                                                                                                    | CKE       | D/A       | Р      | S      | R/W    | UA     | BF          | 0000 0000            | 0000 0000                       |

**Legend:** x = unknown, u = unchanged, --- = unimplemented, read as '0'. Shaded cells are not used by the MSSP in I<sup>2</sup>C<sup>TM</sup> mode.

**Note 1:** Enabled only in Microcontroller mode for PIC18F8525/8621 devices.

## 19.3.2 EUSART SYNCHRONOUS MASTER RECEPTION

Once Synchronous mode is selected, reception is enabled by setting either the Single Receive Enable bit, SREN (RCSTAx<5>), or the Continuous Receive Enable bit, CREN (RCSTAx<4>). Data is sampled on the RXx pin on the falling edge of the clock.

If enable bit SREN is set, only a single word is received. If enable bit CREN is set, the reception is continuous until CREN is cleared. If both bits are set, then CREN takes precedence.

To set up a Synchronous Master Reception:

- 1. Initialize the SPBRGHx:SPBRGx registers for the appropriate baud rate. Set or clear the BRG16 bit, as required, to achieve the desired baud rate.
- 2. Enable the synchronous master serial port by setting bits SYNC, SPEN and CSRC.

- 3. Ensure bits CREN and SREN are clear.
- 4. If interrupts are desired, set enable bit RCxIE.
- 5. If 9-bit reception is desired, set bit RX9.
- 6. If a single reception is required, set bit SREN. For continuous reception, set bit CREN.
- 7. Interrupt flag bit RCxIF will be set when reception is complete and an interrupt will be generated if the enable bit RCxIE was set.
- 8. Read the RCSTAx register to get the 9th bit (if enabled) and determine if any error occurred during reception.
- 9. Read the 8-bit received data by reading the RCREGx register.
- 10. If any error occurred, clear the error by clearing bit CREN.
- If using interrupts, ensure that the GIE and PEIE bits in the INTCON register (INTCON<7:6>) are set.

|                               |                    | 1-1-1         |   |                    |   |                  |   |               |   |                  | 1 | 1          |   | 1-1         |    | 1-1-        |       | 1-1-             | · · ·       |
|-------------------------------|--------------------|---------------|---|--------------------|---|------------------|---|---------------|---|------------------|---|------------|---|-------------|----|-------------|-------|------------------|-------------|
| pin                           | ÷                  | bit 0         | X | bit 1              | Х | bit 2            | Х | bit 3         | Х | bit 4            | Х | bit 5      | X | bit 6       | Х. | 1<br>1<br>1 | bit 7 | ,<br>,<br>,      |             |
| RC7/TX1/CK1 pin<br>(SCKP = 0) | <u> </u>           | <u>.</u><br>: |   | <u>.</u>           |   |                  |   | <u>.</u><br>: |   | <u>.</u>         |   | <u>-</u>   |   | <u>-</u>    |    | ÷           |       | 1<br>1<br>1      |             |
| RC7/TX1/CK1 pin<br>(SCKP = 1) | <u>:</u><br>: L    | ÷             |   |                    |   |                  |   | :<br>         |   | ;<br>:           |   | Ļ          |   | ÷           |    | <u>.</u>    |       | 1<br>1<br>1      |             |
| Write to<br>bit SREN          | <u>.</u>           | 1<br>1<br>1   |   | 1<br>1<br>1        |   | 1                |   | 1<br>1<br>1   |   | 1<br>1<br>1<br>1 |   | 1<br>      |   | •<br>•<br>• |    | 1<br>1<br>1 |       | 1<br>1<br>1<br>1 |             |
| SREN bit                      | ·<br>·             | 1             |   |                    |   | 1                |   |               |   |                  |   | •          |   | ;           |    | <u> </u>    |       |                  |             |
| CREN bit <u>'0'</u>           | 1<br>1             | ·<br>·        |   | 1<br>1             |   | 1<br>1           |   | 1<br>1<br>1   |   | 1<br>1<br>1      |   | <u>.</u>   |   | 1           |    | 1<br>1      |       | •<br>•           | <b>'</b> 0' |
| RC1IF bit<br>(Interrupt)———   | 1<br>1<br>1        |               |   | •<br>•             |   |                  |   | 1<br>1        |   | 1<br>1           |   | 1<br>1<br> |   | ,<br>,      |    | 1<br>1<br>1 |       | •<br>•           | ~           |
| Read<br>RXREG1 ———            | 1<br>1<br><u>1</u> |               |   | 1<br>1<br><u>1</u> |   | 1<br>1<br>1<br>1 |   | ,<br>,<br>,   |   | ,<br>,<br>,      |   |            |   | •<br>•<br>• |    | •<br>•<br>• |       | ÷ď               |             |

## FIGURE 19-12: SYNCHRONOUS RECEPTION (MASTER MODE, SREN)

# 23.0 LOW-VOLTAGE DETECT

In many applications, the ability to determine if the device voltage (VDD) is below a specified voltage level is a desirable feature. A window of operation for the application can be created, where the application software can do "housekeeping tasks" before the device voltage exits the valid operating range. This can be done using the Low-Voltage Detect module.

This module is a software programmable circuitry, where a device voltage trip point can be specified. When the voltage of the device becomes lower then the specified point, an interrupt flag is set. If the interrupt is enabled, the program execution will branch to the interrupt vector address and the software can then respond to that interrupt source. The Low-Voltage Detect circuitry is completely under software control. This allows the circuitry to be "turned off" by the software which minimizes the current consumption for the device.

Figure 23-1 shows a possible application voltage curve (typically for batteries). Over time, the device voltage decreases. When the device voltage equals voltage VA, the LVD logic generates an interrupt. This occurs at time TA. The application software then has the time, until the device voltage is no longer in valid operating range, to shutdown the system. Voltage point VB is the minimum valid operating voltage specification. This occurs at time TB. The difference TB – TA is the total time for shutdown.





The block diagram for the LVD module is shown in Figure 23-2. A comparator uses an internally generated reference voltage as the set point. When the selected tap output of the device voltage crosses the set point (is lower than), the LVDIF bit is set.

Each node in the resistor divider represents a "trip point" voltage. The "trip point" voltage is the minimum supply voltage level at which the device can operate before the LVD module asserts an interrupt. When the supply voltage is equal to the trip point, the voltage tapped off of the resistor array is equal to the 1.2V internal reference voltage generated by the voltage reference module. The comparator then generates an interrupt signal setting the LVDIF bit. This voltage is software programmable to any one of 16 values (see Figure 23-2). The trip point is selected by programming the LVDL3:LVDL0 bits (LVDCON<3:0>).

NOTES:

# 24.3 Power-Down Mode (Sleep)

Power-down mode is entered by executing a  $\ensuremath{\mathtt{SLEEP}}$  instruction.

If enabled, the Watchdog Timer will be cleared but keeps running, the PD bit (RCON<3>) is cleared, the TO (RCON<4>) bit is set and the oscillator driver is turned off. The I/O ports maintain the status they had before the SLEEP instruction was executed (driving high, low or high-impedance).

For lowest current consumption in this mode, place all I/O pins at either VDD or VSS, ensure no external circuitry is drawing current from the I/O pin, power-down the A/D and disable external clocks. Pull all I/O pins that are high-impedance inputs, high or low externally, to avoid switching currents caused by floating inputs. The T0CKI input should also be at VDD or VSS for lowest current consumption. The contribution from on-chip pull-ups on PORTB should be considered.

The MCLR pin must be at a logic high level (VIHMC).

## 24.3.1 WAKE-UP FROM SLEEP

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

- 1. External Reset input on  $\overline{\text{MCLR}}$  pin.
- 2. Watchdog Timer wake-up (if WDT was enabled).
- 3. Interrupt from INTx pin, RB port change or a peripheral interrupt.

The following peripheral interrupts can wake the device from Sleep:

- 1. PSP read or write.
- 2. TMR1 interrupt. Timer1 must be operating as an asynchronous counter.
- 3. TMR3 interrupt. Timer3 must be operating as an asynchronous counter.
- 4. CCP Capture mode interrupt (Capture will not occur).
- 5. MSSP (Start/Stop) bit detect interrupt.
- MSSP transmit or receive in Slave mode (SPI/I<sup>2</sup>C).
- 7. USART RXx or TXx (Synchronous Slave mode).
- 8. A/D conversion (when A/D clock source is RC).
- 9. EEPROM write operation complete.
- 10. LVD interrupt.

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

External MCLR Reset will cause a device Reset. All other events are considered a continuation of program execution and will cause a "wake-up". The TO and PD bits in the RCON register can be used to determine the cause of the device Reset. The PD bit, which is set on power-up, is cleared when Sleep is invoked. The TO bit is cleared if a WDT time-out occurred (and caused wake-up).

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

#### 24.3.2 WAKE-UP USING INTERRUPTS

When global interrupts are disabled (GIE cleared) and any interrupt source has both its interrupt enable bit and interrupt flag bit set, one of the following will occur:

- If an interrupt condition (interrupt flag bit and interrupt enable bits are set) occurs before the execution of a SLEEP instruction, the SLEEP instruction will complete as a NOP. Therefore, the WDT and WDT postscaler will not be cleared, the TO bit will not be set and PD bits will not be cleared.
- If the interrupt condition occurs during or after the execution of a SLEEP instruction, the device will immediately wake-up from Sleep. The SLEEP instruction will be completely executed before the wake-up. Therefore, the WDT and WDT postscaler will be cleared, the TO bit will be set and the PD bit will be cleared.

Even if the flag bits were checked before executing a SLEEP instruction, it may be possible for flag bits to become set before the SLEEP instruction completes. To determine whether a SLEEP instruction executed, test the PD bit. If the PD bit is set, the SLEEP instruction was executed as a NOP.

To ensure that the WDT is cleared, a CLRWDT instruction should be executed before a SLEEP instruction.

| POF      | 2                                 | Рор Тор                                                                                             | Pop Top of Return Stack                                                                    |                                                                                                  |                                                                              |  |  |  |  |  |  |  |
|----------|-----------------------------------|-----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Synt     | ax:                               | [label] F                                                                                           | POP                                                                                        |                                                                                                  |                                                                              |  |  |  |  |  |  |  |
| Oper     | rands:                            | None                                                                                                | None                                                                                       |                                                                                                  |                                                                              |  |  |  |  |  |  |  |
| Ope      | ration:                           | $(TOS) \rightarrow b$                                                                               | $(TOS) \rightarrow bit bucket$                                                             |                                                                                                  |                                                                              |  |  |  |  |  |  |  |
| Statu    | us Affected:                      | None                                                                                                | None                                                                                       |                                                                                                  |                                                                              |  |  |  |  |  |  |  |
| Enco     | oding:                            | 0000                                                                                                | 0000                                                                                       | 0000                                                                                             | 0110                                                                         |  |  |  |  |  |  |  |
| Desc     | cription:                         | The TOS v<br>stack and i<br>then becon<br>was pushe<br>This instruct<br>the user to<br>stack to inc | alue is pu<br>s discard<br>nes the p<br>d onto the<br>ction is pr<br>properly<br>corporate | ulled off th<br>ed. The To<br>revious va<br>e return st<br>rovided to<br>manage th<br>a software | e return<br>OS value<br>Ilue that<br>ack.<br>enable<br>he return<br>e stack. |  |  |  |  |  |  |  |
| Word     | ds:                               | 1                                                                                                   |                                                                                            |                                                                                                  |                                                                              |  |  |  |  |  |  |  |
| Cycl     | es:                               | 1                                                                                                   |                                                                                            |                                                                                                  |                                                                              |  |  |  |  |  |  |  |
| QC       | cycle Activity:                   |                                                                                                     |                                                                                            |                                                                                                  |                                                                              |  |  |  |  |  |  |  |
|          | Q1                                | Q2                                                                                                  | Q3                                                                                         |                                                                                                  | Q4                                                                           |  |  |  |  |  |  |  |
|          | Decode                            | No                                                                                                  | POP T                                                                                      | OS                                                                                               | No                                                                           |  |  |  |  |  |  |  |
|          |                                   | operation                                                                                           | valu                                                                                       | e op                                                                                             | peration                                                                     |  |  |  |  |  |  |  |
| Example: |                                   | POP<br>GOTO                                                                                         | NEW                                                                                        |                                                                                                  |                                                                              |  |  |  |  |  |  |  |
|          | Before Instruc<br>TOS<br>Stack (1 | tion<br>=<br>level down)=                                                                           | 0031A<br>01433                                                                             | ∖2h<br>2h                                                                                        |                                                                              |  |  |  |  |  |  |  |
|          | After Instructio<br>TOS<br>PC     | on<br>=<br>=                                                                                        | 01433<br>NEW                                                                               | 2h                                                                                               |                                                                              |  |  |  |  |  |  |  |

| PUSH                                    | Push Top                                                                                  | Push Top of Return Stack                                                                                                                                                                                                                   |                   |                |  |  |  |  |  |  |
|-----------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------|--|--|--|--|--|--|
| Syntax:                                 | [label] P                                                                                 | [label] PUSH                                                                                                                                                                                                                               |                   |                |  |  |  |  |  |  |
| Operands:                               | None                                                                                      | None                                                                                                                                                                                                                                       |                   |                |  |  |  |  |  |  |
| Operation:                              | $(PC + 2) \rightarrow$                                                                    | TOS                                                                                                                                                                                                                                        |                   |                |  |  |  |  |  |  |
| Status Affected:                        | None                                                                                      |                                                                                                                                                                                                                                            |                   |                |  |  |  |  |  |  |
| Encoding:                               | 0000                                                                                      | 0000                                                                                                                                                                                                                                       | 0000              | 0101           |  |  |  |  |  |  |
| Description:                            | The PC + 2<br>the return s<br>value is pus<br>This instruc<br>software sta<br>then pushin | The PC + 2 is pushed onto the top of<br>the return stack. The previous TOS<br>value is pushed down on the stack.<br>This instruction allows implementing a<br>software stack by modifying TOS and<br>then pushing it onto the return stack |                   |                |  |  |  |  |  |  |
| Words:                                  | 1                                                                                         |                                                                                                                                                                                                                                            |                   |                |  |  |  |  |  |  |
| Cycles:                                 | 1                                                                                         |                                                                                                                                                                                                                                            |                   |                |  |  |  |  |  |  |
| Q Cycle Activity:                       |                                                                                           |                                                                                                                                                                                                                                            |                   |                |  |  |  |  |  |  |
| Q1                                      | Q2                                                                                        | Q                                                                                                                                                                                                                                          | 3                 | Q4             |  |  |  |  |  |  |
| Decode                                  | PUSH<br>PC + 2 onto<br>return stack                                                       | No<br>operat                                                                                                                                                                                                                               | ion o             | No<br>peration |  |  |  |  |  |  |
| Example:                                | PUSH                                                                                      |                                                                                                                                                                                                                                            |                   |                |  |  |  |  |  |  |
| Before Instru                           | ction                                                                                     |                                                                                                                                                                                                                                            |                   |                |  |  |  |  |  |  |
| TOS<br>PC                               | =<br>=                                                                                    | 00345<br>00012                                                                                                                                                                                                                             | iAh<br>14h        |                |  |  |  |  |  |  |
| After Instruct<br>PC<br>TOS<br>Stack (1 | ion<br>=<br>=<br>level down)=                                                             | 00012<br>00012<br>00345                                                                                                                                                                                                                    | 26h<br>26h<br>3Ah |                |  |  |  |  |  |  |





| Param.<br>No | Symbol   | Characteristics                         | Min            | Тур | Мах            | Units |
|--------------|----------|-----------------------------------------|----------------|-----|----------------|-------|
| 167          | Tacc     | Address Valid to Data Valid             | 0.75 Tcy – 25  | —   | —              | ns    |
| 168          | Тое      | $\overline{OE}\downarrow$ to Data Valid |                | _   | 0.5 Tcy – 25   | ns    |
| 169          | TalL2oeH | ALE ↓ to OE ↑                           | 0.625 Tcy – 10 | _   | 0.625 Tcy + 10 | ns    |
| 171          | TalH2csL | Chip Enable Active to ALE $\downarrow$  | —              | —   | 10             | ns    |
| 171A         | TubL2oeH | AD Valid to Chip Enable Active          | 0.25 Tcy - 20  | _   | _              | ns    |

#### **FIGURE 27-8:**

#### PROGRAM MEMORY WRITE TIMING DIAGRAM



| TABLE 27-10: | PROGRAM MEMORY WRITE TIMING REQUIREMENTS |
|--------------|------------------------------------------|
|--------------|------------------------------------------|

| Param.<br>No | Symbol   | Characteristics                                                    | Min Tyr       |         | Max | Units |
|--------------|----------|--------------------------------------------------------------------|---------------|---------|-----|-------|
| 150          | TadV2alL | Address Out Valid to ALE $\downarrow$ (address setup time)         | 0.25 Tcy – 10 | —       | _   | ns    |
| 151          | TalL2adl | ALE $\downarrow$ to Address Out Invalid (address hold time)        | 5             | —       | _   | ns    |
| 153          | TwrH2adl | WRn $\uparrow$ to Data Out Invalid (data hold time)                | 5             | —       |     | ns    |
| 154          | TwrL     | WRn Pulse Width                                                    | 0.5 TCY – 5   | 0.5 TCY |     | ns    |
| 156          | TadV2wrH | Data Valid before WRn ↑ (data setup time)                          | 0.5 Tcy – 10  | —       | _   | ns    |
| 157          | TbsV2wrL | Byte Select Valid before WRn $\downarrow$ (byte select setup time) | 0.25 TCY      | _       | _   | ns    |
| 157A         | TwrH2bsl | WRn $\uparrow$ to Byte Select Invalid (byte select hold time)      | 0.125 TCY – 5 | —       |     | ns    |
| 166          | TalH2alH | ALE $\uparrow$ to ALE $\uparrow$ (cycle time)                      |               | TCY     |     | ns    |

© 2003-2013 Microchip Technology Inc.



| TARI E 27-18.      | EXAMPLE SPITH SLAVE MODE REQUIREMENTS ( | (CKF = 1) |
|--------------------|-----------------------------------------|-----------|
| $IADLL ZI^{-10}$ . |                                         | ONL - I   |

| Param<br>No. | Symbol                | Characterist                                                           | Min                           | Max           | Units | Conditions |          |
|--------------|-----------------------|------------------------------------------------------------------------|-------------------------------|---------------|-------|------------|----------|
| 70           | TssL2scH,<br>TssL2scL | $\overline{SS} \downarrow$ to SCK $\downarrow$ or SCK $\uparrow$ Input | Тсү                           | —             | ns    |            |          |
| 71           | TscH                  | SCK Input High Time                                                    | Continuous                    | 1.25 TCY + 30 | —     | ns         |          |
| 71A          |                       | (Slave mode)                                                           | Single Byte                   | 40            |       | ns         | (Note 1) |
| 72           | TscL                  | SCK Input Low Time                                                     | Continuous                    | 1.25 Tcy + 30 |       | ns         |          |
| 72A          |                       | (Slave mode)                                                           | Single Byte                   | 40            |       | ns         | (Note 1) |
| 73A          | Тв2в                  | Last Clock Edge of Byte 1 to the Fir                                   | 1.5 Tcy + 40                  |               | ns    | (Note 2)   |          |
| 74           | TscH2diL,<br>TscL2diL | Hold Time of SDI Data Input to SO                                      | 100                           | —             | ns    |            |          |
| 75           | TdoR                  | SDO Data Output Rise Time                                              | PIC18F6525/6621/<br>8525/8621 | —             | 25    | ns         |          |
|              |                       |                                                                        | PIC18LF6X2X/8X2X              |               | 45    | ns         |          |
| 76           | TdoF                  | SDO Data Output Fall Time                                              |                               | —             | 25    | ns         |          |
| 77           | TssH2doZ              | SS ↑ to SDO Output High-impeda                                         | 10                            | 50            | ns    |            |          |
| 78           | TscR                  | SCK Output Rise Time<br>(Master mode)                                  | PIC18F6525/6621/<br>8525/8621 | —             | 25    | ns         |          |
|              |                       |                                                                        | PIC18LF6X2X/8X2X              | —             | 45    | ns         |          |
| 79           | TscF                  | SCK Output Fall Time (Master mo                                        | —                             | 25            | ns    |            |          |
| 80           | TscH2doV,<br>TscL2doV | /, SDO Data Output Valid after SCK                                     | PIC18F6525/6621/<br>8525/8621 | —             | 50    | ns         |          |
|              |                       |                                                                        | PIC18LF6X2X/8X2X              |               | 100   | ns         |          |

**Note 1:** Requires the use of Parameter #73A.

2: Only if Parameter #71A and #72A are used.

NOTES:

# 80-Lead Plastic Thin Quad Flatpack (PT) 12x12x1 mm Body, 1.0/0.10 mm Lead Form (TQFP)

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



|                          | Units | INCHES |      |      | MILLIMETERS* |       |       |  |
|--------------------------|-------|--------|------|------|--------------|-------|-------|--|
| Dimension Lir            | MIN   | NOM    | MAX  | MIN  | NOM          | MAX   |       |  |
| Number of Pins n         |       | 80     |      |      | 80           |       |       |  |
| Pitch                    | р     |        | .020 |      |              | 0.50  |       |  |
| Pins per Side            | n1    |        | 20   |      |              | 20    |       |  |
| Overall Height           | Α     | .039   | .043 | .047 | 1.00         | 1.10  | 1.20  |  |
| Molded Package Thickness | A2    | .037   | .039 | .041 | 0.95         | 1.00  | 1.05  |  |
| Standoff                 | A1    | .002   | .004 | .006 | 0.05         | 0.10  | 0.15  |  |
| Foot Length              | L     | .018   | .024 | .030 | 0.45         | 0.60  | 0.75  |  |
| Footprint (Reference)    | (F)   |        | .039 |      |              | 1.00  |       |  |
| Foot Angle               | φ     | 0      | 3.5  | 7    | 0            | 3.5   | 7     |  |
| Overall Width            | E     | .541   | .551 | .561 | 13.75        | 14.00 | 14.25 |  |
| Overall Length           | D     | .541   | .551 | .561 | 13.75        | 14.00 | 14.25 |  |
| Molded Package Width     | E1    | .463   | .472 | .482 | 11.75        | 12.00 | 12.25 |  |
| Molded Package Length    | D1    | .463   | .472 | .482 | 11.75        | 12.00 | 12.25 |  |
| Lead Thickness           | с     | .004   | .006 | .008 | 0.09         | 0.15  | 0.20  |  |
| Lead Width               | В     | .007   | .009 | .011 | 0.17         | 0.22  | 0.27  |  |
| Pin 1 Corner Chamfer     | СН    | .025   | .035 | .045 | 0.64         | 0.89  | 1.14  |  |
| Mold Draft Angle Top     | α     | 5      | 10   | 15   | 5            | 10    | 15    |  |
| Mold Draft Angle Bottom  | β     | 5      | 10   | 15   | 5            | 10    | 15    |  |

\*Controlling Parameter

Notes:

Dimensions D1 and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" (0.254mm) per side.

JEDEC Equivalent: MS-026 Drawing No. C04-092