



Welcome to E-XFL.COM

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

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

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

### Details

| Details                    |                                                                           |
|----------------------------|---------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                  |
| Core Processor             | 8051                                                                      |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 33MHz                                                                     |
| Connectivity               | I <sup>2</sup> C, UART/USART                                              |
| Peripherals                | POR, PWM, WDT                                                             |
| Number of I/O              | 32                                                                        |
| Program Memory Size        | 64KB (64K x 8)                                                            |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 8K x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                               |
| Data Converters            | ·                                                                         |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 44-LCC (J-Lead)                                                           |
| Supplier Device Package    | 44-PLCC (16.59x16.59)                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p89c668hba-00-512 |

Email: info@E-XFL.COM

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

P89C660/P89C662/P89C664/

# 80C51 8-bit Flash microcontroller family 16KB/32KB/64KB ISP/IAP Flash with 512B/1KB/2KB/8KB RAM

### SELECTION TABLE

| Туре    |      | Mem | ory |       |             | Tim          | ers          |              | S            | erial<br>fac |     | r-  |              |          |                          |                     |                       |                        |                           |                                                |                                  |                                  |
|---------|------|-----|-----|-------|-------------|--------------|--------------|--------------|--------------|--------------|-----|-----|--------------|----------|--------------------------|---------------------|-----------------------|------------------------|---------------------------|------------------------------------------------|----------------------------------|----------------------------------|
|         | RAM  | ROM | ОТР | Flash | # of Timers | PWM          | PCA          | WD           | UART         | 12C          | CAN | SPI | ADC bits/ch. | I/O Pins | Interrupts<br>(External) | Program<br>Security | Default Clock<br>Rate | Optional<br>Clock Rate | Reset active<br>low/high? | Max.<br>Freq.<br>at 6-clk<br>/ 12-clk<br>(MHz) | Freq.<br>Range<br>at 3V<br>(MHz) | Freq.<br>Range<br>at 5V<br>(MHz) |
| P89C668 | 8K   | -   | -   | 64K   | 4           |              | $\checkmark$ | $\checkmark$ | V            | $\checkmark$ | -   | -   | -            | 32       | 8(2)/4                   | $\checkmark$        | 6-clk                 | 12-clk                 | н                         | 20/33                                          | -                                | 0-20/33                          |
| P89C664 | 2K   | -   | -   | 64K   | 4           | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | -   | -   | -            | 32       | 8(2)/4                   | $\checkmark$        | 6-clk                 | 12-clk                 | Н                         | 20/33                                          | -                                | 0-20/33                          |
| P89C662 | 1K   | -   | -   | 32K   | 4           | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | -   | -   | -            | 32       | 8(2)/4                   | $\checkmark$        | 6-clk                 | 12-clk                 | н                         | 20/33                                          | -                                | 0-20/33                          |
| P89C660 | 512B | -   | -   | 16K   | 4           | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | -   | -   | -            | 32       | 8(2)/4                   | V                   | 6-clk                 | 12-clk                 | Н                         | 20/33                                          | -                                | 0-20/33                          |

### **ORDERING INFORMATION**

|             | MEM   | ORY   |                                       | VOLTAGE          | FREQUEN      | ICY (MHz)        |          |
|-------------|-------|-------|---------------------------------------|------------------|--------------|------------------|----------|
| DEVICE      | FLASH | RAM   | TEMPERATURE RANGE (°C)<br>AND PACKAGE | VOLTAGE<br>RANGE | 6 CLOCK MODE | 12 CLOCK<br>MODE | DWG #    |
| P89C660HBA  | 16 KB | 512 B | 0 to +70, PLCC                        | 4.5–5.5 V        | 0 to 20 MHz  | 0 to 33 MHz      | SOT187-2 |
| P89C660HFA  | 16 KB | 512 B | -40 to +85, PLCC                      | 4.75–5.25 V      | 0 to 20 MHz  | 0 to 33 MHz      | SOT187-2 |
| P89C660HBBD | 16 KB | 512 B | 0 to +70, LQFP                        | 4.5–5.5 V        | 0 to 20 MHz  | 0 to 33 MHz      | SOT389-1 |
| P89C662HBA  | 32 KB | 1 KB  | 0 to +70, PLCC                        | 4.5–5.5 V        | 0 to 20 MHz  | 0 to 33 MHz      | SOT187-2 |
| P89C662HFA  | 32 KB | 1 KB  | -40 to +85, PLCC                      | 4.75–5.25 V      | 0 to 20 MHz  | 0 to 33 MHz      | SOT187-2 |
| P89C662HBBD | 32 KB | 1 KB  | 0 to +70, LQFP                        | 4.5–5.5 V        | 0 to 20 MHz  | 0 to 33 MHz      | SOT389-1 |
| P89C662HFBD | 32 KB | 1 KB  | -40 to +85, LQFP                      | 4.75–5.25 V      | 0 to 20 MHz  | 0 to 33 MHz      | SOT389-1 |
| P89C664HBA  | 64 KB | 2 KB  | 0 to +70, PLCC                        | 4.5–5.5 V        | 0 to 20 MHz  | 0 to 33 MHz      | SOT187-2 |
| P89C664HFA  | 64 KB | 2 KB  | -40 to +85, PLCC                      | 4.75–5.25 V      | 0 to 20 MHz  | 0 to 33 MHz      | SOT187-2 |
| P89C664HBBD | 64 KB | 2 KB  | 0 to +70, LQFP                        | 4.5–5.5 V        | 0 to 20 MHz  | 0 to 33 MHz      | SOT389-1 |
| P89C664HFBD | 64 KB | 2 KB  | -40 to +85, LQFP                      | 4.75–5.25 V      | 0 to 20 MHz  | 0 to 33 MHz      | SOT389-1 |
| P89C668HBA  | 64 KB | 8 KB  | 0 to +70, PLCC                        | 4.5–5.5 V        | 0 to 20 MHz  | 0 to 33 MHz      | SOT187-2 |
| P89C668HFA  | 64 KB | 8 KB  | -40 to +85, PLCC                      | 4.5–5.5 V        | 0 to 20 MHz  | 0 to 33 MHz      | SOT187-2 |
| P89C668HBBD | 64 KB | 8 KB  | 0 to +70, LQFP                        | 4.5–5.5 V        | 0 to 20 MHz  | 0 to 33 MHz      | SOT389-1 |

P89C660/P89C662/P89C664/

# 80C51 8-bit Flash microcontroller family 16KB/32KB/64KB ISP/IAP Flash with 512B/1KB/2KB/8KB RAM

# **BLOCK DIAGRAM 1**







Figure 1. Typical I<sup>2</sup>C Bus Configuration



Figure 2. Data Transfer on the I<sup>2</sup>C Bus

### **SIO1** Implementation and Operation

Figure 3 shows how the on-chip  $I^2C$  bus interface is implemented, and the following text describes the individual blocks.

### Input Filters and Output Stages

The input filters have I<sup>2</sup>C compatible input levels. If the input voltage is less than 1.5 V, the input logic level is interpreted as 0; if the input voltage is greater than 3.0 V, the input logic level is interpreted as 1. Input signals are synchronized with the internal clock ( $f_{OSC}/4$ ), and spikes shorter than three oscillator periods are filtered out.

The output stages consist of open drain transistors that can sink 3mA at V<sub>OUT</sub> < 0.4 V. These open drain outputs do not have clamping diodes to V<sub>DD</sub>. Thus, if the device is connected to the I<sup>2</sup>C bus and V<sub>DD</sub> is switched off, the I<sup>2</sup>C bus is not affected.

### Address Register, S1ADR

This 8-bit special function register may be loaded with the 7-bit slave address (7 most significant bits) to which SIO1 will respond when programmed as a slave transmitter or receiver. The LSB (GC) is used to enable general call address (00H) recognition.

#### Comparator

The comparator compares the received 7-bit slave address with its own slave address (7 most significant bits in S1ADR). It also compares the first received 8-bit byte with the general call address (00H). If an equality is found, the appropriate status bits are set and an interrupt is requested.

#### Shift Register, S1DAT

This 8-bit special function register contains a byte of serial data to be transmitted or a byte which has just been received. Data in S1DAT is always shifted from right to left; the first bit to be transmitted is the MSB (bit 7) and, after a byte has been received, the first bit of received data is located at the MSB of S1DAT. While data is being shifted out, data on the bus is simultaneously being shifted in; S1DAT always contains the last byte present on the bus. Thus, in the event of lost arbitration, the transition from master transmitter to slave receiver is made with the correct data in S1DAT.

#### Serial Clock Generator

This programmable clock pulse generator provides the SCL clock pulses when SIO1 is in the Master Transmitter or Master Receiver mode. It is switched off when SIO1 is in a Slave mode. The programmable output clock frequencies are:  $f_{OSC}/120$ ,  $f_{OSC}/9600$  (12-clock mode) or  $f_{OSC}/60$ ,  $f_{OSC}/4800$  (6-clock mode) and the Timer 1 overflow rate divided by eight. The output clock pulses have a 50% duty cycle unless the clock generator is synchronized with other SCL clock sources as described above.

### **Timing and Control**

The timing and control logic generates the timing and control signals for serial byte handling. This logic block provides the shift pulses for S1DAT, enables the comparator, generates and detects start and stop conditions, receives and transmits acknowledge bits, controls the master and Slave modes, contains interrupt request logic, and monitors the  $I^2C$  bus status.

#### **Control Register, S1CON**

This 7-bit special function register is used by the microcontroller to control the following SIO1 functions: start and restart of a serial transfer, termination of a serial transfer, bit rate, address recognition, and acknowledgment.

#### Status Decoder and Status Register

The status decoder takes all of the internal status bits and compresses them into a 5-bit code. This code is unique for each I<sup>2</sup>C bus status. The 5-bit code may be used to generate vector addresses for fast processing of the various service routines. Each service routine processes a particular bus status. There are 26 possible bus states if all four modes of SIO1 are used. The 5-bit status code is latched into the five most significant bits of the status register when the serial interrupt flag is set (by hardware) and remains stable until the interrupt flag is cleared by software. The three least significant bits of the status register are always zero. If the status code is used as a vector to service routines, then the routines are displaced by eight address locations. Eight bytes of code is sufficient for most of the service routines.

#### The Four SIO1 Special Function Registers

The microcontroller interfaces to SIO1 via four special function registers. These four SFRs (S1ADR, S1DAT, S1CON, and S1STA) are described individually in the following sections.

#### The Address Register, S1ADR

The CPU can read from and write to this 8-bit, directly addressable SFR. S1ADR is not affected by the SIO1 hardware. The contents of this register are irrelevant when SIO1 is in a Master mode. In the Slave modes, the seven most significant bits must be loaded with the microcontroller's own slave address, and, if the least significant bit is set, the general call address (00H) is recognized; otherwise it is ignored.

|             | 7 | 6 | 5  | 4           | 3      | 2 | 1 | 0  |
|-------------|---|---|----|-------------|--------|---|---|----|
| S1ADR (DBH) | Х | х | Х  | Х           | Х      | Х | х | GC |
|             |   |   | ov | vn slave ad | ddress |   |   |    |

The most significant bit corresponds to the first bit received from the  $I^2C$  bus after a start condition. A logic 1 in S1ADR corresponds to a high level on the  $I^2C$  bus, and a logic 0 corresponds to a low level on the bus.

#### The Data Register, S1DAT

S1DAT contains a byte of serial data to be transmitted or a byte which has just been received. The CPU can read from and write to

this 8-bit, directly addressable SFR while it is not in the process of shifting a byte. This occurs when SIO1 is in a defined state and the serial interrupt flag is set. Data in S1DAT remains stable as long as SI is set. Data in S1DAT is always shifted from right to left: the first bit to be transmitted is the MSB (bit 7), and, after a byte has been received, the first bit of received data is located at the MSB of S1DAT. While data is being shifted out, data on the bus is simultaneously being shifted in; S1DAT always contains the last data byte present on the bus. Thus, in the event of lost arbitration, the transition from master transmitter to slave receiver is made with the correct data in S1DAT.

|             | 7   | 6   | 5   | 4           | 3      | 2   | 1   | 0   |
|-------------|-----|-----|-----|-------------|--------|-----|-----|-----|
| S1DAT (DAH) | SD7 | SD6 | SD5 | SD4         | SD3    | SD2 | SD1 | SD0 |
|             | -   |     |     | shift direc | tion — |     |     |     |

#### SD7 - SD0:

Eight bits to be transmitted or just received. A logic 1 in S1DAT corresponds to a high level on the  $l^2C$  bus, and a logic 0 corresponds to a low level on the bus. Serial data shifts through S1DAT from right to left. Figure 6 shows how data in S1DAT is serially transferred to and from the SDA line.

S1DAT and the ACK flag form a 9-bit shift register which shifts in or shifts out an 8-bit byte, followed by an acknowledge bit. The ACK flag is controlled by the SIO1 hardware and cannot be accessed by the CPU. Serial data is shifted through the ACK flag into S1DAT on the rising edges of serial clock pulses on the SCL line. When a byte has been shifted into S1DAT, the serial data is available in S1DAT, and the acknowledge bit is returned by the control logic during the ninth clock pulse. Serial data is shifted out from S1DAT via a buffer (BSD7) on the falling edges of clock pulses on the SCL line.

When the CPU writes to S1DAT, BSD7 is loaded with the content of S1DAT.7, which is the first bit to be transmitted to the SDA line (see Figure 7). After nine serial clock pulses, the eight bits in S1DAT will have been transmitted to the SDA line, and the acknowledge bit will be present in ACK. Note that the eight transmitted bits are shifted back into S1DAT.

#### The Control Register, S1CON

The CPU can read from and write to this 8-bit, directly addressable SFR. Two bits are affected by the SIO1 hardware: the SI bit is set when a serial interrupt is requested, and the STO bit is cleared when a STOP condition is present on the  $I^{2}C$  bus. The STO bit is also cleared when ENS1 = "0".

|             | 7   | 6    | 5   | 4   | 3  | 2  | 1   | 0   |
|-------------|-----|------|-----|-----|----|----|-----|-----|
| S1CON (D8H) | CR2 | ENS1 | STA | STO | SI | AA | CR1 | CR0 |

**ENS1, the SIO1 Enable Bit:** ENS1 = "0": When ENS1 is "0", the SDA and SCL outputs are in a high impedance state. SDA and SCL input signals are ignored, SIO1 is in the "not addressed" slave state, and the STO bit in S1CON is forced to "0". No other bits are affected. P1.6 and P1.7 may be used as open drain I/O ports.

ENS1 ="1": When ENS1 is "1", SIO1 is enabled. The P1.6 and P1.7 port latches must be set to logic 1.

ENS1 should not be used to temporarily release SIO1 from the I2C bus since, when ENS1 is reset, the I2C bus status is lost. The AA flag should be used instead (see description of the AA flag in the following text).

# P89C660/P89C662/P89C664/ P89C668

# 80C51 8-bit Flash microcontroller family 16KB/32KB/64KB ISP/IAP Flash with 512B/1KB/2KB/8KB RAM

### More Information on SIO1 Operating Modes

- The four operating modes are:
- Master Transmitter
- Master Receiver
- Slave Receiver
- Slave Transmitter

Data transfers in each mode of operation are shown in Figures 8-11. These figures contain the following abbreviations:

| Abbreviation | Explanation                             |
|--------------|-----------------------------------------|
| S            | Start condition                         |
| SLA          | 7-bit slave address                     |
| R            | Read bit (high level at SDA)            |
| W            | Write bit (low level at SDA)            |
| A            | Acknowledge bit (low level at SDA)      |
| Ā            | Not acknowledge bit (high level at SDA) |
| Data         | 8-bit data byte                         |
| Р            | Stop condition                          |

In Figures 8-11, circles are used to indicate when the serial interrupt flag is set. The numbers in the circles show the status code held in the S1STA register. At these points, a service routine must be executed to continue or complete the serial transfer. These service routines are not critical since the serial transfer is suspended until the serial interrupt flag is cleared by software.

When a serial interrupt routine is entered, the status code in S1STA is used to branch to the appropriate service routine. For each status code, the required software action and details of the following serial transfer are given in Tables 4-8.

#### Master Transmitter mode

In the Master Transmitter mode, a number of data bytes are transmitted to a slave receiver (see Figure 8). Before the Master Transmitter mode can be entered, S1CON must be initialized as follows:

|             | 7           | 6    | 5   | 4   | 3  | 2  | 1        | 0     |
|-------------|-------------|------|-----|-----|----|----|----------|-------|
| S1CON (D8H) | CR2         | ENS1 | STA | STO | SI | AA | CR1      | CR0   |
|             | bit<br>rate | 1    | 0   | 0   | 0  | Х  | — bit ra | ate — |

CR0, CR1, and CR2 define the serial bit rate. ENS1 must be set to logic 1 to enable SIO1. If the AA bit is reset, SIO1 will not acknowledge its own slave address or the general call address in the event of another device becoming master of the bus. In other words, if AA is reset, SIO0 cannot enter a Slave mode. STA, STO, and SI must be reset.

The Master Transmitter mode may now be entered by setting the STA bit using the SETB instruction. The SIO1 logic will now test the  $I^2C$  bus and generate a start condition as soon as the bus becomes free. When a START condition is transmitted, the serial interrupt flag (SI) is set, and the status code in the status register (S1STA) will be 08H. This status code must be used to vector to an interrupt service routine that loads S1DAT with the slave address and the data direction bit (SLA+W). The SI bit in S1CON must then be reset before the serial transfer can continue.

When the slave address and the direction bit have been transmitted and an acknowledgment bit has been received, the serial interrupt flag (SI) is set again, and a number of status codes in S1STA are possible. There are 18H, 20H, or 38H for the Master mode and also 68H, 78H, or B0H if the Slave mode was enabled (AA = logic 1). The appropriate action to be taken for each of these status codes is detailed in Table 4. After a repeated start condition (state 10H). SIO1 may switch to the Master Receiver mode by loading S1DAT with SLA+R).

P89C660/P89C662/P89C664/

#### Master Receiver mode

In the Master Receiver mode, a number of data bytes are received from a slave transmitter (see Figure 9). The transfer is initialized as in the Master Transmitter mode. When the start condition has been transmitted, the interrupt service routine must load S1DAT with the 7-bit slave address and the data direction bit (SLA+R). The SI bit in S1CON must then be cleared before the serial transfer can continue.

When the slave address and the data direction bit have been transmitted and an acknowledgment bit has been received, the serial interrupt flag (SI) is set again, and a number of status codes in S1STA are possible. These are 40H, 48H, or 38H for the Master mode and also 68H, 78H, or B0H if the Slave mode was enabled (AA = logic 1). The appropriate action to be taken for each of these status codes is detailed in Table 5. ENS1, CR1, and CR0 are not affected by the serial transfer and are not referred to in Table 5. After a repeated start condition (state 10H), SIO1 may switch to the Master Transmitter mode by loading S1DAT with SLA+W.

#### Slave Receiver mode

In the Slave Receiver mode, a number of data bytes are received from a master transmitter (see Figure 10). To initiate the Slave Receiver mode, S1ADR and S1CON must be loaded as follows:

|             | 7 | 6 | 5  | 4          | 3     | 2 | 1 | 0  |
|-------------|---|---|----|------------|-------|---|---|----|
| S1ADR (DBH) | Х | Х | Х  | х          | х     | Х | х | GC |
|             |   |   | ow | n slave ad | dress |   |   |    |

The upper 7 bits are the address to which SIO1 will respond when addressed by a master. If the LSB (GC) is set, SIO1 will respond to the general call address (00H); otherwise it ignores the general call address.

|             | 7   | 6    | 5   | 4   | 3  | 2  | 1   | 0   |
|-------------|-----|------|-----|-----|----|----|-----|-----|
| S1CON (D8H) | CR2 | ENS1 | STA | STO | SI | AA | CR1 | CR0 |
|             | х   | 1    | 0   | 0   | 0  | 1  | х   | х   |

CR0, CR1, and CR2 do not affect SIO1 in the Slave mode. ENS1 must be set to logic 1 to enable SIO1. The AA bit must be set to enable SIO1 to acknowledge its own slave address or the general call address. STA, STO, and SI must be reset.

When S1ADR and S1CON have been initialized, SIO1 waits until it is addressed by its own slave address followed by the data direction bit which must be "0" (W) for SIO1 to operate in the Slave Receiver mode. After its own slave address and the W bit have been received, the serial interrupt flag (I) is set and a valid status code can be read from S1STA. This status code is used to vector to an interrupt service routine, and the appropriate action to be taken for each of these status codes is detailed in Table 6. The Slave Receiver mode may also be entered if arbitration is lost while SIO1 is in the Master mode (see status 68H and 78H).

If the AA bit is reset during a transfer, SIO1 will return a not acknowledge (logic 1) to SDA after the next received data byte. While AA is reset, SIO1 does not respond to its own slave address or a general call address. However, the  $I^2C$  bus is still monitored and address recognition may be resumed at any time by setting AA. This means that the AA bit may be used to temporarily isolate SIO1 from the  $I^2C$  bus.

P89C660/P89C662/P89C664/

# 80C51 8-bit Flash microcontroller family 16KB/32KB/64KB ISP/IAP Flash with 512B/1KB/2KB/8KB RAM

### Table 6. Slave Receiver mode (Continued)

| STATUS  | STATUS OF THE                                              | APPLICATION SC     | OFTWA | RE RE | SPONS | SE |                                                                                                                                                                                                         |
|---------|------------------------------------------------------------|--------------------|-------|-------|-------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CODE    | I <sup>2</sup> C BUS AND                                   | TO/FROM S1DAT      |       | TO S1 | CON   | _  | NEXT ACTION TAKEN BY SIO1 HARDWARE                                                                                                                                                                      |
| (S1STA) | SIO1 HARDWARE                                              | TO/FROM STDAT      | STA   | STO   | SI    | AA |                                                                                                                                                                                                         |
| A0H     | A STOP condition or<br>repeated START                      | No STDAT action or | 0     | 0     | 0     | 0  | Switched to not addressed SLV mode; no recognition<br>of own SLA or General call address                                                                                                                |
|         | condition has been<br>received while still<br>addressed as | No STDAT action or | 0     | 0     | 0     | 1  | Switched to not addressed SLV mode; Own SLA will<br>be recognized; General call address will be<br>recognized if S1ADR.0 = logic 1                                                                      |
|         | SLV/REC or SLV/TRX                                         | No STDAT action or | 1     | 0     | 0     | 0  | Switched to not addressed SLV mode; no recognition<br>of own SLA or General call address. A START<br>condition will be transmitted when the bus becomes<br>free                                         |
|         |                                                            | No STDAT action    | 1     | 0     | 0     | 1  | Switched to not addressed SLV mode; Own SLA will<br>be recognized; General call address will be<br>recognized if S1ADR.0 = logic 1. A START condition<br>will be transmitted when the bus becomes free. |

### Table 7. Slave Transmitter mode

| STATUS          | STATUS OF THE                                              | APPLICATION SO     | OFTWA | RE RE | SPONS | ε  |                                                                                                                                                                                                         |
|-----------------|------------------------------------------------------------|--------------------|-------|-------|-------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CODE<br>(S1STA) | I <sup>2</sup> C BUS AND<br>SIO1 HARDWARE                  | TO/FROM S1DAT      |       | TO S1 | CON   |    | NEXT ACTION TAKEN BY SIO1 HARDWARE                                                                                                                                                                      |
| (5151A)         | SIOT HARDWARE                                              |                    | STA   | ѕто   | SI    | AA |                                                                                                                                                                                                         |
| A8H             | Own SLA+R has<br>been received; ACK<br>has been returned   | Load data byte or  | X     | 0     | 0     | 0  | Last data byte will be transmitted and ACK bit will be received                                                                                                                                         |
|                 | nas been returned                                          | load data byte     | Х     | 0     | 0     | 1  | Data byte will be transmitted; ACK will be received                                                                                                                                                     |
| B0H             | Arbitration lost in<br>SLA+R/W as master;<br>Own SLA+R has | Load data byte or  | Х     | 0     | 0     | 0  | Last data byte will be transmitted and ACK bit will be received                                                                                                                                         |
|                 | been received, ACK has been returned                       | load data byte     | Х     | 0     | 0     | 1  | Data byte will be transmitted; ACK bit will be received                                                                                                                                                 |
| B8H             | Data byte in S1DAT<br>has been transmitted;                | Load data byte or  | Х     | 0     | 0     | 0  | Last data byte will be transmitted and ACK bit will be received                                                                                                                                         |
|                 | ACK has been<br>received                                   | load data byte     | Х     | 0     | 0     | 1  | Data byte will be transmitted; ACK bit will be received                                                                                                                                                 |
| C0H             | Data byte in S1DAT has been transmitted;                   | No S1DAT action or | 0     | 0     | 0     | 01 | Switched to not addressed SLV mode; no recognition<br>of own SLA or General call address                                                                                                                |
|                 | NOT ACK has been<br>received                               | no S1DAT action or | 0     | 0     | 0     | 1  | Switched to not addressed SLV mode; Own SLA will<br>be recognized; General call address will be<br>recognized if S1ADR.0 = logic 1                                                                      |
|                 |                                                            | no S1DAT action or | 1     | 0     | 0     | 0  | Switched to not addressed SLV mode; no recognition<br>of own SLA or General call address. A START<br>condition will be transmitted when the bus becomes<br>free                                         |
|                 |                                                            | no S1DAT action    | 1     | 0     | 0     | 1  | Switched to not addressed SLV mode; Own SLA will<br>be recognized; General call address will be<br>recognized if S1ADR.0 = logic 1. A START condition<br>will be transmitted when the bus becomes free. |
| C8H             | Last data byte in<br>S1DAT has been                        | No S1DAT action or | 0     | 0     | 0     | 0  | Switched to not addressed SLV mode; no recognition<br>of own SLA or General call address                                                                                                                |
|                 | transmitted (AA = 0);<br>ACK has been<br>received          | no S1DAT action or | 0     | 0     | 0     | 1  | Switched to not addressed SLV mode; Own SLA will<br>be recognized; General call address will be<br>recognized if S1ADR.0 = logic 1                                                                      |
|                 |                                                            | no S1DAT action or | 1     | 0     | 0     | 0  | Switched to not addressed SLV mode; no recognition<br>of own SLA or General call address. A START<br>condition will be transmitted when the bus becomes<br>free                                         |
|                 |                                                            | no S1DAT action    | 1     | 0     | 0     | 1  | Switched to not addressed SLV mode; Own SLA will<br>be recognized; General call address will be<br>recognized if S1ADR.0 = logic 1. A START condition<br>will be transmitted when the bus becomes free. |

# 80C51 8-bit Flash microcontroller family 16KB/32KB/64KB ISP/IAP Flash with 512B/1KB/2KB/8KB RAM

### TIMER 0 AND TIMER 1 OPERATION

### Timer 0 and Timer 1

The "Timer" or "Counter" function is selected by control bits C/T in the Special Function Register TMOD (see Figure 15). These two Timer/Counters have four operating modes, which are selected by bit-pairs (M1, M0) in TMOD. Modes 0, 1, and 2 are the same for both Timers/Counters. Mode 3 is different. The four operating modes are described in the following text.

#### Mode 0

Putting either Timer into Mode 0 makes it behave as an 8048 Timer, which is an 8-bit Counter with a divide-by-32 prescaler. Figure 16 shows the Mode 0 operation.

In this mode, the Timer register is configured as a 13-bit register. As the count rolls over from all 1s to all 0s, it sets the Timer interrupt flag TFn. The counted input is enabled to the Timer when TRn = 1 and either GATE = 0 or  $\overline{INTn}$  = 1. TRn is a control bit in the Special Function Register TCON (Figure 17). (Setting GATE = 1 allows the Timer to be controlled by external input  $\overline{INTn}$ , to facilitate pulse width measurements).

The 13-bit register consists of all 8 bits of THn and the lower 5 bits of TLn. The upper 3 bits of TLn are indeterminate and should be ignored. Setting the run flag (TRn) does not clear the registers.

Mode 0 operation is the same for Timer 0 as for Timer 1. There are two different GATE bits, one for Timer 1 (TMOD.7) and one for Timer 0 (TMOD.3).

#### Mode 1

Mode 1 is the same as Mode 0, except that the Timer register is being run with all 16 bits.

P89C660/P89C662/P89C664/

#### Mode 2

Mode 2 configures the Timer register as an 8-bit Counter (TLn) with automatic reload, as shown in Figure 18. Overflow from TLn not only sets TFn, but also reloads TLn with the contents of THn, which is preset by software. The reload leaves THn unchanged.

Mode 2 operation is the same for Timer 0 as for Timer 1.

#### Mode 3

Timer 1 in Mode 3 simply holds its count. The effect is the same as setting TR1 = 0.

Timer 0 in Mode 3 establishes TL0 and TH0 as two separate counters. The logic for Mode 3 on Timer 0 is shown in Figure 19. TL0 uses the Timer 0 control bits:  $C/\overline{T}$ , GATE, TR0, and TF0 as well as pin INT0. TH0 is locked into a timer function (counting machine cycles) and takes over the use of TR1 and TF1 from Timer 1. Thus, TH0 now controls the "Timer 1" interrupt.

Mode 3 is provided for applications requiring an extra 8-bit timer on the counter. Putting Timer 0 in Mode 3 allows an 80C51 to have three Timer/Counters. When Timer 0 is in Mode 3, Timer 1 can be turned on and off by switching it out of and into its own Mode 3, or can still be used by the serial port as a baud rate generator, or in fact, in any application not requiring an interrupt.

|                                 | ss = 89           | )H      |                                                                                                                                                     |                                                                            |                                                 |                                             |           |         |             | Re                                       | set Value = 00H |
|---------------------------------|-------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------|---------------------------------------------|-----------|---------|-------------|------------------------------------------|-----------------|
| Not Bi                          | t Addre           | essable | 9                                                                                                                                                   |                                                                            |                                                 |                                             |           |         |             |                                          |                 |
|                                 |                   |         | 7                                                                                                                                                   | 6                                                                          | 5                                               | 4                                           | 3         | 2       | 1           | 0                                        |                 |
|                                 |                   |         | GATE                                                                                                                                                | C/T                                                                        | M1                                              | MO                                          | GATE      | C/T     | M1          | MO                                       |                 |
|                                 |                   |         |                                                                                                                                                     | ۱<br>ر                                                                     |                                                 |                                             |           |         |             | I~                                       | ן<br>י          |
|                                 |                   |         |                                                                                                                                                     | ТІМІ                                                                       | ER 1                                            |                                             |           | TIM     | ER 0        |                                          |                 |
| <b>BIT</b><br>TMOD.3/<br>TMOD.7 | I <b>BOL</b><br>E |         | rol wher                                                                                                                                            |                                                                            |                                                 |                                             |           |         |             | in is high and<br>n" control bit is set. |                 |
| TMOD.2/<br>TMOD.6               | C/T               |         | Timer or Counter Selector cleared for Timer operation (input from internal system clock.)<br>Set for Counter operation (input from "Tn" input pin). |                                                                            |                                                 |                                             |           |         |             |                                          |                 |
|                                 | M1                | MO      | OPERATIN                                                                                                                                            | G                                                                          |                                                 |                                             |           |         |             |                                          |                 |
|                                 | 0                 | 0       | 8048 Timer:                                                                                                                                         | "TLn" s                                                                    | erves as                                        | s 5-bit pi                                  | escaler.  |         |             |                                          |                 |
|                                 | 0                 | 0       |                                                                                                                                                     | 16-bit Timer/Counter: "THn" and "TLn" are cascaded; there is no prescaler. |                                                 |                                             |           |         |             |                                          |                 |
|                                 | 0                 | 1       | 16-bit Timer                                                                                                                                        | /Counte                                                                    | r: "THn"                                        | and "TL                                     | n" are ca | scaded; | there is n  | o prescale                               | er.             |
|                                 |                   |         | 16-bit Timer<br>8-bit auto-re<br>into "TLn" e                                                                                                       | load Tin                                                                   | ner/Cou                                         | nter: "TH                                   |           |         |             |                                          |                 |
|                                 | 0                 | 1       | 8-bit auto-re<br>into "TLn" e                                                                                                                       | eload Tin<br>ach time                                                      | ner/Cour<br>it overfl<br>8-bit Tim              | nter: "TH<br>lows.<br>ner/Cour              | In" holds | a value | which is to | be reload                                |                 |
|                                 | 0<br>1            | 1<br>0  | 8-bit auto-re<br>into "TLn" e<br>(Timer 0) TI                                                                                                       | eload Tin<br>ach time<br>.0 is an<br>bit time                              | ner/Cour<br>it overfl<br>8-bit Tim<br>r only co | nter: "Th<br>lows.<br>ner/Cour<br>ontrolled | In" holds | a value | which is to | be reload                                | ded             |

Figure 15. Timer/Counter 0/1 Mode Control (TMOD) Register

# P89C660/P89C662/P89C664/ P89C668

### **TIMER 2 OPERATION**

#### Timer 2

Timer 2 is a 16-bit Timer/Counter which can operate as either an event timer or an event counter, as selected by  $C/T^2$  in the special function register T2CON (see Figure 20). Timer 2 has three operating modes:

- Capture Mode
- Auto-Reload Mode (up or down counting)
- Baud Rate Generator Mode (see Table 10)

#### **Capture Mode**

In the capture mode there are two options which are selected by bit EXEN2 in T2CON. If EXEN2 = 0, then Timer 2 is a 16-bit timer or counter (as selected by C/T2 in T2CON) which, upon overflowing sets bit TF2, the Timer 2 overflow bit. This bit can be used to generate an interrupt (by enabling the Timer 2 interrupt bit in the IE register). If EXEN2 = 1, Timer 2 operates as described above, with the added feature that a 1-to-0 transition at external input pin T2EX causes the current value in the Timer 2 registers, TL2 and TH2, to be captured into registers RCAP2L and RCAP2H. In addition, the transition at T2EX causes bit EXF2 in T2CON to be set. If Timer 2 interrupt has been enabled, EXF2 will generate an interrupt (which vectors to the same location as Timer 2 overflow interrupt). The Timer 2 interrupt service routine can interrogate TF2 and EXF2 to determine which event caused the interrupt. The capture mode is illustrated in Figure 21 (There is no reload value for TL2 and TH2 in this mode). Even when a capture event occurs from T2EX, the counter keeps on counting T2EX pin transitions or osc/6 pulses (osc/12 in 12 clock mode).

#### Auto-Reload Mode (Up or Down Counter)

In the 16-bit auto-reload mode, Timer 2 can be configured as either a timer or counter (C/ $\overline{T}$ 2 in T2CON), then programmed to count up

or down. The counting direction is determined by bit DCEN (Down Counter Enable) which is located in the T2MOD register (see Figure 22). When reset is applied (DCEN = 0), Timer 2 defaults to counting up. If DCEN bit is set, Timer 2 can count up or down depending on the value of the T2EX pin.

Figure 23 shows Timer 2 which will count up automatically since DCEN = 0. In this mode there are two options selected by bit EXEN2 in T2CON register. If EXEN2 = 0, then Timer 2 counts up to 0FFFFH and sets the TF2 (Overflow Flag) bit upon overflow. This causes the Timer 2 registers to be reloaded with the 16-bit value in RCAP2L and RCAP2H. The values in RCAP2L and RCAP2H are preset by software.

If EXEN2 = 1, then a 16-bit reload can be triggered either by an overflow or by a 1-to-0 transition at input pin T2EX. This transition also sets the EXF2 bit. The Timer 2 interrupt, if enabled, can be generated when either TF2 or EXF2 are 1.

In Figure 24 DCEN = 1 which enables Timer 2 to count up or down. This mode allows pin T2EX to control the direction of count. When a logic 1 is applied at pin T2EX Timer 2 will count up. Timer 2 will overflow at 0FFFFH and set the TF2 flag, which can then generate an interrupt, if the interrupt is enabled. This timer overflow also causes the 16-bit value in RCAP2L and RCAP2H to be reloaded into the timer registers TL2 and TH2.

When a logic 0 is applied at pin T2EX this causes Timer 2 to count down. The timer will underflow when TL2 and TH2 become equal to the value stored in RCAP2L and RCAP2H. Timer 2 underflow sets the TF2 flag and causes 0FFFFH to be reloaded into the timer registers TL2 and TH2.

The external flag EXF2 toggles when Timer 2 underflows or overflows. This EXF2 bit can be used as a 17th bit of resolution if needed. The EXF2 flag does not generate an interrupt in this mode of operation.

|        | (MSE     | 3)                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                |              |              |             |               | (LSB)         |                                                                     |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|-------------|---------------|---------------|---------------------------------------------------------------------|
|        | Т        | F2 EXF2                                                                                                                                                             | RCLK                                                                                                                                                                                                                                                                                                                                           | TCLK         | EXEN2        | TR2         | C/T2          | CP/RL2        |                                                                     |
| Symbol | Position | Name and Sig                                                                                                                                                        | nificance                                                                                                                                                                                                                                                                                                                                      |              |              |             |               |               |                                                                     |
| TF2    | T2CON.7  | Timer 2 overflo<br>when either R                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                |              | overflow and | d must be c | leared by sc  | oftware. TF2  | will not be set                                                     |
| EXF2   | T2CON.6  | EXEN2 = 1. W<br>interrupt routin                                                                                                                                    | Timer 2 external flag set when either a capture or reload is caused by a negative transition on T2EX and $EXEN2 = 1$ . When Timer 2 interrupt is enabled, $EXF2 = 1$ will cause the CPU to vector to the Timer 2 interrupt routine. $EXF2$ must be cleared by software. $EXF2$ does not cause an interrupt in up/down counter mode (DCEN = 1). |              |              |             |               |               |                                                                     |
| RCLK   | T2CON.5  |                                                                                                                                                                     | Receive clock flag. When set, causes the serial port to use Timer 2 overflow pulses for its receive clock in modes 1 and 3. RCLK = 0 causes Timer 1 overflow to be used for the receive clock.                                                                                                                                                 |              |              |             |               |               |                                                                     |
| TCLK   | T2CON.4  |                                                                                                                                                                     | Transmit clock flag. When set, causes the serial port to use Timer 2 overflow pulses for its transmit clock in modes 1 and 3, TCLK = 0 causes Timer 1 overflows to be used for the transmit clock.                                                                                                                                             |              |              |             |               |               |                                                                     |
| EXEN2  | T2CON.3  | transition on T                                                                                                                                                     | Timer 2 external enable flag. When set, allows a capture or reload to occur as a result of a negative transition on T2EX if Timer 2 is not being used to clock the serial port. EXEN2 = 0 causes Timer 2 to ignore events at T2EX.                                                                                                             |              |              |             |               |               |                                                                     |
| TR2    | T2CON.2  | Start/stop cont                                                                                                                                                     | Start/stop control for Timer 2. A logic 1 starts the timer.                                                                                                                                                                                                                                                                                    |              |              |             |               |               |                                                                     |
| C/T2   | T2CON.1  | Timer or counter select. (Timer 2)<br>0 = Internal timer (OSC/6 in 6-clock mode or OSC/12 in 12-clock mode)<br>1 = External event counter (falling edge triggered). |                                                                                                                                                                                                                                                                                                                                                |              |              |             |               |               |                                                                     |
| CP/RL2 | T2CON.0  | cleared, auto-r                                                                                                                                                     | eloads will c<br>hen either R                                                                                                                                                                                                                                                                                                                  | occur either | with Timer 2 | overflows   | or negative t | ransitions at | EXEN2 = 1. When<br>T2EX when<br>ced to auto-reload<br><i>SU0125</i> |

Figure 20. Timer/Counter 2 (T2CON) Control Register

P89C660/P89C662/P89C664/

# 80C51 8-bit Flash microcontroller family 16KB/32KB/64KB ISP/IAP Flash with 512B/1KB/2KB/8KB RAM



Figure 30. Serial Port Mode 2

# P89C660/P89C662/P89C664/ P89C668

### **Reduced EMI Mode**

The AO bit (AUXR.0) in the AUXR register when set disables the ALE output.

#### **Reduced EMI Mode**

### AUXR (8EH)



#### **Dual DPTR**

The dual DPTR structure (see Figure 39) is a way by which the chip will specify the address of an external data memory location. There are two 16-bit DPTR registers that address the external memory, and a single bit called DPS (AUXR1.0), that allows the program code to switch between them.

- New Register Name: AUXR1#
- SFR Address: A2H
- Reset Value: xxxxx0x0B

#### AUXR1 (A2H)

| – – ENBOOT – GF2 0 – DPS | 7 | 7 | 6 | 5      | 4 | 3   | 2 | 1 | 0   |
|--------------------------|---|---|---|--------|---|-----|---|---|-----|
|                          | - | - | - | ENBOOT | - | GF2 | 0 | - | DPS |

Where:

DPS (AUXR1.0), enables switching between DPTR0 and DPTR1.

| Select Reg | DPS |
|------------|-----|
| DPTR0      | 0   |
| DPTR1      | 1   |

The DPS bit status should be saved by software when switching between DPTR0 and DPTR1.

The GF2 bit is a general purpose user-defined flag. Note that bit 2 is not writable and is always read as a zero. This allows the DPS bit to be quickly toggled simply by executing an INC AUXR1 instruction without affecting the GF2 bit.

The ENBOOT bit determines whether the BOOTROM is enabled or disabled. This bit will automatically be set if the status byte is non zero during reset or  $\overrightarrow{\text{PSEN}}$  is pulled low, ALE floats high, and EA > V\_{IH} on the falling edge of reset. Otherwise, this bit will be cleared during reset.



Figure 39.

#### **DPTR Instructions**

The instructions, that refer to DPTR, refer to the data pointer that is currently selected by the DPS bit (AUXR1.0). The six instructions that use the DPTR are as follows:

| INC DPTR          | Increments the data pointer by 1          |
|-------------------|-------------------------------------------|
| MOV DPTR, #data16 | Loads the DPTR with a 16-bit constant     |
| MOV A, @ A+DPTR   | Move code byte relative to DPTR to ACC    |
| MOVX A, @ DPTR    | Move external RAM (16-bit address) to ACC |
| MOVX @ DPTR , A   | Move ACC to external RAM (16-bit address) |
| JMP @ A + DPTR    | Jump indirect relative to DPTR            |

The data pointer can be accessed on a byte-by-byte basis by specifying the low or high byte in an instruction which accesses the SFRs. See application note AN458 for more details.

P89C660/P89C662/P89C664/

# 80C51 8-bit Flash microcontroller family 16KB/32KB/64KB ISP/IAP Flash with 512B/1KB/2KB/8KB RAM

| CCAPMn / | Address                                                                                                                      | CCAF<br>CCAF<br>CCAF<br>CCAF<br>CCAF<br>CCAF | PM1 0C3<br>PM2 0C4<br>PM3 0C5 | 8H<br>1H<br>16H |              |               |              |             | R             | eset Value = X000 0000B |
|----------|------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|-------------------------------|-----------------|--------------|---------------|--------------|-------------|---------------|-------------------------|
|          | Not Bit                                                                                                                      | Addressa                                     | ble                           |                 |              |               |              |             |               | _                       |
|          |                                                                                                                              | -                                            | ECOMn                         | CAPPn           | CAPNn        | MATn          | TOGn         | PWMn        | ECCFn         |                         |
|          | Bit:                                                                                                                         | 7                                            | 6                             | 5               | 4            | 3             | 2            | 1           | 0             | -                       |
| Symbol   | Funct                                                                                                                        | tion                                         |                               |                 |              |               |              |             |               |                         |
| -        | Not im                                                                                                                       | nplemente                                    | d, reserved                   | for future u    | se*.         |               |              |             |               |                         |
| ECOMn    | Enable                                                                                                                       | e Compara                                    | ator. ECOM                    | n = 1 enabl     | es the comp  | parator fund  | ction.       |             |               |                         |
| CAPPn    | Captu                                                                                                                        | re Positive                                  | e, CAPPn =                    | 1 enables       | positive edg | e capture.    |              |             |               |                         |
| CAPNn    | Captu                                                                                                                        | ire Negativ                                  | e, CAPNn :                    | = 1 enables     | negative e   | dge capture   | <b>.</b>     |             |               |                         |
| MATn     |                                                                                                                              |                                              | ATn = 1, a r<br>set, flagging |                 |              | ter with this | module's c   | compare/cap | pture registe | er causes the CCFn bit  |
| TOGn     | Toggle. When TOGn = 1, a match of the PCA counter with this module's compare/capture register causes the CEXn pin to toggle. |                                              |                               |                 |              |               |              |             |               |                         |
| PWMn     | Pulse                                                                                                                        | Width Mo                                     | dulation Mo                   | de. PWMn        | = 1 enables  | the CEXn      | pin to be us | ed as a pul | se width mo   | odulated output.        |
| ECCFn    | Enable                                                                                                                       | e CCF inte                                   | errupt. Enab                  | les compai      | e/capture fl | ag CCFn in    | the CCON     | register to | generate ar   | n interrupt.            |
| NOTE:    |                                                                                                                              |                                              |                               |                 |              |               |              |             |               |                         |

\*User software should not write 1s to reserved bits. These bits may be used in future 8051 family products to invoke new features. In that case, the reset or inactive value of the new bit will be 0, and its active value will be 1. The value read from a reserved bit is indeterminate. SU01100

Figure 45. CCAPMn: PCA Modules Compare/Capture Registers

| - | ECOMn | CAPPn | CAPNn | MATn | TOGn | PWMn | ECCFn | MODULE FUNCTION                                   |
|---|-------|-------|-------|------|------|------|-------|---------------------------------------------------|
| Х | 0     | 0     | 0     | 0    | 0    | 0    | 0     | No operation                                      |
| Х | Х     | 1     | 0     | 0    | 0    | 0    | Х     | 16-bit capture by a positive-edge trigger on CEXn |
| Х | Х     | 0     | 1     | 0    | 0    | 0    | Х     | 16-bit capture by a negative trigger on CEXn      |
| Х | Х     | 1     | 1     | 0    | 0    | 0    | Х     | 16-bit capture by a transition on CEXn            |
| Х | 1     | 0     | 0     | 1    | 0    | 0    | Х     | 16-bit Software Timer                             |
| Х | 1     | 0     | 0     | 1    | 1    | 0    | Х     | 16-bit High Speed Output                          |
| Х | 1     | 0     | 0     | 0    | 0    | 1    | 0     | 8-bit PWM                                         |
| Х | 1     | 0     | 0     | 1    | Х    | 0    | Х     | Watchdog Timer                                    |

Figure 46. PCA Module Modes (CCAPMn Register)

#### PCA Capture Mode

To use one of the PCA modules in the capture mode, either one or both of the CCAPM bits CAPN and CAPP for that module must be set. The external CEX input for the module (on port 1) is sampled for a transition. When a valid transition occurs, the PCA hardware loads the value of the PCA counter registers (CH and CL) into the module's capture registers (CCAPnL and CCAPnH). If the CCFn bit for the module in the CCON SFR and the ECCFn bit in the CCAPMn SFR are set, then an interrupt will be generated (refer to Figure 47).

#### 16-bit Software Timer Mode

The PCA modules can be used as software timers by setting both the ECOM and MAT bits in the modules CCAPMn register. The PCA timer will be compared to the module's capture registers, and when a match occurs, an interrupt will occur if the CCFn (CCON SFR) and the ECCFn (CCAPMn SFR) bits for the module are both set (see Figure 48).

#### **High Speed Output Mode**

In this mode, the CEX output (on port 1) associated with the PCA module will toggle each time a match occurs between the PCA

counter and the module's capture registers. To activate this mode, the TOG, MAT, and ECOM bits in the module's CCAPMn SFR must be set (see Figure 49).

#### **Pulse Width Modulator Mode**

All of the PCA modules can be used as PWM outputs. Figure 50 shows the PWM function. The frequency of the output depends on the source for the PCA timer. All of the modules will have the same frequency of output because they all share the PCA timer. The duty cycle of each module is independently variable by using the module's capture register CCAPLn. When the value of the PCA CL SFR is less than the value in the module's CCAPLn SFR, the output will be low. When it is equal to or greater than, the output will be high. When CL overflows from FF to 00, CCAPLn is reloaded with the value in CCAPHn. This allows PWM update without glitches. The PWM and ECOM bits in the module's CCAPMn register must be set to enable the PWM mode.

# P89C660/P89C662/P89C664/ P89C668



Figure 47. PCA Capture Mode



Figure 48. PCA Compare Mode

# 80C51 8-bit Flash microcontroller family 16KB/32KB/64KB ISP/IAP Flash with 512B/1KB/2KB/8KB RAM



Figure 54. Internal and External Data Memory Address Space with EXTRAM = 0

# Hardware WatchDog Timer (One-Time Enabled with Reset-Out for P89C660/662/664/668)

The WDT is intended as a recovery method in situations where the CPU may be subjected to software upset. The WDT consists of a 14-bit counter and the WatchDog Timer reset (WDTRST) SFR. The WDT is disabled at reset. To enable the WDT, user must write 01EH and 0E1H in sequence to the WDTRST (SFR location 0A6H). When WDT is enabled, it will increment every machine cycle while the oscillator is running and there is no way to disable the WDT except through reset (either hardware reset or WDT overflow reset). When WDT overflows, it will drive an output reset HIGH pulse at the RST pin.

### Using the WDT

To enable the WDT, user must write 01EH and 0E1H in sequence to the WDTRST (SFR location 0A6H). When WDT is enabled, the user needs to service it by writing 01EH and 0E1H to WDTRST to avoid WDT overflow. The 14-bit counter overflows when it reaches 16383 (3FFFH) and this will reset the device. When WDT is enabled, it will increment every machine cycle while the oscillator is running. This means the user must reset the WDT at least every 16383 machine cycles. To reset the WDT, the user must write 01EH and 0E1H to WDTRST. WDTRST is a write only register. The WDT counter cannot be read or written. When the WDT overflows, it will generate an output RESET pulse at the RST pin. The RESET pulse duration is  $98 \times T_{OSC}$  (6 clock mode; 196 in 12 clock mode), where  $T_{OSC} = 1/f_{OSC}$ . To make the best use of the WDT, it should be serviced in those sections of code that will periodically be executed within the time required to prevent a WDT reset.

P89C660/P89C662/P89C664/

# 80C51 8-bit Flash microcontroller family 16KB/32KB/64KB ISP/IAP Flash with 512B/1KB/2KB/8KB RAM

### In Application Programming Method

Several In Application Programming (IAP) calls are available for use by an application program to permit selective erasing and programming of Flash sectors. All calls are made through a common interface, PGM\_MTP. The programming functions are selected by setting up the microcontroller's registers before making a call to PGM\_MTP at FFF0H. The oscillator frequency is an integer number rounded down to the nearest megahertz. For example, set R0 to 11 for 11.0592 MHz. Results are returned in the registers. The IAP calls are shown in Table 15.

#### Using the Watchdog Timer (WDT)

The 89C66x devices support the use of the WDT in IAP. The user specifies that the WDT is to be fed by setting the most significant bit of the function parameter passed in R1 prior to calling PGM\_MTP. The WDT function is only supported for Block Erase when using the Quick Block Erase. The Quick Block Erase is specified by performing a Block Erase with register R0 = 0. Requesting a WDT feed during IAP should only be performed in applications that use the WDT since the process of feeding the WDT will start the WDT if the WDT was not working.

P89C660/P89C662/P89C664/

### Table 15. IAP calls

| IAP CALL          | PARAMETER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PROGRAM DATA BYTE | Input Parameters:         R0 = osc freq (integer)         R1 = 02h         R1 = 82h (WDT feed, Rx2 & 66x only)         DPTR = address of byte to program         ACC = byte to program         Return Parameter         ACC = 00 if pass, !00 if fail         Sample routine:         ;***** Program Device Data (DData) *****         ;***** ACC holds data to write         ;***** Returns with ACC = 00h if successful, else ACC NEQ 00h         WRData:         MOV       AUXR1,#20H       ;set the ENBOOT bit         MOV       R0, #11       ;FOSC         MOV       R1,#02H       ;data to write         MOV       AJMATA       ;data to write         MOV       DPTR,Address       ;specify address of byte to read         CALL       PGM_MTP       ;execute the function |
| ERASE BLOCK       | <pre>Input Parameters:<br/>R0 = osc freq (integer)<br/>R0 = 0 (QUICK ERASE, Rx2 &amp; 66x only)<br/>R1 = 01h<br/>R1 = 81h (WDT feed, Rx2 &amp; 66x only; can only be used with Quick Erase)<br/>DPH = block code as shown below:<br/>block 0, 0k to 8k, 00H<br/>block 1, 8k to 16k, 20H<br/>block 2, 16k to 32k, 40H<br/>block 3, 32k to 48k, 80H<br/>block 4, 48k to 64k, C0H<br/>DPL = 00h</pre>                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | Return Parameter<br>none<br>Sample routine:<br>;***** Erase Code Memory Block *****<br>;***** DPH (7:5) indicates which of the 5 blocks to erase<br>;***** DPTR values for the blocks are:<br>; 0000h = block 0<br>; 2000h = block 0<br>; 4000h = block 1<br>; 4000h = block 2<br>; 8000h = block 3<br>; C000h = block 4                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                   | ERSBLK:<br>MOV AUXR1,#20H ;set the ENBOOT bit<br>MOV R0, #11 ;FOSC<br>MOV R1,#01H ;erase block<br>MOV DPTR,#BLk_NUM ;specify which block<br>CALL PGM_MTP ;execute the function<br>RET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

# P89C660/P89C662/P89C664/ P89C668

### **ABSOLUTE MAXIMUM RATINGS1, 2, 3**

| PARAMETER                                                                                    | RATING                 | UNIT |
|----------------------------------------------------------------------------------------------|------------------------|------|
| Operating temperature under bias                                                             | 0 to +70 or -40 to +85 | °C   |
| Storage temperature range                                                                    | -65 to +150            | °C   |
| Voltage on EA/V <sub>PP</sub> pin to V <sub>SS</sub>                                         | 0 to +13.0             | V    |
| Voltage on any other pin to $V_{SS}$                                                         | -0.5 to +6.5           | V    |
| Maximum I <sub>OL</sub> per I/O pin                                                          | 15                     | mA   |
| Power dissipation (based on package heat transfer limitations, not device power consumption) | 1.5                    | W    |

NOTES:

Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any conditions other than those described in the AC and DC Electrical Characteristics section of this specification is not implied.

This product includes circuitry specifically designed for the protection of its internal devices from the damaging effects of excessive static charge. Nonetheless, it is suggested that conventional precautions be taken to avoid applying greater than the rated maximum. Parameters are valid over operating temperature range unless otherwise specified. All voltages are with respect to V<sub>SS</sub> unless otherwise noted. 2.

3.

### DC ELECTRICAL CHARACTERISTICS

 $T_{amb} = 0 \degree C$  to +70  $\degree C$ , 5 V ± 10% or -40  $\degree C$  to +85  $\degree C$ ; 5V ±5%; V<sub>SS</sub> = 0 V

| CVMDOL           | DADAMETED                                                                                                                                                                                       | TEST                                                                                                                                                 |                         | UNIT             |                          |                |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------------------|--------------------------|----------------|--|
| SYMBOL           | PARAMETER                                                                                                                                                                                       | CONDITIONS                                                                                                                                           | MIN                     | TYP <sup>1</sup> | MAX                      | UNIT           |  |
| V <sub>IL</sub>  | Input low voltage                                                                                                                                                                               | 4.5 V < V <sub>CC</sub> < 5.5 V                                                                                                                      | -0.5                    |                  | 0.2 V <sub>CC</sub> -0.1 | V              |  |
| V <sub>IL2</sub> | Input low voltage to P1.6/SCL, P1.7/SDA <sup>11</sup>                                                                                                                                           |                                                                                                                                                      | -0.5                    |                  | 0.3V <sub>DD</sub>       | V              |  |
| VIH              | Input high voltage (ports 0, 1, 2, 3, EA)                                                                                                                                                       |                                                                                                                                                      | 0.2V <sub>CC</sub> +0.9 |                  | V <sub>CC</sub> +0.5     | V              |  |
| V <sub>IH1</sub> | Input high voltage, XTAL1, RST                                                                                                                                                                  |                                                                                                                                                      | 0.7V <sub>CC</sub>      |                  | V <sub>CC</sub> +0.5     | V              |  |
| V <sub>IH2</sub> | Input high voltage, P1.6/SCL, P1.7/SDA <sup>11</sup>                                                                                                                                            |                                                                                                                                                      | 0.7V <sub>DD</sub>      |                  | 6.0                      | V              |  |
| V <sub>OL</sub>  | Output low voltage, ports 1, 2, 3 <sup>8</sup>                                                                                                                                                  | $V_{CC} = 4.5 V$<br>$I_{OL} = 1.6 mA^2$                                                                                                              | -                       |                  | 0.4                      | V              |  |
| V <sub>OL1</sub> | Output low voltage, port 0, ALE, PSEN 7, 8                                                                                                                                                      | $V_{CC} = 4.5 V$<br>$I_{OL} = 3.2 mA^2$                                                                                                              | -                       |                  | 0.45                     | V              |  |
| V <sub>OL2</sub> | Output low voltage, P1.6/SCL, P1.7/SDA                                                                                                                                                          | I <sub>OL</sub> = 3.0 mA                                                                                                                             | -                       |                  | 0.4                      | V              |  |
| V <sub>OH</sub>  | Output high voltage, ports 1, 2, 3 <sup>3</sup>                                                                                                                                                 | V <sub>CC</sub> = 4.5 V<br>I <sub>OH</sub> = -30 μA                                                                                                  | V <sub>CC</sub> – 0.7   |                  | -                        | V              |  |
| V <sub>OH1</sub> | Output high voltage (port 0 in external bus mode), ALE <sup>9</sup> , PSEN <sup>3</sup>                                                                                                         | $V_{CC} = 4.5 V$<br>$I_{OH} = -3.2 mA$                                                                                                               | V <sub>CC</sub> – 0.7   |                  | -                        | V              |  |
| IIL              | Logical 0 input current, ports 1, 2, 3                                                                                                                                                          | V <sub>IN</sub> = 0.4 V                                                                                                                              | -1                      |                  | -75                      | μΑ             |  |
| I <sub>TL</sub>  | Logical 1-to-0 transition current, ports 1, 2, 3 <sup>6</sup>                                                                                                                                   | V <sub>IN</sub> = 2.0 V<br>See Note 4                                                                                                                | -                       |                  | -650                     | μΑ             |  |
| ILI              | Input leakage current, port 0                                                                                                                                                                   | $0.45 < V_{IN} < V_{CC} - 0.3$                                                                                                                       | -                       |                  | ±10                      | μΑ             |  |
| I <sub>L2</sub>  | Input leakage current, P1.6/SCL, P1.7/SDA                                                                                                                                                       | 0V < VI < 6 V<br>0V < V <sub>DD</sub> < 5.5 V                                                                                                        | -                       |                  | 10                       | μA             |  |
| I <sub>CC</sub>  | Power supply current (see Figure 64):<br>Active mode (see Note 5)<br>Idle mode (see Note 5)<br>Power-Down mode or clock stopped (see Figure 71<br>for conditions)<br>Programming and erase mode | See Note 5<br>$T_{amb} = 0 \degree C \text{ to } 70 \degree C$<br>$T_{amb} = -40 \degree C \text{ to } +85 \degree C$<br>$f_{amb} = -20 \text{ MHz}$ |                         | 20               | 100<br>125               | μA<br>μA<br>mA |  |
| P                | Internal reset pull-down resistor                                                                                                                                                               | f <sub>osc</sub> = 20 MHz                                                                                                                            | 40                      | 00               | 225                      | mA<br>kΩ       |  |
| R <sub>RST</sub> | Pin capacitance <sup>10</sup> (except EA)                                                                                                                                                       |                                                                                                                                                      | 40                      |                  |                          |                |  |
| CIO              | Pin capacitance (except EA)                                                                                                                                                                     |                                                                                                                                                      | -                       |                  | 15                       | pF             |  |

NOTES:

1. Typical ratings are not guaranteed. The values listed are at room temperature, 5 V.

Capacitive loading on ports 0 and 2 may cause spurious noise to be superimposed on the VoLs of ALE and ports 1 and 3. The noise is due to external bus capacitance discharging into the port 0 and port 2 pins when these pins make 1-to-0 transitions during bus operations. In the worst cases (capacitive loading > 100 pF), the noise pulse on the ALE pin may exceed 0.8 V. In such cases, it may be desirable to qualify ALE with a Schmitt Trigger, or use an address latch with a Schmitt Trigger STROBE input. IOL can exceed these conditions provided that no single output sinks more than 5mA and no more than two outputs exceed the test conditions.

3. Capacitive loading on ports 0 and 2 may cause the V<sub>OH</sub> on ALE and PSEN to momentarily fall below the V<sub>CC</sub>-0.7 specification when the address bits are stabilizing.

Pins of ports 1, 2 and 3 source a transition current when they are being externally driven from 1 to 0. The transition current reaches its 4. maximum value when V<sub>IN</sub> is approximately 2 V.

5. See Figures 68 through 71 for  $I_{CC}$  test conditions and Figure 64 for  $I_{CC}$  vs Freq.

Idle mode:  $I_{CC(MAX)} = (1.2 \times FREQ. + 0.0)$  mA in all devices, in 6 clock mode;  $(1.4 \times FREQ. + 8.0)$  mA in 12 clock mode. 6. This value applies to  $T_{amb} = 0$  °C to +70 °C. 7. Load capacitones for each 0.4 T I<sub>CC(MAX)</sub> = (2.8 × FREQ. + 8.0)mA for all devices, in 6 clock mode; (1.4 × FREQ. + 8.0)mA in 12 clock mode.

- Load capacitance for port 0, ALE, and PSEN = 100 pF, load capacitance for all other outputs = 80 pF.
- Under steady state (non-transient) conditions, I<sub>OL</sub> must be externally limited as follows: Maximum I<sub>OL</sub> per port pin: 15 mA (\*NOTE: This is 85 °C specification.)

Maximum IOL per 8-bit port: 26 mA

Maximum total IOL for all outputs: 71 mA

If IOL exceeds the test condition, VOL may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test conditions.

9. ALE is tested to V<sub>OH1</sub>, except when ALE is off then V<sub>OH</sub> is the voltage specification.

10. Pin capacitance is characterized but not tested. Pin capacitance is less than 25 pF. Pin capacitance of ceramic package is less than 15 pF (except EA is 25 pF).

11. The input threshold voltage of P1.6 and P1.7 (SIO1) meets the I<sup>2</sup>C specification, so an input voltage below 1.5 V will be recognized as a logic 0 while an input voltage above 3.0 V will be recognized as a logic 1.

# P89C660/P89C662/P89C664/ P89C668

# P89C660/P89C662/P89C664/ P89C668

# AC ELECTRICAL CHARACTERISTICS (6 CLOCK MODE) $T_{amb} = 0 \ ^{\circ}C \ to \ +70 \ ^{\circ}C, \ V_{CC} = 5 \ V \pm 10\% \ or \ -40 \ ^{\circ}C \ to \ +85 \ ^{\circ}C, \ V_{CC} = 5 \ V \pm 5\%, \ V_{SS} = 0 \ V^{1, \ 2, \ 3}$

|                     |        |                                          | VARIABL                   | E CLOCK <sup>4</sup>                 | 20 MHz |     |      |
|---------------------|--------|------------------------------------------|---------------------------|--------------------------------------|--------|-----|------|
| SYMBOL              | FIGURE | PARAMETER                                | MIN                       | MAX                                  | MIN    | MAX | דואט |
| 1/t <sub>CLCL</sub> | 57     | Oscillator frequency                     | 0                         | 20                                   | -      | -   | MHz  |
| t <sub>LHLL</sub>   | 57     | ALE pulse width                          | t <sub>CLCL</sub> -40     | _                                    | 10     | - 1 | ns   |
| t <sub>AVLL</sub>   | 57     | Address valid to ALE low                 | 0.5t <sub>CLCL</sub> -20  | -                                    | 5      | -   | ns   |
| t <sub>LLAX</sub>   | 57     | Address hold after ALE low               | 0.5t <sub>CLCL</sub> -20  | -                                    | 5      | -   | ns   |
| t <sub>LLIV</sub>   | 57     | ALE low to valid instruction in          | -                         | 2t <sub>CLCL</sub> -65               | -      | 35  | ns   |
| t <sub>LLPL</sub>   | 57     | ALE low to PSEN low                      | 0.5t <sub>CLCL</sub> -20  | -                                    | 5      | -   | ns   |
| t <sub>PLPH</sub>   | 57     | PSEN pulse width                         | 1.5t <sub>CLCL</sub> -45  | -                                    | 30     | - 1 | ns   |
| t <sub>PLIV</sub>   | 57     | PSEN low to valid instruction in         | -                         | 1.5t <sub>CLCL</sub> -60             | -      | 15  | ns   |
| t <sub>PXIX</sub>   | 57     | Input instruction hold after PSEN        | 0                         | -                                    | 0      | -   | ns   |
| t <sub>PXIZ</sub>   | 57     | Input instruction float after PSEN       | -                         | 0.5t <sub>CLCL</sub> -20             | -      | 5   | ns   |
| t <sub>AVIV</sub>   | 57     | Address to valid instruction in          | -                         | 2.5t <sub>CLCL</sub> -80             | -      | 45  | ns   |
| t <sub>PLAZ</sub>   | 57     | PSEN low to address float                | -                         | 10                                   | -      | 10  | ns   |
| Data Mem            | ory    |                                          | •                         |                                      |        |     |      |
| t <sub>RLRH</sub>   | 58, 59 | RD pulse width                           | 3t <sub>CLCL</sub> -100   | -                                    | 50     | -   | ns   |
| t <sub>WLWH</sub>   | 58, 59 | WR pulse width                           | 3t <sub>CLCL</sub> -100   | -                                    | 50     | -   | ns   |
| t <sub>RLDV</sub>   | 58, 59 | RD low to valid data in                  | -                         | 2.5t <sub>CLCL</sub> -90             | -      | 35  | ns   |
| t <sub>RHDX</sub>   | 58, 59 | Data hold after RD                       | 0                         | -                                    | 0      | -   | ns   |
| t <sub>RHDZ</sub>   | 58, 59 | Data float after RD                      | -                         | t <sub>CLCL</sub> -20                | -      | 5   | ns   |
| t <sub>LLDV</sub>   | 58, 59 | ALE low to valid data in                 | -                         | 4t <sub>CLCL</sub> -150              | -      | 50  | ns   |
| t <sub>AVDV</sub>   | 58, 59 | Address to valid data in                 | -                         | 4.5t <sub>CLCL</sub> -165            | -      | 60  | ns   |
| t <sub>LLWL</sub>   | 58, 59 | ALE low to RD or WR low                  | 1.5t <sub>CLCL</sub> -50  | 1.5t <sub>CLCL</sub> +50             | 25     | 125 | ns   |
| t <sub>AVWL</sub>   | 58, 59 | Address valid to WR low or RD low        | 2t <sub>CLCL</sub> -75    | -                                    | 25     | -   | ns   |
| t <sub>QVWX</sub>   | 58, 59 | Data valid to WR transition              | 0.5t <sub>CLCL</sub> -25  | -                                    | 0      | -   | ns   |
| t <sub>WHQX</sub>   | 58, 59 | Data hold after WR                       | 0.5t <sub>CLCL</sub> -20  | -                                    | 5      | - 1 | ns   |
| t <sub>QVWH</sub>   | 59     | Data valid to WR high                    | 3.5t <sub>CLCL</sub> -130 | -                                    | 45     | - 1 | ns   |
| t <sub>RLAZ</sub>   | 58, 59 | RD low to address float                  | -                         | 0                                    | -      | 0   | ns   |
| t <sub>WHLH</sub>   | 58, 59 | RD or WR high to ALE high                | 0.5t <sub>CLCL</sub> -20  | 0.5t <sub>CLCL</sub> +20             | 5      | 45  | ns   |
| External C          | lock   |                                          |                           |                                      |        |     |      |
| t <sub>CHCX</sub>   | 61     | High time                                | 20                        | t <sub>CLCL</sub> -t <sub>CLCX</sub> | _      | -   | ns   |
| t <sub>CLCX</sub>   | 61     | Low time                                 | 20                        | tCLCL-tCHCX                          | -      | -   | ns   |
| t <sub>CLCH</sub>   | 61     | Rise time                                | -                         | 5                                    | -      | -   | ns   |
| tCHCL               | 61     | Fall time                                | -                         | 5                                    | -      | -   | ns   |
| Shift Regi          | ster   |                                          | I                         |                                      |        |     |      |
| t <sub>XLXL</sub>   | 60     | Serial port clock cycle time             | 6t <sub>CLCL</sub>        | -                                    | 300    | -   | ns   |
| t <sub>QVXH</sub>   | 60     | Output data setup to clock rising edge   | 5t <sub>CLCL</sub> -133   | _                                    | 117    | -   | ns   |
| t <sub>XHQX</sub>   | 60     | Output data hold after clock rising edge | t <sub>CLCL</sub> -30     | _                                    | 20     | -   | ns   |
| t <sub>XHDX</sub>   | 60     | Input data hold after clock rising edge  | 0                         | _                                    | 0      | -   | ns   |
| t <sub>XHDV</sub>   | 60     | Clock rising edge to input data valid    |                           | 5t <sub>CLCL</sub> -133              | _      | 117 | ns   |

NOTES:

Parameters are valid over operating temperature range unless otherwise specified.
 Load capacitance for port 0, ALE, and PSEN = 100 pF, load capacitance for all other outputs = 80 pF.

3. Interfacing the microcontroller to devices with float times up to 45ns is permitted. This limited bus contention will not cause damage to Port 0 drivers.

4. Parts are tested to 2 MHz, but are guaranteed to operate down to 0 Hz.

# P89C660/P89C662/P89C664/ P89C668

## AC ELECTRICAL CHARACTERISTICS (6 CLOCK MODE) (Continued)

 $T_{amb}$  = 0 °C to +70 °C,  $V_{CC}$  = 5 V ± 10% or -40 °C to +85 °C,  $V_{CC}$  = 5 V ± 5%,  $V_{SS}$  = 0 V<sup>1, 2</sup>

| amb                      |                                           |                                         |                                          |
|--------------------------|-------------------------------------------|-----------------------------------------|------------------------------------------|
| SYMBOL                   | PARAMETER                                 | INPUT                                   | OUTPUT                                   |
| I <sup>2</sup> C Interfa | ce                                        |                                         |                                          |
| t <sub>HD;STA</sub>      | START condition hold time                 | ≥ 7 t <sub>CLCL</sub>                   | > 4.0 µs <sup>4</sup>                    |
| t <sub>LOW</sub>         | SCL low time                              | ≥ 8 t <sub>CLCL</sub>                   | > 4.7 µs <sup>46</sup>                   |
| t <sub>HIGH</sub>        | SCL high time                             | ≥ 7 t <sub>CLCL</sub>                   | > 4.0 µs <sup>4</sup>                    |
| t <sub>RC</sub>          | SCL rise time                             | ≤ 1 μs                                  | _ 5                                      |
| t <sub>FC</sub>          | SCL fall time                             | ≤ 0.3 μs                                | < 0.3 µs <sup>6</sup>                    |
| t <sub>SU;DAT1</sub>     | Data set-up time                          | ≥ 250 ns                                | > 10 t <sub>CLCL</sub> – t <sub>RD</sub> |
| t <sub>SU;DAT2</sub>     | SDA set-up time (before rep. START cond.) | ≥ 250 ns                                | > 1 µs <sup>4</sup>                      |
| t <sub>SU;DAT3</sub>     | SDA set-up time (before STOP cond.)       | ≥ 250 ns                                | > 4 t <sub>CLCL</sub>                    |
| t <sub>HD;DAT</sub>      | Data hold time                            | ≥ 0 ns                                  | $> 4 t_{CLCL} - t_{FC}$                  |
| t <sub>SU;STA</sub>      | Repeated START set-up time                | $\geq$ 7 t <sub>CLCL</sub> <sup>4</sup> | > 4.7 µs <sup>4</sup>                    |
| t <sub>SU;STO</sub>      | STOP condition set-up time                | $\geq$ 7 t <sub>CLCL</sub> <sup>4</sup> | > 4.0 µs <sup>4</sup>                    |
| t <sub>BUF</sub>         | Bus free time                             | $\geq$ 7 t <sub>CLCL</sub> <sup>4</sup> | > 4.7 µs <sup>4</sup>                    |
| t <sub>RD</sub>          | SDA rise time                             | $\leq 1 \ \mu s^7$                      | _ 5                                      |
| t <sub>FD</sub>          | SDA fall time                             | ≤ 300 ns <sup>7</sup>                   | < 0.3 μs <sup>6</sup>                    |

NOTES:

Parameters are valid over operating temperature range and voltage range unless otherwise specified.
 Load capacitance for port 0, ALE, and PSEN = 100 pF, load capacitance for all other outputs = 80 pF.

3. These values are characterized but not 100% production tested.

At 100 kbit/s. At other bit rates this value is inversely proportional to the bit-rate of 100 kbit/s.
 Determined by the external bus-line capacitance and the external bus-line pull-resistor, this must be < 1 μs.</li>

6. Spikes on the SDA and SCL lines with a duration of less than 3 t<sub>CLCL</sub> will be filtered out. Maximum capacitance on bus-lines SDA and

SCL = 400 pF.7.  $t_{CLCL} = 1/f_{OSC}$  = one oscillator clock period at pin XTAL1.

# P89C660/P89C662/P89C664/ P89C668

### AC ELECTRICAL CHARACTERISTICS (12 CLOCK MODE) (Continued)

 $T_{amb} = 0^{\circ}C$  to +70°C,  $V_{CC} = 5 V \pm 10\%$ , or -40°C to +85°C,  $V_{CC} = 5 V \pm 5\%$ ,  $V_{SS} = 0 V^{1, 2}$ 

| SYMBOL                   | PARAMETER                                 | INPUT                                    | OUTPUT                                   |
|--------------------------|-------------------------------------------|------------------------------------------|------------------------------------------|
| I <sup>2</sup> C Interfa | ce                                        |                                          |                                          |
| t <sub>HD;STA</sub>      | START condition hold time                 | $\geq$ 14 t <sub>CLCL</sub>              | > 4.0 µs <sup>4</sup>                    |
| t <sub>LOW</sub>         | SCL low time                              | ≥ 16 t <sub>CLCL</sub>                   | > 4.7 µs <sup>4</sup>                    |
| t <sub>HIGH</sub>        | SCL high time                             | $\geq$ 14 t <sub>CLCL</sub>              | > 4.0 µs <sup>4</sup>                    |
| t <sub>RC</sub>          | SCL rise time                             | ≤ 1 μs                                   | _ 5                                      |
| t <sub>FC</sub>          | SCL fall time                             | ≤ 0.3 μs                                 | < 0.3 µs <sup>6</sup>                    |
| t <sub>SU;DAT1</sub>     | Data set-up time                          | ≥ 250 ns                                 | > 20 t <sub>CLCL</sub> – t <sub>RD</sub> |
| t <sub>SU;DAT2</sub>     | SDA set-up time (before rep. START cond.) | ≥ 250 ns                                 | > 1 µs <sup>4</sup>                      |
| t <sub>SU;DAT3</sub>     | SDA set-up time (before STOP cond.)       | ≥ 250 ns                                 | > 8 t <sub>CLCL</sub>                    |
| t <sub>HD;DAT</sub>      | Data hold time                            | ≥ 0 ns                                   | $> 8 t_{CLCL} - t_{FC}$                  |
| t <sub>SU;STA</sub>      | Repeated START set-up time                | $\geq$ 14 t <sub>CLCL</sub> <sup>4</sup> | > 4.7 µs <sup>4</sup>                    |
| t <sub>SU;STO</sub>      | STOP condition set-up time                | $\geq$ 14 t <sub>CLCL</sub> <sup>4</sup> | > 4.0 µs <sup>4</sup>                    |
| t <sub>BUF</sub>         | Bus free time                             | $\geq$ 14 t <sub>CLCL</sub> <sup>4</sup> | > 4.7 µs <sup>4</sup>                    |
| t <sub>RD</sub>          | SDA rise time                             | $\leq 1 \ \mu s^7$                       | _ 5                                      |
| t <sub>FD</sub>          | SDA fall time                             | ≤ 300 ns <sup>7</sup>                    | < 0.3 μs <sup>6</sup>                    |

NOTES:

1. Parameters are valid over operating temperature range and voltage range unless otherwise specified.

2. Load capacitance for port 0, ALE, and PSEN = 100 pF, load capacitance for all other outputs = 80 pF.

3. These values are characterized but not 100% production tested.

4. At 100 kbit/s. At other bit rates this value is inversely proportional to the bit-rate of 100 kbit/s.

5. Determined by the external bus-line capacitance and the external bus-line pull-resistor, this must be < 1  $\mu$ s.

 Spikes on the SDA and SCL lines with a duration of less than 3 t<sub>CLCL</sub> will be filtered out. Maximum capacitance on bus-lines SDA and SCL = 400 pF.

7. t<sub>CLCL</sub> = 1/f<sub>OSC</sub> = one oscillator clock period at pin XTAL1. For 63 ns < t<sub>CLCL</sub> < 285 ns (16 MHz > f<sub>OSC</sub> > 3.5 MHz) the I<sup>2</sup>C interface meets the I<sup>2</sup>C-bus specification for bit-rates up to 100 kbit/s.

# 80C51 8-bit Flash microcontroller family 16KB/32KB/64KB ISP/IAP Flash with 512B/1KB/2KB/8KB RAM



Figure 62. AC Testing Input/Output



P89C660/P89C662/P89C664/





Figure 64. I<sub>CC</sub> vs. FREQ Valid only within frequency specifications of the device under test