### PRELIMINARY TECHNICAL DATA

# ADuC841 MicroConverter<sup>®</sup>, 12- Bit ADCs and DACs

### with Embedded Hi-Speed 62KB FLASH MCU

# **Preliminary Technical Data**

# ADuC841

#### FEATURES

**PIN COMPATABLE** Upgrade to ADuC812/ADuC831 INCREASED PERFORMANCE Single Cycle 16MIPS 8052 core High Speed 400kSPS 12-Bit ADC **INCREASED MEMORY** 62Kbytes On-Chip Flash/EE Program Memory 4KBytes On-Chip Flash/EE Data Memory In circuit re-programmable Flash/EE, 100 Yr Retention, 100 Kcycles Endurance 2304 Bytes On-Chip Data RAM SMALLER PACKAGE Available in 8mm x 8mm Chip Scale Package Also available in 52 pin PQFP - pin compatable with ADuC812/ADuC831 ANALOG I/O 8-Channel, 400kSPS High Accuracy, 12-Bit ADC On-Chip, 20 ppm/°C Voltage Reference DMA Controller, High-Speed ADC-to-RAM capture Two 12-Bit Voltage Output DACs Dual Output PWM-ΣΔ DACs **On-Chip Temperature Monitor Function** 8051 Based Core 8051-Compatible Instruction Set (16 MHz Max) High performance Single Cycle Core\* 12 Interrupt Sources, Two Priority Levels Dual Data Pointers, Extended 11-bit Stack Pointer **On-Chip Peripherals** Time Interval Counter (TIC) UART, I2C and SPI® Serial I/O Watchdog Timer (WDT), Power Supply Monitor (PSM) Power Specified for 3 and 5 volt operation Normal: 25mA @ 5 V (Core CLK = 16MHz) Power-Down: 15µA @ 3V **Development Tools** Low Cost, comprehensive development system incorporating non-intrusive single pin emulation IDE based, assembly and C source debug APPLICATIONS **Optical Networking - Laser Power Control Basestation Systems** Precision Instrumentation, Smart Sensors **Transient Capture Systems DAS and Communications Systems** MicroConverter is a registered trademark of Analog Devices, Inc.

SPI is a registered trademark of Motorola Inc. 12C is a registered trademark of Philips Inc.

 $^{*}$  68% of insturctions completed in one or two clock cycles REV. PrC

Information furnished by Analog Devices is believed to be accurate and reliable. However, no responsibility is assumed by Analog Devices for its use, nor for any infringements of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Analog Devices.



#### GENERAL DESCRIPTION

The ADuC841 is a complete smart transducer front-end, integrating a high-performance self calibrating multichannel ADC, dual DAC and an optimized single cycle 16MHz 8-bit MCU(8051 instruction set compatible) on a single chip.

The microcontroller is an optimized 8052 core offering up to 16 MIPS peak performance. 62 Kbytes of nonvolatile Flash/EE program memory are provided on-chip. 4 Kbytes of nonvolatile Flash/EE data memory, 256 bytes RAM and 2 KBytes of extended RAM are also integrated on-chip.

The ADuC841 also incorporates additional analog functionality with two 12-bit DACs, power supply monitor, and a bandgap reference. On-chip digital peripherals include two 16-bit  $\Sigma\Delta$  DACs, dual output 16-bit PWM, watchdog timer, time interval counter, three timers/counters, and three serial I/O ports (SPI, I2C and UART).

On the ADuC812 and ADuC831 the I2C and SPI interfaces shared some of the same pins. For backwards compatability this is also the case for the ADuC841. However, there is also the option to allow SPI operate separately on P3.3, P3.4 and P3.5 while I2C uses the standard pins. The I2C interface has also been enhanced to offer repeated start, general call and quad addressing.

On-chip factory firmware supports in-circuit serial download and debug modes (via UART), as well as single-pin emulation mode via the EA pin. A functional block diagram of the ADuC841 is shown above.

The part is specified for 3V and 5V operation. When operating from 5V the maximum operating frequency is 16MHz and when operating from 3V the maximum operating frequency is 8MHz.

One Technology Way, P.O. Box 9106, Norwood, MA 02062-9106, U.S.A Tel: 781/329-4700 World Wide Web Site: http://www.analog.com Fax: 781/326-8703 © Analog Devices, Inc., 2003

# $\label{eq:alpha} \begin{array}{l} \textbf{ADUC841-SPECIFICATIONS}^{1} \\ \text{to 5.5V. } V_{\text{REF}} = 2.5 \text{ V Internal Reference, MCLKIN} = 16 \text{ MHz All specifications} \\ \textbf{T}_{\text{A}} = \textbf{T}_{\text{MIN}} \text{ to } \textbf{T}_{\text{MAX}} \text{, unless otherwise noted.} \end{array} \right)$

| Parameter                                 | V <sub>DD</sub> = 5 V | $V_{DD} = 3 V$        | Unit           | Test Conditions/Comments                |
|-------------------------------------------|-----------------------|-----------------------|----------------|-----------------------------------------|
| ADC CHANNEL SPECIFICATIONS                |                       |                       |                |                                         |
| DC ACCURACY <sup>2,3</sup>                |                       |                       |                | $f_{SAMPLE} = 147 \text{ kHz},$         |
| Resolution                                | 12                    | 12                    | Bits           |                                         |
| Integral Nonlinearity                     | ±1                    | ±1                    | LSB max        | 2.5V Internal Reference                 |
|                                           | ±0.3                  | $\pm 0.3$             | LSB typ        |                                         |
| Differential Nonlinearity                 | $\pm 0.9$             | $\pm 0.9$             | LSB max        | 2.5V Internal Reference                 |
| 5                                         | ±0.25                 | $\pm 0.25$            | LSB typ        |                                         |
| Integral Nonlinearity <sup>9</sup>        | ±1.5                  | ±1.5                  | LSB max        | 1V External Reference                   |
| Differential Nonlinearity <sup>9</sup>    | +1.5/-0.9             | +1.5/-0.9             | LSB max        | 1V External Reference                   |
| Code Distrbution                          | 1                     | 1                     | LSB typ        | ADC Input is a DC Voltage               |
| CALIBRATED ENDPOINT ERRORS <sup>4,5</sup> |                       |                       |                |                                         |
| Offset Error                              | ±2                    | $\pm 3$               | LSB max        |                                         |
| Offset Error Match                        | $\pm 1$               | $\pm 1$               | LSB typ        |                                         |
| Gain Error                                | $\pm 1$<br>$\pm 2$    | $\pm 1$<br>$\pm 3$    | LSB typ        |                                         |
|                                           |                       |                       |                |                                         |
| Gain Error Match                          | -85                   | -85                   | dB typ         |                                         |
| DYNAMIC PERFORMANCE                       |                       |                       |                | $f_{IN} = 10 \text{ kHz}$ Sine Wave     |
| Circual to Main Datis (CND)6              | 71                    | 71                    | dD to          | $f_{SAMPLE} = 147 \text{ kHz}$          |
| Signal-to-Noise Ratio (SNR) <sup>6</sup>  | 71                    | 71                    | dB typ         |                                         |
| Total Harmonic Distortion (THD)           | -85                   | -85                   | dB typ         |                                         |
| Peak Harmonic or Spurious Noise           | -85                   | -85                   | dB typ         |                                         |
| Channel-to-Channel Crosstalk <sup>7</sup> | -80                   | -80                   | dB typ         |                                         |
| ANALOG INPUT                              |                       |                       |                |                                         |
| Input Voltage Ranges                      | 0 to V <sub>REF</sub> | 0 to V <sub>REF</sub> | Volts          |                                         |
| Leakage Current                           | ±1                    | ±1                    | μA max         |                                         |
| Input Capacitance                         | 32                    | 32                    | pF typ         |                                         |
| TEMPERATURE SENSOR <sup>8</sup>           |                       |                       |                |                                         |
| Voltage Output at 25°C                    | 650                   | 650                   | mV typ         |                                         |
| Voltage TC                                | -2.0                  | -2.0                  | mV/°C typ      |                                         |
| Accuracy                                  | ±3                    | ±3                    | °C typ         | Internal 2.5V V <sub>REF</sub>          |
| Accuracy                                  | ±1.5                  | ±1.5                  | °C typ         | External 2.5V V <sub>REF</sub>          |
| DAC CHANNEL SPECIFICATIONS                |                       |                       |                | DAC Load to AGND                        |
| Internal Buffer Enabled                   |                       |                       |                | $R_L = 10k\Omega, C_L = 100 \text{ pF}$ |
| DC ACCURACY <sup>10</sup>                 |                       |                       |                |                                         |
| Resolution                                | 12                    | 12                    | Bits           |                                         |
| Relative Accuracy                         | $\pm 3$               | $\pm 3$               | LSB typ        |                                         |
| Differential Nonlinearity <sup>11</sup>   | -1                    | -1                    | LSB max        | Guaranteed 12-Bit Monotonic             |
| Differential Noninicarity                 | $\pm 1/2$             | $\pm 1/2$             | LSB typ        |                                         |
| Offset Error                              | $\pm 1/2$<br>$\pm 50$ | $\pm 1/2$<br>$\pm 50$ | mV max         | V <sub>REF</sub> Range                  |
| Gain Error                                | ±30<br>±1             | ±30<br>±1             | % max          | AV <sub>DD</sub> Range                  |
| Gain Enoi                                 | ±1<br>±1              | $\pm 1$               |                |                                         |
| Gain Error Mismatch                       | $1 \pm 1$<br>0.5      | 1 $0.5$               | % typ<br>% typ | VREF Range<br>% of Full-Scale on DAC1   |
|                                           |                       |                       | JP             |                                         |
| ANALOG OUTPUTS<br>Voltage Range_0         | 0 to V <sub>REF</sub> | 0 to V <sub>REF</sub> | V typ          | DAC $V_{REF} = 2.5V$                    |
|                                           |                       |                       | V typ<br>V typ |                                         |
| Voltage Range_1                           | 0 to $V_{DD}$         | 0 to $V_{DD}$         | V typ          | DAC $V_{REF} = V_{DD}$                  |
| Output Impedance                          | 0.5<br>50             | 0.5<br>50             | $\Omega$ typ   |                                         |
| I <sub>SINK</sub>                         | 50                    | 50                    | µA typ         |                                         |
| DAC AC CHARACTERISTICS                    |                       |                       |                |                                         |
| Voltage Output Settling Time              | 15                    | 15                    | µs typ         | Full-Scale Settling Time to             |
|                                           |                       |                       |                | Within 1/2 LSB of Final Value           |
| Digital-to-Analog Glitch Energy           | 10                    | 10                    | nV sec typ     | 1 LSB Change at Major Carry             |

| Parameter                                                               | $V_{DD} = 5 V$        | <b>V</b> <sub>DD</sub> = <b>3 V</b> | Unit                       | Test Conditions/Comments                   |
|-------------------------------------------------------------------------|-----------------------|-------------------------------------|----------------------------|--------------------------------------------|
| DAC CHANNEL SPECIFICATIONS <sup>12,13</sup><br>Internal Buffer Disabled |                       |                                     |                            |                                            |
| DC ACCURACY <sup>10</sup>                                               |                       |                                     |                            |                                            |
| Resolution                                                              | 12                    | 12                                  | Bits                       |                                            |
| Relative Accuracy                                                       | ±3                    | ±3                                  | LSB typ                    |                                            |
| Differential Nonlinearity <sup>11</sup>                                 | -1                    | -1                                  | LSB max                    | Guaranteed 12-Bit Monotonic                |
| Differential Profilinearity                                             | ±1/2                  | $\pm 1/2$                           | LSB typ                    | Guaranteeu 12 Bit Wohotonie                |
| Offset Error                                                            | $\pm 1/2$<br>$\pm 10$ | $\pm 1/2$<br>$\pm 10$               | mV max                     | V <sub>REF</sub> Range                     |
| Gain Error                                                              | $\pm 10$<br>$\pm 1$   | $\pm 10$<br>$\pm 1$                 | % typ                      | VREF Range                                 |
| Gain Error Mismatch                                                     |                       | 0.5                                 |                            | % of Full-Scale on DAC1                    |
|                                                                         | 0.5                   | 0.5                                 | % typ                      | % OF Full-Scale Of DAC1                    |
| ANALOG OUTPUTS                                                          | 0 . T                 |                                     | <b>T</b> .                 |                                            |
| Voltage Range_0                                                         | $0$ to $V_{REF}$      | 0 to V <sub>REF</sub>               | V typ                      | DAC $V_{REF} = 2.5V$                       |
| REFERENCE INPUT/OUTPUT                                                  |                       |                                     |                            |                                            |
| REFERENCE OUPUT <sup>14</sup>                                           |                       |                                     |                            |                                            |
| Output Voltage (V <sub>REF</sub> )                                      | 2.5                   | 2.5                                 | V                          |                                            |
| Accuracy                                                                | $\pm 2.5$             | $\pm 2.5$                           | % max                      | Of $V_{REF}$ measured at the $C_{REF}$ pin |
| Power Supply Rejection                                                  | 47                    | 57                                  | dB typ                     | -                                          |
| Reference Temperature Coefficient                                       | ±20                   | ±20                                 | ppm/°C typ                 |                                            |
| Internal V <sub>REF</sub> Power-On Time                                 | 80                    | 80                                  | ms typ                     |                                            |
| EXTERNAL REFERNCE INPUT <sup>15</sup>                                   |                       |                                     | 51                         |                                            |
| Voltage Range $(V_{REF})^9$                                             | 0.1                   | 0.1                                 | V min                      |                                            |
| Voltage Range (V <sub>REF</sub> )                                       |                       |                                     | V max                      |                                            |
| Tana tana dana a                                                        | V <sub>DD</sub>       | V <sub>DD</sub>                     |                            |                                            |
| Input Impedance                                                         | 20                    | 20                                  | kΩ typ                     |                                            |
| Input Leakage                                                           | 10                    | 10                                  | μA max                     | Internal Band Gap Deselected via           |
|                                                                         |                       |                                     |                            | ADCCON1.6                                  |
| POWER SUPPLY MONITOR (PSM)                                              |                       |                                     |                            |                                            |
| $DV_{DD}$ Trip Point Selection Range                                    | 2.63                  |                                     | Vmin                       | Four Trip Points Selectable in             |
| D V DD THP Tome Selection Range                                         | 4.37                  |                                     | Vmax                       | This Range Programmed via                  |
|                                                                         | 1.07                  |                                     | VIIIux                     | TPD1–0 in PSMCON                           |
| DV <sub>DD</sub> Power Supply Trip Point                                |                       |                                     |                            |                                            |
| Accuracy                                                                | ±3.5                  |                                     | % max                      |                                            |
|                                                                         | ±3.5                  |                                     | 70 max                     |                                            |
| WATCH DOG TIMER (WDT) <sup>9</sup>                                      |                       |                                     |                            |                                            |
| Time-out Period                                                         | 0                     | 0                                   | ms min                     | Nine Time-out Periods                      |
|                                                                         | 2000                  | 2000                                | ms max.                    | Selectable in This Range                   |
| FLASH/EE MEMORY RELIABILITY                                             |                       |                                     |                            |                                            |
| CHARACTERISTICS <sup>16</sup>                                           |                       |                                     |                            |                                            |
| Endurance <sup>17</sup>                                                 | 100,000               | 100,000                             | Cycles min                 |                                            |
| Data Retention <sup>18</sup>                                            | 100,000               | 100,000                             | Years min                  |                                            |
|                                                                         | 100                   | 100                                 |                            |                                            |
| DIGITAL INPUTS                                                          |                       |                                     |                            |                                            |
| Input High Voltage (V <sub>INH</sub> )                                  | 2.4                   |                                     | V min                      |                                            |
| Input Low Voltage (V <sub>INL</sub> )                                   | 0.8                   |                                     | V max                      |                                            |
| Input Leakage Current (Port 0,1, EA)                                    | ±10                   |                                     | μA max                     | $V_{IN} = 0 V \text{ or } V_{DD}$          |
|                                                                         | ±1                    | ±1                                  | μA typ                     | $V_{\rm IN} = 0$ V or $V_{\rm DD}$         |
| Logic 1 Input Current                                                   |                       |                                     |                            |                                            |
| (All Digital Inputs)                                                    | ±10                   |                                     | µA max                     | $V_{IN} = V_{DD}$                          |
|                                                                         | ±1                    | ±1                                  | μA typ                     | $V_{IN} = V_{DD}$                          |
| Logic 0 Input Current (Port 2, 3)                                       | -80                   |                                     | μA max                     |                                            |
| Logie o input ourient (i ort 2, 0)                                      | -40                   | -40                                 | μA typ                     | $V_{IL} = 0 V$                             |
| Logic 1-0 Transition Current (Port 2, 3)                                | -40                   | 10                                  | $\mu A typ$<br>$\mu A max$ | $V_{IL} = 0 V$<br>$V_{IL} = 2 V$           |
| Logic 1-0 Transition Current (Fort 2, 5)                                | -400                  | -400                                | μA typ                     | $V_{IL} = 2 V$<br>$V_{IL} = 2 V$           |
|                                                                         |                       | 100                                 | Pr 2 17 P                  | · IL ~ ·                                   |
| CRYSTAL OSCILLATOR                                                      |                       |                                     |                            |                                            |
| Logic Inputs, XTAL1 Only                                                | 0.0                   |                                     | V/ +                       |                                            |
| VINL, Input Low Voltage                                                 | 0.8                   | 0.4                                 | V typ                      |                                            |
| VINH, Input High Voltage                                                | 3.5                   | 2.5                                 | V typ                      |                                            |

# ADuC841-SPECIFICATIONS<sup>1</sup>

| Parameter                                                         | V <sub>DD</sub> =5V | V <sub>DD</sub> =3V | Units            | Test Conditions                                          |
|-------------------------------------------------------------------|---------------------|---------------------|------------------|----------------------------------------------------------|
| XTAL1 Input Capacitance                                           | 18                  | 18                  | pF typ           |                                                          |
| XTAL2 Output Capacitance                                          | 18                  | 18                  | pF typ           |                                                          |
| MCU Clock Rate                                                    | 16                  | 8                   | MHz max          |                                                          |
|                                                                   | 10                  | 0                   | IVII IZ IIIAX    |                                                          |
| DIGITAL OUTPUTS                                                   |                     |                     |                  |                                                          |
| Output High Voltage (V <sub>OH</sub> )                            | 2.4                 | 2.4                 | V min            | $V_{DD} = 4.5 \text{ V} \text{ to } 5.5 \text{ V}$       |
|                                                                   |                     |                     |                  | $I_{SOURCE} = 80 \ \mu A$                                |
|                                                                   | 4.0                 | 2.6                 | V typ            | $V_{DD} = 2.7 \text{ V to } 3.3 \text{ V}$               |
|                                                                   |                     |                     |                  | $I_{SOURCE} = 20 \ \mu A$                                |
| Output Low Voltage (V <sub>OL</sub> )<br>ALE, Ports 0 and 2       | 0.4                 | 0.4                 | V max            | I 1.C m A                                                |
| ALE, POITS 0 allu 2                                               | 0.4<br>0.2          | 0.4 0.2             | V max<br>V typ   | $I_{SINK} = 1.6 \text{ mA}$ $I_{SINK} = 1.6 \text{ mA}$  |
| Port 3                                                            | 0.2                 | 0.2                 | V typ<br>Vmax    | $I_{SINK} = 1.0 \text{ mA}$<br>$I_{SINK} = 4 \text{ mA}$ |
| SCLOCK/SDATA                                                      | 0.4                 | 0.4                 | Vmax             | $I_{SINK} = 4 \text{ mA}$<br>$I_{SINK} = 8 \text{ mA}$   |
| Jeleeksbrin                                                       | 0.1                 | 0.4                 | VIIIdx           | ISINK – O III Y                                          |
| Floating State Leakage Current                                    | ±10                 | ±10                 | μA max           |                                                          |
| 0 0 0                                                             | ±1                  | ±1                  | μA typ           |                                                          |
| Floating State Output Capacitance                                 | 10                  | 10                  | pF typ           |                                                          |
| 5 i i                                                             |                     |                     | 1 71             |                                                          |
| START UP TIME                                                     |                     |                     |                  | Core CLK = 16MHz                                         |
| At Power-On                                                       | 500                 | 500                 | ms typ           |                                                          |
| From Idle Mode                                                    | 100                 | 100                 | μs typ           |                                                          |
| From Power-Down Mode                                              |                     |                     | 1 - J F          |                                                          |
| Wakeup with INT0 Interrupt                                        | 150                 | 400                 | ms typ           |                                                          |
| Wakeup with SPI/I <sup>2</sup> C Interrupt                        | 150                 | 400                 | ms typ           |                                                          |
| Wakeup with External RESET                                        | 150                 | 400                 | ms typ           |                                                          |
| After External RESET in Normal Mode                               | 3                   | 3                   | ms typ           |                                                          |
| After WDT Reset in Normal Mode                                    | 3                   | 3                   | ms typ           | Controlled via WDCON SFR                                 |
| POWER REQUIREMENTS <sup>19,20</sup>                               |                     |                     |                  |                                                          |
| Power Supply Voltages                                             |                     |                     |                  |                                                          |
| $AV_{DD} / DV_{DD} - AGND$                                        |                     | 2.7                 | V min.           | $AV_{DD} / DV_{DD} = 3V$ nom.                            |
|                                                                   |                     | 3.3                 | V max.           |                                                          |
|                                                                   | 4.5                 |                     | V min.           | $AV_{DD} / DV_{DD} = 5V$ nom.                            |
|                                                                   | 5.5                 |                     | V max.           |                                                          |
|                                                                   |                     |                     |                  |                                                          |
| Power Supply Currents Normal Mode                                 | 19                  | 6                   | m A trum         | Core CLK-9 MU-                                           |
| $D_{VDD}$ Current <sup>9</sup>                                    | 12<br>1.4           | 6                   | mA typ           | Core CLK=8 MHz                                           |
| A <sub>VDD</sub> Current <sup>9</sup><br>D <sub>VDD</sub> Current | 1.4<br>25           | 1.4<br>n/a          | mA max<br>mA max | Core CLK=16 MHz                                          |
|                                                                   | 25                  | n/a                 | mA max<br>mA typ | COLE CLIX=10 MILIZ                                       |
| A <sub>VDD</sub> Current                                          | 1.4                 | n/a                 | mA typ<br>mA max |                                                          |
|                                                                   |                     | in a                | in inax          |                                                          |
| Power Supply Currents Idle Mode                                   |                     |                     |                  |                                                          |
| D <sub>VDD</sub> Current <sup>9</sup>                             | 5                   | 2.5                 | mA typ           | Core CLK=8 MHz                                           |
| A <sub>VDD</sub> Current <sup>9</sup>                             | 0.11                | 0.11                | mA typ           |                                                          |
| D <sub>VDD</sub> Current <sup>9</sup>                             | 11                  | n/a                 | mA max           | Core CLK=16 MHz                                          |
|                                                                   | 10                  | n/a                 | mA typ           |                                                          |
| A <sub>VDD</sub> Current <sup>9</sup>                             | 0.11                | n/a                 | mA typ           |                                                          |
|                                                                   |                     |                     |                  |                                                          |
| Power Supply Currents Power Down Mode                             |                     | 9.5                 | 1 +              | For any Core CLK                                         |
| A <sub>VDD</sub> Current                                          | 3<br>35             | 2.5                 | uA typ<br>uA max | TIMECON.1=0                                              |
| D <sub>VDD</sub> Current                                          | 35<br>25            | 15<br>12            | uA max<br>uA typ | 1 INIECON, 1=0                                           |
|                                                                   | 120                 | 12                  | uA typ<br>uA typ | TIMECON.1=1                                              |
|                                                                   | 140                 | 120                 | uA typ           |                                                          |
| Typical Additional Power Supply Currents                          |                     |                     |                  | AVDD = DVDD = 5V                                         |
| PSM Peripheral                                                    | 50                  |                     | uA typ           |                                                          |
| ADC                                                               | 1.5                 |                     | mA typ           |                                                          |
| DAC                                                               | 150                 |                     | uA typ           |                                                          |

NOTES

<sup>1</sup> Temperature Range -40°C to +85°C.

- <sup>2</sup> ADC Linearity is guaranteed during normal MicroConverter Core operation.
- <sup>3</sup> ADC LSB Size = Vref / 2^12 i.e for Internal Vref=2.5V, 1LSB = 610uV and for External Vref = 1V, 1LSB = 244uV.
- <sup>4</sup> Offset and Gain Error and Offset and Gain Error Match are measured after factory calibration.
- <sup>5</sup> Based on external ADC system components the user may need to execute a system calibration to remove additional external channel errors and achieve these specifications.
- <sup>6</sup> SNR calculation includes distortion and noise components. <sup>7</sup> Channel to Channel Crosstalk is measured on adjacent channels.
- <sup>8</sup> The Temperature Monitor will give a measure of the die temperature directly, air temperature can be inferred from this result.
- <sup>9</sup> These numbers are not production tested but are guaranteed by Design and/or Characterization data on production release.

<sup>10</sup> DAC linearity is calculated using :

reduced code range of 48 to 4095, 0 to Vref range.

reduced code range of 48 to 3945, 0 to  $V_{DD}$  range.

- DAC Output Load = 10K Ohms and 100 pF.
- <sup>11</sup> DAC Differential NonLinearity specified on 0 to Vref and 0 to Vdd ranges
- <sup>12</sup> DAC specification for output impedance in the unbuffered case depends on DAC code
- <sup>13</sup> DAC specifications for Isink, voltage output settling time and digital-to-analog glitch engergy depend on external buffer implementation in unbuffered mode.
- <sup>14</sup> Measured with Vref and Cref pins decoupled with 0.1µF capacitors to graound. Power-up time for the Internal Reference will be determined by the value of the decoupling capacitor chosen for both the Vref and Cref pins.
- <sup>15</sup> When using an External Reference device, the internal bandgap reference input can be bypassed by setting the ADCCON1.6 bit. In this mode the Vref and Cref pins need to be shorted together for correct operation.

<sup>16</sup>Flash/EE Memory Reliability Characteristics apply to both the Flash/EE program memory and the Flash/EE data memory.

- <sup>17</sup> Endurance is qualified to 100 Kcycles as per JEDEC Std. 22 method A117 and measured at -40°C, +25°C, and +85°C, typical endurance at 25°C is 700 Kcycles.
- <sup>18</sup> Retention lifetime equivalent at junction temperature (Tj) = 55°C as per JEDEC Std. 22 method A117. Retention lifetime based on an activation energy of 0.6eV will derate with junction temperature as shown in Figure 27 in the Flash/EE Memory description section of this data sheet.
- <sup>19</sup> Power Supply current consumption is measured in Normal, Idle, and Power-Down Modes under the following conditions: Normal Mode: Reset = 0.4 V, Digital I/O pins = open circuit, Core Executing internal software loop.
  - Idle Mode: Reset = 0.4 V, Digital I/O pins = open circuit, Core Execution suspended in idle mode.
  - Power-Down Mode:Reset = 0.4 V, All Port 0 pins = 0.4 V, All other digital I/O pins and Port 1 are open circuit, OSC off, TIC off.
- <sup>20</sup> D<sub>VDD</sub> power supply current will increase typically by 3 mA (3 V operation) and 10 mA (5 V operation) during a Flash/EE memory program or erase cycle.

Specifications subject to change without notice.

#### ABSOLUTE MAXIMUM RATINGS\*

(T<sub>A</sub> = 25°C unless otherwise noted)

| $\begin{array}{cccccccccccccccccccccccccccccccccccc$ |
|------------------------------------------------------|
| Operating Temperature Range Industrial ADuC841BS     |
| -40°C to +85°C                                       |
| Operating Temperature Range Industrial ADuC841BCP    |
| $-40^{\circ}C \text{ to } +85^{\circ}C$              |
|                                                      |
| Storage Temperature Range65°C to +150°C              |
| Storage Temperature Range                            |
|                                                      |
| Junction Temperature 150°C                           |
| $\begin{array}{llllllllllllllllllllllllllllllllllll$ |
| $\begin{array}{llllllllllllllllllllllllllllllllllll$ |
| $\begin{array}{llllllllllllllllllllllllllllllllllll$ |

\*Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; functional operation of the device at these or any other conditions above those listed in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| ORDERING G | UIDE |
|------------|------|
|------------|------|

| Model                 | Supply<br>Voltage Vdd | User Program<br>Code Space         | Package<br>Option |  |
|-----------------------|-----------------------|------------------------------------|-------------------|--|
| ADuC841BS62-5         | 5                     | 62                                 | S-52              |  |
| ADuC841BS62-3         | 3                     | 62                                 | S-52              |  |
| ADuC841BCP62-5        | 5                     | 62                                 | CP-56             |  |
| ADuC841BCP62-3        | 3                     | 62                                 | CP-56             |  |
| ADuC841BCP32-5        | 5                     | 32                                 | CP-56             |  |
| ADuC841BCP32-3        | 3                     | 32                                 | CP-56             |  |
| ADuC841BCP8-5         | 5                     | 8                                  | CP-56             |  |
| ADuC841BCP8-3         | 3                     | 8                                  | CP-56             |  |
| S-52 = 52-Lead Plasti | c Quad Flatpack       |                                    |                   |  |
| CP-56 = 56-Lead Chi   | p Scale Package       |                                    |                   |  |
|                       |                       |                                    |                   |  |
| EVAL-ADuC841QS        |                       | QuickStart Development             | System            |  |
| EVAL-ADuC841QSP       |                       | QuickStart Plus Development System |                   |  |

#### CAUTION

ESD (electrostatic discharge) sensitive device. Electrostatic charges as high as 4000 V readily accumulate on the human body and test equipment and can discharge without detection. Although the ADuC841 features proprietary ESD protection circuitry, permanent damage may occur on devices subjected to high energy electrostatic discharges. Therefore, proper ESD precautions are recommended to avoid performance degradation or loss of functionality.



#### **PIN CONFIGURATION**





Figure 1 ADuC841 Block Diagram (Shaded areas are features not present on the ADuC812)

**PIN FUNCTION DESCRIPTIONS** 

| Mnemonic              | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DV <sub>DD</sub>      | Р    | Digital Positive Supply Voltage, 3 V or 5 V Nominal                                                                                                                                                                                                                                                                                                                                                            |
| $AV_{DD}$             | Р    | Analog Positive Supply Voltage, 3 V or 5 V Nominal                                                                                                                                                                                                                                                                                                                                                             |
| C <sub>REF</sub>      | Ι    | Decoupling Input for On-Chip Reference. Connect 0.1 µF between this pin and AGND.                                                                                                                                                                                                                                                                                                                              |
| V <sub>REF</sub>      | I/O  | Reference Input/Output. This pin is connected to the internal reference through a series resistor and is the reference source for the analog-to-digital converter. The nominal internal reference voltage is 2.5 V and this appears at the pin. This pin can be overdriven by an external reference.                                                                                                           |
| AGND                  | G    | Analog Ground. Ground Reference point for the analog circuitry.                                                                                                                                                                                                                                                                                                                                                |
| P1.0-P1.7             | Ι    | Port 1 is an 8-bit Input Port only. Unlike other Ports, Port 1 defaults to Analog Input Mode, to configure any of these Port Pins as a digital input, write a "0" to the port bit. Port 1 pins are multifunction and share the following functionality.                                                                                                                                                        |
| ADC0-ADC7             | Ι    | Analog Inputs. Eight single-ended analog inputs. Channel selection is via ADCCON2 SFR.                                                                                                                                                                                                                                                                                                                         |
| T2                    | Ι    | Timer 2 Digital Input. Input to Timer/Counter 2. When Enabled, Counter 2 is incremented in response to a 1 to 0 transition of the T2 input.                                                                                                                                                                                                                                                                    |
| T2EX                  | Ι    | Digital Input. Capture/Reload trigger for Counter 2 and also functions as an Up/Down control input for Counter 2.                                                                                                                                                                                                                                                                                              |
| SS                    | Ι    | Slave Select Input for the SPI Interface                                                                                                                                                                                                                                                                                                                                                                       |
| SDATA                 | I/O  | User Selectable, I <sup>2</sup> C-Compatible or SPI Data Input/Output Pin                                                                                                                                                                                                                                                                                                                                      |
| SCLOCK                | I/O  | Serial Clock Pin for I <sup>2</sup> C-Compatible or SPI Serial Interface Clock                                                                                                                                                                                                                                                                                                                                 |
| MOSI                  | I/O  | SPI Master Output/Slave Input Data I/O Pin for SPI Interface                                                                                                                                                                                                                                                                                                                                                   |
| MISO                  | I/O  | SPI Master Input/Slave Output Data I/O Pin for SPI Serial Interface                                                                                                                                                                                                                                                                                                                                            |
| DAC0                  | 0    | Voltage Output from DAC0                                                                                                                                                                                                                                                                                                                                                                                       |
| DAC1                  | 0    | Voltage Output from DAC1                                                                                                                                                                                                                                                                                                                                                                                       |
| RESET                 | Ι    | Digital Input. A high level on this pin for 24 master clock cycles while the oscillator is running resets the device.                                                                                                                                                                                                                                                                                          |
| P3.0-P3.7             | I/O  | Port 3 is a bidirectional port with internal pull-up resistors. Port 3 pins that have 1s written to them are pulled high by the internal pull-up resistors, and in that state they can be used as inputs. As inputs Port 3 pins being pulled externally low will source current because of the internal pull-up resistors. Port 3 pins also contain various secondary functions which are described below.     |
| PWMC                  | Ι    | PWM Clock Input                                                                                                                                                                                                                                                                                                                                                                                                |
| PWM0                  | 0    | PMW0 Voltage Output. PWM outputs can be configured to use ports 2.6 & 2.7 or 3.4 and 3.3                                                                                                                                                                                                                                                                                                                       |
| PWM1                  | 0    | PMW1 Voltage Ouput. See CFG831 Register for further Information.                                                                                                                                                                                                                                                                                                                                               |
| RxD                   | I/O  | Receiver Data Input (Asynchronous) or Data Input/Output (Synchronous) of Serial (UART) Port                                                                                                                                                                                                                                                                                                                    |
| TxD                   | 0    | Transmitter Data Output (Asynchronous) or Clock Output (Synchronous) of Serial (UART) Port                                                                                                                                                                                                                                                                                                                     |
| INT0                  | Ι    | Interrupt 0, programmable edge or level triggered Interrupt input, which can be programmed to one of two priority levels. This pin can also be used as a gate control input to Timer 0.                                                                                                                                                                                                                        |
| INT1                  | Ι    | Interrupt 1, programmable edge or level triggered Interrupt input, which can be programmed to one of two priority levels. This pin can also be used as a gate control input to Timer 1.                                                                                                                                                                                                                        |
| Т0                    | Ι    | Timer/Counter 0 Input                                                                                                                                                                                                                                                                                                                                                                                          |
| T1                    | Ι    | Timer/Counter 1 Input                                                                                                                                                                                                                                                                                                                                                                                          |
| CONVST                | Ι    | Active low Convert Start Logic input for the ADC block when the external Convert start function is enabled.<br>A low-to-high transition on this input puts the track/hold into its hold mode and starts conversion.                                                                                                                                                                                            |
| WR                    | 0    | Write Control Signal, Logic Output. Latches the data byte from Port 0 into the external data memory.                                                                                                                                                                                                                                                                                                           |
| RD                    | 0    | Read Control Signal, Logic Output. Enables the external data memory to Port 0.                                                                                                                                                                                                                                                                                                                                 |
| XTAL2                 | 0    | Output of the Inverting Oscillator Amplifier                                                                                                                                                                                                                                                                                                                                                                   |
| XTAL1                 | Ι    | Input to the inverting oscillator amplifier and input to the internal clock generator circuits.                                                                                                                                                                                                                                                                                                                |
| DGND                  | G    | Digital Ground. Ground reference point for the digital circuitry.                                                                                                                                                                                                                                                                                                                                              |
| P2.0-P2.7             | I/O  | Port 2 is a bidirectional port with internal pull-up resistors. Port 2 pins that have 1s written to them are                                                                                                                                                                                                                                                                                                   |
| (A8–A15)<br>(A16–A23) |      | pulled high by the internal pull-up resistors, and in that state they can be used as inputs. As inputs Port 2 pins being pulled externally low will source current because of the internal pull-up resistors. Port 2 emits the high order address bytes during fetches from external program memory and middle and high order address bytes during accesses to the external 24-bit external data memory space. |

| PIN FUNCTION DESCRIPTION (continued) |      |                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|--------------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Mnemonic                             | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| PSEN                                 | 0    | Program Store Enable, Logic Output. This output is a control signal that enables the external program memory to the bus during external fetch operations. It is active every six oscillator periods except during external data memory accesses. This pin remains high during internal program execution. PSEN can also be used to enable serial download mode when pulled low through a resistor on power-up or RESET. |  |
| ALE                                  | 0    | Address Latch Enable, Logic Output. This output is used to latch the low byte (and page byte for 24-bit address space accesses) of the address into external memory during normal operation.                                                                                                                                                                                                                            |  |
| EA                                   | I    | External Access Enable, Logic Input. When held high, this input enables the device to fetch code from internal program memory locations 0000H to 1FFFH. When held low this input enables the device to fetch all instructions from external program memory. This pin should not be left float.                                                                                                                          |  |
| P0.7–P0.0<br>(A0–A7)                 | I/O  | Port 0 is an 8-Bit Open Drain Bidirectional I/O port. Port 0 pins that have 1s written to them float and in that state can be used as high impedance inputs. Port 0 is also the multiplexed low order address and data bus during accesses to external program or data memory. In this application it uses strong internal pull-ups when emitting 1s.                                                                   |  |

#### TERMINOLOGY ADC SPECIFICATIONS Integral Nonlinearity

This is the maximum deviation of any code from a straight line passing through the endpoints of the ADC transfer function. The endpoints of the transfer function are zero scale, a point 1/2 LSB below the first code transition and full scale, a point 1/2 LSB above the last code transition.

#### **Differential Nonlinearity**

This is the difference between the measured and the ideal 1 LSB change between any two adjacent codes in the ADC.

#### **Offset Error**

This is the deviation of the first code transition  $(0000 \dots 000)$  to  $(0000 \dots 001)$  from the ideal, i.e., +1/2 LSB.

#### **Gain Error**

This is the deviation of the last code transition from the ideal AIN voltage (Full Scale – 1.5 LSB) after the offset error has been adjusted out.

#### Signal to (Noise + Distortion) Ratio

This is the measured ratio of signal to (noise + distortion) at the output of the A/D converter. The signal is the rms amplitude of the fundamental. Noise is the rms sum of all nonfundamental signals up to half the sampling frequency ( $f_S/2$ ), excluding dc.

The ratio is dependent upon the number of quantization levels in the digitization process; the more levels, the smaller the quantization noise. The theoretical signal to (noise +distortion) ratio for an ideal N-bit converter with a sine wave input is given by:

Signal to (Noise + Distortion) = (6.02N + 1.76) dB

Thus for a 12-bit converter, this is 74 dB.

#### **Total Harmonic Distortion**

Total Harmonic Distortion is the ratio of the rms sum of the harmonics to the fundamental.

#### **DAC SPECIFICATIONS**

#### **Relative Accuracy**

Relative accuracy or endpoint linearity is a measure of the maximum deviation from a straight line passing through the endpoints of the DAC transfer function. It is measured after adjusting for zero error and full-scale error.

#### **Voltage Output Settling Time**

This is the amount of time it takes for the output to settle to a specified level for a full-scale input change.

#### Digital-to-Analog Glitch Impulse

This is the amount of charge injected into the analog output when the inputs change state. It is specified as the area of the glitch in nV sec.

#### INTRODUCTION

The ADuC841 is a 16MIPs 8052 core upgrade to the ADuC831. It has all the same features as the ADuC831 but the standard 12-cycle 8052 core has been replaced with a 16MIPs single cycle core.

Since the ADuC841 and ADuC831 share the same feature set only the differneces bettween the two chips are documented here. For full documentation on the ADuC831 please consult the datasheet available at http://www.analog.com/microconverter

8052 Instruction Set

The following pages document the number of clock cycles required for each instruction. Most instructions are executed in one or two clock cycles resulting in a 16MIPs peak peformance when operating from a 16MHz crystal.

#### **Timer Operation**

Timers on a standard 8052 increment by one with each machine cycle. On the ADuC841 one machine cycle is equal to one clock cycle hence the timers will increment at the same rate as the core clock.

#### ALE

The output on the ALE pin on the ADuC831 was a clock at 1/ 6th of the core operating frequency. On the ADuC841 the ALE pin operates as follows.

For a single machine cycle instruction: ALE is high for the first half of the machine cycle and low for the second half. The ALE output is at the core operating frequency.

For a two or more machine cycle instruction: ALE is high for the first half of the first machine cycle and then low for the rest of the machine cycles.

#### **External Memory Access**

There is no support for external program memory access on the ADuC841. When accessing external RAM the EWAIT register may need to be programmed in order to give extra machine cycles to MOVX commands. This is to account for differing external RAM access speeds.

#### **Baud Rate Generation**

There is an addition divide by two in the fractional divider of the ADuC841 this means that any values calculated for T3CON for the ADuC831 need to be incremented by one in order to give the same baud rate on the ADuC841.

# INSTRUCTION TABLE

| Mnemonic      | Description                                 | Bytes | Cycles |
|---------------|---------------------------------------------|-------|--------|
| Arithmetic    |                                             |       |        |
| ADD A,Rn      | Add register to A                           | 1     | 1      |
| ADD A,@Ri     | Add indirect memory to A                    | 1     | 2      |
| ADD A,dir     | Add direct byte to A                        | 2     | 2      |
| ADD A,#data   | Add immediate to A                          | 2     | 2      |
| ADDC A,Rn     | Add register to A with carry                | 1     | 1      |
| ADDC A,@Ri    | Add indirect memory to A with carry         | 1     | 2      |
| ADDC A,dir    | Add direct byte to A with carray            | 2     | 2      |
| ADD A,#data   | Add immediate to A with carry               | 2     | 2      |
| SUBB A,Rn     | Subtract register from A with borrow        | 1     | 1      |
| SUBB A,@Ri    | Subtract indirect memory from A with borrow | 1     | 2      |
| SUBB A,dir    | Subtract direct from A with borrow          | 2     | 2      |
| SUBB A,#data  | Subtract immediate from A with borrow       | 2     | 2      |
| INC A         | Increment A                                 | 1     | 1      |
| INC Rn        | Increment register                          | 1     | 1      |
| INC @Ri       | Increment indirect memory                   | 1     | 2      |
| INC dir       | Increment direct byte                       | 2     | 2      |
| INC DPTR      | Increment data pointer                      | 1     | 3      |
| DEC A         | Decrement A                                 | 1     | 1      |
| DEC Rn        | Decrement Register                          | 1     | 1      |
| DEC @Ri       | Decrement indirect memory                   | 1     | 2      |
| DEC dir       | Decrement direct byte                       | 2     | 2      |
| MUL AB        | Multiply A by B                             | 1     | 9      |
| DIV AB        | Divide A by B                               | 1     | 9      |
| DA A          | Decimal Adjust A                            | 1     | 2      |
| Logic         |                                             |       |        |
| ANL A,Rn      | AND register to A                           | 1     | 1      |
| ANL A,@Ri     | AND indirect memory to A                    | 1     | 2      |
| ANL A, dir    | AND direct byte to A                        | 2     | 2      |
| ANL A,#data   | AND immediate to A                          | 2     | 2      |
| ANL dir,A     | AND A to direct byte                        | 2     | 2      |
| ANL dir,#data | AND immediate data to direct byte           | 3     | 3      |
| ORL A,Rn      | OR register to A                            | 1     | 1      |
| ORL A,@Ri     | OR indirect memory to A                     | 1     | 2      |
| ORL A,dir     | OR direct byte to A                         | 2     | 2      |
| ORL A,#data   | OR immediate to A                           | 2     | 2      |
| ORL dir,A     | OR A to direct byte                         | 2     | 2      |
| ORL dir,#data | OR immediate data to direct byte            | 3     | 3      |
|               |                                             |       |        |

| XRL A,Rn       | Exclusive-OR register to A            | 1 | 1 |  |
|----------------|---------------------------------------|---|---|--|
| XRL A,@Ri      | Exclusive-OR indirect memory to A     | 2 | 2 |  |
| XRL A,#data    | Exclusive-OR immediate to A           | 2 | 2 |  |
| XRL dir,A      | Exclusive-OR A to direct byte         | 2 | 2 |  |
| XRL A,dir      | Exclusive-OR indirect memory to A     | 2 | 2 |  |
| XRL dir,#data  | Exclusive-OR immediate data to direct | 3 | 3 |  |
| CLR A          | Clear A                               | 1 | 1 |  |
| CPL A          | Complement A                          | 1 | 1 |  |
| SWAP A         | Swap Nibbles of A                     | 1 | 1 |  |
| RL A           | Rotate A left                         | 1 | 1 |  |
| RLC A          | Rotate A left through carry           | 1 | 1 |  |
| RR A           | Rotate A right                        | 1 | 1 |  |
| RRC A          | Rotate A right through carry          | 1 | 1 |  |
| Data Transfer  | 5 5 5                                 |   |   |  |
| MOV A,Rn       | Move register to A                    | 1 | 1 |  |
| MOV A,@Ri      | Move indirect memory to A             | 1 | 2 |  |
| MOV Rn,A       | Move A to register                    | 1 | 1 |  |
| MOV @Ri,A      | Move A to indirect memory             | 1 | 2 |  |
| MOV A,dir      | Move direct byte to A                 | 2 | 2 |  |
| MOV A,#data    | Move immediate to A                   | 2 | 2 |  |
| MOV Rn,#data   | Move register to immediate            | 2 | 2 |  |
| MOV dir,A      | Move A to direct byte                 | 2 | 2 |  |
| MOV Rn, dir    | Mov register to direct byte           | 2 | 2 |  |
| MOV dir, Rn    | Move direct to register               | 2 | 2 |  |
| MOV @Ri,#data  | Move immediate to indirect memory     | 2 | 2 |  |
| MOV dir,dir    | Move direct byte to direct byte       | 3 | 3 |  |
| MOV dir,#data  | Move immediate to direct byte         | 3 | 3 |  |
| MOV DPTR,#data | Move immediate to data pointer        | 3 | 3 |  |
| MOVC A,@A+DPTR | Move code byte relative DPTR to A     | 1 | 4 |  |
| MOVC A,@A+PC   | Move code byte relative PC to A       | 1 | 4 |  |
| MOVX A,@Ri     | Move external (A8) data to A          | 1 | 4 |  |
| MOVX A,@DPTR   | Move external (A16) data to A         | 1 | 4 |  |
| MOVX @Ri,A     | Move A to external data (A8)          | 1 | 4 |  |
| MOVX @DPTR,A   | Move A to external data (A16)         | 1 | 4 |  |
| PUSH dir       | Push direct byte onto stack           | 2 | 2 |  |
| POP dir        | Pop direct byte from stack            | 2 | 2 |  |
| XCH A,Rn       | Exchange A and register               | 1 | 1 |  |
| XCH A,@Ri      | Exchange A and indirect memory        | 1 | 2 |  |
| XCHD A,@Ri     | Exchange A and indirect memory nibble | 1 | 2 |  |
| XCH A,dir      | Exchange A and direct byte            | 2 | 2 |  |
| Boolean        |                                       |   |   |  |

|                    |                                          | 4 | 1 |  |
|--------------------|------------------------------------------|---|---|--|
| CLR C              | Clear carry                              | 1 | 1 |  |
| CLR bit            | Clear direct bit                         | 2 | 2 |  |
| SETB C             | Set Carry                                | 1 | 1 |  |
| SETB bit           | Set direct bit                           | 2 | 2 |  |
| CPL C              | Complement carry                         | 1 | 1 |  |
| CPL bit            | Complement direct bit                    | 2 | 2 |  |
| ANL C,bit          | AND direct bit and carry                 | 2 | 2 |  |
| ANL C,/bit         | AND direct bit inverse to carry          | 2 | 2 |  |
| ORL C,bit          | OR direct bit and carry                  | 2 | 2 |  |
| ORL C,/bit         | OR direct bit inverse to carry           | 2 | 2 |  |
| MOV C,bit          | Move direct bit to carry                 | 2 | 2 |  |
| MOV bit,C          | Move carry to direct bit                 | 2 | 2 |  |
| Branching          |                                          |   |   |  |
| JMP @A+DPTR        | Jump indirect relative to DPTR           | 1 | 3 |  |
| RET                | Return from subroutine                   | 1 | 4 |  |
| RETI               | Return from interrupt                    | 1 | 4 |  |
| ACALL addr11       | Absolute jump to subroutine              | 2 | 3 |  |
| AJMP addr11        | Absolute jump unconditional              | 2 | 3 |  |
| SJMP rel           | Short jump (relative address)            | 2 | 3 |  |
| JC rel             | Jump on carry = 1                        | 2 | 3 |  |
| JNC rel            | Jump on carry = 0                        | 2 | 3 |  |
| JZ rel             | Jump on accumulator = 0                  | 2 | 3 |  |
| JNZ rel            | Jump on accumulator != 0                 | 2 | 3 |  |
| DJNZ Rn,rel        | Decrement register, jnz relative         | 2 | 3 |  |
| LJMP               | Long jump unconditional                  | 3 | 4 |  |
| LCALL addr16       | Long jump to subroutine                  | 3 | 4 |  |
| JB bit,rel         | Jump on direct bit = 1                   | 3 | 4 |  |
| JNB bit,rel        | Jump on direct bit = 0                   | 3 | 4 |  |
| JBC bit,rel        | Jump on direct bit = 1 and clear         | 3 | 4 |  |
| CJNE A,dir,rel     | Compare A, direct JNE relative           | 3 | 4 |  |
| CJNE A,#data,rel   | Compare A, immediate JNE relative        | 3 | 4 |  |
| CJNE Rn,#data,rel  | Compare register, immediate JNE relative | 3 | 4 |  |
| CJNE @Ri,#data,rel | Compare indirect, immediate JNE relative | 3 | 4 |  |
| DJNZ dir,rel       | Decrement direct byte, JNZ relative      | 3 | 4 |  |
| Miscellaneous      | у ·                                      |   |   |  |
| NOP                | No operation                             | 1 | 1 |  |
| Notes:             | <u>۵</u>                                 |   |   |  |
|                    |                                          |   |   |  |

1. One cycle is one clock.

2. Cycles of MOVX instructions are 4 cycles when they have 0 wait state. Cycles of MOVX instructions are 4+n cycles when they have n wait states.

3. Cycles of LCALL instruction are 3 cycles when the LCALL instruction comes from interrupt.

#### ADuC841 I<sup>2</sup>C-COMPATIBLE INTERFACE

The ADuC831 supports a fully licensed<sup>\*</sup> I<sup>2</sup>C serial interface. The I<sup>2</sup>C interface is implemented as a full hardware slave and software master. SDATA is the data I/O pin and SCLOCK is the serial clock. These two pins are shared with the MOSI and SCLOCK pins of the on-chip SPI interface. To enable the I2C interface the SPI interface must be turned off (see SPE in SPICON previously) OR the SPI interface must be moved to P3.3, P3.4 and P3.5 via the CFG841.1 bit. Application Note uC001 describes the operation of this interface as implemented is available from the MicroConverter Website at www.analog.com/microconverter.

Three SFRs are used to control the I<sup>2</sup>C interface. These are described below:

| I2CCON:                | I <sup>2</sup> C Control Register |
|------------------------|-----------------------------------|
| SFR Address            | E8H                               |
| Power-On Default Value | 00H                               |
| Bit Addressable        | Yes                               |

#### Table I2CCON SFR Bit Designations Master Mode

| Bit |      | Name Description                                                                                                     |
|-----|------|----------------------------------------------------------------------------------------------------------------------|
| 7   | MDO  | I <sup>2</sup> C Software Master Data Output Bit (MASTER MODE ONLY).                                                 |
|     |      | This data bit is used to implement a master I <sup>2</sup> C transmitter interface in software. Data written to this |
|     |      | bit will be outputted on the SDATA pin if the data output enable (MDE) bit is set.                                   |
| 6   | MDE  | I <sup>2</sup> C Software Master Data Output Enable Bit (MASTER MODE ONLY).                                          |
|     |      | <i>Set</i> by user to enable the SDATA pin as an output (Tx).                                                        |
|     |      | <i>Cleared</i> by the user to enable SDATA pin as an input (Rx).                                                     |
| 5   | MCO  | I <sup>2</sup> C Software Master Clock Output Bit (MASTER MODE ONLY).                                                |
|     |      | This data bit is used to implement a master I <sup>2</sup> C transmitter interface in software. Data written to      |
|     |      | this bit will be outputted on the SCLOCK pin.                                                                        |
| 4   | MDI  | I <sup>2</sup> C Software Master Data Input Bit (MASTER MODE ONLY).                                                  |
|     |      | This data bit is used to implement a master I <sup>2</sup> C receiver interface in software. Data on the SDATA       |
|     |      | pin is latched into this bit on SCLOCK if the Data Output Enable (MDE) bit is '0.'                                   |
| 3   | I2CM | I <sup>2</sup> C Master/Slave Mode Bit.                                                                              |
|     |      | Set by user to enable I <sup>2</sup> C software master mode.                                                         |
|     |      | Cleared by user to enable I <sup>2</sup> C hardware slave mode.                                                      |
| 2   |      | RSVD                                                                                                                 |
| 1   |      | RSVD                                                                                                                 |
| 0   |      | RSVD                                                                                                                 |

#### Table I2CCON SFR Bit Designations Slave Mode

| Bit |        | Name Description                                                                                                                                                                                                                           |
|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | I2CSI  | I <sup>2</sup> C Stop Interrupt Enable Bit.<br>Set by the user to enable I2C stop interrupts. If set a stop bit that follows a valid start condition<br>will generate an interrupt.<br>Cleared by the user to disable I2C stop interrupts. |
| 6   | I2CGC  | I <sup>2</sup> C General Call Status Bit<br>Set by hardware after receiving a general call address.<br>Cleared by the user.                                                                                                                |
| 5   | I2CID1 | I <sup>2</sup> C Interrupt Decode Bits.                                                                                                                                                                                                    |
| 4   | I2CID0 | Set by hardware to indicate the source of an I2C interrupt<br>00 Start and Matching Address<br>01 Repeated Start and Matching Address<br>10 User Data<br>11 Stop after a Start and Matching Address                                        |
| 3   | I2CM   | I <sup>2</sup> C Master/Slave Mode Bit.<br><i>Set</i> by user to enable I <sup>2</sup> C software master mode.<br><i>Cleared</i> by user to enable I <sup>2</sup> C hardware slave mode.                                                   |
| 2   | I2CRS  | I <sup>2</sup> C Reset Bit (SLAVE MODE ONLY).<br>Set by user to reset the I <sup>2</sup> C interface.<br>Cleared by user code for normal I <sup>2</sup> C operation.                                                                       |
| 1   | I2CTX  | I <sup>2</sup> C Direction Transfer Bit (SLAVE MODE ONLY).<br><i>Set</i> by the MicroConverter if the interface is transmitting.<br><i>Cleared</i> by the MicroConverter if the interface is receiving.                                    |

|                           | ADuC841                                                                                                                                                                                                                                                                                                                                                          |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 I2CI                    | I <sup>2</sup> C Interrupt Bit (SLAVE MODE ONLY).<br><i>Set</i> by the MicroConverter after a byte has been transmitted or received.<br><i>Cleared</i> automatically when user code reads the I2CDAT SFR (see I2CDAT below).                                                                                                                                     |
| <b>I2CADD</b><br>Function | <b>I<sup>2</sup>C Address Register</b><br>Holds the first I <sup>2</sup> C peripheral address for the part. It may be overwritten by user code. Technical<br>NoteuC001 at www.analog.com/microconverter describes the format of the I <sup>2</sup> C standard 7-bit<br>address in detail.                                                                        |
| SFR Address               | 9BH                                                                                                                                                                                                                                                                                                                                                              |
| Power-On Default Value    | 55H                                                                                                                                                                                                                                                                                                                                                              |
| Bit Addressable           | No                                                                                                                                                                                                                                                                                                                                                               |
| <b>I2CADD1</b>            | <b>I<sup>2</sup>C Address Register</b>                                                                                                                                                                                                                                                                                                                           |
| Function                  | Holds the second I <sup>2</sup> C peripheral address for the part. It may be overwritten by user code.                                                                                                                                                                                                                                                           |
| SFR Address               | 91H                                                                                                                                                                                                                                                                                                                                                              |
| Power-On Default Value    | 00H                                                                                                                                                                                                                                                                                                                                                              |
| Bit Addressable           | No                                                                                                                                                                                                                                                                                                                                                               |
| <b>I2CADD2</b>            | $I^2C$ Address Register                                                                                                                                                                                                                                                                                                                                          |
| Function                  | Holds the third $I^2C$ peripheral address for the part. It may be overwritten by user code.                                                                                                                                                                                                                                                                      |
| SFR Address               | 92H                                                                                                                                                                                                                                                                                                                                                              |
| Power-On Default Value    | 00H                                                                                                                                                                                                                                                                                                                                                              |
| Bit Addressable           | No                                                                                                                                                                                                                                                                                                                                                               |
| <b>I2CADD3</b>            | <b>I<sup>2</sup>C Address Register</b>                                                                                                                                                                                                                                                                                                                           |
| Function                  | Holds the fourth I <sup>2</sup> C peripheral address for the part. It may be overwritten by user code.                                                                                                                                                                                                                                                           |
| SFR Address               | 93H                                                                                                                                                                                                                                                                                                                                                              |
| Power-On Default Value    | 00H                                                                                                                                                                                                                                                                                                                                                              |
| Bit Addressable           | No                                                                                                                                                                                                                                                                                                                                                               |
| <b>I2CDAT</b>             | <b>I<sup>2</sup>C Data Register</b>                                                                                                                                                                                                                                                                                                                              |
| Function                  | The I2CDAT SFR is written by the user to transmit data over the I <sup>2</sup> C interface or read by user code to read data just received by the I <sup>2</sup> C interface. Accessing I2CDAT automatically clears any pending I <sup>2</sup> C interrupt and the I2CI bit in the I2CCON SFR. User software should only access I2CDAT once per interrupt cycle. |
| SFR Address               | 9AH                                                                                                                                                                                                                                                                                                                                                              |
| Power-On Default Value    | 00H                                                                                                                                                                                                                                                                                                                                                              |
| Bit Addressable           | No                                                                                                                                                                                                                                                                                                                                                               |

\* Purchase of licensed I<sup>2</sup>C components of Analog Devices or one of its sublicensed Associated Companies conveys a license for the purchaser under the Philips I<sup>2</sup>C Patent Rights to use the ADuC841 in an I<sup>2</sup>C system, provided that the system conforms to the I<sup>2</sup>C Standard Specification as defined by Philips.

The main features of the MicroConverter I<sup>2</sup>C interface are:

- Only two bus lines are required; a serial data line (SDATA) and a serial clock line (SCLOCK).
- An I<sup>2</sup>C master can communicate with multiple slave devices. Because each slave device has a unique 7-bit address then single master/slave relationships can exist at all times even in a multi slave environment
- Ability to respond to 4 seperate addresses when operating in slave mode
- An I<sup>2</sup>C slave can respond to repeated start conditions without a stop bit in between. This allows a master to change direction of transfer without giving up the bus.
- On-Chip filtering rejects <50ns spikes on the SDATA and the SCLOCK lines to preserve data integrity.



Figure 36. Typical ₽C System

#### Software Master Mode

The ADuC841 can be used as a  $I^2C$  master device by configuring the  $I^2C$  peripheral in master mode and writing sotware to output the data bit by bit. This is referred to as a software master. Master mode is enabled by setting the I2CM bit in the I2CCON register.

To transmit data on the SDATA line, MDE must be set to enable the output driver on the SDATA pin. If MDE is set then the SDATA pin will be pulled high or low depending on whether the MDO bit is set or cleared. MCO controls the SCLOCK pin and is always configured as an output in master mode. In master mode the SCLOCK pin will be pulled high or low depending on the whether MCO is set or cleared.

To receive data, MDE must be cleared to disable the output driver on SDATA. Software must provide the clocks by toggling the MCO bit and read SDATA pin via the MDI bit. If MDE is cleared MDI can be used to read the SDATA pin. The value of the SDATA pin is latched into MDI on a rising edge pf SCLOCK. MDI is set if the SDATA pin was high on the last rising edge of SCLOCK. MDI is clear if the SDATA pin was low on the last rising edge of SCLOCK.

Software must control MDO, MCO and MDE appropriately to generate the START condition, slave address, acknowledge bits, data bytes and STOP conditions appropriately. These

functions are provided in tech note uC001.

#### **Hardware Slave Mode**

After reset the ADuC841 defaults to hardware slave mode. The I<sup>2</sup>C interface is enabled by clearing the SPE bit in SPICON. Slave mode is enabled by clearing the I2CM bit in I2CCON. The ADuC841 has a full hardware slave. In slave mode the I<sup>2</sup>C address is stored in the I2CADD register. Data received or to be transmitted is stored in the I2CDAT register.

Once enabled in I<sup>2</sup>C slave mode the slave controller waits for a START condition. If the ADuC831 detects a valid start condition, followed by a valid address, followed by the R/W bit the I2CI interrupt bit will get automatically set by hardware.

The I<sup>2</sup>C peripheral will only generate a core interrupt if the user has pre-configured the I<sup>2</sup>C interrupt enable bit in the IEIP2 SFR as well as the global interrupt bit EA in the IE SFR. i.e.

```
; Enabling I2C Interrupts for the ADuC831
MOV IEIP2,#01h ; enable I2C interrupt
SETB EA
```

On the ADuC841 an auto-clear of the I2CI bit is implemented so this bit is cleared automatically on a read or write access to the I2CDAT SFR.

MOV I2CDAT, A ; I2CI auto-cleared MOV A, I2CDAT ; I2CI auto-cleared

If for any reason the user tries to clear the interrupt more than once i.e. access the data SFR more than once per interrupt then the I<sup>2</sup>C controller will halt. The interface will then have to be reset using the I2CRS bit.

The user can choose to poll the I2CI bit or enable the interrupt. In the case of the interrupt the PC counter will vector to 003BH at the end of each complete byte. For the first byte when the user gets to the I2CI ISR the 7-bit address and the R/W bit will appear in the I2CDAT SFR.

The I2CTX bit contains the R/W bit sent from the master. If I2CTX is set then the master would like to receive a byte. Hence the slave will transmit data by writing to the I2CDAT register. If I2CTX is cleared the master would like to transmit a byte. Hence the slave will receive a serial byte. Software can interrogate the state of I2CTX to determine whether is should write to or read from I2CDAT.

Once the ADuC841 has received a valid address, hardware will hold SCLOCK low until the I2CI bit is cleared by software. This allows the master to wait for the slave to be ready before transmitting the clocks for the next byte.

The I2CI interrupt bit will be set every time a complete data byte is received or transmitted provided it is followed by a valid ACK. If the byte is followed by a NACK an interrupt is NOT generated. The ADuC841 will continue to issue interrupts for each complete data byte transferred until a STOP condition is received or the interface is reset.

When a STOP condition is received, the interface will reset to a state where it is waiting to be addressed (idle). Similarly, if the interface receives a NACK at the end of a sequence it also returns to the default idle state. The I2CRS bit can be used to reset the  $I^2C$  interface. This bit can be used to force the interface back to the default idle state.

#### OUTLINE DIMENSIONS

Dimensions shown in inches and (mm).











