

# **General Description**

The MAX7651/MAX7652 are complete 12-bit data-acquisition systems featuring an algorithmic, switched-capacitor, analog-to-digital converter (ADC), a pulsewidth-modulated digital-to-analog converter (DAC), three timer/counters, and an industry-standard 8051 microprocessor core with a variety of I/O peripherals. Powerdown capability and full functionality with supply voltages as low as +3V make the MAX7651/MAX7652 suitable for portable and power-sensitive applications.

The MAX7651/MAX7652 perform fully differential voltage measurements with 12-bit resolution, programmable gain, and separate track-and-hold for both positive and negative inputs. The converter accepts versatile input modes consisting of four 2-channel signal pairs or eight 1-channel signals relative to a floating common.

The MAX7651/MAX7652 microprocessor systems feature a CPU, 256 bytes of RAM, two 8kB flash memory, four 8-bit I/O ports, two UARTs, an interrupt controller, and a watchdog timer. Only four clock cycles are required to complete each microprocessor instruction.

The MAX7651/MAX7652 are available in 64-pin TQFP packages.

# **Applications**

Hand-Held Instruments Portable Data-Acquisition Systems **Temperature Controllers Smart Transmitters Data Loggers** Multi-Channel Data-Acquisition with Data Formatting

#### Features

- ♦ 12-Bit 53ksps ADC with Fully Differential Inputs
- ◆ Dual 8-Bit PWM DAC Outputs
- **♦ Three Timers**
- ♦ 4-Clock Cycle 8051-Compatible Instruction Set with Dual Data Pointers
- ♦ Programmable Watchdog Supervisor
- ♦ Four Parallel I/O Ports
- ◆ Dual Serial I/O Ports (up to 375kb)
- ♦ +3V or +5V Single-Supply Operation
- ♦ DC to 12MHz Clock Speed
- ♦ 64-Pin TQFP Package

## **Ordering Information**

| PART       | TEMP. RANGE    | PIN-PACKAGE |
|------------|----------------|-------------|
| MAX7651CCB | 0°C to +70°C   | 64 TQFP     |
| MAX7651ECB | -40°C to +85°C | 64 TQFP     |
| MAX7652CCB | 0°C to +70°C   | 64 TQFP     |
| MAX7652ECB | -40°C to +85°C | 64 TQFP     |

Pin configuration appears at end of data sheet.

# **Functional Diagram**



MIXIM

Maxim Integrated Products 1

## **ABSOLUTE MAXIMUM RATINGS**

| AVDD, PWMV, DVDD to AGND            | 0.3V to +6V                         |
|-------------------------------------|-------------------------------------|
| AVDD, DVDD to DGND                  | 0.3V to +6V                         |
| AVDD to DVDD                        | 0.3V to +0.3V                       |
| AGND, PWMG to DGND                  | 0.3V to +0.3V                       |
| Analog Inputs (AIN_, ACOM, XTAL1,   | XTAL2)                              |
| to AGND                             | 0.3V to AV <sub>DD</sub> + 0.3V     |
| Analog Outputs (PWMA, PWMB)         | _                                   |
| to AGND                             | 0.3V to AV <sub>DD</sub> + 0.3V     |
| Digital I/O (A_, AD_, ALE/PROG, EA/ | / <sub>PP</sub> , <del>INTO</del> , |
| ÎNT1, P, PSEN, RST) to DGND         | 0.3V to $DV_{DD} + 0.3V$            |
|                                     |                                     |

| REF+, REF- to AGND0.3V to AVDD_+                      |       |
|-------------------------------------------------------|-------|
| Short-Circuit Duration (PWM_, P, ALE/PROG, PSEN)      | 1s    |
| Continuous Power Dissipation ( $T_A = +70^{\circ}C$ ) |       |
| 64-Pin TQFP (derate 5.00mW/°C above +70°C)50          | 0mW   |
| Operating Temperature Range                           |       |
| MAX765_CCB0°C to +                                    | -70°C |
| MAX765_ECB40°C to +                                   | .85°C |
| Junction Temperature+1                                | 50°C  |
| Storage Temperature Range65°C to +1                   | 50°C  |
| Lead Temperature (soldering, 10s)+3                   |       |

Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of the specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

# **ELECTRICAL CHARACTERISTICS**

(MAX7651 AVDD = VPWMV = DVDD = VREF+ =  $\pm 4.5$ V to  $\pm 5.5$ V, VREF- = 0, fXTAL =  $\pm 12$ MHz. MAX7652 AVDD = VPWMV = DVDD =  $\pm 2.7$ V to  $\pm 3.6$ V, VREF+ =  $\pm 2.5$ V, VREF- = 0, ACOM = AVDD/2, fXTAL =  $\pm 12$ MHz. TA = TMIN to TMAX, unless otherwise noted. Typical values are at TA =  $\pm 25$ °C.)

| PARAMETER                               | SYMBOL     | CONDITIONS              |                        |            | TYP   | MAX  | UNITS  |
|-----------------------------------------|------------|-------------------------|------------------------|------------|-------|------|--------|
| DC ACCURACY                             |            |                         |                        |            |       |      |        |
| Resolution                              | RES        |                         |                        | 12         |       |      | bits   |
|                                         |            | Differential            | MAX7651                |            |       | ±1.5 |        |
| Relative Accuracy (Note 1)              | INL        | Dillerential            | MAX7652                |            |       | ±1.0 | LSB    |
| Thelative Accuracy (Note 1)             | IINL       | Single-ended            | MAX7651                |            |       | ±4.0 | LSD    |
|                                         |            | origic crided           | MAX7652                |            |       | ±1.5 |        |
| Differential Nonlinearity               | DNL        | Differential            |                        |            | ±0.5  | ±1   | LSB    |
| (Note2)                                 | DIVL       | Single-ended            |                        |            | ±0.5  | ±1   | LOD    |
| Offset Error (Note 2)                   |            |                         |                        |            | ±2.3  | ±7   | LSB    |
| Offset Temperature<br>Coefficient       |            |                         |                        |            | ±0.25 |      | LSB/°C |
| Gain Error (Note 2)                     |            |                         |                        |            |       | 3    | %      |
| Gain Temperature<br>Coefficient         |            |                         |                        |            | ±3    |      | ppm/°C |
| Channel-to-Channel<br>Matching (Note 2) |            | Offset and gain         |                        |            | ±0.25 |      | LSB    |
| DYNAMIC SPECIFICATIO                    | NS (53ksps | , 1kHz SINE-WAVE INPUT, | 5Vp-p (ΜΑΧ7651), 2.5Vμ | р-р (MAX76 | 52))  |      | •      |
| Signal-to-Noise +                       | SINAD      | Differential            |                        |            | 71    |      | - dB   |
| Distortion                              | SINAD      | Single-ended            |                        |            | 67    |      | QB     |
| Total Harmonic Distortion               | THD        | All unaliased harmonics | Differential           |            | -78   | dB   |        |
| Total Harmonic Distortion               | טחו        | All unaliased narmonics | Single-ended           |            | -73   |      | ив     |
| Spurious-Free Dynamic                   | SFDR       | Differential            |                        |            | 81    |      | dB     |
| Range                                   | SEDH       | Single-ended            |                        |            | 79    |      | ив     |
| Channel-to-Channel<br>Crosstalk         |            | (Note 3)                |                        |            | -85   |      | dB     |
| Small-Signal Bandwidth                  |            | -3dB rolloff            |                        |            | 1     |      | MHz    |
| Full-Power Bandwidth                    |            |                         |                        |            | 1     |      | MHz    |

# **ELECTRICAL CHARACTERISTICS (continued)**

 $(MAX7651\ AV_{DD} = V_{PWMV} = DV_{DD} = V_{REF+} = +4.5V\ to\ +5.5V,\ V_{REF-} = 0,\ f_{XTAL} = 12MHz.\ MAX7652\ AV_{DD} = V_{PWMV} = DV_{DD} = +2.7V\ to\ +3.6V,\ V_{REF+} = +2.5V,\ V_{REF-} = 0,\ A_{COM} = A_{VDD}/2,\ f_{XTAL} = 12MHz.\ T_{A} = T_{MIN}\ to\ T_{MAX},\ unless otherwise\ noted.\ Typical\ values\ are\ at\ T_{A} = +25^{\circ}C.)$ 

| PARAMETER                                                     | SYMBOL           | CONDITIONS                              | MIN                                  | TYP | MAX                         | UNITS |
|---------------------------------------------------------------|------------------|-----------------------------------------|--------------------------------------|-----|-----------------------------|-------|
| CONVERSION RATE                                               | •                |                                         |                                      |     |                             | •     |
| Conversion Time                                               | tCONV            | $f_{XTAL} = 12MHz$                      | 18.7                                 |     |                             | μs    |
| Conversion Rate                                               |                  | f <sub>XTAL</sub> = 12MHz               |                                      |     | 53.6                        | ksps  |
| ANALOG INPUTS (AIN0-                                          | AIN7, ACOM       | 1)                                      |                                      |     |                             |       |
| Input Voltage Range                                           |                  |                                         | 0                                    | ,   | AV <sub>DD</sub>            | V     |
| Common-Mode Range                                             |                  |                                         | 0                                    | ,   | AV <sub>DD</sub>            | V     |
| Input Current                                                 |                  |                                         |                                      |     | 1                           | μΑ    |
| Input Capacitance                                             | C <sub>IN</sub>  |                                         |                                      | 10  |                             | рF    |
| DIGITAL INPUTS                                                |                  |                                         | •                                    |     |                             |       |
| Input Voltage Low                                             | VIL              |                                         | -0.5                                 |     | ).2 x<br><sub>DD</sub> - 1) | V     |
| Input Voltage High                                            | V                | Input high voltage, except XTAL and RST | 0.2 x<br>(DV <sub>DD</sub><br>+ 0.9) |     | DV <sub>DD</sub><br>+ 0.5   | V     |
|                                                               | V <sub>IH</sub>  | Input high voltage, XTAL and RST        | 0.7 x<br>(DV <sub>DD</sub><br>+ 0.1  |     | DV <sub>DD</sub><br>+ 0.5   | V     |
| Internal Reset Pulldown                                       |                  | MAX7651                                 | 90                                   |     | 409                         | L.O   |
| Resistance                                                    | R <sub>RST</sub> | MAX7652                                 | 170                                  |     | 490                         | kΩ    |
| Logical High-to-Low<br>Transition Current                     | I <sub>TL</sub>  | Guaranteed by design                    |                                      |     | 750                         | μΑ    |
| Logical Zero Input Current,<br>Ports 1, 2, and 3 ALE,<br>PSEN |                  | (Note 4)                                |                                      |     | 75                          | μΑ    |
| Input Leakage Current,<br>Port 0                              | I <sub>IN</sub>  | $V_{IN} = DV_{DD}$ or DGND              |                                      |     | ±10                         | μΑ    |
| Input Capacitance                                             |                  |                                         |                                      | 10  |                             | рF    |
| DIGITAL OUTPUTS                                               | •                |                                         | •                                    |     |                             |       |
| Output Low Voltage                                            | VoL              | I <sub>SINK</sub> = 4mA                 |                                      |     | 0.45                        | V     |
| 0 1 112 1 11 11                                               |                  | MAX7651: I <sub>SOURCE</sub> = 4mA      | 2.4                                  |     |                             | .,    |
| Output High Voltage                                           | Voн              | MAX7652: ISOURCE = 2mA                  | 2.4                                  |     |                             | V     |

# **ELECTRICAL CHARACTERISTICS (continued)**

 $(MAX7651: AV_{DD} = V_{PWMV} = DV_{DD} = V_{REF+} = +4.5V \ to +5.5V, V_{REF-} = 0, f_{XTAL} = 12MHz. \ MAX7652: AV_{DD} = V_{PWMV} = DV_{DD} = +2.7V \ to +3.6V, V_{REF+} = +2.5V, V_{REF-} = 0, A_{COM} = A_{VDD}/2, f_{XTAL} = 12MHz. \ T_A = T_{MIN} \ to T_{MAX}, unless otherwise noted. Typical values are at T_A = +25°C.)$ 

| PARAMETER                              | SYMBOL            | CONDITIONS                                     | MIN TY                      | P MAX                        | UNITS |
|----------------------------------------|-------------------|------------------------------------------------|-----------------------------|------------------------------|-------|
| EXTERNAL VOLTAGE R                     | EFERENCE (        | CHARACTERISTICS (REF+, REF-)                   |                             |                              |       |
| Reference Voltage<br>Range             |                   | V <sub>REF+</sub> - V <sub>REF-</sub>          | 0                           | $AV_{DD}$                    | V     |
| Reference Input Current                |                   |                                                |                             | 35                           | μΑ    |
| Reference Input<br>Capacitance         |                   |                                                | 10                          | )                            | pF    |
| POWER REQUIREMENTS                     | S                 |                                                | <b>I</b>                    |                              |       |
| Analog Supply Current                  |                   |                                                |                             | 5                            | mA    |
| D: :: 10                               |                   | MAX7651, during page erase                     |                             | 55                           |       |
| Digital Supply Current                 |                   | MAX7652, during page erase                     |                             | 40                           | mA    |
| Idle-Mode Digital                      |                   | MAX7651                                        | 13                          | 3 30                         | 0     |
| Supply Current                         |                   | MAX7652                                        | 5                           | 12                           | mA    |
| Stop-Mode Supply<br>Current            |                   | I <sub>AVDD</sub> + I <sub>DVDD</sub> (Note 5) |                             | 10                           | μA    |
| Analog Power-Supply<br>Rejection Ratio | PSRR              |                                                | -4                          | 0                            | dB    |
| PWM OUTPUTS                            |                   |                                                | L                           |                              | 1     |
| Output Low Voltage                     |                   | ISINK = 2mA                                    |                             | 0.4                          | V     |
| Output High Voltage                    |                   | ISOURCE = 2mA                                  | 2.4                         |                              | V     |
| FLASH EXTERNAL PRO                     | GRAMMING          | (FIGURE 1, NOTE 6)                             |                             |                              |       |
| Program Pulse Width                    | tprogl            |                                                | 10t <sub>CK</sub>           |                              | ns    |
| Program Address and Data Setup         | tasuw             | Guaranteed by design                           | 3t <sub>CK</sub>            |                              | ns    |
| Program Cycle Time                     | twrite            | MAX7651                                        | 7t <sub>CK</sub><br>+ 54000 | 16t <sub>CK</sub><br>+ 72000 | ns    |
| Trogram Cycle Time                     | WALLE             | MAX7652                                        | 7t <sub>CK</sub><br>+ 54000 | 32t <sub>CK</sub><br>+ 72000 | 110   |
| Verify Address and<br>Data Set         | tadsur            |                                                | 3t <sub>CK</sub>            |                              | ns    |
| Verify Access Time                     | t <sub>READ</sub> |                                                |                             | 9t <sub>CK</sub><br>+ 50     | ns    |
| Minimum P2.7 Pulse<br>Width Low        | t <sub>P27L</sub> |                                                | 10t <sub>CK</sub>           |                              | ns    |
| Minimum P2.7 Pulse<br>Width High       | <sup>t</sup> P27H | Guaranteed by design                           | 3t <sub>CK</sub>            |                              | ns    |
| Clock Period                           | tck               |                                                | 83                          | 250                          | ns    |
| FLASH EXTERNAL MAS                     | S ERASE (FI       | GURE 2, NOTE 6)                                |                             |                              |       |
| Erase Mode Setup                       | tp23SU            |                                                | 3t <sub>CK</sub>            |                              | ns    |
| Program Pulse Width                    | teraslow          |                                                | 10t <sub>CK</sub>           |                              | ns    |
| Erase Cycle Time                       | tmasserase        |                                                | 8.29                        | 11                           | ms    |

## **TIMING CHARACTERISTICS**

 $(MAX7651: AVDD = VPWMV = DVDD = VREF_+ = +4.5 \text{ to } +5.5 \text{V}, VREF_- = 0, \text{ } f_{XTAL} = 12 \text{MHz}. \text{ } MAX7652: \text{ } AVDD = VPWMV = DVDD = +2.7 \text{V to } +3.6 \text{V}, \text{ } V_{REF_+} = +2.5 \text{V}, \text{ } V_{REF_-} = 0, \text{ } ACOM = AV_{DD}/2, \text{ } f_{XTAL} = 12 \text{MHz}. \text{ } T_A = T_{MIN} \text{ to } T_{MAX}, \text{ } unless \text{ } otherwise \text{ } noted. \text{ } Typical \text{ } values \text{ } are \text{ } at \text{ } T_A = +25 ^{\circ}\text{C.}) \text{ } (\text{Figure } 3)$ 

| PARAMETER                           | SYMBOL            | CONDITIONS           | MIN                          | TYP | MAX                           | UNITS |
|-------------------------------------|-------------------|----------------------|------------------------------|-----|-------------------------------|-------|
| RST Pulse Width (High)              |                   |                      | 100 +                        |     |                               | μs    |
| EVERNAL OLOGIC                      |                   |                      | (64 x t <sub>CK</sub> )      |     |                               |       |
| EXTERNAL CLOCK                      | Т                 |                      | Г                            |     |                               |       |
| Clock Frequency                     | fck               |                      |                              |     | 12                            | MHz   |
| Clock Period                        | tCLCL             |                      | 83                           |     |                               | ns    |
| Clock High Time                     | tCHCX             |                      | 25                           |     |                               | ns    |
| Clock Low Time                      | tCLCX             |                      | 25                           |     |                               | ns    |
| Clock Rise Time                     | tclch             | Guaranteed by design |                              |     | 10                            | ns    |
| Clock Fall Time                     | tCHCL             | Guaranteed by design |                              |     | 10                            | ns    |
| INSTRUCTION TIMING CHA              | RACTERIST         | ics                  |                              |     |                               |       |
| ALE Pulse Width                     | tLHLL             |                      | 1.5t <sub>CLCL</sub><br>20   | -   |                               | ns    |
| Address Valid to ALE Low            | t <sub>AVLL</sub> |                      | 0.5t <sub>CLCL</sub>         | _   |                               | ns    |
| Address Hold after ALE<br>Low       | t <sub>LLAX</sub> |                      | 0.5t <sub>CLCL</sub>         | -   |                               | ns    |
| ALE Low to Valid<br>Instruction In  | tLLIV             |                      |                              |     | 2.5t <sub>CLC</sub><br>L - 35 | ns    |
| ALE Low to PSEN Low                 | tLLPL             |                      | 0.5t <sub>CLCL</sub><br>- 10 | -   |                               | ns    |
| PSEN Pulse Width                    | tplph             |                      | 2t <sub>CLCL</sub><br>- 15   |     |                               | ns    |
| PSEN Low to Valid<br>Instruction In | tpLIV             |                      |                              |     | 2t <sub>CLCL</sub> -<br>35    | ns    |
| Input Instruction Hold after PSEN   | tpxix             |                      | 0                            |     |                               | ns    |
| Input Instruction Float after PSEN  | t <sub>PXIZ</sub> |                      |                              |     | tCLCL -<br>15                 | ns    |
| Address to Valid Instruction In     | t <sub>AVIV</sub> |                      |                              |     | 3t <sub>CLCL</sub> -<br>50    | ns    |
| PSEN Low to Address Float           | tplaz             |                      |                              |     | 10                            | ns    |

# **TIMING CHARACTERISTICS (continued)**

 $(MAX7651: AVDD = VPWMV = DVDD = VREF_{+} = +4.5 \text{ to } +5.5 \text{V}, VREF_{-} = 0, \text{ } f_{XTAL} = 12 \text{MHz}. \text{ } MAX7652: \text{ } AVDD = VPWMV = DVDD = +2.7 \text{V to } +3.6 \text{V}, VREF_{+} = +2.5 \text{V}, VREF_{-} = 0, \text{ } ACOM = AVDD/2, \text{ } f_{XTAL} = 12 \text{MHz}. \text{ } T_{A} = T_{MIN} \text{ to } T_{MAX}, \text{ } unless \text{ } otherwise \text{ } noted. \text{ } Typical \text{ } values \text{ } are \text{ } at \text{ } T_{A} = +25 \text{°C.}) \text{ } (Figure 3)$ 

| PARAMETER                            | SYMBOL                                                             | CONDITIONS                                 | MIN TY                      | P MAX                                           | UNITS                                         |
|--------------------------------------|--------------------------------------------------------------------|--------------------------------------------|-----------------------------|-------------------------------------------------|-----------------------------------------------|
| MOVX TIMING CHARACTER                | RISTICS (Not                                                       | te 6)                                      | <u>.</u>                    |                                                 |                                               |
| DD Dulge Wielth                      | t <sub>MCS</sub> = 0, Guaranteed by design 2t <sub>CLCL</sub> - 20 |                                            |                             |                                                 |                                               |
| RD Pulse Width                       | <sup>t</sup> RLRH                                                  | t <sub>MCS</sub> > 0, Guaranteed by design | t <sub>MCS</sub> - 20       |                                                 | ns                                            |
| WR Pulse Width                       | t. a.u a.u                                                         | t <sub>MCS</sub> = 0                       | 2t <sub>CLCL</sub> - 20     |                                                 | ns                                            |
| Wh Fuise Width                       | twLwH                                                              | t <sub>MCS</sub> > 0                       | t <sub>MCS</sub> - 20       |                                                 | 115                                           |
| RD Low to Valid Data In              | t <sub>RLDV</sub>                                                  | $t_{MCS} = 0$                              |                             | 2t <sub>CLCL</sub><br>- 55                      | ns                                            |
|                                      |                                                                    | t <sub>MCS</sub> > 0                       |                             | t <sub>MCS</sub> - 55                           |                                               |
| Data Hold After RD                   | trhdx                                                              |                                            | 0                           |                                                 | ns                                            |
| Data Float After RD                  |                                                                    | $t_{MCS} = 0$                              |                             | tCLCL -<br>10                                   |                                               |
| Data Float After ND                  | tRHDZ                                                              | t <sub>MCS</sub> > 0                       |                             | 2t <sub>CLCL</sub><br>- 10                      | ns                                            |
| ALEL LA VILLE LA                     |                                                                    | t <sub>MCS</sub> = 0                       |                             | 2.5t <sub>CLCL</sub><br>- 58                    |                                               |
| ALE Low to Valid Data In             | tLLDV                                                              | t <sub>MCS</sub> > 0                       |                             | 1.5t <sub>CLCL</sub><br>- 58 + t <sub>MCS</sub> | ns                                            |
| Port 0 Address to Valid              | <sup>†</sup> AVDV1                                                 | t <sub>MCS</sub> = 0                       |                             | 3t <sub>CLCL</sub><br>- 60                      |                                               |
| Data In                              |                                                                    |                                            | t <sub>MCS</sub> > 0        |                                                 | 2t <sub>CLCL</sub> -<br>61 + t <sub>MCS</sub> |
| Port 2 Address to Valid              |                                                                    | t <sub>MCS</sub> = 0                       |                             | 3t <sub>CLCL</sub><br>- 60                      |                                               |
| Data In                              | tavdv2                                                             | t <sub>MCS</sub> > 0                       |                             | 2t <sub>CLCL</sub> - 64<br>+ t <sub>MCS</sub>   | ns                                            |
| ALE Low to RD or WR Low              | *******                                                            | $t_{MCS} = 0$                              | 0.5t <sub>CLCL</sub><br>- 5 | 0.5t <sub>CLCL</sub><br>+ 10                    |                                               |
| ALE LOW TO AD OF WA LOW              | tLLWL                                                              | t <sub>MCS</sub> > 0                       | 1.5t <sub>CLCL</sub><br>- 5 | 1.5t <sub>CLCL</sub><br>+ 10                    | ns                                            |
| Port 0 Address Valid to RD or WR Low |                                                                    | $t_{MCS} = 0$                              | tCLCL<br>- 10               |                                                 |                                               |
|                                      | tavwl1                                                             | t <sub>MCS</sub> > 0                       | 2tc.Lc.L -<br>10            |                                                 | ns                                            |
| Port 2 Address Valid to RD           | <b>.</b>                                                           | t <sub>MCS</sub> = 0                       | tCLCL<br>- 10               |                                                 |                                               |
| or WR Low                            | tavwl2                                                             | t <sub>MCS</sub> > 0                       | 2t <sub>CLCL</sub> -        |                                                 | ns                                            |

# **TIMING CHARACTERISTICS (continued)**

 $(MAX7651: AVDD = VPWMV = DVDD = VREF+ = +4.5 \text{ to } +5.5 \text{V}, VREF- = 0, \text{ } f_{XTAL} = 12 \text{MHz}. \text{ } MAX7652: AVDD = VPWMV = DVDD = +2.7 \text{V} \text{ to } +3.6 \text{V}, VREF+ = +2.5 \text{V}, VREF- = 0, ACOM = AVDD/2, } f_{XTAL} = 12 \text{MHz}. \text{ } T_A = T_{MIN} \text{ to } T_{MAX}, \text{ unless otherwise noted. } T_{MAX} = 12 \text{MHz}.$ 

| PARAMETER                                | SYMBOL            | CONDITIONS                                            | MIN                        | TYP                                       | MAX          | UNITS |
|------------------------------------------|-------------------|-------------------------------------------------------|----------------------------|-------------------------------------------|--------------|-------|
|                                          |                   | $t_{MCS} = 0$                                         | -9                         |                                           |              |       |
| Data Valid to WR Transition              | t <sub>QVWX</sub> | t <sub>MCS</sub> > 0                                  | t <sub>CLCL</sub>          |                                           |              | ns    |
| Data Valid Before WR High                | +0.000            | $t_{MCS} = 0$                                         | 2t <sub>CLCL</sub><br>- 20 |                                           |              | 200   |
| Data valid belore Wh high                | tQVWH             | t <sub>MCS</sub> > 0                                  | tMCs<br>- 30               |                                           |              | ns    |
| Data Hald After MD High                  |                   | $t_{MCS} = 0$                                         | t <sub>CLCL</sub>          |                                           |              |       |
| Data Hold After WR High                  | twhqx             | t <sub>MCS</sub> > 0                                  | 2t <sub>CLCL</sub> - 18    |                                           |              | ns    |
| RD Low to Address Float                  | tRLAZ             |                                                       |                            |                                           | 0            | ns    |
|                                          | twhlh             | t <sub>MCS</sub> = 0                                  | 0                          |                                           | 10           |       |
| RD or WR High to ALE High                |                   | t <sub>MCS</sub> > 0                                  | tCLCL<br>- 5               |                                           | tCLCL<br>+11 | ns    |
| SERIAL PORT TIMING CHAI                  | RACTERISTI        | cs                                                    | -                          |                                           |              | •     |
| Serial Port Clock Cycle                  | txLxL             | SM2 = 0 (12 clocks/cycle)                             |                            | 12 t <sub>CLCL</sub>                      |              | ns    |
| Time                                     | 1XLXL             | SM2 = 1 (4 clocks/cycle)                              |                            | 4tclcl                                    |              | 110   |
| Output Data Setup to Clock               | tQVXH             | SM2 = 0 (12 clocks/cycle)                             |                            | 10 t <sub>CLCL</sub>                      |              | ns    |
| Rising Edge                              | *QVXIII           | SM2 = 1 (4 clocks/cycle)                              |                            | 3 tolol                                   |              | 1.0   |
| Output Data Hold after                   | txhqx             | SM2 = 0 (12 clocks/cycle)                             |                            | 2tclcl                                    |              | ns    |
| Clock Rising Edge                        | 7(1)Q/(           | SM2 = 1 (4 clocks/cycle)                              |                            | tCLCL                                     |              |       |
| Input Data Hold after Clock              | txhdx             | SM2 = 0 (12 clocks/cycle)                             |                            | tCLCL                                     |              | ns    |
| Rising Edge                              | ,,,,,,,,          | SM2 = 1 (4 clocks/cycle)                              |                            | tclcl                                     |              |       |
| Clock Rising Edge to Input<br>Data Valid | txhdv             | SM2 = 0 (12 clocks/cycle)<br>SM2 = 1 (4 clocks/cycle) |                            | 11t <sub>CLCL</sub><br>3t <sub>CLCL</sub> |              | ns    |

- Note 1: Relative accuracy is the deviation of the analog value at any code from its theoretical value after the offset and gain errors have been nullified.
- **Note 2:**  $A_{VDD} = +5.0V$ ,  $(V_{REF}+) (V_{REF}-) = +5.0V$  or  $A_{VDD} = +3.0V$ ,  $(V_{REF}+) (V_{REF}-) = +2.5V$ .
- Note 3: Ground at "ON" channel; 10kHz sine-wave applied to all "off" channels.
- Note 4: ALE and PSEN are in reset cycle.
- Note 5: All digital inputs are at DGND or DVDD. fxTAL = 0.
- Note 6: Table 1. Data Memory Stretch Values.
- Note 7: The minimum frequency when writing to the internal flash is 4MHz.

**Table 1. Data Memory Stretch Values** 

| MD2 | MD1 | MD0 | MEMORY CYCLES | READ/WRITE STROBE<br>WIDTH (CLOCKS) | STROBE WIDTH TIME<br>AT 12MHz | tMCS                |
|-----|-----|-----|---------------|-------------------------------------|-------------------------------|---------------------|
| 0   | 0   | 0   | 2             | 2                                   | 167ns                         | Ot <sub>CLCL</sub>  |
| 0   | 0   | 1   | 3 (default)   | 4                                   | 334ns                         | 4tCLCL              |
| 0   | 1   | 0   | 4             | 8                                   | 668ns                         | 8t <sub>CLCL</sub>  |
| 0   | 1   | 1   | 5             | 12                                  | 997ns                         | 12t <sub>CLCL</sub> |
| 1   | 0   | 0   | 6             | 16                                  | 1330ns                        | 16t <sub>CLCL</sub> |
| 1   | 0   | 1   | 7             | 20                                  | 1666ns                        | 20t <sub>CLCL</sub> |
| 1   | 1   | 0   | 8             | 24                                  | 2000ns                        | 24t <sub>CLCL</sub> |
| 1   | 1   | 1   | 9             | 28                                  | 2333ns                        | 28t <sub>CLCL</sub> |

**Table 2. External Flash Programming Modes** 

|                   |     | _    | _                    |                    |      |                      |      |      |      |
|-------------------|-----|------|----------------------|--------------------|------|----------------------|------|------|------|
| MODE              | RST | PSEN | ALE/PROG             | EA/V <sub>PP</sub> | P2.6 | P2.7                 | P3.6 | P3.7 | P2.5 |
| Write Lower FLASH | Н   | L    | $\uparrow\downarrow$ | Н                  | L    | Н                    | Н    | Н    | L    |
| Read Lower FLASH  | Н   | L    | Н                    | Н                  | L    | $\uparrow\downarrow$ | Н    | Н    | L    |
| Write Lock Bit 1  | Н   | L    | $\uparrow\downarrow$ | Н                  | Н    | Н                    | Н    | Н    | Н    |
| Write Lock Bit 2  | Н   | L    | $\uparrow\downarrow$ | Н                  | Н    | Н                    | L    | L    | Н    |
| Write Lock Bit 3  | Н   | L    | $\uparrow\downarrow$ | Н                  | Н    | L                    | Н    | L    | Н    |
| Mass Erase        | Н   | L    | $\uparrow\downarrow$ | Н                  | Н    | L                    | L    | L    | Н    |
| Read Sig Bytes    | Н   | L    | Н                    | Н                  | L    | L                    | L    | L    | L    |
| Write Upper FLASH | Н   | L    | $\uparrow\downarrow$ | Н                  | L    | Н                    | Н    | Н    | Н    |
| Read Upper FLASH  | Н   | L    | Н                    | Н                  | L    | ↑↓                   | Н    | Н    | Н    |

Note 1: To program the lock bits, ALE must be low for duration of "Write Lockbit" cycle.

Note 2: INTO and INT1 are open-drain and must either be driven or require a pullup (typically 10kΩ) to DV<sub>DD</sub>.



Figure 1. FLASH External Mass Erase Waveforms



Figure 2. FLASH External Programming and Verification Waveforms



Figure 3a. External Program Memory Read Cycle



Figure 3b. External Data Memory Read Cycle



Figure 3c. External Program Memory Write Cycle

# **Typical Operating Characteristics**

 $(T_A = +25^{\circ}C, \text{ unless otherwise noted.})$ MAX7651: AVDD = VPWMV = DVDD = VREF+ = 5.0V, VREF- = 0, VCOM = AVDD/2, fXTAL = 12MHz. MAX7652: AVDD = VPWMV = DVDD = VREF+ = 3.0V, VREF- = 0, VCOM = AVDD/2, fXTAL = 12MHz. **NEGATIVE GAIN ERROR vs.** SINGLE-ENDED INL vs. OUTPUT CODE **DNL vs. OUTPUT CODE SUPPLY VOLTAGE** 1.0 1.0 0.3 SINGLE-ENDED 0.8 8.0 0.2 0.6 0.6 0.1 0.4 0.4 0.2 0.2 DNL (LSB) (LSB) -0.1 DIFFERENTIAL 0 0 봄 -0.2 -0.2 -0.2 -0.3 -0.4 -0.4 -0.4 -0.6 -0.6 -0.5 -0.8 -0.8 -0.6 -1.0 -1.0 500 1000 1500 2000 2500 3000 3500 4000 4500 -2000-1500-1000 -500 0 500 1000 1500 2000 -2000 -1500 -1000 -500 0 500 1000 1500 2000 0 CODE CODE CODE OFFSET ERROR vs. **POSITIVE GAIN ERROR vs. SUPPLT VOLTAGE OFFSET ERROR vs.TEMPERATURE SUPPLY VOLTAGE** 1.0 0 1.0 -0.1 DIFFERENTIAL 0.5 0.5 -0.2 OFFSET ERROR (LSB) OFFSET ERROR (LSB) GAIN ERROR (LSB) -0.3 SINGLE-ENDED 0 SINGLE-ENDED 0 SINGLE-ENDED -0.4 -0.5-0.5 -0.5 -0.6DIFFERENTIAL DIFFERENTIAL -1.0 -1.0 2.5 3.0 4.0 4.5 5.0 5.5 3.5 -40 35 60 85 2.5 3.0 4.0 SUPPLY VOLTAGE (V) TEMPERATURE (°C) SUPPLY VOLTAGE (V) **NEGATIVE GAIN ERROR POSITIVE GAIN ERROR PWM OUTPUT HIGH** vs. TEMPERATURE vs. TEMPERATURE vs. SOURCE CURRENT 0.4 1.4 5.000 1.2 0.2 DIFFERENTIAL 4.950 DIFFERENTIAL PWM OUTPUT HIGH (V) GAIN ERROR (LSB) 0 GAIN ERROR (LSB)  $AV_{DD} = 5V$ 0.8 -0.2 4.900 0.6 -0.4 SINGLE-ENDED 0.4 4.850 SINGLE-ENDED -0.6 0.2 4 800 -0.8 0 -40 -15 10 35 .-40 -15 10 35 0 2 3 TEMPERATURE (°C) TEMPERATURE (°C) SOURCE CURRENT (mA)

# Typical Operating Characteristics (continued)

 $(T_A = +25^{\circ}C, \text{ unless otherwise noted.})$ 

MAX7651:  $AV_{DD} = V_{PWMV} = DV_{DD} = V_{REF+} = 5.0V$ ,  $V_{REF-} = 0$ ,  $V_{COM} = AV_{DD}/2$ ,  $f_{XTAL} = 12MHz$ .



















# **Pin Description**

| PIN | NAME             | FUNCTION                                                                                                                                                                                                                     |
|-----|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | AIN0             | Analog Input 0. Negative differential input relative to AIN1 or positive differential input relative to ACOM. (See Table 6)                                                                                                  |
| 2   | AIN1             | Analog Input 1. Positive differential input relative to AIN0 or positive differential input relative to ACOM. (See Table 6)                                                                                                  |
| 3   | AIN2             | Analog Input 2. Negative differential input relative to AIN3 or positive differential input relative to ACOM. (See Table 6)                                                                                                  |
| 4   | AIN3             | Analog Input 3. Positive differential input relative to AIN2 or positive differential input relative to ACOM. (See Table 6)                                                                                                  |
| 5   | AIN4             | Analog Input 4. Negative differential input relative to AIN5 or positive differential input relative to ACOM. (See Table 6)                                                                                                  |
| 6   | AIN5             | Analog Input 5. Positive differential input relative to AIN4 or positive differential input relative to ACOM. (See Table 6)                                                                                                  |
| 7   | AIN6             | Analog Input 6. Negative differential input relative to AIN7 or positive differential input relative to ACOM. (See Table 6)                                                                                                  |
| 8   | AIN7             | Analog Input 7. Positive differential input relative to AIN6 or positive differential input relative to ACOM. (See Table 6)                                                                                                  |
| 9   | AV <sub>DD</sub> | Positive Analog Supply Voltage. Analog power source for the A/D converter and other analog functions excluding the PWM D/A converter. Bypass with a 0.1µF in parallel with a 10µF low ESR capacitor to AGND.                 |
| 10  | AGND             | Analog Ground. Connect PWMG to AGND.                                                                                                                                                                                         |
| 11  | REF+             | High-Side Reference Input. High-side reference voltage for A/D conversions. Must be between AV <sub>DD</sub> and AGND. Bypass to AGND with a 0.1µF in parallel with a 10µF low ESR capacitor to AGND.                        |
| 12  | REF-             | Low-Side Reference Input. Low-side reference voltage for A/D conversions. Must be between AV <sub>DD</sub> and AGND. If not connected to AGND bypass to AGND with a 0.1µF in parallel with a 10µF low ESR capacitor to AGND. |
| 13  | PWMV             | Positive Analog Supply Voltage 2. Analog power source for the the PWM D/A converter outputs. Bypass with a 0.1µF in parallel with a 10µF low ESR capacitor to PWMG.                                                          |
| 14  | PWMG             | Ground for PWM. Connect to AGND.                                                                                                                                                                                             |
| 15  | PWMA             | PWM Output A. Output of PWM D/A Converter A. See PWM Digital-to-Analog Conversions.                                                                                                                                          |
| 16  | PWMB             | PWM Output B. Output of PWM D/A Converter B. See PWM Digital-to-Analog Conversions.                                                                                                                                          |
| 17  | ĪNT0             | External Interrupt 0 Input (active-low)                                                                                                                                                                                      |
| 18  | ĪNT1             | External Interrupt 1 Input (active-low)                                                                                                                                                                                      |
| 10  | D0 7/DD          | P3.7: Bit 7 for General Purpose I/O Port 3 (most significant bit)                                                                                                                                                            |
| 19  | P3.7/RD          | RD: Read Output. Read strobe for accessing external data memory (active-low)                                                                                                                                                 |
| 00  | DO CAMID         | P3.6: Bit 6 for General Purpose I/O Port 3                                                                                                                                                                                   |
| 20  | P3.6/WR          | WR: Write Output. Write strobe for writing to external data memory (active-low)                                                                                                                                              |
| 01  | D0 E/T1          | P3.5: Bit 5 for General Purpose I/O Port 3                                                                                                                                                                                   |
| 21  | P3.5/T1          | T1: Timer 1 External Input                                                                                                                                                                                                   |
|     |                  | P3.4: Bit 4 for General Purpose I/O Port 3                                                                                                                                                                                   |
| 22  | P3.4/T0/         | T0: Timer 0 External Input                                                                                                                                                                                                   |
|     | READY            | READY: Ready State Output (external flash programming mode only)                                                                                                                                                             |
| 23  | P3.3             | P3.3: Bit 3 for General Purpose I/O Port 3                                                                                                                                                                                   |
| 24  | P3.2             | P3.2: Bit 2 for General Purpose I/O Port 3                                                                                                                                                                                   |
| L   | l                | ·                                                                                                                                                                                                                            |

# Pin Description (continued)

| PIN         | NAME             | FUNCTION                                                                                                                                                                                          |
|-------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | P3.1/            | P3.1: Bit 1 for General Purpose I/O Port 3                                                                                                                                                        |
| 25          | TXD0             | TXD0: Transmit Serial Output for Serial Port                                                                                                                                                      |
|             | P3.0/            | P3.0: Bit 0 for General Purpose I/O Port 3 (least significant bit)                                                                                                                                |
| 26          | RXD0             | RXD0: Receive Serial Input for Serial Port                                                                                                                                                        |
| 27          | DGND             | Digital Ground. Connect DGND to AGND at the power source. Connect pins 27, 39, and 61 together.                                                                                                   |
| 28          | DV <sub>DD</sub> | Positive Digital Supply Voltage. Bypass with a 0.1µF in parallel with a 10µF low ESR capacitor to DGND. Connect pins 28, 40, and 62 together.                                                     |
| 00          | D0.0/40          | P2.0: Bit 0 for General Purpose I/O Port 2 (least significant bit)                                                                                                                                |
| 29          | P2.0/A8          | A8: Bit 8 for Internal Flash Memory Address                                                                                                                                                       |
| 20          | D0 1/A0          | P2.1: Bit 1 for General Purpose I/O Port 2                                                                                                                                                        |
| 30          | P2.1/A9          | A9: Bit 9 for Internal Flash Memory Address                                                                                                                                                       |
| 0.1         | DO 0/440         | P2.2: Bit 2 for General Purpose I/O Port 2                                                                                                                                                        |
| 31          | P2.2/A10         | A10: Bit 10 for Internal Flash Memory Address                                                                                                                                                     |
|             |                  | P2.3: Bit 3 for General Purpose I/O Port 2                                                                                                                                                        |
| 32          | P2.3/A11         | A11: Bit 11 for Internal Flash Memory Address                                                                                                                                                     |
| 00 50 4/440 |                  | P2.4: Bit 4 for General Purpose I/O Port 2                                                                                                                                                        |
| 33          | P2.4/A12         | A12: Bit 12 for Internal Flash Memory Address                                                                                                                                                     |
| 0.4         | D0.5             | P2.5: Bit 5 for General Purpose I/O Port 2                                                                                                                                                        |
| 34          | P2.5             | Upper and Lower Internal Flash Memory Select (see Table 2)                                                                                                                                        |
| 0.5         | D0.0             | P2.6: Bit 6 for General Purpose I/O Port 2                                                                                                                                                        |
| 35          | P2.6             | Flash Programming Mode Select (see Table 2)                                                                                                                                                       |
| 20          | D0.7             | P2.7: Bit 7 for General Purpose I/O Port 2 (most significant bit)                                                                                                                                 |
| 36          | P2.7             | Flash Programming Mode Select (see Table 2)                                                                                                                                                       |
| 37          | PSEN             | Program Store Enable (active-low). Qualifies program read from external devices. To ensure flash data integrity during RST insertions, $R_{LOAD}$ must be greater than or equal to $200k\Omega$ . |
| 38          | ALE/<br>PROG     | ALE: Address Latch Enable. To ensure flash data integrity during RST insertions, $R_{LOAD}$ must be greater than or equal to $200k\Omega$ .                                                       |
|             | PROG             | PROG: Flash Memory Program Pulse                                                                                                                                                                  |
| 39          | DGND             | Digital Ground. Connect pins 27, 39, and 61 together.                                                                                                                                             |
| 40          | DV <sub>DD</sub> | Positive Digital Supply Voltage. Bypass with a 0.1µF in parallel with a 10µF low ESR capacitor to DGND. Connect pins 28, 40 and 62 together.                                                      |
| 41          | P0.0/AD0         | P0.0: Bit 0 for General Purpose I/O Port 0 (least significant bit)                                                                                                                                |
| 41          | 1 0.0/AD0        | AD0: Bit 0 for Internal Flash Memory Data or External Memory I/O Data (least significant bit)                                                                                                     |
| 42          | P0.1/AD1         | P0.1: Bit 1 for General Purpose I/O Port 0                                                                                                                                                        |
| 42          | 1 U. I/AD1       | AD1: Bit 1 for Internal Flash Memory Data or External Memory I/O Data                                                                                                                             |
| 43          | DO 2/AD2         | P0.2: Bit 2 for General Purpose I/O Port 0                                                                                                                                                        |
| 40          | P0.2/AD2         | AD2: Bit 2 for Internal Flash Memory Data or External Memory I/O Data                                                                                                                             |
| 11          | DU 3/VD3         | P0.3: Bit 3 for General Purpose I/O Port 0                                                                                                                                                        |
| 44          | P0.3/AD3         | AD3: Bit 3 for Internal Flash Memory Data or External Memory I/O Data                                                                                                                             |
| 1E          | P0.4/AD4         | P0.4: Bit 4 for General Purpose I/O Port 0                                                                                                                                                        |
| 45          | ΓU.4/AD4         | AD4: Bit 4 for Internal Flash Memory Data or External Memory I/O Data                                                                                                                             |

# Pin Description (continued)

| PIN  | NAME               | FUNCTION                                                                                                                                                                         |
|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | P0.5/              | P0.5: Bit 5 for General Purpose I/O Port 0                                                                                                                                       |
| 46   | AD5                | AD5: Bit 5 for Internal Flash Memory Data or external memory I/O                                                                                                                 |
|      | P0.6/              | P0.6: Bit 6 for General Purpose I/O Port 0                                                                                                                                       |
| 47   | AD6                | AD6: Bit 6 for Internal Flash Memory Data or external memory I/O                                                                                                                 |
|      | P0.7/              | P0.7: Bit 7 for General Purpose I/O Port 0 (most significant bit)                                                                                                                |
| 48   | AD7                | AD7: Bit 7 for Internal Flash Memory Data or external memory I/O                                                                                                                 |
|      |                    | P1.0: Bit 0 for General Purpose I/O Port 1 (least significant bit)                                                                                                               |
|      | P1.0/T2/           | T2: Timer 2 External Input                                                                                                                                                       |
| 49   | T2OUT/<br>AD0      | T2OUT: Timer 2 External Output                                                                                                                                                   |
|      | ADO                | AD0: Bit 0 for Internal Flash Memory Address                                                                                                                                     |
|      | P1.1/              | P1.1: Bit 1 for General Purpose I/O Port 1                                                                                                                                       |
| 50   | T2EX/              | T2EX: Timer 2 External Capture/Reload Trigger                                                                                                                                    |
|      | AD1                | AD1: Bit 1 for Internal Flash Memory Address                                                                                                                                     |
|      | P1.2/              | P1.2: Bit 2 for General Purpose I/O Port 1                                                                                                                                       |
| 51   | RXD1/<br>AD2       | RXD1: Receive Serial Input for UART 1                                                                                                                                            |
|      |                    | AD2: Bit 2 for Internal Flash memory Address                                                                                                                                     |
|      | P1.3/              | P1.3: Bit 3 for General Purpose I/O Port 1                                                                                                                                       |
| 52   | TXD1/              | TXD1: Transmit Serial Input for UART 1                                                                                                                                           |
|      | AD3                | AD3: Bit 3 for Internal Flash Memory Address                                                                                                                                     |
| 53   | P1.4/              | P1.4: Bit 4 for General Purpose I/O Port 1                                                                                                                                       |
| 55   | AD4                | AD4: Bit 4 for Internal Flash Memory Address                                                                                                                                     |
| 54   | P1.5/              | P1.5: Bit 5 for General Purpose I/O Port 1                                                                                                                                       |
| 54   | AD5                | AD5: Bit 5 for Internal Flash Memory Address                                                                                                                                     |
| 55   | P1.6/              | P1.6: Bit 6 for General Purpose I/O Port 1                                                                                                                                       |
| - 55 | AD6                | AD6: Bit 6 for Internal Flash Memory Address                                                                                                                                     |
| 56   | P1.7/              | P1.7: Bit 7 for General Purpose I/O Port 1                                                                                                                                       |
| - 50 | AD7                | AD7: Bit 7 for Internal Flash Memory Address                                                                                                                                     |
| 57   | ĒĀ/V <sub>PP</sub> | $\overline{EA}$ : Connect to DGND to use external ROM. Connect $\overline{EA}$ to $DV_DD$ for internal flash memory.                                                             |
| 01   | <u></u>            | V <sub>PP</sub> : Flash Programming Voltage (external flash programming mode only)                                                                                               |
| 58   | RST                | Active High Reset. Connected to an internal $130k\Omega$ pulldown resistor. Connect a $2.2\mu\text{F}$ (typ) capacitor from DV <sub>DD</sub> to RST.                             |
| 59   | XTAL2              | Clock Output. Connect a crystal across XTAL1 and XTAL2. The on-chip clock signal is not available at XTAL2. Leave XTAL2 unconnected when XTAL1 is driven with an external clock. |
| 60   | XTAL1              | Clock Input. Connect a crystal across XTAL1 and XTAL2. Alternatively, drive XTAL1 with a CMOS-compatible clock and leave XTAL2 unconnected.                                      |
| 61   | DGND               | Digital Ground. Connect pins 27, 39, and 61 together.                                                                                                                            |
| 62   | DV <sub>DD</sub>   | Positive Digital Supply Voltage. Bypass with a 0.1µF in parallel with a 10µF low ESR capacitor to DGND. Connect pins 28, 40 and 62 together.                                     |
| 63   | TEST               | Test Point. Must be connected to DGND.                                                                                                                                           |
| 64   | ACOM               | Analog Common Input. Negative differential input relative to AIN_ for single-ended measurements (see Table 6). Connect to AV <sub>DD</sub> /2 for maximum input range.           |

# **Detailed Description**

#### MAX7651/MAX7652 Architecture

The MAX7651/MAX7652 are complete 12-bit data-acquisition systems featuring an algorithmic, switched-capacitor, analog-to-digital converter (ADC), dual pulse-width-modulated digital-to-analog converter (DAC), and an industry-standard 8051 microprocessor core with a variety of I/O and timing peripherals.

Using an external oscillator with an operating frequency between 1MHz and 12MHz, the MAX7651/MAX7652 execute the majority of its commands in only four clock periods to yield an average speed improvement of 2.5 times over typical 8051 microprocessors requiring 12 clock periods instructions. See the MAX7651/MAX7652 *Programmer's Reference Manual* for further details.

On-chip peripherals include four 8-bit parallel ports, two serial ports, three general-purpose timers, and a watchdog timer. The MAX7651/MAX7652 also feature 16kB in two banks of 8kB flash memory and 256 bytes of high-speed random access memory.

## **Memory Organization**

The MAX7651/MAX7652 support up to 64kB of external program (read-only) memory and data (random-access) memory in conformance with the 8051 industry standard.

Figure 4 shows the program memory organization. When  $\overline{EA}$  is high, the CPU has access to two internal 8kB blocks of flash memory beginning at addresses 0000H (lower block) and 2000H (upper block). Addresses 0000H–0002H and 0003H–006AH of the lower block are reserved for the CPU reset vector and a set of interrupt vectors, respectively (see Table 3). Addresses 3FC0H–3FFFH of the upper block are also reserved and cannot be accessed by the CPU. Addresses 4000H–FFFFH are for external ROM. When  $\overline{EA}$  is low, the external ROM must be used for all program addresses (0000H–FFFFH).

Figure 5 shows the data memory (RAM) organization. The first 256 bytes are partitioned between two internal 128-byte blocks. The lower block (addresses 0000H–007FH) is used for registers or scratchpad memory and can be accessed either directly or indirectly (see the MAX7651/MAX7652 *Programmer's Reference Manual*). The upper block (addresses 0080H–00FFH) reflects a set of special function registers (SFRs) when accessed directly, and separate scratchpad memory when accessed indirectly. Addresses 0100H–FFFFH are reserved for external RAM.

Table 4 shows the SFR mapping to memory and Table 5 shows the SFR contents on power-up or reset. Unshaded register designations are consistent with the industry standard 8051. Shaded register designations



Figure 4. Program Memory Organization



Figure 5. Data Memory (RAM) Organization

**Table 3. Reset and Interrupt Vector Locations** 

| ADDRESS RANGE | FUNCTION                       | NATURAL PRIORITY* |
|---------------|--------------------------------|-------------------|
| 0000H-0002H   | Reset Vector                   | 0                 |
|               | INTERRUPT VECTORS              | ·                 |
| 0003H-000AH   | INTO (external interrupt 0)    | 1                 |
| 000BH-0012H   | Timer 0                        | 2                 |
| 0013H-001AH   | INT1 (external interrupt 1)    | 3                 |
| 001BH-0022H   | Timer 1                        | 4                 |
| 0023H-002AH   | Serial Port 0 transmit/receive | 5                 |
| 002BH-0032H   | Timer 2                        | 6                 |
| 0033H-003AH   | Reserved                       | _                 |
| 003BH-0042H   | Serial Port 1 transmit/receive | 7                 |
| 0043H-004AH   | Flash memory write/page erase  | 8                 |
| 004BH-0052H   | ADC (end of conversion)        | 9                 |
| 0053H-005AH   | Reserved                       | 10                |
| 005BH-0062H   | Reserved                       | 11                |
| 0063H-006AH   | Watchdog timer                 | 12                |

<sup>\*</sup>Lower priority number takes precedence.

**Table 4. SFR Memory Organization** 

| HEX<br>ADDRESS | 0/8   | 1/9   | 2/A      | 3/B      | 4/C      | 5/D     | 6/E   | 7/F      |
|----------------|-------|-------|----------|----------|----------|---------|-------|----------|
| F8             | EIP   |       |          |          |          |         | PWMC  |          |
| F0             | В     |       |          |          |          |         |       |          |
| E8             | EIE   |       | EEAL     | EEAH     | EEDAT    | EESTCMD |       |          |
| E0             | ACC   |       |          |          |          |         |       |          |
| D8             | EICON |       | PWPS     | PWDA     | PWDB     | WDT     |       |          |
| D0             | PSW   |       |          |          |          |         |       |          |
| C8             | T2CON |       | RCAP2L   | RCAP2H   | TL2      | TH2     |       |          |
| C0             | SCON1 | SBUF1 | ADDAT0   | ADDAT1   | Reserved | ADCON   |       |          |
| B8             | IP    |       | Reserved | Reserved |          |         |       |          |
| В0             | P3    |       | VERSION  | Reserved | Reserved |         |       |          |
| A8             | IE    |       |          |          |          |         |       |          |
| A0             | P2    |       |          |          |          |         |       |          |
| 98             | SCON0 | SBUF0 |          |          |          |         |       |          |
| 90             | P1    | EXIF  |          |          |          |         |       |          |
| 88             | TCON  | TMOD  | TL0      | TH0      | TL1      | TH1     | CKCON | Reserved |
| 80             | P0    | SP    | DPL0     | DPH0     | DPL1     | DPH1    | DPS   | PCON     |

Note 1: SFRs in column 0/8 are bit addressable. Other SFRs are not bit addressable.

Note 2: The VERSION SFR contains the silicon ID and will change for future MAX7651/MAX7652 revisions.

**Table 5. SFR Contents on Power-Up or Reset** 

| REGISTER | ADDRESS | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|----------|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| P0       | 80      | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| SP       | 81      | 0     | 0     | 0     | 0     | 0     | 1     | 1     | 1     |
| DPL0     | 82      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| DPH0     | 83      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| DPL1     | 84      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| DPH1     | 85      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| DPS      | 86      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| PCON     | 87      | 0     | 0     | 1     | 1     | 0     | 0     | 0     | 0     |
| TCON     | 88      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| TMOD     | 89      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| TL0      | 8A      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| TH0      | 8B      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| TL1      | 8C      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| TH1      | 8D      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| CKCON    | 8E      |       |       |       |       |       |       |       |       |
| P1       | 90      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| EXIF     | 91      | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| SCON0    | 98      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| SBUF0    | 99      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| P2       | A0      | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| ΙE       | A8      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| P3       | В0      | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| ΙP       | B8      | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| SCON1    | C0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| SBUF1    | C1      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| ADDAT0   | C2      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| ADDAT1   | C3      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| ADCON    | C5      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| T2CON    | C8      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| RCAP2L   | CA      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| RCAP2H   | СВ      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| TL2      | CC      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| TH2      | CD      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| PSW      | D0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| EICON    | D8      | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     |
| PWPS     | DA      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| PWDTA    | DB      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| PWDTB    | DC      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| WDT      | DD      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Table 5. SFR Contents on Power-Up or Reset (continued)

| REGISTER | ADDRESS | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|----------|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| ACC      | E0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| EIE      | E8      | 1     | 1     | 1     | 0     | 0     | 0     | 0     | 0     |
| EEAL     | EA      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| EEAH     | EB      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| EEDAT    | EC      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| EESTCMD  | ED      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| В        | F0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| EIP      | F8      | 1     | 1     | 1     | 0     | 0     | 0     | 0     | 0     |
| PWMC     | FE      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

are unique to the MAX7651/MAX7652. Subsequent sections of this data sheet explain the SFR functions.

RESERVED SFR addresses are used for MAX7651/MAX7652 testing and should not be accessed by user software. Undesignated SFR addresses are not implemented and will return indefinite data when read.

## Special Function Registers for Microprocessor Operations and Control

#### Accumulator SFR

The Accumulator SFR is used for arithmetic operations including addition, subtraction, multiplication, division, and Boolean bit manipulation. Accumulator specific instructions designate the accumulator as "A".

#### **B SFR**

The B SFR is used for multiply and divide operations. It is otherwise available as a scratchpad register.

#### **Program Status Word SFR**

The PSW or Program Status Word SFR contains bits that indicate the state of the microprocessor CPU. Table 6 shows the individual bit functions.

#### Stack Pointer SFR

The SP or Stack Pointer SFR contains the "top-of-the-stack" address in internal RAM. This address increments before data is stored during PUSH and CALL executions. The default value is 07H after reset, so that the stack begins at 08H.

#### **Dual Data Pointer SFRs**

The MAX7651/MAX7652 feature dual data pointers to enhance execution times when moving large blocks of data. All DPTR-related instructions use 16 bits contained at SFR pairs DPH0 and DPL0 or DPH1 and DPL1 to address external data RAM or peripherals. Bit 0 (SEL) within the DPS SFR determines the data pointer.

No other bits have significance in this register. When SEL= 0, DPTR instructions use DPH0 and DPL0, when SEL=1, DPTR instructions use DPH1 and DPL1. Program code developed for 8051 platforms that use a single data pointer (DPH0 and DPL0) requires no modification if SEL = 0 (the default value).

#### **Power Control SFR**

The PCON Power Control SFR provides software control over the power modes. In both IDLE and STOP modes, CPU processing is suspended and internal registers maintain their current data. The STOP mode additionally disables the internal clock and analog circuitry. Any enabled CPU interrupt can be used to terminate the IDLE mode. A reset is necessary to terminate the STOP mode and is sufficient to terminate the IDLE mode. Table 7 shows the PCON SFR format.

#### Instruction Set

The MAX7651/MAX7652 instruction set is compatible with the 8051 industry standard. See the MAX7651/ MAX7652 *Programmer's Reference Manual* for a complete listing.

# Analog-to-Digital Converter

#### ADC Operation

Figure 6 shows a simplified model of the converter input structure and the associated switch timing. Once initiated, a voltage conversion requires 224 periods of the external master clock. Capacitor C<sub>HOLD</sub> charges to the difference between inputs AIN+ and AIN- during eight clock periods of acquisition time that begin on the rising edge of clock cycle 13. This charge sample is subsequently transferred to the ADC (through the action of SW5) during eight clock periods that begin on the rising edge of clock cycle 21. The ADC asserts a conversion complete flag on the rising-edge of clock cycle 225 (see *ADC Special Function Registers*).



Figure 6. ADC Input Structure and Switch Timing

Since the acquisition time is limited to eight clock periods, the acquired voltage at  $C_{HOLD}$  can have significant error if the analog input source impedance ( $R_{\rm S}$ ) is large. Limit the worst-case error to 1/2 LSB by ensuring.

#### Rs < 0.9 tclk / Chold

where  $t_{CLK}$  is the clock period. Smaller  $R_S$  values may be necessary if an antialiasing filter is used.

The ADC continuously samples the positive and negative difference between the two external reference voltages REF+ and REF- by reconfiguring capacitor CREF over alternate eight clock-period intervals. Switch pairs 1 and 2 are forced off and on, respectively, on the rising edge of clock cycle five to ensure synchronization with conversions. Capacitor  $C_{\mbox{\scriptsize HOLD}}$  also charges to the difference

between REF+ and REF- on the rising edge of clock cycle 29 and remains charged until the next conversion. Nevertheless, continuous C<sub>REF</sub> charging requirements dominate loading at the REF+ and REF- inputs.

#### Analog Inputs

The MAX7651/MAX7652 operate in either single-ended or differential mode. In single-ended mode, one of eight input channels (AIN0–AIN7) is assigned to AIN+, and ACOM is assigned to AIN- (see Figure 6). In differential mode, the eight input channels are assigned to AIN+ and AIN- with four distinct pairings. Table 6 shows the input assignments for different values of bits M3, M2, M1, and M0 in the A/D Control SFR (see *ADC Special Function Registers*).

## **Analog Input Protection**

Internal protection diodes clamp the analog inputs to  ${\rm AV_{DD}}$  and AGND, so channels can swing within AGND -

0.3V and AVDD + 0.3V without damage. For accurate conversions the inputs should not extend beyond the supply rails.

#### Transfer Function

Figure 7 shows the bipolar two's complement ADC transfer function. The single-ended conversion range extends from -VREF/2 to +VREF/2, where VREF = VREF+ - VREF-. The differential conversion range extends from -VREF to +VREF. Each LSB in the single-ended and dif-

ferential mode reflects voltage increments of VREF/4096 and 2VREF/4096, respectively.

## **ADC Special Function Registers**

The ADCON or A/D Control SFR establishes ADC operating conditions and input configurations. Table 7 shows the individual bit functions. A "write" to ADCON initiates the A/D conversion process.

Table 6. Program Status Word (PSW) Format

| BIT 7<br>(MSB) | BIT 6       | BIT 5             | BIT 4                                                                                                                                                       | BIT 3                              | BIT 2                              | BIT 1               | BIT 0<br>(LSB) |  |  |  |  |
|----------------|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|------------------------------------|---------------------|----------------|--|--|--|--|
| CY             | AC          | F0                | RS1                                                                                                                                                         | RS0                                | OV                                 | F1                  | Р              |  |  |  |  |
| BIT            | NAME        |                   | DESCRIPTION                                                                                                                                                 |                                    |                                    |                     |                |  |  |  |  |
| 7              | CY          |                   | arry Flag. Set to "1", following an additional operation that results in a carry or a subtraction operation at results in a borrow. Otherwise cleared to 0. |                                    |                                    |                     |                |  |  |  |  |
| 6              | AC          | Auxiliary Carry F | uxiliary Carry Flag. Similar to CY, but used for BCD operations.                                                                                            |                                    |                                    |                     |                |  |  |  |  |
| 5              | F0          | User Flag 0. Ger  | lser Flag 0. General-purpose flag for software control.                                                                                                     |                                    |                                    |                     |                |  |  |  |  |
|                |             | •                 | Bits. These select<br>lower internal RA                                                                                                                     | one of four banks                  | of eight registers                 | that occupy the f   | irst 32        |  |  |  |  |
|                | 50.         | RS1               | RS0                                                                                                                                                         |                                    | SELECTED REGISTER BA               |                     |                |  |  |  |  |
| 4,3            | RS1,<br>RS0 | 0                 | 0                                                                                                                                                           | Register bank                      | 0, addresses 00l                   | H-07H               |                |  |  |  |  |
|                | 1100        | 0                 | 1                                                                                                                                                           | Register bank                      | Register bank 1, addresses 08H–0FH |                     |                |  |  |  |  |
|                |             | 1                 | 0                                                                                                                                                           | Register bank                      | 2, addresses 10l                   | H-17H               |                |  |  |  |  |
|                |             | 1                 | 1                                                                                                                                                           | Register bank                      | 3, addresses 18l                   | H-1FH               |                |  |  |  |  |
| 2              | OV          | Overflow Flag. Se | t to "1", for any arith                                                                                                                                     | nmetic operation th                | at yields an overflo               | w. Otherwise cleare | ed to zero.    |  |  |  |  |
| 1              | F1          | User Flag 1. Ger  | User Flag 1. General-purpose flag for software control.                                                                                                     |                                    |                                    |                     |                |  |  |  |  |
| 0              | Р           |                   | "1", when the mo<br>o zero (even num                                                                                                                        | odule 2 sum of the<br>ber of 1's). | accumulator bits                   | s is one (odd numl  | ber of 1's),   |  |  |  |  |

# Table 7. Power Control (PCON) Format

| BIT 7<br>(MSB) | BIT 6 | BIT 5            | BIT 4                                                                                         | BIT 3              | BIT 2           | BIT 1 | BIT 0<br>(LSB) |  |  |  |
|----------------|-------|------------------|-----------------------------------------------------------------------------------------------|--------------------|-----------------|-------|----------------|--|--|--|
| SMOD0          | _     | _                | _                                                                                             | GF1                | GF0             | STOP  | IDLE           |  |  |  |
| BIT            | NAME  |                  | DESCRIPTION                                                                                   |                    |                 |       |                |  |  |  |
| 7              | SMOD0 | Serial Port 0 Ba | Serial Port 0 Baud-Rate Doubler Enable. SMOD0 = 1, doubles the baud rate.                     |                    |                 |       |                |  |  |  |
| 6,5,4          | _     | Reserved         | Reserved                                                                                      |                    |                 |       |                |  |  |  |
| 3              | GF1   | General Flag 1   | . General-purpos                                                                              | e flag for softwar | e control.      |       |                |  |  |  |
| 2              | GF0   | General Flag 0   | . General-purpos                                                                              | e flag for softwar | e control.      |       |                |  |  |  |
| 1              | STOP  | STOP Mode Se     | STOP Mode Select. STOP = 1 stops the crystal oscillator and powers down the analog circuitry. |                    |                 |       |                |  |  |  |
| 0              | IDLE  | IDLE Mode Sel    | ect. IDLE = 1 res                                                                             | ults in suspensio  | n of CPU proces | sing. |                |  |  |  |

#### **External Reference**

The MAX7651/MAX7652 require external reference voltages at VREF+ and VREF-. A single reference voltage can be used at VREF+, when VREF- is connected to AGND. The positive reference voltages must be no greater than the analog supply voltage AVDD and capable of supplying 30µA. Bypass each reference voltage to AGND with a 0.1µF capacitor in parallel with a 10µF low ESR capacitor.

# +FS = +V<sub>REF</sub> 2 -FS = -V<sub>REF</sub> 2 011 ... 111 011 ... 110 1LSB = V<sub>REF</sub> 4096 000 ... 001 000 ... 001 VIN = (V<sub>AIN</sub>) - (V<sub>ACOM</sub>) 111 ... 111 111 ... 110 110 ... 001 100 ... 001 INPUT VOLTAGE (LSBs)

Figure 7a. Single-Ended Mode Transfer Function

#### **PWM Digital-to-Analog Converters (DACs)**

The MAX7651/MAX7652 provide two pulse-width modulated (PWM) DACs for applications that do not require high conversion accuracy. Figure 8 shows the pulse-width-modulator block diagram. The clock signal is divided by 2 (x + 1), where x is the content of the Pulse-Width Prescaler (PWPS) SFR register. This reduced frequency signal is used to drive a modulo-255 counter. When the counter value exceeds the value stored in SFRs PWDA (Output A) or PWDB



Figure 7b. Differential Mode Transfer Function

# **Table 8. Analog Input Selection**

| MD3 | MD2 | MD1 | MD0 | MODE         | AIN+ | AIN- |
|-----|-----|-----|-----|--------------|------|------|
| 0   | 0   | 0   | 0   | Single-ended | AIN0 | ACOM |
| 0   | 0   | 0   | 1   | Single-ended | AIN1 | ACOM |
| 0   | 0   | 1   | 0   | Single-ended | AIN2 | ACOM |
| 0   | 0   | 1   | 1   | Single-ended | AIN3 | ACOM |
| 0   | 1   | 0   | 0   | Single-ended | AIN4 | ACOM |
| 0   | 1   | 0   | 1   | Single-ended | AIN5 | ACOM |
| 0   | 1   | 1   | 0   | Single-ended | AIN6 | ACOM |
| 0   | 1   | 1   | 1   | Single-ended | AIN7 | ACOM |
| 1   | 0   | 0   | 0   | Differential | AIN1 | AIN0 |
| 1   | 0   | 0   | 1   | Differential | AIN3 | AIN2 |
| 1   | 0   | 1   | 0   | Differential | AIN5 | AIN4 |
| 1   | 0   | 1   | 1   | Differential | AIN7 | AIN6 |
| 1   | 1   | 0   | 0   | _            | REF+ | REF- |



Figure 8. PWM Block Diagram

(Output B), the corresponding output transitions from low to high (Figure 9).

Writing 00H to PWDA or PWDB, yields a waveform with 100% duty cycle (High), and writing FFH to PWDA or PWDB yields a waveform with 0% duty cycle (Low). Writing an intermediate register value y, yields a waveform with duty cycle (1 - y / 255) × 100%. Tables 10, 11, and 12 show the formats of the PWPS, PWDA, and PWDB SFR's.

External low-pass filters are needed to obtain DC voltages between 0 and DVDD from the PWM outputs. Simple RC filters are preferred. Choose R  $>\!\!2k\Omega$  to avoid excessive loading, and choose C  $<\!\!0.1\mu\mathrm{F}$  to avoid large transient currents that reflect the PWM switching action. Each filtered PWM output can source or sink up to 2mA. Do not exceed this specification. If larger output capability is required, provide an appropriate buffer such as a unity-gain op amp. PWM circuitry and PWM Outputs A and B are enabled with the Pulse-Width Modulator Control (PWMC) SFR. Table 13 shows the PWMC SFR format.

#### **Watchdog Timer**

The MAX7651/MAX7652 features a watchdog timer that resolves irregular software control. The watchdog timer resets the microprocessor if software fails to reset the timer within one of four pre-selected time intervals. The timer generates an optional interrupt after 2<sup>16</sup>, 2<sup>19</sup>, 2<sup>22</sup>, or 2<sup>25</sup> clock periods of the external oscillator. It generates the reset signal after an additional 512 clock periods. Table 14 indicates specific interrupt and reset times that apply for a 12MHz clock frequency.



Figure 9. PWM Output Waveform

Five watchdog-related control bits and two status flags are located in different special function registers. Table 15 shows the particular functions and SFR locations.

## 8051-Compatible Peripherals

## Parallel I/O Ports

Like other 8051-based systems, the MAX7651/MAX7652 features four 8-bit parallel ports that support general input and output, address and data lines, and various special functions. Each bidirectional port has a latch register (SFRs P0, P1, P2, and P3), an input buffer, and an output driver.

Port P0 is open-drain. Writing a logic level 1 to a P0 pin establishes a high-impedance input. When used as a general-purpose output, a P0 pin requires an external pull-up resistor to validate a logic level 1. When used as an address/data output, a P0 pin features an internal active high driver. Port 0 is a bidirectional Flash data I/O port during Flash programming and verification.

Port 1: Port 1 is a bidirectional I/O port with internal pullups. Port 1 pins that have 1's written to them are pulled high by the internal pullups and can serve as inputs. Port 1 receives low-order address bytes during Flash programming and verification.

Port 2: Port 2 is a bidirectional I/O port with internal pullups. Port 2 pins that have 1's written to them are pulled high by the internal pullups and can serve as inputs. Port 2 also serves as the high-order address and data bus (for 16-bit operations) during accesses to external memory, using strong internal pullups when emitting 1's.

Port 3: Port 3 is a bidirectional I/O port with internal pullups. Port 3 pins that have 1's written to them are pulled high by the internal pullups and can serve as inputs.

The P1 and P3 ports support the special functions listed in Table 16. Write a "1" to the corresponding bit in the port register to enable the alternative function.

Table 9. A/D Control (ADCON) Format—SFR Address C5H

| BIT 7<br>(MSB) | BIT 6 | BIT 5                            | BIT 4                                                                                                                                                                                                                                                                                               | BIT 3           | BIT 2           | BIT 1               | BIT 0<br>(LSB) |  |  |  |
|----------------|-------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|---------------------|----------------|--|--|--|
| CC             | CCVT  | CCIE                             | OVRN                                                                                                                                                                                                                                                                                                | M3              | M2              | M1                  | M0             |  |  |  |
| BIT            | NAME  |                                  | DESCRIPTION                                                                                                                                                                                                                                                                                         |                 |                 |                     |                |  |  |  |
| 7              | CC    | conversion to in                 | conversion Complete Flag (Read Only). The MAX7651/MAX7652 set this flag to 1 following a conversion to indicate valid data in the ADDAT1 and ADDAT0 data SFRs (see below). The CC it is cleared to 0 when ADDAT1 is read by the CPU.                                                                |                 |                 |                     |                |  |  |  |
| 6              | CCVT  | conversions at<br>MAX7652 is res | Continuous Conversion Enable (Read/Write). When CCVT = 1, the ADC performs continuous conversions at the rate of 224 clock cycles/conversion. Conversions continue until the MAX7651/ MAX7652 is reset or until CCVT is cleared, in which case conversions stops after the current conversion ends. |                 |                 |                     |                |  |  |  |
| 5              | CCIE  | Conversion Co<br>the end of each |                                                                                                                                                                                                                                                                                                     | Enable (Read/Wr | ite). When CCIE | = 1, interrupt 3 is | generated at   |  |  |  |
| 4              | OVRN  | completes whil                   | Overrun Flag (Read Only). The MAX7651/MAX7652 set this flag to 1 whenever a conversion completes while CC is set. The previous conversion result is overwritten. The OVRN bit is cleared to 0 when ADDAT1 is read by the CPU.                                                                       |                 |                 |                     |                |  |  |  |
| 3–0            | M3-M0 | - '                              | Analog Input Multiplexer Select Bits. Used to establish input configurations for single-ended or differential conversions (see Table 6).                                                                                                                                                            |                 |                 |                     |                |  |  |  |

**Note:** SFRs ADDAT1 and ADDAT0 contain the results of individual A/D conversions with the formats shown in Tables 8 and 9. A read to ADDAT1 clears the CC and OVRN flags in ADCON.

# Table 10. A/D Data-1 (ADDAT1) Format—SFR Address C3H

| BIT 7<br>(MSB) | BIT 6  | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0<br>(LSB) |
|----------------|--------|-------|-------|-------|-------|-------|----------------|
| SIGN BIT       | BIT 10 | BIT 9 | BIT 8 | BIT 7 | BIT 6 | BIT 5 | BIT 4          |

# Table 11. A/D Data-0 (ADDAT0) Format—SFR Address C2H

| BIT 7<br>(MSB) | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0<br>(LSB) |
|----------------|-------|-------|-------|-------|-------|-------|----------------|
| BIT 3          | BIT 2 | BIT 1 | BIT 0 | 0     | 0     | 0     | 0              |

# Table 12. Pulse-Width Prescaler (PWPS) Format—SFR address DAH

| BIT 7<br>(MSB) | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0<br>(LSB) |
|----------------|-------|-------|-------|-------|-------|-------|----------------|
| PWPS7          | PWPS6 | PWPS5 | PWPS4 | PWPS3 | PWPS2 | PWPS1 | PWPS0          |

# Table 13. Pulse-Width Data A (PWDA) Format—SFR address DBH

| BIT 7<br>(MSB) | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0<br>(LSB) |
|----------------|-------|-------|-------|-------|-------|-------|----------------|
| PWDA7          | PWDA6 | PWDA5 | PWDA4 | PWDA3 | PWDA2 | PWDA1 | PWDA0          |

## Table 14. Pulse-Width Data B (PWDB) Format—SFR address DCH

| BIT 7<br>(MSB) | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0<br>(LSB) |
|----------------|-------|-------|-------|-------|-------|-------|----------------|
| PWDB7          | PWDB6 | PWDB5 | PWDB4 | PWDB3 | PWDB2 | PWDB1 | PWDB0          |

# Table 15. Pulse-Width-Modulator Control (PWMC) Format—SFR Address FEH

|                |       |              | •                                                     | -                        |                 |                   |                |  |  |
|----------------|-------|--------------|-------------------------------------------------------|--------------------------|-----------------|-------------------|----------------|--|--|
| BIT 7<br>(MSB) | BIT 6 | BIT 5        | BIT 4                                                 | BIT 3                    | BIT 2           | BIT 1             | BIT 0<br>(LSB) |  |  |
| PWON           | _     | _            | _                                                     | _                        | _               | PWENA             | PWENB          |  |  |
|                |       |              |                                                       |                          |                 |                   |                |  |  |
| BIT            | NAME  |              | DESCRIPTION                                           |                          |                 |                   |                |  |  |
| 7              | PWON  |              | odulator Enable.<br>5 counter circuit                 | Set PWON to 1 functions. | to enable the c | livide-by-two, PV | VPS prescaler, |  |  |
| 6–2            | _     | Not used     |                                                       |                          |                 |                   |                |  |  |
| 1              | PWENA | PWM Output A | PWM Output A Enable. Set to 1 to enable PWM output A. |                          |                 |                   |                |  |  |
| 0              | PWENB | PWM Output B | Enable. Set to 1                                      | to enable PWM c          | output B.       |                   |                |  |  |

# Table 16. Watchdog Interrupt and Reset Times (fck = 12MHz)

| WD1 | WD0 | INTERRUPT TIMOUT       | TIME (ms) | RESET TIMOUT                 | TIME (ms) |
|-----|-----|------------------------|-----------|------------------------------|-----------|
| 0   | 0   | 216 clocks             | 5.461     | 2 <sup>16</sup> + 512 clocks | 5.474     |
| 0   | 1   | 2 <sup>19</sup> clocks | 43.691    | 219 + 512 clocks             | 43.734    |
| 1   | 0   | 2 <sup>2</sup> clocks  | 349.525   | 222 + 512 clocks             | 349.567   |
| 1   | 1   | 2 <sup>25</sup> clocks | 2796.000  | 2 <sup>25</sup> + 512 clocks | 2796.042  |

#### Serial Interface Ports

The MAX7651/MAX7652 each have two serial interfaces that operate according to the 8051 industry standard. Serial Port 0 uses SFRs SCON0 and SBUF0 for control and buffer functions. Serial Port 1 uses SFRs SCON1 and SBUF1 with identical bit functionality. See the MAX7651/MAX7652 *Programmer's Reference Manual* for details concerning serial-port data operations and timing information.

#### Timers/Counters

The MAX7651/MAX7652 have three timer/counters that function in several different modes for applications such as UART baud-rate control. All three timer/counters operate according to the 8051 industry standard. Specifically, the control (TCON), mode (TMOD), timer-0 parameter (TL0, TH0), Timer1 parameter (TL1, TH1), and Timer-2 parameter (TL2, TH2, RCAP2L, RCAP2H) SFRs have conventional formats. See the MAX7651/MAX7652 *Programmer's Reference Manual* for information concerning timer/counter applications.

#### Crystal Oscillator

The MAX7651/MAX7652 each have a single-stage inverter (Input at XTAL1, Output at XTAL2) that supports a crystal controlled oscillator. The crystal oscillator frequency should be between 1 and 12 MHz.

**Note:** External flash memory programming requires a minimum crystal oscillator frequency of 4MHz.

# **Crystal Specification:**

| Rs(typ)                    | 25–40Ω          |
|----------------------------|-----------------|
| Rs(max)                    | 150Ω            |
| Load Capacitance           | 10-15pF         |
| Oscillation Mode           | Fundamental     |
| Frequency                  | 12,000MHz (max) |
| Tolerance                  | ±0.01%          |
| Holder Capacitance         | 3pF             |
| Motional Inductance (typ)  | 50mH            |
| Motional capacitance (typ) | 0.0035pF        |

An external oscillator can also be used to clock the MAX7651/MAX7652 at frequencies between 1 and 12MHz, provided that the duty cycle is between 40% and 60%. When using an external clock source connect the clock to XTAL1, with XTAL2 unconnected.

# **Applications Information**

#### **Performing a Conversion**

An example of a conversion with the MAX7651/MAX7652 is as follows:

- Write to the ADCON SFR, setting bit CCIE to 1, and bits M3–M0 to appropriate values for the desired differential or single-ended analog input configuration (Tables 6 and 7).
- Wait 224 clock cycles to receive Interrupt 3 as an indication that the A/D conversion is complete.
- Read the conversion data in SFRs ADDAT0 and ADDAT1 as described in Tables 8 and 9.

## **Using FLASH Memory**

The upper and lower 8kB blocks of internal Flash memory are each organized as 128 64-byte pages. Read, write, and page-erase operations cannot be applied to either block while executing program commands from the other block.

**Note:** Standard MOVC operations are supported.

## FLASH Memory Special Function Registers

Tables 17 and 18 show the formats for the EEAH and EEAL SFRs. The EEAH register specifies the applicable Flash memory block (high or low) and the page address within that block. The EEAL register specifies the byte address within the specified page.

Table 19 shows the format for the Flash memory data (EEDAT) SFR that is used for 8-bit read and write transfers from and to a specified address.

Table 20 shows the format for the Flash memory status and command (EESTCMD) SFR. Bits RDYHI and RDYLO are cleared to zero when a read, write, or page-erase operation is applied to the high or low flash memory block. These bits are set to one once the flash

**Table 17. Watchdog Timer Control and Status Bits** 

| NAME | SFR   | BIT | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WDIF | EICON | 3   | Watchdog Interrupt Flag. WDIF is set to 1 after completion of the interrupt timeout period (see Table 14). WDIF must be cleared by software before exiting interrupt service routine. Otherwise interrupt reoccurs upon exiting. WDIF is automatically cleared by either an external RST assertion or a WDT-generated reset.                                                                                                                                                                                                                                                 |
| WTRF | WDT   | 2   | Watchdog Reset Flag. The WTRF bit is a status/control bit indicating that the Watchdog counter has counted an additional 512 clocks past the WDT interrupt and has generated a processor RESET. The 8051's "reset" routine should check the WTRF flag to determine the source of the reset. Additionally, if the WTRF flag has been set the Watchdog Timer counts will be reset when a zero is written to the WTRF flag. This allows the processor to regain synchronization with the WDT after a WDT reset has occurred. WTRF is also cleared when a zero is written to it. |
| EWT  | EICON | 1   | Enable Watchdog Timer. Set to 1 to enable the watchdog timer. An assertion at the external RST pin automatically clears EWT. If EWT is cleared after being set. The watchdog timer count will suspend until EWT is set to 1 again.                                                                                                                                                                                                                                                                                                                                           |
| RWT  | EICON | 0   | Reset Watchdog Timer. Writing a "1" to the RWT bit will reset the watchdog counter ONLY if the end of the count has been reached (WDIF = 1) and the 512 clock window has not expired (WTRF = 0). Writing to RWT before the timeout period will not reset the watchdog timer.                                                                                                                                                                                                                                                                                                 |
| WD1  | CKCON | 7   | Watchdog Control Bit 1. Controls the watchdog interrupt timeout (see Table 14).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| WD0  | CKCON | 6   | Watchdog Control Bit 0. Controls the watchdog interrupt timeout (see Table 14).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| EWDI | EIE   | 4   | Enable Watchdog Interrupt. An interrupt will be generated after the interrupt timeout period when EWDI = 1. Either a WDT-generated reset or an assertion at the external RST pin automatically clears EWDI.                                                                                                                                                                                                                                                                                                                                                                  |

## **Table 18. Alternate Port Functions**

| PORT PIN | ALTERNATIVE<br>FUNCTION | DESCRIPTION                                                                      |
|----------|-------------------------|----------------------------------------------------------------------------------|
| P1.3     | TXD1                    | Transmit Serial Output for Serial Port                                           |
| P1.2     | RXD1                    | Receive Serial Input for Serial Sort                                             |
| P1.1     | T2EX                    | Timer 2 External Capture/Reload Trigger                                          |
| P1.0     | T2/T2_OUT               | Timer 2 External Input/Output                                                    |
| P3.7     | RD                      | Read Output                                                                      |
| P3.6     | WR                      | Write Output                                                                     |
| P3.5     | T1                      | Timer 1 External Input                                                           |
| P3.4     | T0/READY                | Timer 0 External Input/Ready State Output (External Flash Programming mode only) |
| P3.1     | TXD0                    | Transmit Serial Output for UART 0                                                |
| P3.0     | RXD0                    | Receive Serial Input for UART 0                                                  |

# Table 19. Flash Address High (EEAH) Format—SFR Address EBH

| BIT 7<br>(MSB) | BIT 6 | BIT 5         | BIT 4                                                                                                                        | BIT 3 | BIT 2 | BIT 1 | BIT 0<br>(LSB) |  |  |
|----------------|-------|---------------|------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|----------------|--|--|
| BLOCK          | EEAH6 | EEAH5         | EEAH4                                                                                                                        | EEAH3 | EEAH2 | EEAH1 | EEAH0          |  |  |
|                |       |               |                                                                                                                              |       |       |       |                |  |  |
| BIT            | NAME  |               | DESCRIPTION                                                                                                                  |       |       |       |                |  |  |
| 7              | BLOCK | ,             | Flash Memory Block. Set BLOCK = 1 to access the high Flash memory block. Set BLOCK = 0 to access the low Flash memory block. |       |       |       |                |  |  |
| 6 - 0          | EEAH_ | Page Address. | Page Address. Determines the Flash memory page. EEAH6 is the MSB.                                                            |       |       |       |                |  |  |

# Table 20. Flash Address Low (EEAL) Format—SFR Address EAH

| BIT 7<br>(MSB) | BIT 6 | BIT 5           | BIT 4             | BIT 3            | BIT 2             | BIT 1          | BIT 0<br>(LSB) |
|----------------|-------|-----------------|-------------------|------------------|-------------------|----------------|----------------|
| _              | _     | EEAL5           | EEAL4             | EEAL3            | EEAL2             | EEAL1          | EEAL0          |
|                |       |                 |                   |                  |                   |                |                |
| BIT            | NAME  |                 |                   | DESCR            | IPTION            |                |                |
| 7,6            | _     | Not used.       |                   |                  |                   |                |                |
| 5 - 0          | EEAL_ | Byte within Pag | ge Address Bit. D | etermines the by | te address within | a Flash memory | page. EEAL5    |

memory operation is complete. Never attempt to execute a flash memory command when either RDYHI or RDYLO are 0 (command action in progress).

#### Flash Memory Read

To read Flash memory, load the address into SFRs EEAH and EEAL. Then write AAH to EESTCMD. The results of the read operation will be available in SFR EEDAT in the next CPU instruction cycle.

#### Flash Memory Write

Erase operations set all bits to "1". After a byte has been programmed it must be erased before it is re-written. To write to Flash memory, load the address into SFRs EEAH and EEAL, and load the data into EEDAT. Then write 55H to EESTCMD. The execution time for flash memory write is 63µs (typ) and is independent of the CPU clock.

**Note:** Do not write to the same location more than twice before the next page/mass erase operation.

#### Flash Memory Page Erase

The page erase operation sets all bits within the page to "1"s. To erase a page from Flash memory, load the page address into SFR EEAH, register EEAL is not used. Then write 5AH to EESTCMD. The execution time for page erase is 9.4ms (typ) and is independent of the CPU clock.

**Note:** Do not attempt to apply read, write, or pageerase operations to the flash memory block in which the CPU is currently executing program instructions.

## **External Flash Memory Programming**

The MAX7651/MAX7652 are normally shipped with the internal Flash memory blocks fully erased (all bits set to 1) and ready for external programming. External write, read (verify), and mass-erase operations are available. Flash memory addresses for either the upper or lower 8-kbyte blocks are specified at Ports 1 and 2.

Before applying any external Flash memory operations, power-up the MAX7651/MAX7652 with RST asserted. ALE,  $\overline{\text{PSEN}}$ , and ports P1 –P3 are pulled high with weak resistive pullups. Port P0 requires 10k $\Omega$  external pullups. Wait at least 10ms for the oscillator and internal circuitry to stabilize. The program, verify and masserase flash memory programming steps are outlined below.

**Note:** Failure to follow proper power-up conditions or the specified flash memory programming steps can result in loss of flash data integrity.

## External Flash Memory Program (Table 2)

Erase operations. Set all bits to "1". After a byte has been programmed it must be erased before it is re-written.

- 1) Power-up the device with RST asserted and allow ALE and PSEN to float to the "1" state (they will be internally pulled-up during RST assertion).
- Wait 10ms for the internal bandgap and oscillator to stabilize.
- 3) Apply the memory location on the address lines at ports 1 and 2.
- 4) Apply data to the data lines at port 0.
- 5) Raise EA / VPP to DVDD and pull PSEN low.
- 6) Set P2.6, P2.7, P3.6, and P3.7 to the levels shown in Table 2.
- 7) Set P2.5 low or high for the lower or higher 8kB Flash memory block.

- 8) Force ALE / PROG low. P3.4 (READY) will go low to indicate a write in progress.
- 9) When P3.4 returns high (write complete after approximately 63µs), set ALE / PROG high.
- 10) Power-down sequence.
  - A) Remove drive from and allow PSEN and ALE/PROG to float high.
  - B) Pull EA low.
  - C) High-Z all digital pins.
  - D) Remove power from all power pins.

**Note:** Do not write to the same location more than twice before the next page/mass erase operation.

# External Flash Memory Verify (Table 2)

## **External Verify:**

If lock bits LB1 and LB2 have not been programmed, the programmed flash array(s) can be read back through the address and data lines for verification. The lock bits cannot be verified directly. Verification of the lock bits is achieved by observing that their features are enabled.

#### External verify (readback) power-up sequence:

- 1) Power-up the MAX7651/MAX7652 with RST asserted, allow ALE and PSEN to float to the "1" state (they will be internally pulled-up during RST assertion). Wait 10ms for the internal bandgap and oscillator to stabilize.
- 2) Pull PSEN LOW, EA HIGH, ALE HIGH, and set P2.6, P2.7, P3.6, P3.7, P2.5, as per *Flash Programming* Modes (Table 2) for reading either LOWER or UPPER flash memory block.

**Note:** P2.7 is cycled low/high to perform a FLASH read operation. Minimum low time for P2.7 is ten clock cycles.

## External verify power-down sequence:

- 1) Power-down sequence
  - A)Remove drive from and allow  $\overline{\text{PSEN}}$  and ALE/  $\overline{\text{PROG}}$  to float high.
  - B) Pull EA low.
  - C) Hi-z all digital pins.
  - D) Remove power from all power pins.

#### External Flash Memory Mass Erase

A mass erase operation sets all bits, including the lock bits to "1" (Table 22).

## **External Erase:**

Both FLASH arrays can be simultaneously mass-erased electrically by using the proper combination of control signals as shown in Table 2. The erase operation must be executed before either memory can be programmed. Lock bits are also erased (Set to 1).

## External chip erase power-up sequence:

- 1) Power-up chip with RST asserted, and allow ALE and PSEN to float to the "1" state (they will be internally pulled-up during RST assertion). Wait 10ms for the internal bandgap and oscillator to stabilize.
- 2) Pull PSEN LOW, EA HIGH, set P2.6, P2.7, P3.6, P3.7, and P2.5, as per Mass Erase mode in the Flash Programming Modes (table 2).
- 3) P3.4 will be LOW during mass erase cycle and return HI at the end of mass erase cycle.

#### External chip erase power-down sequence:

- 1) Power-down sequence
  - A)Remove drive from and allow PSEN and ALE/PROG to float high.
  - B) Pull  $\overline{\mathsf{EA}}$  low.

- C) Hi z all digital pins.
- D) Remove power from all power pins.

Figure 2 shows the timing waveforms that apply for the Flash memory mass erase operation.

## Flash Memory Lock Bits

The MAX7651/MAX7652 each contains three lock bits which can be left unprogrammed (logic "1") or can be programmed (logic "0") to obtain the additional features listed in the table below:

When lock bit "1" is programmed (set to logic "0"), the logic level at the  $\overline{EA}$  pin is sampled and latched during RST deassertion. Subsequent changes in logic levels on  $\overline{EA}$  have no effect. If the device is powered-up without a reset (RST), the latch initializes to a random value and holds that value until RST is pulsed high, then low. It is necessary that the latched value of  $\overline{EA}$  be in agreement with the current logic level at that pin in order for the device to function properly.

#### Signature Bytes

The MAX7651/MAX7652 contain three signature bytes with the information shown in Table 23. Read each byte by following the *Flash Memory Read* procedure, but set P2.6, P2.7, P3.6, and P3.7 at low. Signature bytes are not affected by mass erase or page erase operations.

# Table 21. Flash Memory Data (EEDAT) Format—SFR Address ECH

| BIT 7<br>(MSB) | BIT 6  | BIT 5  | BIT 4  | BIT 3  | BIT 2  | BIT 1  | BIT 0<br>(LSB) |
|----------------|--------|--------|--------|--------|--------|--------|----------------|
| EEDAT7         | EEDAT6 | EEDAT5 | EEDAT4 | EEDAT3 | EEDAT2 | EEDAT1 | EEDAT0         |

# Table 22. Flash Status and Control (EESTCMD) Format—SFR Address EDH

| BIT 7            |                  |                               |                                                                                                                                                                                                        |                                    |                    |                | BIT 0     |
|------------------|------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|--------------------|----------------|-----------|
| (MSB)            | BIT 6            | BIT 5                         | BIT 4                                                                                                                                                                                                  | BIT 3                              | BIT 2              | BIT 1          | (LSB)     |
| RDYHI/<br>EECMD7 | RDYLO/<br>EECMD6 | EECMD5                        | EECMD4                                                                                                                                                                                                 | EECMD3                             | EECMD2             | EECMD1         | EECMD0    |
|                  |                  | _                             |                                                                                                                                                                                                        |                                    |                    |                |           |
| BIT              | NAME             |                               |                                                                                                                                                                                                        | DESCR                              | RIPTION            |                |           |
| 7                | RDYHI            | erase operation               | High Block Ready Status. The MAX7651/MAX7652 set RDYHI to 0 during read, write, and page erase operations that are applied to the 8-kbyte "high" block of flash memory. The bit is otherwise set to 1. |                                    |                    |                |           |
| 6                | RDYLO            |                               | ,                                                                                                                                                                                                      | AX7651/MAX765<br>ed to the 8-kbyte |                    | ,              | , ,       |
| 7 - 0            | EECMD            | Flash Memory<br>EECMD7 is the |                                                                                                                                                                                                        | Jsed to specify re                 | ead, write, or pag | e-erase memory | commands. |

## **Interrupt System**

The MAX7651/MAX7652 has ten program-assist interrupts that are either external or internal to the 8051 system. Table 24 shows the SFR bit locations for interrupt enable and priority control. Shaded Table regions reflect the 8051 industry standard. Set SFR bit IE.7 high to enable all interrupts. See the MAX7651/MAX7652 *Programmer's Reference Manual.* 

#### **Timers**

The MAX7651/MAX7652 feature several modes of timing control through the CKCON special function register. Table 25 shows the CKCON SFR format. The individual control bits can be used to set the number of

clock cycles needed (four or twelve) to increment each timer/counter or the number of clock cycles needed to execute the MOVX instruction. See the MAX7651/MAX7652 *Programmer's Reference Manual* for further details

## **Analog and Digital Supplies**

The MAX7651/MAX7652 have multiple power-supply inputs: one analog AV<sub>DD</sub> and three digital DV<sub>DD</sub>. The pulse width modulators have their own power supply inputs, PWMV and PWMG. Decouple all supply inputs with a  $0.1\mu F$  capacitor in parallel with a  $10\mu F$  low ESR capacitor, with both capacitors as close to the supply pins as possible and with the shortest possible connection to the ground plane.

## Table 23

| PARAMETER MIN      |                         | MAX                     | COMMENTS                                       |
|--------------------|-------------------------|-------------------------|------------------------------------------------|
| T <sub>PROGL</sub> | 10T <sub>CK</sub>       |                         | TPROGL must equal TWRITE during lockbit writes |
| T <sub>ASUW</sub>  | 3T <sub>CK</sub>        |                         |                                                |
| TWRITE             | 7T <sub>CK</sub> + 54μs | 7T <sub>CK</sub> + 72μs |                                                |
| T <sub>ADSUR</sub> | 3T <sub>CK</sub>        |                         |                                                |
| T <sub>READ</sub>  |                         | 8T <sub>CK</sub> + 50ns | Read access time                               |
| T <sub>P27</sub> L | 10T <sub>CK</sub>       |                         |                                                |
| T <sub>P27H</sub>  | 3T <sub>CK</sub>        |                         |                                                |
| T <sub>CK</sub>    | 83ns                    | 250ns                   |                                                |

Note: P2.6, P2.7, P3.6, and P3.7 must also meet T<sub>ASUW</sub> (min) timing specification.

#### **Table 24. Lock Bit Protection Modes**

| PROGRAM LOCK<br>BITS |     | СК  | DROTECTION TYPE |                                                                                                                                                                                                                                                    |  |  |  |
|----------------------|-----|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                      | LB1 | LB2 | LB3             | PROTECTION TYPE                                                                                                                                                                                                                                    |  |  |  |
| 1                    | 1   | 1   | 1               | No program lock features (Default after a mass erase)                                                                                                                                                                                              |  |  |  |
| 2                    | 0   | 1   | 1               | MOVC instructions executed from external program memory are disabled from fetching code bytes from internal memory, $\overline{EA}$ is sampled and latched on reset (RST), and further external data programming of both FLASH arrays is disabled. |  |  |  |
| 3                    | 0   | 0   | 1               | Verify (read) is disabled. (see Mode 2)                                                                                                                                                                                                            |  |  |  |
| 4                    | 0   | 0   | 0               | External execution is disabled (EA override, see Mode 3).                                                                                                                                                                                          |  |  |  |

## Table 25. MAX7651/MAX7652 Signature Bits

| ADDRESS | DATA | MEANING                 |  |  |
|---------|------|-------------------------|--|--|
| 30H     | 7FH  | JEDEC Continuation Byte |  |  |
| 31H     | CBH  | Manufactured by Maxim   |  |  |
| 32H     | 20H  | MAX7651/MAX7652         |  |  |

Table 26. MAX7651/MAX7652 Interrupts (Note 1)

| INTERRUPT    | ASSOCIATED FEATURE       | ENABLE SFR BIT<br>(NOTE 2) | PRIORITY SFR BIT<br>(NOTE 3) | PRIORITY |
|--------------|--------------------------|----------------------------|------------------------------|----------|
| ĪNT0         | External Interrupt 0     | IE.0                       | IP.0                         | 1        |
| ĪNT1         | External Interrupt 1     | IE.2                       | IP.1                         | 3        |
| FLASH        | Flash Operation Complete | EIE.0                      | EIP.0                        | 8        |
| ADC          | A / D Operation Complete | EIE.1                      | EIP.1                        | 9        |
| WDTI         | Watchdog Timer           | EICON.1                    | EIP.4                        | 10       |
| TF0 or EXF0  | Timer 0                  | IE.1                       | IP.1                         | 2        |
| TF1 or EXF2  | Timer 1                  | IE.3                       | IP.3                         | 4        |
| TI_0 or RI_0 | Serial Port 0            | IE.4                       | IP.4                         | 5        |
| TF2 or EXF2  | Timer 2                  | IE.5                       | IP.5                         | 6        |
| TI_1 or RI_1 | Serial Port 1            | IE.6                       | IP.6                         | 7        |

Note 1: Shaded areas reflect the 8051 industry standard.

Note 2: Set Enable SFR bit high to enable interrupt.

Note 3: Set Priority SFR bit high to eatablish high priority.

## Table 27, CKCON SFR Address 8EH

| BIT 7<br>(MSB) | BIT 6  | BIT 5                                                                                                                                                            | BIT 4       | BIT 3  | BIT 2 | BIT 1         | BIT 0<br>(LSB) |
|----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------|-------|---------------|----------------|
| WD1            | WD0    | TIMER2                                                                                                                                                           | TIMER1      | TIMER0 | MD2   | MD1           | MD0            |
|                |        |                                                                                                                                                                  |             |        |       |               |                |
| BIT            | NAME   |                                                                                                                                                                  | DESCRIPTION |        |       |               |                |
| 7              | WD1    | Cat WD1 and WD0 to adjust the interview interval for the watched at times. (Can Matchedon Times.)                                                                |             |        |       |               |                |
| 6              | WD10   | Set WD1 and WD0 to adjust the interrupt interval for the watchdog timer. (See <i>Watchdog Timer</i> .)                                                           |             |        |       |               |                |
| 5              | TIMER2 | Timer 2 Control. Set TIMER2 = 1 for TIMER2-associated counter increments at four clock intervals. Set TIMER2 = 0 for increments at 12 clock intervals.           |             |        |       |               |                |
| 4              | TIMER1 | Timer 1 Control. Set TIMER1 = 1 for Timer1-associated counter increments at four clock intervals. Set TIMER1 = 0 for increments at 12 clock intervals.           |             |        |       |               |                |
| 3              | TIMER0 | Timer 0 Control. Set TIMER0 = 1 for Timer0-associated counter increments at four clock intervals. Set TIMER0 = 0 for increments at 12 clock intervals.           |             |        |       |               |                |
| 2              | MD2    |                                                                                                                                                                  |             |        |       |               |                |
| 1              | MD1    | Set MD2, MD1, and MD0 to adjust the Read/Write strobe width (in clocks). The number of clock cycles is two plus the MD2, MD1, MD0 decimal value. MD0 is the LSB. |             |        |       | mber of clock |                |
| 0              | MD0    |                                                                                                                                                                  |             |        |       |               |                |

## **Power Requirements**

MAX7651 operates from +5V while the MAX7652 operates from +3V analog and digital supply voltages. The analog supply current is typically 2mA. The typical digital supply currents (continuous A/D conversions at 12MHz clock frequency) are 5mA and 13mA at +3V and +5V, respectively. Current consumption will vary

depending on RAM read/write and flash read/write page erase duty cycle.

## Idle Mode

In idle mode, CPU processing is suspended and internal data registers maintain their current data. However, unlike typical 8051 systems, the clock is not disabled internally. Set PCON.0 (IDLE) high to enter the Idle

mode after the instruction is complete. Figure 10 shows the related timing characteristics.

Enable any interrupt to clear PCON.0 and exit the Idle mode (See Figure 11 for the related timing). Assert RST alternately.

#### Stop Mode

In stop mode, the internal clock and analog circuitry are powered-down. Set PCON.1 (STOP) HIGH to enter the Stop mode after the instruction is complete. Figure 12 shows the related timing characteristics. The only way to exit Stop mode is to assert RST.

## **Definitions**

## Integral Nonlinearity (INL)

Integral nonlinearity is the deviation of the values on an actual transfer function from a straight line. This straight line can be either a best straight-line fit or a line drawn between the endpoints of the transfer function, once offset and gain errors have been nullified. The static linearity parameters for the MAX7651/MAX7652 are measured using the best straight-line fit method.



Figure 10. Idle Mode Entry Timing



Figure 11. Idle Mode Exit Timing



Figure 12. Stop Mode Timing

## **Differential Nonlinearity (DNL)**

Differential nonlinearity is the difference between an actual step width and the ideal value of 1LSB. A DNL error specification of less than 1LSB guarantees no missing codes and a monotonic transfer function.

#### Offset Error

The offset error is the difference between the ideal and the actual offset points. For an ADC, the offset point is the midstep value when the digital output is zero.

#### **Gain Error**

The gain or full-scale error is the difference between the ideal and actual gain points on the transfer function, after the offset error has been canceled out. For an ADC the gain point is the midstep value when the digital output is full-scale.

## Signal-To-Noise Ratio (SNR)

For a waveform perfectly reconstructed from digital samples, SNR is the ratio of full-scale analog input (RMS value) to the RMS quantization error (residual error). The ideal theoretical minimum analog-to-digital noise is caused by quantization error only and results directly from the ADCs resolution (N Bits):

$$SNR = (6.02 \times N + 1.76)dB$$

In reality, there are other noise sources besides quantization noise including thermal noise, reference noise, clock jitter. Therefore, SNR is computed by taking the ratio of the RMS signal to the RMS noise which includes all spectral components minus the fundamental, the first five harmonics, and the DC offset.

#### Signal-To-Noise Plus Distortion (SINAD)

Signal-To-Noise Plus Distortion is the ratio of the fundamental input frequency's RMS amplitude to RMS equivalent of all other ADC output signals.

SINAD (dB) = 20 x log (Signal RMS / NoiseRMS)

## **Effective Number Of Bits (ENOB)**

ENOB indicates the global accuracy of an ADC at a specific input frequency and sampling rate. An ideal ADCs error consists of quantization noise only. With an input range equal to the full-scale range of the ADC, calculate the effective number of bits as follows:

$$ENOB = (SINAD - 1.76) / 6.02$$

#### **Total Harmonic Distortion (THD)**

THD is the ratio of the RMS sum of the first five harmonics of the input signal to the fundamental itself. This is expressed as:

THD = 20×log 
$$\sqrt{\left(V_2^2 + V_3^2 + V_4^2 + V_5^2\right)}$$

where V1 is the fundamental amplitude, and V2 through V5 are the amplitudes of the 2nd- through 5th-order harmonics.

## **Spurious-Free Dynamic Range (SFDR)**

SFDR is the ratio of RMS amplitude of the fundamental maximum signal component to the RMS value of the next largest distortion component.

## **Chip Information**

TRANSISTOR COUNT: 358,000

PROCESS: CMOS

# **Pin Configuration**



# Package Information



Maxim cannot assume responsibility for use of any circuitry other than circuitry entirely embodied in a Maxim product. No circuit patent licenses are implied. Maxim reserves the right to change the circuitry and specifications without notice at any time.