



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                              |
|----------------------------|---------------------------------------------------------------------|
| Core Processor             | 8052                                                                |
| Core Size                  | 8-Bit                                                               |
| Speed                      | 12.58MHz                                                            |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                   |
| Peripherals                | PSM, Temp Sensor, WDT                                               |
| Number of I/O              | 34                                                                  |
| Program Memory Size        | 8KB (8K x 8)                                                        |
| Program Memory Type        | FLASH                                                               |
| EEPROM Size                | 640 x 8                                                             |
| RAM Size                   | 256 x 8                                                             |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                         |
| Data Converters            | A/D 7x16b; D/A 1x12b                                                |
| Oscillator Type            | Internal                                                            |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                   |
| Mounting Type              | Surface Mount                                                       |
| Package / Case             | 52-QFP                                                              |
| Supplier Device Package    | 52-MQFP (10x10)                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/analog-devices/aduc816bsz-reel |

Email: info@E-XFL.COM

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

### TABLE OF CONTENTS

| FEATURES 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GENERAL DESCRIPTION 1 SPECIFICATIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TIMING SPECIFICATIONS 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ABSOLUTE MAXIMUM RATINGS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ORDERING GUIDE 18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| PIN FUNCTION DESCRIPTIONS 19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ADuC816 BLOCK DIAGRAM 21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| MEMORY ORGANIZATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| OVERVIEW OF MCU-RELATED SFRS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Accumulator SFR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| B SFR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Data Pointer 23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Program Status Word SFR 23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Power Control SFR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| SPECIAL FUNCTION REGISTERS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| SFR INTERFACE TO THE PRIMARY AND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| AUXILIARY ADCs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| ADCSTAT (ADC Status Register) 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ADCMODE (ADC Mode Register) 26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| ADC0CON (Primary ADC Control Register) 27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| ADC1CON (Auxiliary ADC Control Register) 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| SF (Sinc Filter Register) 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ICON (Current Sources Control Register) 29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ADC0H/ADC0M (Primary ADC Conversion Result                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ADCILL(ADCILL (Auguitizer ADC Companying Devict                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ADCIH/ADCIL (Auxiliary ADC Conversion Result                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| OFOH/OFOM (Drimory ADC Offset Calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Pagistors) 20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| OF1H/OF1L (Auviliary ADC Offset Calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Registers) 30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| GN0H/GN0M (Primary ADC Gain Calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Registers)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| GN1H/GN1L (Auxiliary ADC Gain Calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Registers)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PRIMARY AND AUXILIARY ADC CIRCUIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| DESCRIPTION OVERVIEW 31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Primary ADC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Auxiliary ADC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| PRIMARY AND AUXILIARY ADC NOISE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| PERFORMANCE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Analog Input Channels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Analog Input Ranges 33                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Programmable Gain Amplifier 34                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bipolar/Unipolar Inputs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Burnout Currents                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Excitation Currents                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Reference Input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Reference Detect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Reference Detect       35         Sigma-Delta Modulator       35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Reference Detect35Sigma-Delta Modulator35Digital Filter35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Reference Detect35Sigma-Delta Modulator35Digital Filter35ADC Chopping36                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Reference Detect       35         Sigma-Delta Modulator       35         Digital Filter       35         ADC Chopping       36         Calibration       36         VONUCATURE ELE ACUTE MERCENT       37                                                                                                                                                                                                                                                                                                                                               |
| Reference Detect       35         Sigma-Delta Modulator       35         Digital Filter       35         ADC Chopping       36         Calibration       36         NONVOLATILE FLASH/EE MEMORY       37                                                                                                                                                                                                                                                                                                                                                |
| Reference Detect       35         Sigma-Delta Modulator       35         Digital Filter       35         ADC Chopping       36         Calibration       36         NONVOLATILE FLASH/EE MEMORY       37         Flash/EE Memory Overview       37         Flash/EE Memory overview       37                                                                                                                                                                                                                                                            |
| Reference Detect       35         Sigma-Delta Modulator       35         Digital Filter       35         ADC Chopping       36         Calibration       36         NONVOLATILE FLASH/EE MEMORY       37         Flash/EE Memory Overview       37         Flash/EE Memory and the ADuC816       37         Flash/EE Memory Reliability       27                                                                                                                                                                                                        |
| Reference Detect       35         Sigma-Delta Modulator       35         Digital Filter       35         ADC Chopping       36         Calibration       36         NONVOLATILE FLASH/EE MEMORY       37         Flash/EE Memory Overview       37         Flash/EE Memory and the ADuC816       37         ADuC816 Flash/EE Memory Reliability       37                                                                                                                                                                                                |
| Reference Detect       35         Sigma-Delta Modulator       35         Digital Filter       35         ADC Chopping       36         Calibration       36         NONVOLATILE FLASH/EE MEMORY       37         Flash/EE Memory Overview       37         Flash/EE Memory and the ADuC816       37         ADuC816 Flash/EE Memory Reliability       37         Using the Flash/EE Program Memory       38         Flash/EE Program Memory       38                                                                                                    |
| Reference Detect       35         Sigma-Delta Modulator       35         Digital Filter       35         ADC Chopping       36         Calibration       36         NONVOLATILE FLASH/EE MEMORY       37         Flash/EE Memory Overview       37         Flash/EE Memory Overview       37         Flash/EE Memory and the ADuC816       37         ADuC816 Flash/EE Memory Reliability       37         Using the Flash/EE Program Memory       38         Flash/EE Program Memory Security       38         Using the Flash/EE Data Memory       39 |
| Reference Detect35Sigma-Delta Modulator35Digital Filter35ADC Chopping36Calibration36NONVOLATILE FLASH/EE MEMORY37Flash/EE Memory Overview37Flash/EE Memory and the ADuC81637ADuC816 Flash/EE Memory Reliability37Using the Flash/EE Program Memory38Flash/EE Program Memory Security38Using the Flash/EE Data Memory39ECON-Flash/EE Memory Control SFR39                                                                                                                                                                                                |

| Using the Flash/EE Memory Interface              | 40       |
|--------------------------------------------------|----------|
| Erase-All                                        | 40       |
| Program a Byte                                   | 40       |
| USER INTERFACE TO OTHER ON-CHIP ADuC816          |          |
| PERIPHERALS                                      | 41       |
| DAC                                              | 41       |
| On-Chip PLL                                      | 42       |
| Time Interval Counter (TIC)                      | 43       |
| Watchdog Timer                                   | 46       |
| Power Supply Monitor                             | 47       |
| SERIAL PERIPHERAL INTERFACE                      | 48       |
| MISO (Master In, Slave Out Data I/O Pin), Pin 14 | 48       |
| MOSI (Master Out, Slave In Pin), Pin 27          | 48       |
| SCLOCK (Serial Clock I/O Pin), Pin 26            | 48       |
| SS (Slave Select Input Pin), Pin 13              | 48       |
| Using the SPI Interface                          | 49       |
| SPI Interface—Master Mode                        | 49       |
| SPI Interface—Slave Mode                         | 49       |
| I <sup>2</sup> C-COMPATIBLE INTERFACE            | 50       |
| 8051-COMPATIBLE ON-CHIP PERIPHERALS              | 51       |
| Parallel I/O Ports 0–3                           | 51       |
| Timers/Counters                                  | 51       |
| TIMER/COUNTER 0 AND 1 OPERATING MODES            | 54       |
| Mode 0 (13-Bit Timer/Counter)                    | 54       |
| Mode 1 (16-Bit Timer/Counter)                    | 54       |
| Mode 2 (8-Bit Timer/Counter with Autoreload)     | 54       |
| Mode 3 (Two 8-Bit Timer/Counters)                | 54       |
| Timer/Counter 2 Data Registers                   | 55       |
| TH2 and TL2                                      | 55       |
| RCAP2H and RCAP2L                                | 55       |
| Timer/Counter 2 Operating Modes                  | 56       |
| 16-Bit Autoreload Mode                           | 56       |
| 16-Bit Capture Mode                              | 56       |
| UART SERIAL INTERFACE                            | 57       |
| SBUF                                             | 57       |
| Mode 0: 8-Bit Shift Register Mode                | 58       |
| Mode 1: 8-Bit UART, Variable Baud Rate           | 58       |
| Mode 2: 9-Bit UART with Fixed Baud Rate          | 58       |
| Mode 3: 9-Bit UART with Variable Baud Rate       | 58       |
| UART Serial Port Baud Rate Generation            | 58       |
| Timer I Generated Baud Rates                     | 59       |
| Timer 2 Generated Baud Rates                     | 59       |
| INTERRUPT SYSTEM                                 | 60       |
|                                                  | 61       |
| ADuC816 HARDWARE DESIGN CONSIDERATIONS           | 62       |
| Clock Oscillator                                 | 62       |
| External Memory Interface                        | 02<br>(2 |
| Power-On Reset Operation                         | 03       |
| Power Supplies                                   | 63       |
| Power Consumption                                | 64       |
| Crown ding and Doord Lewent Decommon detions     | 64       |
| ADv Cold System Sold Layout Recommendations      | 64       |
|                                                  | 05       |
| In Circuit Social December 1 Access              | 05       |
| In-Circuit Serial Download Access                | 65       |
| Single Din Emplotion Mode                        | 65       |
| Single-Fin Emulation Mode                        | 60       |
| Emianced-mooks Emulation Mode                    | 00<br>66 |
| OLICKSTART DEVELODMENT SVSTEM                    | 67       |
| Download_In_Circuit Seriel Downloader            | 01<br>67 |
| Download—In-Circuit Debugger                     | 01<br>67 |
| ADSIM_Windows Simulator                          | 67       |
|                                                  | 69       |
|                                                  | 00       |

| Parameter                                               | ADuC816BS | Unit    | Test Conditions/Comments                                          |
|---------------------------------------------------------|-----------|---------|-------------------------------------------------------------------|
| POWER REQUIREMENTS (continued)                          |           |         |                                                                   |
| Power Supply Currents Normal Mode <sup>16, 17</sup>     |           |         |                                                                   |
| DV <sub>DD</sub> Current                                | 4         | mA max  | $DV_{DD} = 4.75 V$ to 5.25 V, Core CLK = 1.57 MHz                 |
| 22                                                      | 2.1       | mA max  | $DV_{DD} = 2.7 \text{ V to } 3.6 \text{ V}$ , Core CLK = 1.57 MHz |
| AV <sub>DD</sub> Current                                | 170       | µA max  | $AV_{DD} = 5.25 \text{ V}, \text{ Core CLK} = 1.57 \text{ MHz}$   |
| $DV_{DD}$ Current                                       | 15        | mA max  | $DV_{DD} = 4.75 \text{ V}$ to 5.25 V, Core CLK = 12.58 MHz        |
|                                                         | 8         | mA max  | $DV_{DD} = 2.7 \text{ V}$ to 3.6 V, Core CLK = 12.58 MHz          |
| AV <sub>DD</sub> Current                                | 170       | µA max  | $AV_{DD} = 5.25 \text{ V}, \text{ Core CLK} = 12.58 \text{ MHz}$  |
| Power Supply Currents Idle Mode <sup>16, 17</sup>       |           | •       |                                                                   |
| DV <sub>DD</sub> Current                                | 1.2       | mA max  | $DV_{DD} = 4.75 V$ to 5.25 V, Core CLK = 1.57 MHz                 |
| 22                                                      | 750       | μA typ  | $DV_{DD} = 2.7 \text{ V to } 3.6 \text{ V}$ , Core CLK = 1.57 MHz |
| AV <sub>DD</sub> Current                                | 140       | uA typ  | Measured @ $AV_{DD} = 5.25 V$ , Core CLK = 1.57 MHz               |
| $DV_{DD}$ Current                                       | 2         | mA typ  | $DV_{DD} = 4.75 \text{ V}$ to 5.25 V, Core CLK = 12.58 MHz        |
| 22                                                      | 1         | mA typ  | $DV_{DD} = 2.7 \text{ V}$ to 3.6 V, Core CLK = 12.58 MHz          |
| AV <sub>DD</sub> Current                                | 140       | μA typ  | Measured at $AV_{DD} = 5.25$ V, Core CLK = 12.58 MHz              |
| Power Supply Currents Power-Down Mode <sup>16, 17</sup> |           | • • • • | Core CLK = 1.57 MHz or 12.58 MHz                                  |
| DV <sub>DD</sub> Current                                | 50        | μA max  | $DV_{DD}$ = 4.75 V to 5.25 V, Osc. On, TIC On                     |
|                                                         | 20        | µA max  | $DV_{DD} = 2.7 V$ to 3.6 V, Osc. On, TIC On                       |
| AV <sub>DD</sub> Current                                | 1         | µA max  | Measured at $AV_{DD}$ = 5.25 V, Osc. On or Osc. Off               |
| DV <sub>DD</sub> Current                                | 20        | µA max  | $DV_{DD} = 4.75 V$ to 5.25 V, Osc. Off                            |
|                                                         | 5         | μA typ  | $DV_{DD} = 2.7 V$ to 3.6 V, Osc. Off                              |
| Typical Additional Power Supply Currents                |           |         | Core CLK = 1.57 MHz, $AV_{DD} = DV_{DD} = 5 V$                    |
| $(AI_{DD} \text{ and } DI_{DD})$                        |           |         |                                                                   |
| PSM Peripheral                                          | 50        | μA typ  |                                                                   |
| Primary ADC                                             | 1         | mA typ  |                                                                   |
| Auxiliary ADC                                           | 500       | μA typ  |                                                                   |
| DAC                                                     | 150       | μA typ  |                                                                   |
| Dual Current Sources                                    | 400       | μA typ  |                                                                   |

NOTES

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

<sup>2</sup>These numbers are not production tested but are guaranteed by Design and/or Characterization data on production release.

<sup>3</sup>The primary ADC is factory-calibrated at  $25^{\circ}$ C with AV<sub>DD</sub> = DV<sub>DD</sub> = 5 V yielding this full-scale error. If user power supply or temperature conditions are significantly different from these, an Internal Full-Scale Calibration will restore this error to this level.

<sup>4</sup>Gain Error Drift is a span drift. To calculate Full-Scale Error Drift, add the Offset Error Drift to the Gain Error Drift times the full-scale input.

 $^{5}$ The auxiliary ADC is factory-calibrated at 25 °C with AV<sub>DD</sub> = DV<sub>DD</sub> = 5 V yielding this full-scale error of -2.5 LSB. A system zero-scale and full-scale calibration will remove this error altogether.

<sup>6</sup>DAC linearity and AC Specifications are calculated using:

reduced code range of 48 to 4095, 0 to  $V_{\text{REF}}$ 

reduced code range of 48 to 3995, 0 to  $V_{\rm DD}.$ 

<sup>7</sup>Gain Error is a measure of the span error of the DAC.

 $^{8}$ In general terms, the bipolar input voltage range to the primary ADC is given by Range<sub>ADC</sub> =  $\pm (V_{REF} 2^{RN})/125$ , where:

 $V_{REF} = REFIN(+)$  to REFIN(-) voltage and  $V_{REF} = 1.25$  V when internal ADC  $V_{REF}$  is selected.

RN = decimal equivalent of RN2, RN1, RN0, e.g.,  $V_{REF}$  = 2.5 V and RN2, RN1, RN0 = 1, 1, 0 the Range<sub>ADC</sub> = ±1.28 V.

In unipolar mode the effective range is 0 V to 1.28 V in our example.

<sup>9</sup>1.25 V is used as the reference voltage to the ADC when internal V<sub>REF</sub> is selected via XREF0 and XREF1 bits in ADC0CON and ADC1CON respectively.

<sup>10</sup>In bipolar mode, the Auxiliary ADC can only be driven to a minimum of  $A_{GND}$  – 30 mV as indicated by the Auxiliary ADC absolute AIN voltage limits. The bipolar range is still –V<sub>REF</sub> to +V<sub>REF</sub>; however, the negative voltage is limited to –30 mV.

<sup>11</sup>Pins configured in I<sup>2</sup>C-compatible mode or SPI mode, pins configured as digital inputs during this test.

<sup>12</sup>Pins configured in I<sup>2</sup>C-compatible mode only.

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

<sup>14</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>15</sup>Retention lifetime equivalent at junction temperature (T<sub>J</sub>) = 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>16</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 Clk changed via CD bits in PLLCON, Core Executing internal software loop. Idle Mode: Reset = 0.4 V, Digital I/O pins = open circuit, Core Clk changed via CD bits in PLLCON, PCON.0 = 1, Core Execution suspended in idle mode.

Power-Down Mode: Reset = 0.4 V, All P0 pins and P1.2–P1.7 pins = 0.4 V, All other digital I/O pins are open circuit, Core Clk changed via CD bits in PLLCON, PCON.1 = 1, Core Execution suspended in power-down mode, OSC turned ON or OFF via OSC\_PD bit (PLLCON.7) in PLLCON SFR.

<sup>17</sup>DV<sub>DD</sub> power supply current will typically increase 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

# **TIMING SPECIFICATIONS**<sup>1, 2, 3</sup> ( $AV_{DD} = 2.7$ V to 3.6 V or 4.75 V to 5.25 V, $DV_{DD} = 2.7$ V to 3.6 V or 4.75 V to 5.25 V; all specifications T<sub>MIN</sub> to T<sub>MAX</sub> unless otherwise noted.)

|                     |                                           | 32.768 kHz External Crystal |       |        |      |        |
|---------------------|-------------------------------------------|-----------------------------|-------|--------|------|--------|
| Parameter           |                                           | Min                         | Тур   | Max    | Unit | Figure |
| CLOCK INP           | UT (External Clock Driven XTAL1)          |                             |       |        |      |        |
| t <sub>CK</sub>     | XTAL1 Period                              |                             | 30.52 |        | μs   | 1      |
| t <sub>CKL</sub>    | XTAL1 Width Low                           |                             | 15.16 |        | μs   | 1      |
| t <sub>CKH</sub>    | XTAL1 Width High                          |                             | 15.16 |        | μs   | 1      |
| t <sub>CKR</sub>    | XTAL1 Rise Time                           |                             | 20    |        | ns   | 1      |
| t <sub>CKF</sub>    | XTAL1 Fall Time                           |                             | 20    |        | ns   | 1      |
| 1/t <sub>CORE</sub> | ADuC816 Core Clock Frequency <sup>4</sup> | 0.098                       |       | 12.58  | MHz  |        |
| t <sub>CORE</sub>   | ADuC816 Core Clock Period <sup>5</sup>    |                             | 0.636 |        | μs   |        |
| t <sub>CYC</sub>    | ADuC816 Machine Cycle Time <sup>6</sup>   | 0.95                        | 7.6   | 122.45 | μs   |        |

NOTES

 $^{1}AC$  inputs during testing are driven at  $DV_{DD} - 0.5 V$  for a Logic 1, and 0.45 V for a Logic 0. Timing measurements are made at  $V_{IH}$  min for a Logic 1, and  $V_{IL}$  max for a Logic 0 as shown in Figure 2.

 $^{2}$ For timing purposes, a port pin is no longer floating when a 100 mV change from load voltage occurs. A port pin begins to float when a 100 mV change from the loaded  $V_{OH}/V_{OL}$  level occurs as shown in Figure 2.

 ${}^{3}C_{LOAD}$  for Port0, ALE, PSEN outputs = 100 pF;  $C_{LOAD}$  for all other outputs = 80 pF unless otherwise noted.

<sup>4</sup>ADuC816 internal PLL locks onto a multiple (384 times) the external crystal frequency of 32.768 kHz to provide a Stable 12.583 MHz internal clock for the system. The core can operate at this frequency or at a binary submultiple called Core\_Clk, selected via the PLLCON SFR.

<sup>5</sup>This number is measured at the default Core\_Clk operating frequency of 1.57 MHz.

<sup>6</sup>ADuC816 Machine Cycle Time is nominally defined as 12/Core\_CLK.

Specifications subject to change without notice.



Figure 1. XTAL1 Input



Figure 2. Timing Waveform Characteristics

|                   |                                     | 12.58 MH | z Core_Clk | Variable                | Variable Core_Clk        |      |        |
|-------------------|-------------------------------------|----------|------------|-------------------------|--------------------------|------|--------|
| Paramete          | er                                  | Min      | Max        | Min                     | Max                      | Unit | Figure |
| EXTERN            | AL PROGRAM MEMORY                   |          |            |                         |                          |      |        |
| t <sub>LHLL</sub> | ALE Pulsewidth                      | 119      |            | $2t_{CORE} - 40$        |                          | ns   | 3      |
| t <sub>AVLL</sub> | Address Valid to ALE Low            | 39       |            | $t_{CORE} - 40$         |                          | ns   | 3      |
| t <sub>LLAX</sub> | Address Hold after ALE Low          | 49       |            | t <sub>CORE</sub> – 30  |                          | ns   | 3      |
| t <sub>LLIV</sub> | ALE Low to Valid Instruction In     |          | 218        |                         | $4t_{CORE} - 100$        | ns   | 3      |
| t <sub>LLPL</sub> | ALE Low to <b>PSEN</b> Low          | 49       |            | $t_{CORE} - 30$         |                          | ns   | 3      |
| t <sub>PLPH</sub> | <b>PSEN</b> Pulsewidth              | 193      |            | 3t <sub>CORE</sub> - 45 |                          | ns   | 3      |
| t <sub>PLIV</sub> | PSEN Low to Valid Instruction In    |          | 133        |                         | 3t <sub>CORE</sub> - 105 | ns   | 3      |
| t <sub>PXIX</sub> | Input Instruction Hold after PSEN   | 0        |            | 0                       |                          | ns   | 3      |
| t <sub>PXIZ</sub> | Input Instruction Float after PSEN  |          | 54         |                         | t <sub>CORE</sub> – 25   | ns   | 3      |
| t <sub>AVIV</sub> | Address to Valid Instruction In     |          | 292        |                         | 5t <sub>CORE</sub> - 105 | ns   | 3      |
| t <sub>PLAZ</sub> | PSEN Low to Address Float           |          | 25         |                         | 25                       | ns   | 3      |
| t <sub>PHAX</sub> | Address Hold after <b>PSEN</b> High | 0        |            | 0                       |                          | ns   | 3      |



Figure 3. External Program Memory Read Cycle

|                   |                              | 12.58 | MHz Co | re_Clk | Variable Core_Clk        |             |     |      |        |
|-------------------|------------------------------|-------|--------|--------|--------------------------|-------------|-----|------|--------|
| Parameter         | •                            | Min   | Тур    | Max    | Min                      | Тур         | Max | Unit | Figure |
| UART TIN          | AING (Shift Register Mode)   |       |        |        |                          |             |     |      |        |
| t <sub>XLXL</sub> | Serial Port Clock Cycle Time |       | 0.95   |        |                          | $2t_{CORE}$ |     | μs   | 6      |
| t <sub>QVXH</sub> | Output Data Setup to Clock   | 662   |        |        | 10t <sub>CORE</sub> – 13 | 3           |     | ns   | 6      |
| t <sub>DVXH</sub> | Input Data Setup to Clock    | 292   |        |        | 2t <sub>CORE</sub> + 133 | 3           |     | ns   | 6      |
| t <sub>XHDX</sub> | Input Data Hold after Clock  | 0     |        |        | 0                        |             |     | ns   |        |
| t <sub>XHQX</sub> | Output Data Hold after Clock | 42    |        |        | 2t <sub>CORE</sub> - 117 |             |     | ns   | 6      |



Figure 6. UART Timing in Shift Register Mode



Figure 12. 52-MQFP Block Diagram

Reset initializes the stack pointer to location 07 hex and increments it once to start from locations 08 hex which is also the first register (R0) of register bank 1. Thus, if one is going to use more than one register bank, the stack pointer should be initialized to an area of RAM not used for data storage.

The SFR space is mapped to the upper 128 bytes of internal data memory space and accessed by direct addressing only. It provides an interface between the CPU and all on-chip peripherals. A block diagram showing the programming model of the ADuC816 via the SFR area is shown in Figure 16. A complete SFR map is shown in Figure 17.



Figure 16. Programming Model

# **OVERVIEW OF MCU-RELATED SFRS**

#### Accumulator SFR

ACC is the Accumulator register and is used for math operations including addition, subtraction, integer multiplication and division, and Boolean bit manipulations. The mnemonics for accumulator-specific instructions refer to the Accumulator as A.

# **B** SFR

The B register is used with the ACC for multiplication and division operations. For other instructions it can be treated as a general-purpose scratchpad register.

# **Stack Pointer SFR**

The SP register is the stack pointer and is used to hold an internal RAM address that is called the *"top of the stack."* The SP register is incremented before data is stored during PUSH and CALL executions. While the Stack may reside anywhere in on-chip RAM, the SP register is initialized to 07H after a reset. This causes the stack to begin at location 08H.

# Data Pointer

The Data Pointer is made up of three 8-bit registers, named DPP (page byte), DPH (high byte) and DPL (low byte). These are used to provide memory addresses for internal and external code access and external data access. It may be manipulated as a 16-bit register (DPTR = DPH, DPL), although INC DPTR instructions will automatically carry over to DPP, or as three independent 8-bit registers (DPP, DPH, DPL).

# **Program Status Word SFR**

The PSW register is the Program Status Word which contains several bits reflecting the current status of the CPU as detailed in Table I.

| SFR Address            | D0H |
|------------------------|-----|
| Power ON Default Value | 00H |
| Bit Addressable        | Yes |
|                        |     |

| CY AC F0 R | S1 RS0 | ov | F1 | Р |
|------------|--------|----|----|---|

Table I. PSW SFR Bit Designations

| Bit | Name | Description               |  |  |  |  |
|-----|------|---------------------------|--|--|--|--|
| 7   | CY   | Carry Flag                |  |  |  |  |
| 6   | AC   | Auxiliary Carry Flag      |  |  |  |  |
| 5   | F0   | General-Purpose Flag      |  |  |  |  |
| 4   | RS1  | Register Bank Select Bits |  |  |  |  |
| 3   | RS0  | RS1 RS0 Selected Bank     |  |  |  |  |
|     |      | 0 0 0                     |  |  |  |  |
|     |      | 0 1 1                     |  |  |  |  |
|     |      | 1 0 2                     |  |  |  |  |
|     |      | 1 1 3                     |  |  |  |  |
| 2   | OV   | Overflow Flag             |  |  |  |  |
| 1   | F1   | General-Purpose Flag      |  |  |  |  |
| 0   | Р    | Parity Bit                |  |  |  |  |

# Power Control SFR

The Power Control (PCON) register contains bits for powersaving options and general-purpose status flags as shown in Table II.

| SFR Address            | 87H |
|------------------------|-----|
| Power ON Default Value | 00H |
| Bit Addressable        | No  |

| SMOD SERIPD INTOPD ALE | OFF GF1 | GF0 | PD | IDL |
|------------------------|---------|-----|----|-----|
|------------------------|---------|-----|----|-----|

Table II. PCON SFR Bit Designations

| Bit | Name   | Description                               |
|-----|--------|-------------------------------------------|
| 7   | SMOD   | Double UART Baud Rate                     |
| 6   | SERIPD | I <sup>2</sup> C/SPI Power-Down Interrupt |
| 5   | INTOPD | Enable<br>INT0 Power-Down Interrupt       |
|     |        | Enable                                    |
| 4   | ALEOFF | Disable ALE Output                        |
| 3   | GF1    | General-Purpose Flag Bit                  |
| 2   | GF0    | General-Purpose Flag Bit                  |
| 1   | PD     | Power-Down Mode Enable                    |
| 0   | IDL    | Idle Mode Enable                          |

# SPECIAL FUNCTION REGISTERS

All registers except the program counter and the four generalpurpose register banks, reside in the SFR area. The SFR registers include control, configuration, and data registers that provide an interface between the CPU and all on-chip peripherals. Figure 17 shows a full SFR memory map and SFR contents on RESET; NOT USED indicates unoccupied SFR locations. Unoccupied locations in the SFR address space are not implemented; i.e., no register exists at this location. If an unoccupied location is read, an unspecified value is returned. SFR locations reserved for future use are shaded (RESERVED) and should not be accessed by user software.

| ISPI<br>FFH 0 | WCOL          | SPE<br>FDH 0  | SPIM<br>FCH 0   | CPOL           | CPHA<br>FAH 1  | SPR1           | SPR0<br>F8H 0 | BITS | >      | SPICON            | RESERVED           | RESERVED           | DACL               | DACH              | DACCON            | RESERVED          | RESERVED          |
|---------------|---------------|---------------|-----------------|----------------|----------------|----------------|---------------|------|--------|-------------------|--------------------|--------------------|--------------------|-------------------|-------------------|-------------------|-------------------|
| F7H 0         | F6H 0         | F5H 0         | F4H 0           | F3H 0          | F2H 0          | F1H 0          | FOH 0         | BITS | $\geq$ | B                 | RESERVED           | RESERVED           | NOT USED           | RESERVED          | RESERVED          | RESERVED          | SPIDAT            |
| MDO<br>EFH 0  | MDE<br>EEH 0  | MCO<br>EDH 0  | MDI<br>ECH 0    | I2CM<br>EBH 0  | I2CRS<br>EAH 0 | 12CTX<br>E9H 0 | 12CI<br>E8H 0 | BITS |        | 12CCON<br>E8H 00H | RESERVED           | GN0M*<br>EAH 55H   | GN0H*<br>EBH 53H   | GN1L*<br>ECH 9AH  | GN1H*<br>EDH 59H  | RESERVED          | RESERVED          |
| E7H 0         | E6H 0         | E5H 0         | E4H 0           | ) E3H 0        | E2H 0          | E1H 0          | E0H 0         | BITS | >      | ACC<br>E0H 00H    | RESERVED           | OF0M*<br>E2H 00H   | OF0H*<br>E3H 80H   | OF1L*<br>E4H 00H  | OF1H*<br>E5H 80H  | RESERVED          | RESERVED          |
| RDY0<br>DFH 0 | RDY1<br>DEH 0 | CAL<br>DDH 0  | NOXREP<br>DCH 0 | ERR0<br>DBH 0  | ERR1<br>DAH 0  | D9H 0          | D8H 0         | BITS | $\geq$ | ADCSTAT           | RESERVED           | ADCOM<br>DAH 00H   | ADC0H<br>DBH 00H   | ADC1L<br>DCH 00H  | ADC1H<br>DDH 00H  | RESERVED          | PSMCON<br>DFH DEH |
| СҮ<br>D7H 0   | AC<br>D6H 0   | F0<br>D5H 0   | RSI<br>D4H 0    | RS0<br>D3H 0   | OV<br>D2H 0    | FI<br>D1H 0    | P<br>DOH 0    | BITS | >      | PSW<br>DOH 00H    | ADCMODE<br>D1H 00H | ADC0CON<br>D2H 07H | ADC1CON<br>D3H 00H | SF<br>D4H 45H     | ICON<br>D5H 00H   | RESERVED          | PLLCON<br>D7H 03H |
| TF2<br>CFH 0  | EXF2<br>CEH 0 | RCLK<br>CDH 0 | TCLK<br>CCH 0   | EXEN2<br>CBH 0 | TR2<br>CAH 0   | СNT2<br>С9Н 0  | CAP2<br>C8H 0 | BITS | $\geq$ | Т2CON<br>С8Н 00Н  | RESERVED           | RCAP2L<br>CAH 00H  | RCAP2H<br>СВН 00Н  | TL2<br>CCH 00H    | ТН2<br>СDH 00H    | RESERVED          | RESERVED          |
| PRE3<br>C7H 0 | PRE2<br>C6H 0 | PRE1<br>C5H 0 | PRE0<br>C4H 1   | WDIR<br>C3H 0  | WDS<br>C2H 0   | WDE<br>C1H 0   | WDWR<br>C0H 0 | BITS | $\geq$ | WDCON<br>C0H 10H  | RESERVED           | CHIPID<br>C2H 16H  | RESERVED           | RESERVED          | RESERVED          | EADRL<br>C6H 00H  | RESERVED          |
| BFH 0         | PADC<br>BEH 0 | PT2<br>BDH 0  | PS<br>BCH 0     | PT1<br>BBH 0   | PX1<br>BAH     | РТ0<br>В9Н 0   | PX0<br>B8H 0  | BITS | $\geq$ | IР<br>            | ECON<br>B9H 00H    | RESERVED           | RESERVED           | EDATA1<br>BCH 00H | EDATA2<br>BDH 00H | EDATA3<br>BEH 00H | EDATA4<br>BFH 00H |
| RD<br>B7H 1   | WR<br>B6H 1   | T1<br>B5H 1   | T0<br>B4H 1     | INT1<br>B3H 1  | INTO<br>B2H 1  | TXD<br>B1H 1   | RXD<br>B0H 1  | BITS | $\geq$ | P3<br>BOH FFH     | NOT USED           | NOT USED           | NOT USED           | NOT USED          | RESERVED          | RESERVED          | NOT USED          |
| EA<br>AFH 0   | EADC<br>AEH 0 | ET2<br>ADH 0  | ES<br>ACH 0     | ET1<br>ABH 0   | EX1<br>AAH 0   | ET0<br>A9H 0   | EX0<br>A8H 0  | BITS | $\geq$ | IE<br>            | IEIP2<br>A9H A0H   | RESERVED           | RESERVED           | RESERVED          | RESERVED          | RESERVED          | RESERVED          |
| A7H 1         | A6H 1         | A5H 1         | A4H 1           | A3H 1          | A2H 1          | A1H 1          | A0H 1         | BITS | $\geq$ | P2<br>A0H FFH     | TIMECON<br>A1H 00H | HTHSEC             | SEC<br>A3H 00H     | MIN<br>A4H 00H    | HOUR<br>A5H 00H   | INTVAL<br>A6H 00H | NOT USED          |
| SM0<br>9FH 0  | SM1<br>9EH 0  | SM2<br>9DH 0  | REN<br>9CH 0    | ТВ8<br>9ВН 0   | RB8<br>9AH 0   | Т1<br>99Н 0    | R1<br>98H 0   | BITS | $\geq$ | SCON<br>98H 00H   | SBUF<br>99H 00H    | I2CDAT<br>9AH 00H  | 12CDAT<br>9BH 00H  | NOT USED          | NOT USED          | NOT USED          | NOT USED          |
| 97H 1         | 96H 1         | 95H 1         | 94H 1           | 93H 1          | 92H 1          | T2EX<br>91H 1  | T2<br>90H 1   | BITS | $\geq$ | P1<br>90H FFH     | NOT USED           | NOT USED           | NOT USED           | NOT USED          | NOT USED          | NOT USED          | NOT USED          |
| TF1<br>8FH 0  | TR1<br>8EH 0  | TF0<br>8DH 0  | TR0<br>8CH 0    | IE1<br>8BH 0   | IT1<br>8AH 0   | IE0<br>89H 0   | IT0<br>88H 0  | BITS | $\geq$ | TCON<br>88H 00H   | TMOD<br>89H 00H    | TL0<br>8AH 00H     | TL1<br>8BH 00H     | тно<br>8сн оон    | TH1<br>8DH 00H    | RESERVED          | RESERVED          |
| 87H 1         | 86H 1         | 85H 1         | 84H 1           | 83H 1          | 82H 1          | 81H 1          | 80H 1         | BITS | $\geq$ | P0<br>80H FFH     | SP<br>81H 07H      | DPL<br>82H 00H     | DPH<br>83H 00H     | DPP<br>84H 00H    | RESERVED          | RESERVED          | PCON<br>87H 00H   |

\*CALIBRATION COEFFICIENTS ARE PRECONFIGURED AT POWER-UP TO FACTORY-CALIBRATED VALUES.



THESE BITS ARE CONTAINED IN THIS BYTE.



SFR NOTE: SFRs WHOSE ADDRESSES END IN 0H OR 8H ARE BIT-ADDRESSABLE.

Figure 17. Special Function Register Locations and Reset Values

# SFR INTERFACE TO THE PRIMARY AND AUXILIARY ADCS

Both ADCs are controlled and configured via a number of SFRs that are mentioned here and described in more detail in the following pages.

| ADCSTAT: | ADC Status Register. Holds general status of the Primary and Auxiliary ADCs.                                                           |
|----------|----------------------------------------------------------------------------------------------------------------------------------------|
| ADCMODE: | ADC Mode Register. Controls general modes of operation for Primary and Auxiliary ADCs.                                                 |
| ADC0CON: | Primary ADC Control Register. Controls specific configuration of Primary ADC.                                                          |
| ADC1CON: | Auxiliary ADC Control Register. Controls specific configuration of Auxiliary ADC.                                                      |
| SF:      | Sinc Filter Register. Configures the decimation<br>factor for the Sinc3 filter and thus the Primary<br>and Auxiliary ADC update rates. |

| ICON:                                        | Current Source Control Register. Allows<br>user control of the various on-chip current<br>source options.  |
|----------------------------------------------|------------------------------------------------------------------------------------------------------------|
| ADC0H/M*:                                    | Primary ADC 16-bit conversion result held in these two 8-bit registers.                                    |
| ADC1H/L:                                     | Auxiliary ADC 16-bit conversion result held in these two 8-bit registers.                                  |
| OF0H/M*:                                     | Primary ADC 16-bit Offset Calibration Coefficient held in these two 8-bit registers.                       |
| OF1H/L:                                      | Auxiliary ADC 16-bit Offset Calibration Coefficient held in these two 8-bit registers.                     |
| GN0H/M*:                                     | Primary ADC 16-bit Gain Calibration Coefficient held in these two 8-bit registers.                         |
| GN1H/L:                                      | Auxiliary ADC 16-bit Gain Calibration Coefficient held in these two 8-bit registers.                       |
| *To maintain code co<br>associated with thes | ompatibility with the ADuC824, it is the low-byte SFR<br>e register groups that is omitted on the ADuC816. |

ADCSTAT (ADC Status Register)

This SFR reflects the status of both ADCs including data ready, calibration and various (ADC-related) error and warning conditions including reference detect and conversion overflow/underflow flags.

| SFR Address            | D8H |
|------------------------|-----|
| Power-On Default Value | 00H |
| Bit Addressable        | Yes |

| RDY0 RDY1 CAL NOXREF | ERR0 | ERR1 |  |  |
|----------------------|------|------|--|--|
|----------------------|------|------|--|--|

# Table III. ADCSTAT SFR Bit Designations

| Bit | Name   | Description                                                                                           |
|-----|--------|-------------------------------------------------------------------------------------------------------|
| 7   | RDY0   | Ready Bit for Primary ADC.                                                                            |
|     |        | Set by hardware on completion of ADC conversion or calibration cycle.                                 |
|     |        | Cleared directly by the user or indirectly by write to the mode bits to start another Primary         |
|     |        | ADC conversion or calibration. The Primary ADC is inhibited from writing further results to its       |
|     |        | data or calibration registers until the RDY0 bit is cleared.                                          |
| 6   | RDY1   | Ready Bit for Auxiliary ADC.                                                                          |
|     |        | Same definition as RDY0 referred to the Auxiliary ADC.                                                |
| 5   | CAL    | Calibration Status Bit.                                                                               |
|     |        | Set by hardware on completion of calibration.                                                         |
| _   |        | <i>Cleared</i> indirectly by a write to the mode bits to start another ADC conversion or calibration. |
| 4   | NOXREF | No External Reference Bit (only active if Primary or Auxiliary ADC is active).                        |
|     |        | Set to indicate that one or both of the REFIN pins is floating or the applied voltage is below a      |
|     |        | specified threshold. When Set conversion results are clamped to all ones, if using ext. reference.    |
| 2   | FDDA   | Cleared to indicate valid $V_{\text{REF}}$ .                                                          |
| 3   | ERR0   | Primary ADC Error Bit.                                                                                |
|     |        | Set by hardware to indicate that the result written to the Primary ADC data registers has             |
|     |        | been clamped to all zeros or all ones. After a calibration this bit also flags error conditions that  |
|     |        | caused the calibration registers not to be written.                                                   |
| 2   | EDD 1  | Cleared by a write to the mode bits to initiate a conversion or calibration.                          |
| Ζ   | EKKI   | Auxiliary ADC Error Bit.                                                                              |
| 1   |        | Same definition as EKRO referred to the Auxiliary ADC.                                                |
| 1   |        | Reserved for Future Use.                                                                              |
| 0   |        | Reserved for Future Use.                                                                              |

Figures 23 and 24 show the NMR for 50 Hz and 60 Hz across the full range of SF word, i.e., SF = 13 dec to SF = 255 dec.



Figure 23. 50 Hz Normal Mode Rejection vs. SF



Figure 24. 60 Hz Normal Mode Rejection vs. SF

#### **ADC Chopping**

Both ADCs on the ADuC816 implement a chopping scheme whereby the ADC repeatability reverses its inputs. The decimated digital output words from the Sinc<sup>3</sup> filters therefore have a positive offset and negative offset term included.

As a result, a final summing stage is included in each ADC so that each output word from the filter is summed and averaged with the previous filter output to produce a new valid output result to be written to the ADC data SFRs. In this way, while the ADC throughput or update rate is as discussed earlier and illustrated in Table VII, the full settling time through the ADC (or the time to a first conversion result), will actually be given by  $2 \times t_{ADC}$ .

The chopping scheme incorporated in the ADuC816 ADC results in excellent dc offset and offset drift specifications and is extremely beneficial in applications where drift, noise rejection, and optimum EMI rejection are important factors.

#### Calibration

The ADuC816 provides four calibration modes that can be programmed via the mode bits in the ADCMODE SFR detailed in Table IV. In fact, every ADuC816 has already been factory calibrated. The resultant Offset and Gain calibration coefficients for both the primary and auxiliary ADCs are stored on-chip in manufacturing-specific Flash/EE memory locations. At poweron, these factory calibration coefficients are automatically downloaded to the calibration registers in the ADuC816 SFR space. Each ADC (primary and auxiliary) has dedicated calibration SFRs, these have been described earlier as part of the general ADC SFR description. However, the factory calibration values in the ADC calibration SFRs will be overwritten if any one of the four calibration options are initiated and that ADC is enabled via the ADC enable bits in ADCMODE.

Even though an internal offset calibration mode is described below, it should be recognized that both ADCs are chopped. This chopping scheme inherently minimizes offset and means that an internal offset calibration should never be required. Also, because factory 5 V/25°C gain calibration coefficients are automatically present at power-on, an internal full-scale calibration will only be required if the part is being operated at 3 V or at temperatures significantly different from 25°C.

The ADuC816 offers "internal" or "system" calibration facilities. For full calibration to occur on the selected ADC, the calibration logic must record the modulator output for two different input conditions. These are "zero-scale" and "full-scale" points. These points are derived by performing a conversion on the different input voltages provided to the input of the modulator during calibration. The result of the "zero-scale" calibration conversion is stored in the Offset Calibration Registers for the appropriate ADC. The result of the "full-scale" calibration conversion is stored in the Gain Calibration Registers for the appropriate ADC. With these readings, the calibration logic can calculate the offset and the gain slope for the input-to-output transfer function of the converter.

During an "internal" zero-scale or full-scale calibration, the respective "zero" input and "full-scale" input are automatically connected to the ADC input pins internally to the device. A "system" calibration, however, expects the system zero-scale and system full-scale voltages to be applied to the external ADC pins before the calibration mode is initiated. In this way external ADC errors are taken into account and minimized as a result of system calibration. It should also be noted that to optimize calibration accuracy, all ADuC816 ADC calibrations are carried out automatically at the slowest update rate.

Internally in the ADuC816, the coefficients are normalized before being used to scale the words coming out of the digital filter. The offset calibration coefficient is subtracted from the result prior to the multiplication by the gain coefficient. All ADuC816 ADC specifications will only apply after a zero-scale and full-scale calibration at the operating point (supply voltage/temperature) of interest.

From an operational point of view, a calibration should be treated like another ADC conversion. A zero-scale calibration (if required) should always be carried out before a full-scale calibration. System software should monitor the relevant ADC RDY0/1 bit in the ADCSTAT SFR to determine end of calibration via a polling sequence or interrupt driven routine.

### Using the Flash/EE Program Memory

The 8 Kbyte Flash/EE Program Memory array is mapped into the lower 8 Kbytes of the 64 Kbytes program space addressable by the ADuC816, and is used to hold user code in typical applications.

The program memory Flash/EE memory arrays can be programmed in one of two modes, namely:

### Serial Downloading (In-Circuit Programming)

As part of its factory boot code, the ADuC816 facilitates serial code download via the standard UART serial port. Serial download mode is automatically entered on power-up if the external pin,  $\overrightarrow{PSEN}$ , is pulled low through an external resistor as shown in Figure 27. Once in this mode, the user can download code to the program memory array while the device is sited in its target application hardware. A PC serial download executable is provided as part of the ADuC816 QuickStart development system. The Serial Download protocol is detailed in a MicroConverter Applications Note uC004 available from the ADI MicroConverter Website at www.analog.com/microconverter.





#### Parallel Programming

The parallel programming mode is fully compatible with conventional third party Flash or EEPROM device programmers. A block diagram of the external pin configuration required to support parallel programming is shown in Figure 28. In this mode, Ports 0, 1, and 2 operate as the external data and address bus interface, ALE operates as the Write Enable strobe, and Port 3 is used as a general configuration port that configures the device for various program and erase operations during parallel programming.

The high voltage (12 V) supply required for Flash/EE programming is generated using on-chip charge pumps to supply the high voltage program lines.



Figure 28. Flash/EE Memory Parallel Programming

Table XII. Flash/EE Memory Parallel Programming Modes

|       |         | Pe    | ort 3 I |     | Programming |     |                                                        |
|-------|---------|-------|---------|-----|-------------|-----|--------------------------------------------------------|
| 0.7   | 0.6     | 0.5   | 0.4     | 0.3 | 0.2         | 0.1 | Mode                                                   |
| X     | Х       | Х     | Х       | 0   | 0           | 0   | Erase Flash/EE<br>Program, Data, and<br>Security Modes |
| Х     | Х       | Х     | Х       | 0   | 0           | 1   | Read Device<br>Signature/ID                            |
| Х     | Х       | Х     | 1       | 0   | 1           | 0   | Program Code Byte                                      |
| Х     | Х       | Х     | 0       | 0   | 1           | 0   | Program Data Byte                                      |
| Х     | Х       | Х     | 1       | 0   | 1           | 1   | Read Code Byte                                         |
| Х     | Х       | Х     | 0       | 0   | 1           | 1   | Read Data Byte                                         |
| Х     | Х       | Х     | Х       | 1   | 0           | 0   | Program Security<br>Modes                              |
| Х     | Х       | Х     | Х       | 1   | 0           | 1   | Read/Verify Security<br>Modes                          |
| All ( | Other ( | Codes |         |     |             |     | Redundant                                              |

#### Flash/EE Program Memory Security

The ADuC816 facilitates three modes of Flash/EE program memory security. These modes can be independently activated, restricting access to the internal code space. These security modes can be enabled as part of the user interface available on all ADuC816 serial or parallel programming tools referenced on the MicroConverter web page at www.analog.com/microconverter. The security modes available on the ADuC816 are described as follows:

#### Lock Mode

This mode locks code in memory, disabling parallel programming of the program memory although reading the memory in parallel mode is still allowed. This mode is deactivated by initiating a "code-erase" command in serial download or parallel programming modes.

#### Secure Mode

This mode locks code in memory, disabling parallel programming (program and verify/read commands) as well as disabling the execution of a "MOVC" instruction from external memory, which is attempting to read the op codes from internal memory. This mode is deactivated by initiating a "code-erase" command in serial download or parallel programming modes.

| TIMECON                | TIC CONTROL REGISTER |
|------------------------|----------------------|
| SFR Address            | A1H                  |
| Power-On Default Value | 00H                  |
| Bit Addressable        | No                   |
|                        |                      |

|  |  | ITS1 | ITS0 | STI | TII | TIEN | TCEN |
|--|--|------|------|-----|-----|------|------|
|--|--|------|------|-----|-----|------|------|

# Table XVI. TIMECON SFR Bit Designations

| Bit | Name | Description                                                                                                 |  |  |  |  |  |
|-----|------|-------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7   |      | Reserved for Future Use.                                                                                    |  |  |  |  |  |
| 6   |      | Reserved for Future Use. For future product code compatibility this bit should be written as a '1.'         |  |  |  |  |  |
| 5   | ITS1 | Interval Timebase Selection Bits.                                                                           |  |  |  |  |  |
| 4   | ITS0 | Written by user to determine the interval counter update rate.                                              |  |  |  |  |  |
|     |      | ITS1 ITS0 Interval Timebase                                                                                 |  |  |  |  |  |
|     |      | 0 0 1/128 Second                                                                                            |  |  |  |  |  |
|     |      | 0 1 Seconds                                                                                                 |  |  |  |  |  |
|     |      | 1 0 Minutes                                                                                                 |  |  |  |  |  |
|     |      | 1 1 Hours                                                                                                   |  |  |  |  |  |
| 3   | STI  | Single Time Interval Bit.                                                                                   |  |  |  |  |  |
|     |      | Set by user to generate a single interval timeout. If set, a timeout will clear the TIEN bit.               |  |  |  |  |  |
|     |      | Cleared by user to allow the interval counter to be automatically reloaded and start counting again at      |  |  |  |  |  |
|     |      | each interval timeout.                                                                                      |  |  |  |  |  |
| 2   | TII  | TIC Interrupt Bit.                                                                                          |  |  |  |  |  |
|     |      | Set when the 8-bit Interval Counter matches the value in the INTVAL SFR.                                    |  |  |  |  |  |
|     |      | Cleared by user software.                                                                                   |  |  |  |  |  |
| 1   | TIEN | Time Interval Enable Bit.                                                                                   |  |  |  |  |  |
|     |      | Set by user to enable the 8-bit time interval counter.                                                      |  |  |  |  |  |
|     |      | Cleared by user to disable and clear the contents of the interval counter.                                  |  |  |  |  |  |
| 0   | TCEN | Time Clock Enable Bit.                                                                                      |  |  |  |  |  |
|     |      | Set by user to enable the time clock to the time interval counters.                                         |  |  |  |  |  |
|     |      | <i>Cleared</i> by user to disable the clock to the time interval counters and clear the time interval SFRs. |  |  |  |  |  |
|     |      | The time registers (HTHSEC, SEC, MIN and HOUR) can be written while TCEN is low.                            |  |  |  |  |  |

# INTVAL

Function

SFR Address Power-On Default Value Bit Addressable Valid Value

### HTHSEC

Function

SFR Address Power-On Default Value Bit Addressable Valid Value

**SEC** Function

Function

SFR Address Power-On Default Value Bit Addressable Valid Value

### MIN

Function

SFR Address Power-On Default Value Bit Addressable Valid Value

# HOUR

Function

SFR Address Power-On Default Value Bit Addressable Valid Value

### User Time Interval Select Register

User code writes the required time interval to this register. When the 8-bit interval counter is equal to the time interval value loaded in the INTVAL SFR, the TII bit (TIMECON.2) bit is set and generates an interrupt if enabled. (See IEIP2 SFR description under Interrupt System later in this data sheet.) A6H 00H

No 0 to 255 decimal

### Hundredths Seconds Time Register

This register is incremented in (1/128) second intervals once TCEN in TIMECON is active. The HTHSEC SFR counts from 0 to 127 before rolling over to increment the SEC time register. A2H 00H No 0 to 127 decimal

# **Seconds Time Register**

This register is incremented in 1-second intervals once TCEN in TIMECON is active. The SEC SFR counts from 0 to 59 before rolling over to increment the MIN time register. A3H 00H No 0 to 59 decimal

### **Minutes Time Register**

This register is incremented in 1-minute intervals once TCEN in TIMECON is active. The MIN counts from 0 to 59 before rolling over to increment the HOUR time register. A4H 00H No 0 to 59 decimal

# **Hours Time Register**

This register is incremented in 1-hour intervals once TCEN in TIMECON is active. The HOUR SFR counts from 0 to 23 before rolling over to 0. A5H 00H No 0 to 23 decimal

#### 8051-COMPATIBLE ON-CHIP PERIPHERALS

This section gives a brief overview of the various secondary peripheral circuits are also available to the user on-chip. These remaining functions are fully 8051-compatible and are controlled via standard 8051 SFR bit definitions.

#### Parallel I/O Ports 0-3

The ADuC816 uses four input/output ports to exchange data with external devices. In addition to performing general-purpose I/O, some ports are capable of external memory operations; others are multiplexed with an alternate function for the peripheral features on the device. In general, when a peripheral is enabled, that pin may not be used as a general purpose I/O pin.

Port 0 is an 8-bit open drain bidirectional I/O port that is directly controlled via the Port 0 SFR (SFR address = 80 hex). Port 0 pins that have 1s written to them via the Port 0 SFR will be configured as open drain and will therefore float. In that state, Port 0 pins can be used as high impedance inputs. An external pull-up resistor will be required on Port 0 outputs to force a valid logic high level externally. 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.

Port 1 is also an 8-bit port directly controlled via the P1 SFR (SFR address = 90 hex). The Port 1 pins are divided into two distinct pin groupings.

P1.0 and P1.1 pins on Port 1 are bidirectional digital I/O pins with internal pull-ups. If P1.0 and P1.1 have 1s written to them via the P1 SFR, these pins are pulled high by the internal pull-up resistors. In this state they can also be used as inputs; as input pins being externally pulled low, they will source current because of the internal pull-ups. With 0s written to them, both these pins will drive a logic low output voltage (VOL) and will be capable of sinking 10 mA compared to the standard 1.6 mA sink capability on the other port pins. These pins also have various secondary functions described in Table XXI.

#### Table XXI. Port 1, Alternate Pin Functions

| Pin  | Alternate Function                            |
|------|-----------------------------------------------|
| P1.0 | T2 (Timer/Counter 2 External Input)           |
| P1.1 | T2EX (Timer/Counter 2 Capture/Reload Trigger) |

The remaining Port 1 pins (P1.2–P1.7) can only be configured as Analog Input (ADC), Analog Output (DAC) or Digital Input pins. By (power-on) default these pins are configured as Analog Inputs, i.e., "1" written in the corresponding Port 1 register bit. To configure any of these pins as digital inputs, the user should write a "0" to these port bits to configure the corresponding pin as a high impedance digital input.

Port 2 is a bidirectional port with internal pull-up resistors directly controlled via the P2 SFR (SFR address = A0 hex). Port 2 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 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 16-bit external data memory space.

Port 3 is a bidirectional port with internal pull-ups directly controlled via the P2 SFR (SFR address = B0 hex). Port 3 pins that have 1s written to them are pulled high by the internal pullups 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-ups. Port 3 pins also have various secondary functions described in Table XXII.

|--|

| Pin  | Alternate Function                     |
|------|----------------------------------------|
| P3.0 | RXD (UART Input Pin)                   |
|      | (or Serial Data I/O in Mode 0)         |
| P3.1 | TXD (UART Output Pin)                  |
|      | (or Serial Clock Output in Mode 0)     |
| P3.2 | INT0 (External Interrupt 0)            |
| P3.3 | INT1 (External Interrupt 1)            |
| P3.4 | T0 (Timer/Counter 0 External Input)    |
| P3.5 | T1 (Timer/Counter 1 External Input)    |
| P3.6 | WR (External Data Memory Write Strobe) |
| P3.7 | RD (External Data Memory Read Strobe)  |
|      |                                        |

The alternate functions of P1.0, P1.1, and Port 3 pins can only be activated if the corresponding bit latch in the P1 and P3 SFRs contains a 1. Otherwise, the port pin is stuck at 0.

#### **Timers/Counters**

The ADuC816 has three 16-bit Timer/Counters: Timer 0, Timer 1, and Timer 2. The Timer/Counter hardware has been included on-chip to relieve the processor core of the overhead inherent in implementing timer/counter functionality in software. Each Timer/Counter consists of two 8-bit registers THx and TLx (x = 0, 1 and 2). All three can be configured to operate either as timers or event counters.

In "Timer" function, the TLx register is incremented every machine cycle. Thus one can think of it as counting machine cycles. Since a machine cycle consists of 12 core clock periods, the maximum count rate is 1/12 of the core clock frequency.

In "Counter" function, the TLx register is incremented by a 1-to-0 transition at its corresponding external input pin, T0, T1, or T2. In this function, the external input is sampled during S5P2 of every machine cycle. When the samples show a high in one cycle and a low in the next cycle, the count is incremented. The new count value appears in the register during S3P1 of the cycle following the one in which the transition was detected. Since it takes two machine cycles (16 core clock periods) to recognize a 1-to-0 transition, the maximum count rate is 1/16 of the core clock frequency. There are no restrictions on the duty cycle of the external input signal, but to ensure that a given level is sampled at least once before it changes, it must be held for a minimum of one full machine cycle. Remember that the core clock frequency is programmed via the CD0–2 selection bits in the PLLCON SFR.

#### **TIMER/COUNTER 0 AND 1 OPERATING MODES**

The following paragraphs describe the operating modes for timer/ counters 0 and 1. Unless otherwise noted, it should be assumed that these modes of operation are the same for timer 0 as for timer 1.

#### Mode 0 (13-Bit Timer/Counter)

Mode 0 configures an 8-bit timer/counter with a divide-by-32 prescaler. Figure 33 shows mode 0 operation.



\*THE CORE CLOCK IS THE OUTPUT OF THE PLL AS DESCRIBED ON PAGE 42.

### Figure 33. Timer/Counter 0, Mode 0

In this mode, the timer register is configured as a 13-bit register. As the count rolls over from all 1s to all 0s, it sets the timer overflow flag TF0. The overflow flag, TF0, can then be used to request an interrupt. The counted input is enabled to the timer when TR0 = 1 and either Gate = 0 or  $\overline{INT0} = 1$ . Setting Gate = 1 allows the timer to be controlled by external input  $\overline{INT0}$ , to facilitate pulsewidth measurements. TR0 is a control bit in the special function register TCON; Gate is in TMOD. The 13-bit register consists of all eight bits of TH0 and the lower five bits of TL0. The upper three bits of TL0 are indeterminate and should be ignored. Setting the run flag (TR0) does not clear the registers.

#### Mode 1 (16-Bit Timer/Counter)

Mode 1 is the same as Mode 0, except that the timer register is running with all 16 bits. Mode 1 is shown in Figure 34.



\*THE CORE CLOCK IS THE OUTPUT OF THE PLL AS DESCRIBED ON PAGE 42.

#### Figure 34. Timer/Counter 0, Mode 1

#### Mode 2 (8-Bit Timer/Counter with Autoreload)

Mode 2 configures the timer register as an 8-bit counter (TL0) with automatic reload, as shown in Figure 35. Overflow from TL0 not only sets TF0, but also reloads TL0 with the contents of TH0, which is preset by software. The reload leaves TH0 unchanged.



\*THE CORE CLOCK IS THE OUTPUT OF THE PLL AS DESCRIBED ON PAGE 42.

Figure 35. Timer/Counter 0, Mode 2

#### Mode 3 (Two 8-Bit Timer/Counters)

Mode 3 has different effects on timer 0 and timer 1. Timer 1 in Mode 3 simply holds its count. The effect is the same as setting TR1 = 0. Timer 0 in Mode 3 establishes TL0 and TH0 as two separate counters. This configuration is shown in Figure 36. TL0 uses the timer 0 control bits: C/T, Gate, TR0, INT0, and TF0. TH0 is locked into a timer function (counting machine cycles) and takes over the use of TR1 and TF1 from timer 1. Thus, TH0 now controls the "timer 1" interrupt. Mode 3 is provided for applications requiring an extra 8-bit timer or counter.

When timer 0 is in Mode 3, timer 1 can be turned on and off by switching it out of, and into, its own Mode 3, or can still be used by the serial interface as a *Baud Rate Generator*. In fact, it can be used, in any application not requiring an interrupt from timer 1 itself.



Figure 36. Timer/Counter 0, Mode 3

#### **Timer/Counter 2 Operating Modes**

The following paragraphs describe the operating modes for timer/ counter 2. The operating modes are selected by bits in the T2CON SFR as shown in Table XXVI.

|  | Table XXVI. TIMECON SFR | Bit Designations |  |
|--|-------------------------|------------------|--|
|--|-------------------------|------------------|--|

| RCLK (or) TCLK | CAP2 | TR2 | MODE              |
|----------------|------|-----|-------------------|
| 0              | 0    | 1   | 16-Bit Autoreload |
| 0              | 1    | 1   | 16-Bit Capture    |
| 1              | Х    | 1   | Baud Rate         |
| X              | X    | 0   | OFF               |

#### 16-Bit Autoreload Mode

In "Autoreload" mode, there are two options, which are selected by bit EXEN2 in T2CON. If EXEN2 = 0, then when Timer 2 rolls over it not only sets TF2 but also causes the Timer 2 registers to be reloaded with the 16-bit value in registers RCAP2L and RCAP2H, which are preset by software. If EXEN2 = 1, then Timer 2 still performs the above, but with the added feature that a 1-to-0 transition at external input T2EX will also trigger the 16-bit reload and set EXF2. The autoreload mode is illustrated in Figure 37 below.

#### 16-Bit Capture Mode

In the "Capture" mode, there are again two options, which are selected by bit EXEN2 in T2CON. If EXEN2 = 0, then Timer 2 is a 16-bit timer or counter which, upon overflowing, sets bit TF2, the Timer 2 overflow bit, which can be used to generate an interrupt. If EXEN2 = 1, then Timer 2 still performs the above, but a 1-to-0 transition on external input T2EX causes the current value in the Timer 2 registers, TL2 and TH2, to be captured into registers RCAP2L and RCAP2H, respectively. In addition, the transition at T2EX causes bit EXF2 in T2CON to be set, and EXF2, like TF2, can generate an interrupt. The Capture Mode is illustrated in Figure 38.

The baud rate generator mode is selected by RCLK = 1 and/or TCLK = 1.

In either case if Timer 2 is being used to generate the baud rate, the TF2 interrupt flag will not occur. Hence Timer 2 interrupts will not occur so they do not have to be disabled. In this mode the EXF2 flag, however, can still cause interrupts and this can be used as a third external interrupt.

Baud rate generation will be described as part of the UART serial port operation in the following pages.



\*THE CORE CLOCK IS THE OUTPUT OF THE PLL AS DESCRIBED ON PAGE 42.

Figure 37. Timer/Counter 2, 16-Bit Autoreload Mode



\*THE CORE CLOCK IS THE OUTPUT OF THE PLL AS DESCRIBED ON PAGE 42.

Figure 38. Timer/Counter 2, 16-Bit Capture Mode

### Mode 0: 8-Bit Shift Register Mode

Mode 0 is selected by clearing both the SM0 and SM1 bits in the SFR SCON. Serial data enters and exits through RXD. TXD outputs the shift clock. Eight data bits are transmitted or received. Transmission is initiated by any instruction that writes to SBUF. The data is shifted out of the RXD line. The eight bits are transmitted with the least-significant bit (LSB) first, as shown in Figure 39.



Figure 39. UART Serial Port Transmission, Mode 0

Reception is initiated when the receive enable bit (REN) is 1 and the receive interrupt bit (RI) is 0. When RI is cleared the data is clocked into the RXD line and the clock pulses are output from the TXD line.

### Mode 1: 8-Bit UART, Variable Baud Rate

Mode 1 is selected by clearing SM0 and setting SM1. Each data byte (LSB first) is preceded by a start bit(0) and followed by a stop bit(1). Therefore 10 bits are transmitted on TXD or received on RXD. The baud rate is set by the Timer 1 or Timer 2 overflow rate, or a combination of the two (one for transmission and the other for reception).

Transmission is initiated by writing to SBUF. The "write to SBUF" signal also loads a 1 (stop bit) into the ninth bit position of the transmit shift register. The data is output bit by bit until the stop bit appears on TXD and the transmit interrupt flag (TI) is automatically set as shown in Figure 40.



# Figure 40. UART Serial Port Transmission, Mode 0

Reception is initiated when a 1-to-0 transition is detected on RXD. Assuming a valid start bit was detected, character reception continues. The start bit is skipped and the eight data bits are clocked into the serial port shift register. When all eight bits have been clocked in, the following events occur:

The eight bits in the receive shift register are latched into SBUF

The ninth bit (Stop bit) is clocked into RB8 in SCON

The Receiver interrupt flag (RI) is set

if, and only if, the following conditions are met at the time the final shift pulse is generated:

RI = 0, and

Either SM2 = 0, or SM2 = 1 and the received stop bit = 1.

If either of these conditions is not met, the received frame is irretrievably lost, and RI is not set.

#### Mode 2: 9-Bit UART with Fixed Baud Rate

Mode 2 is selected by setting SM0 and clearing SM1. In this mode the UART operates in 9-bit mode with a fixed baud rate. The baud rate is fixed at Core\_Clk/64 by default, although by setting the SMOD bit in PCON, the frequency can be doubled to Core\_Clk/32. Eleven bits are transmitted or received, a start bit(0), eight data bits, a programmable ninth bit and a stop bit(1). The ninth bit is most often used as a parity bit, although it can be used for anything, including a ninth data bit if required.

To transmit, the eight data bits must be written into SBUF. The ninth bit must be written to TB8 in SCON. When transmission is initiated the eight data bits (from SBUF) are loaded onto the transmit shift register (LSB first). The contents of TB8 are loaded into the ninth bit position of the transmit shift register. The transmission will start at the next valid baud rate clock. The TI flag is set as soon as the stop bit appears on TXD.

Reception for Mode 2 is similar to that of Mode 1. The eight data bytes are input at RXD (LSB first) and loaded onto the receive shift register. When all eight bits have been clocked in, the following events occur:

The eight bits in the receive shift register are latched into SBUF

The ninth data bit is latched into RB8 in SCON

The Receiver interrupt flag (RI) is set

if, and only if, the following conditions are met at the time the final shift pulse is generated:

#### RI = 0, and

Either SM2 = 0, or SM2 = 1 and the received stop bit = 1.

If either of these conditions is not met, the received frame is irretrievably lost, and RI is not set.

# Mode 3: 9-Bit UART with Variable Baud Rate

Mode 3 is selected by setting both SM0 and SM1. In this mode the 8051 UART serial port operates in 9-bit mode with a variable baud rate determined by either Timer 1 or Timer 2. The operation of the 9-bit UART is the same as for Mode 2 but the baud rate can be varied as for Mode 1.

In all four modes, transmission is initiated by any instruction that uses SBUF as a destination register. Reception is initiated in Mode 0 by the condition RI = 0 and REN = 1. Reception is initiated in the other modes by the incoming start bit if REN = 1.

# UART Serial Port Baud Rate Generation Mode 0 Baud Rate Generation

The baud rate in Mode 0 is fixed:

Mode 0 Baud Rate = (Core Clock Frequency $^{1}/12$ )

#### NOTE

 $^1 \rm In$  these descriptions Core Clock Frequency refers to the core clock frequency selected via the CD0–2 bits in the PLLCON SFR.

#### Mode 2 Baud Rate Generation

The baud rate in Mode 2 depends on the value of the SMOD bit in the PCON SFR. If SMOD = 0, the baud rate is 1/64 of the core clock. If SMOD = 1, the baud rate is 1/32 of the core clock:

Mode 2 Baud Rate =  $(2^{\text{SMOD}}/64) \times (\text{Core Clock Frequency})$ 

# Modes 1 and 3 Baud Rate Generation

The baud rates in Modes 1 and 3 are determined by the overflow rate in Timer 1 or Timer 2, or both (one for transmit and the other for receive).

| IEIP2:                 | Secondary I | nterrupt Enable | and Priority Re | gister |  |
|------------------------|-------------|-----------------|-----------------|--------|--|
| SFR Address            | A9H         |                 |                 |        |  |
| Power-On Default Value | A0H         |                 |                 |        |  |
| Bit Addressable        | No          |                 |                 |        |  |
|                        |             |                 |                 |        |  |
|                        |             |                 |                 |        |  |

| <br>PTI | PPSM | PSI | <br>ETI | EPSM | ESI |
|---------|------|-----|---------|------|-----|
|         |      |     |         |      |     |

### Table XXXII. IEIP2 SFR Bit Designations

| Bit | Name | Description                                                                                            |
|-----|------|--------------------------------------------------------------------------------------------------------|
| 7   |      | Reserved for Future Use.                                                                               |
| 6   | PTI  | Written by User to Select TIC Interrupt Priority ("1" = High; "0" = Low).                              |
| 5   | PPSM | Written by User to Select Power Supply Monitor Interrupt Priority ("1" = High; "0" = Low).             |
| 4   | PSI  | Written by User to Select SPI/I <sup>2</sup> C Serial Port Interrupt Priority ("1" = High; "0" = Low). |
| 3   |      | Reserved, This Bit Must Be "0."                                                                        |
| 2   | ETI  | Written by User to Enable "1" or Disable "0" TIC Interrupt.                                            |
| 1   | EPSM | Written by User to Enable "1" or Disable "0" Power Supply Monitor Interrupt.                           |
| 0   | ESI  | Written by User to Enable "1" or Disable "0" SPI/I <sup>2</sup> C Serial Port Interrupt.               |

#### **Interrupt Priority**

The Interrupt Enable registers are written by the user to enable individual interrupt sources, while the Interrupt Priority registers allow the user to select one of two priority levels for each interrupt. An interrupt of a high priority may interrupt the service routine of a low priority interrupt, and if two interrupts of different priority occur at the same time, the higher level interrupt will be serviced first. An interrupt cannot be interrupted by another interrupt of the same priority level. If two interrupts of the same priority level occur simultaneously, a polling sequence is observed as shown in Table XXXIII.

#### Table XXXIII. Priority within an Interrupt Level

| Source      | Priority    | Description                     |
|-------------|-------------|---------------------------------|
| PSMI        | 1 (Highest) | Power Supply Monitor Interrupt  |
| WDS         | 2           | Watchdog Interrupt              |
| IE0         | 3           | External Interrupt 0            |
| RDY0/RDY1   | 4           | ADC Interrupt                   |
| TF0         | 5           | Timer/Counter 0 Interrupt       |
| IE1         | 6           | External Interrupt 1            |
| TF1         | 7           | Timer/Counter 1 Interrupt       |
| I2CI + ISPI | 8           | I <sup>2</sup> C/SPI Interrupt  |
| RI + TI     | 9           | Serial Interrupt                |
| TF2 + EXF2  | 10          | Timer/Counter 2 Interrupt       |
| TII         | 11 (Lowest) | Time Interval Counter Interrupt |

#### **Interrupt Vectors**

When an interrupt occurs the program counter is pushed onto the stack and the corresponding interrupt vector address is loaded into the program counter. The interrupt vector addresses are shown in Table XXXIV.

Table XXXIV. Interrupt Vector Addresses

| Source                                        | Vector Address                   |  |  |
|-----------------------------------------------|----------------------------------|--|--|
| IE0                                           | 0003 Hex                         |  |  |
| TF0                                           | 000B Hex                         |  |  |
| IE1                                           | 0013 Hex                         |  |  |
| TF1                                           | 001B Hex                         |  |  |
| RI + TI                                       | 0023 Hex                         |  |  |
| TF2 + EXF2                                    | 002B Hex                         |  |  |
| RDY0/RDY1 (ADC)                               | 0033 Hex                         |  |  |
| $II^{2}C + ISPI$                              | 003B Hex                         |  |  |
| PSMI                                          | 0043 Hex                         |  |  |
| TII                                           | 0053 Hex                         |  |  |
| WDS $(WDIR = 1)^*$                            | 005B Hex                         |  |  |
| PSMI<br>TII<br>WDS (WDIR = $1$ ) <sup>*</sup> | 0043 Hex<br>0053 Hex<br>005B Hex |  |  |

\*The watchdog can be configured to generate an interrupt instead of a reset when it times out. This is used for logging errors or to examine the internal status of the microcontroller core to understand, from a software debug point of view, why a watchdog timeout occurred. The watchdog interrupt is slightly different from the normal interrupts in that its priority level is always set to 1 and it is not possible to disable the interrupt via the global disable bit (EA) in the IE SFR. This is done to ensure that the interrupt will always be responded to if a watchdog timeout occurs. The watchdog will only produce an interrupt if the watchdog timeout is greater than zero.



Figure 51. System Grounding Schemes

In all of these scenarios, and in more complicated real-life applications, keep in mind the flow of current from the supplies and back to ground. Make sure the return paths for all currents are as close as possible to the paths the currents took to reach their destinations. For example, do not power components on the analog side of Figure 51b with  $DV_{DD}$  since that would force return currents from  $DV_{DD}$  to flow through AGND. Also, try to avoid digital currents flowing under analog circuitry, which could happen if the user placed a noisy digital chip on the left half of the board in Figure 51c. Whenever possible, avoid large discontinuities in the ground plane(s) (such as are formed by a long trace on the same layer), since they force return signals to travel a longer path. And of course, make all connections to the ground plane directly, with little or no trace separating the pin from its via to ground.

If the user plans to connect fast logic signals (rise/fall time < 5 ns) to any of the ADuC816's digital inputs, add a series resistor to each relevant line to keep rise and fall times longer than 5 ns at the ADuC816 input pins. A value of  $100 \Omega$  or  $200 \Omega$  is usually sufficient to prevent high-speed signals from coupling capacitively into the ADuC816 and affecting the accuracy of ADC conversions.

# ADuC816 System Self-Identification

In some hardware designs it may be an advantage for the software running on the ADuC816 target to identify the host Micro-Converter. For example, code running on the ADuC816 may be used at future date to run on an ADuC816 MicroConverter host and the code may be required to operate differently.

The CHIPID SFR is a read-only register located at SFR address C2 hex. The top nibble of this byte is set to "1" to designate an ADuC824 host. For an ADuC824 host, the CHIPID SFR will contain the value "0" in the upper nibble.

# **OTHER HARDWARE CONSIDERATIONS**

To facilitate in-circuit programming, plus in-circuit debug and emulation options, users will want to implement some simple connection points in their hardware that will allow easy access to download, debug, and emulation modes.

# In-Circuit Serial Download Access

Nearly all ADuC816 designs will want to take advantage of the in-circuit reprogrammability of the chip. This is accomplished by a connection to the ADuC816's UART, which requires an external RS-232 chip for level translation if downloading code from a PC. Basic configuration of an RS-232 connection is illustrated in Figure 52 with a simple ADM202-based circuit. If users would rather not design an RS-232 chip onto a board, refer to the application note "uC006–A 4-Wire UART-to-PC Interface"<sup>1</sup> for a simple (and zero-cost-per-board) method of gaining in-circuit serial download access to the ADuC816.

# NOTE

### <sup>1</sup>Application note uC006 is available at www.analog.com/microconverter

In addition to the basic UART connections, users will also need a way to trigger the chip into download mode. This is accomplished via a 1 k $\Omega$  pull-down resistor that can be jumpered onto the PSEN pin, as shown in Figure 52. To get the ADuC816 into download mode, simply connect this jumper and powercycle the device (or manually reset the device, if a manual reset button is available) and it will be ready to receive a new program serially. With the jumper removed, the device will come up in normal mode (and run the program) whenever power is cycled or RESET is toggled.

Note that  $\overline{\text{PSEN}}$  is normally an output (as described in the External Memory Interface section) and it is sampled as an input only on the falling edge of RESET (i.e., at power-up or upon an external manual reset). Note also that if any external circuitry unintentionally pulls  $\overline{\text{PSEN}}$  low during power-up or reset events, it could cause the chip to enter download mode and therefore fail to begin user code execution as it should. To prevent this, ensure that no external signals are capable of pulling the  $\overline{\text{PSEN}}$  pin low, except for the external  $\overline{\text{PSEN}}$  jumper itself.

# Embedded Serial Port Debugger

From a hardware perspective, entry to serial port debug mode is identical to the serial download entry sequence described above. In fact, both serial download and serial port debug modes can be thought of as essentially one mode of operation used in two different ways.

Note that the serial port debugger is fully contained on the ADuC816 device, (unlike "ROM monitor" type debuggers) and therefore no external memory is needed to enable in-system debug sessions.

# Single-Pin Emulation Mode

Also built into the ADuC816 is a dedicated controller for single-pin in-circuit emulation (ICE) using standard production ADuC816 devices. In this mode, emulation access is gained by connection to a single pin, the  $\overline{\text{EA}}$  pin. Normally, this pin is hardwired either high or low to select execution from internal or external program memory space, as described earlier. To enable single-pin emulation mode, however, users will need to pull the  $\overline{\text{EA}}$  pin high through a 1 k $\Omega$  resistor as shown in Figure 52. The emulator will then connect to the 2-pin header also shown in Figure 52. To be compatible with the standard connector that



Figure 52. Typical System Configuration

comes with the single-pin emulator available from Accutron Limited (www.accutron.com), use a 2-pin 0.1-inch pitch "Friction Lock" header from Molex (www.molex.com) such as their part number 22-27-2021. Be sure to observe the polarity of this header. As represented in Figure 52, when the Friction Lock tab is at the right, the ground pin should be the lower of the two pins (when viewed from the top).

### **Enhanced-Hooks Emulation Mode**

ADuC816 also supports enhanced-hooks emulation mode. An enhanced-hooks-based emulator is available from Metalink Corporation (www.metaice.com). No special hardware support for these emulators needs to be designed onto the board since these are "pod-style" emulators where users must replace the chip on their board with a header device that the emulator pod plugs into. The only hardware concern is then one of determining if adequate space is available for the emulator pod to fit into the system enclosure.

#### **Typical System Configuration**

A typical ADuC816 configuration is shown in Figure 52. It summarizes some of the hardware considerations discussed in the previous paragraphs.

Figure 52 also includes connections for a typical analog measurement application of the ADuC816, namely an interface to an RTD (Resistive Temperature Device). The arrangement shown is commonly referred to as a 4-wire RTD configuration.

Here, the on-chip excitation current sources are enabled to excite the sensor. An external differential reference voltage is generated by the current sourced through resistor R1. This current also flows directly through the RTD, which generates a differential voltage directly proportional to temperature. This differential voltage is routed directly to the positive and negative inputs of the primary ADC (AIN1, AIN2 respectively). A second external resistor, R2, is used to ensure that absolute analog input voltage on the negative input to the primary ADC stays within that specified for the ADuC816, i.e., AGND + 100 mV.