# Interfacing the LM12458 **Data Acquisition System to** the MC68HC11AX Microcontroller

National Semiconductor **Application Note 947** Nelson Caldani July 1994



## TABLE OF CONTENTS

**1.0 INTRODUCTION** 

- 2.0 GENERAL OVERVIEW OF THE MC68HC11AX AND THE LM12458 DAS
  - 2.1 MC68HC11Ax
  - 2.2 LM12458 DAS

## 3.0 SYSTEM EXAMPLE

- 3.1 Furnace Description and System Requirements
- 3.2 DAS Registers
- 3.3 Determining the Throughput Rate

#### 4.0 SYSTEM OVERVIEW

- 4.1 How to Communicate with the DAS
- 4.2 Hardware Description of the Interface Circuitry
- 4.3 Description of the Software

#### **1.0 INTRODUCTION**

This application note shows how to interface Motorola's MC68HC11 family of microcontrollers to the LM12458 parallel data acquisition system (DAS). It is intended to give the reader a better understanding of the DAS and how it can be integrated in a  $\mu P/\mu C$  system. There is a brief description of the MC68HC11Ax and the LM12458. An example is provided that will illustrate how to use the DAS in a system where a specific sampling rate is desired, single-ended and differential measurements of multiple channels need to be made and alarm conditions must be monitored. The application note provides a detailed circuit schematic showing the interface circuitry of the DAS to the 68HC11 accompanied with the appropriate assembly code necessary to program the DAS to fulfill the specific requirements of the example.

#### 2.0 GENERAL OVERVIEW OF THE MC68HC11AX AND THE LM12458 DAS

## 2.1 MC68HC11Ax

The 68HC11 is an 8-bit microcontroller with a 16-bit address range. It has two user modes of operation: single-chip and expanded-multiplexed mode. In single-chip mode, the 68HC11 has no external data bus or address bus. It communicates with external peripherals using its I/O ports. In expanded-multiplexed mode, the 68HC11 uses its 8-bit I/O ports B and C as address and data buses. Port B is the upper address byte. The lower address byte and the data bus are multiplexed together on port C. An address strobe (AS) generated by the 68HC11 indicates when the lower address byte is on port C. This signal may be used with external latches to demultiplex the lower address byte and data bus. In a read or write cycle the address is first placed on ports B and C and the AS is asserted. After a certain time period has elapsed, data is placed on port C. Refer to the manual of the 68HC11 for detailed timing diagrams. The 68HC11 has a R/W control signal that indicates the direction of data flow with respect to the  $\mu$ C. This signal in conjunction with the E clock may be used to generate read ( $\overline{RD}$ ) and write (WR) signals going to the DAS and other peripherals. The 68HC11 has two 8-bit accumulators, ACCA and ACCB and a 16-bit accumulator ACCD that are used for manipulating data. ACCD is a cascade of ACCA and ACCB. When using ACCD to read from or write to memory, data is not transferred in a single 16-bit word but a succession of two 8-bit bytes. Data is first transferred via ACCA, followed by ACCB. Figure 1 shows a block diagram of the MC68HC11Ax in expanded multiplexed mode.



RRD-B30M75/Printed in U. S. A

## 2.2 LM12458 DAS

The LM12458 is a 12-bit  $\pm$  sign parallel ADC that has an Instruction RAM, Configuration register, FIFO, Timer register, Interrupt Enable and Status register, watchdog detection circuitry, and an eight channel fully differential multiplexer. The DAS has three modes of operation: 12-bit  $\pm$  sign conversion, 8-bit  $\pm$  sign conversion and an 8-bit watchdog comparison mode.

The Instruction RAM has eight 48-bit wide programmable instruction registers (INSTR0–INSTR7). These instructions are used to set the mode of the DAS, the acquisition time, channels that are to be converted and the watchdog limits. The watchdog detects when a particular channel has passed a programmed limit set in the Instruction RAM. Refer to section 2.1 of the data sheet for a detailed description of the Instruction RAM and the watchdog feature. The MUX channel assignments are also set in the Instruction RAM. Table I in section 2.3 of the data sheet gives the MUX address channel assignments. The Configuration register is the control "panel" of the DAS, Its bits start/stop instruction and

auto-zero. Refer to section 2.2 of the data sheet for a detailed description of the configuration register. The FIFO has thirty-two 16-bit wide locations. The FIFO stores the conversion data performed by the ADC. Refer to section 3.0 of the data sheet for a detailed description of the FIFO. The DAS has an internal Timer used to delay execution of an instruction by a related amount of clock cycles programmed in the Timer register. Refer to section 2.7 of the data sheet for a detailed description of the timer. The Interrupt Enable register can set up eight different sources that will cause interrupts to occur and the Interrupt Status register indicates the sources of these interrupts. Refer to section 2.4 of the data sheet for a detailed description of the Interrupt Enable register and the Interrupt Status register.

## 3.0 SYSTEM EXAMPLE

## 3.1 Furnace Description and System Requirements

A high temperature semiconductor furnace will be the source of the analog signals going to the inputs of the DAS. Refer to *Figure 2* for a detailed setup of the furnace and the signals from the furnace that need to be digitized.



The DAS will measure:

- T1 at IN0 with 12-bit resolution. (single-ended)
- T1-T2 with 12-bit + sign resolution. T2 is connected to IN1. (differential)
- T1-T3 with 12-bit + sign resolution. T3 is connected to IN2. (differential)
- The gas flow, F at IN3 with 8-bit resolution and an extended acquisition. (single-ended)
- The pressure, P at IN4 with 8-bit resolution. (single-end-ed)

The DAS will also be used to monitor three alarm conditions.

- Gas flow, F exceeds a maximum limit.
- · Gas flow, F falls below a minimum limit.
- Pressure, P exceeds a maximum limit.

The following assumptions are made about the furnace system:

- All the analog signals to be measured by the DAS are conditioned so that their voltage levels are within the range 0V-2.5V.
- The output of the flow sensor signal conditioning circuit has a  $600\Omega$  source impedance.
- The DAS reference voltage is 2.5V. (V\_{REF}+  $\,=\,$  2.5V and V\_{REF}-  $\,=\,$  AGND)
- The DAS is to achieve a throughput rate of 50 Hz per signal measured.

The DAS will be programmed as follows:

- Seven instructions, INSTR0 through INSTR6 of the Instruction RAM will be used.
- **INSTRO:** Watchdog mode for the gas flow, F, with the acquisition factor D = 1. The timer bit is also set.
- INSTR1: Watchdog mode for the gas pressure P.
- INSTR2: Measure T1 at IN0 with 12-bit resolution.  $V_{IN}+$  = IN0 and  $V_{IN}-$  = AGND.
- INTSR3: Measure T1-T2 with 12-bit + sign resolution. T2 is connected to IN1.  $V_{IN}+$  = IN0 and  $V_{IN}-$  = IN1.
- INSTR4: Measure T1-T3 with 12-bit + sign resolution. T3 is connected to IN2.  $V_{IN}+$  = IN0 and  $V_{IN}-$  = IN2.
- INSTR5: Measure the gas flow, F at IN3 with 8-bit resolution and the acquisition factor D = 1.  $V_{IN}+$  = IN3 and  $V_{IN}-$  = AGND.
- **INSTR6:** Measure the pressure, P at IN4 with 8-bit resolution.  $V_{IN}$  + = IN4 and  $V_{IN}$  = AGND.
- The DAS loops back to INSTR0 after executing INSTR6. Each loop is called an instruction loop.
- Each instruction loop generates five conversion results. The DAS is programmed to interrupt the 68HC11 when the FIFO has five conversions stored in it. This interrupt will occur after execution of INSTR6 in every instruction loop at which time the FIFO will be read by the 68HC11.
- The DAS will not be stopped when the FIFO is read. The FIFO is read during the time delay added between INSTR6 and INSTR0.

Since the flow sensor circuitry has an output impedance of 600 $\Omega,$  it requires additional acquisition time. From the data sheet, the acquisition factor D in 8-bit mode is:

$$\begin{split} D &= 0.36 * R_S * f_{CLK} \\ D &= 0.36 * 0.600 * 5 = 1.08 \\ \textbf{D} &= \textbf{1} \end{split}$$

| 015                                                                                             | Instruction Register Definition for RP = 00 |         |     |       |         |       |                      |    |                   |         |       |           |    |       |     |
|-------------------------------------------------------------------------------------------------|---------------------------------------------|---------|-----|-------|---------|-------|----------------------|----|-------------------|---------|-------|-----------|----|-------|-----|
|                                                                                                 | D14                                         | D13     | D12 | D11   | D10     | D9    | D8                   | D7 | D6                | D5      | D4    | D3        | D2 | D1    | D0  |
|                                                                                                 | Acquisitio                                  | on Time |     | W-dog | 8/12    | Timer | Sync                 |    | V <sub>IN</sub> - |         |       | $V_{IN}+$ |    | Pause | Loo |
|                                                                                                 |                                             |         |     | INST  | R0: Wat |       | lode for<br>= IN3, V |    |                   | mer Ena | abled |           |    |       |     |
| D15                                                                                             | D14                                         | D13     | D12 | D11   | D10     | D9    | D8                   | D7 | D6                | D5      | D4    | D3        | D2 | D1    | DO  |
| 0                                                                                               | 0                                           | 0       | 1   | 1     | 0       | 1     | 0                    | 0  | 0                 | 0       | 0     | 1         | 1  | 0     | 0   |
|                                                                                                 |                                             |         |     |       | INS     |       | atchdog<br>= IN4, V  |    |                   | ure     |       |           |    |       |     |
| D15                                                                                             | D14                                         | D13     | D12 | D11   | D10     | D9    | D8                   | D7 | D6                | D5      | D4    | D3        | D2 | D1    | DO  |
| 0                                                                                               | 0                                           | 0       | 0   | 1     | 0       | 0     | 0                    | 0  | 0                 | 0       | 1     | 0         | 0  | 0     | 0   |
|                                                                                                 |                                             |         |     |       |         |       | uring T1<br>IN0 (T1) |    |                   |         |       |           |    |       |     |
| D15                                                                                             | D14                                         | D13     | D12 | D11   | D10     | D9    | D8                   | D7 | D6                | D5      | D4    | D3        | D2 | D1    | DO  |
| 0                                                                                               | 0                                           | 0       | 0   | 0     | 0       | 0     | 0                    | 0  | 0                 | 0       | 0     | 0         | 0  | 0     | 0   |
|                                                                                                 |                                             |         |     | INS   |         |       | j T1–T2,<br>N0 (T1), |    |                   |         | ign   |           |    |       |     |
| D15                                                                                             | D14                                         | D13     | D12 | D11   | D10     | D9    | D8                   | D7 | D6                | D5      | D4    | D3        | D2 | D1    | DO  |
| 0                                                                                               | 0                                           | 0       | 0   | 0     | 0       | 0     | 0                    | 0  | 0                 | 1       | 0     | 0         | 0  | 0     | 0   |
|                                                                                                 |                                             |         |     | INS   |         |       | T1–T3, S<br>IN0 (T1) |    |                   |         | Sign  |           |    |       |     |
| D15                                                                                             | D14                                         | D13     | D12 | D11   | D10     | D9    | D8                   | D7 | D6                | D5      | D4    | D3        | D2 | D1    | DC  |
| 0                                                                                               | 0                                           | 0       | 0   | 0     | 0       | 0     | 0                    | 0  | 1                 | 0       | 0     | 0         | 0  | 0     | 0   |
| INSTR5: Measuring Flow, Single-Ended, 8-Bit, D = 1 $V_{IN}$ + = IN3, $V_{IN}$ - = AGND          |                                             |         |     |       |         |       |                      |    |                   |         |       |           |    |       |     |
| D15                                                                                             | D14                                         | D13     | D12 | D11   | D10     | D9    | D8                   | D7 | D6                | D5      | D4    | D3        | D2 | D1    | D   |
| 0                                                                                               | 0                                           | 0       | 1   | 0     | 1       | 0     | 0                    | 0  | 0                 | 0       | 0     | 1         | 1  | 0     | 0   |
| INSTR6: Measuring Pressure, Single-Ended, 8-Bit, Loop Bit Set $V_{IN}+$ = IN4, $V_{IN}-$ = AGND |                                             |         |     |       |         |       |                      |    |                   |         |       |           |    |       |     |
| D15                                                                                             | D14                                         | D13     | D12 | D11   | D10     | D9    | D8                   | D7 | D6                | D5      | D4    | D3        | D2 | D1    | DC  |
| 0                                                                                               | 0                                           | 0       | 0   | 0     | 1       | 0     | 0                    | 0  | 0                 | 0       | 1     | 0         | 0  | 0     | 1   |

| D15<br>D15                           |                  |                 | Continue        | d)                          | l                                                        | nstructio                                  | on RAM.                              | Limits                                   | Definitio                               | on                                   |                                                                                          |                |                |                |                |
|--------------------------------------|------------------|-----------------|-----------------|-----------------------------|----------------------------------------------------------|--------------------------------------------|--------------------------------------|------------------------------------------|-----------------------------------------|--------------------------------------|------------------------------------------------------------------------------------------|----------------|----------------|----------------|----------------|
| D15                                  | D14              | D13             | D12             | D11                         | D10                                                      | D9                                         | D8                                   | D7                                       | D6                                      | D5                                   | 5 D4                                                                                     | D3             | D2             | D1             | D0             |
|                                      | 014              |                 | Care            | DII                         | 0.10                                                     | >/<                                        | Sign                                 |                                          |                                         |                                      |                                                                                          | Limit          | 52             |                |                |
|                                      |                  |                 |                 |                             |                                                          |                                            | R0, Limi <sup>,</sup>                | +<br>#1 BI                               | P = 01                                  |                                      |                                                                                          |                |                |                |                |
|                                      | D14              | D13             | D12             | D11                         | D10                                                      | D9                                         | D8                                   | D7                                       | D6                                      | D5                                   | D4                                                                                       | D3             | D2             | D1             | D0             |
| 0                                    | 0                | 0               | 0               | 0                           | 0                                                        | 1                                          | 0                                    |                                          |                                         |                                      | 1                                                                                        | wMax           |                |                |                |
|                                      |                  |                 |                 |                             |                                                          | 1                                          | R0, Limi                             | #2 BI                                    | <b>P</b> = 10                           |                                      |                                                                                          |                |                |                |                |
| D15                                  | D14              | D13             | D12             | D11                         | D10                                                      | D9                                         | D8                                   | D7                                       | D6                                      | D5                                   | D4                                                                                       | D3             | D2             | D1             | D0             |
| 0                                    | 0                | 0               | 0               | 0                           | 0                                                        | 0                                          | 0                                    |                                          |                                         |                                      | Flo                                                                                      | wMin           |                |                |                |
|                                      |                  |                 |                 |                             |                                                          | INSTI                                      | R1, Limi <sup>.</sup>                | t # 1, RI                                | P = 01                                  |                                      |                                                                                          |                |                |                |                |
| D15                                  | D14              | D13             | D12             | D11                         | D10                                                      | D9                                         | D8                                   | D7                                       | D6                                      | D5                                   | D4                                                                                       | D3             | D2             | D1             | D0             |
| 0                                    | 0                | 0               | 0               | 0                           | 0                                                        | 1                                          | 0                                    |                                          |                                         |                                      | Pre                                                                                      | es_Max         |                |                |                |
|                                      |                  |                 |                 |                             |                                                          | INSTI                                      | R1, Limi <sup>.</sup>                | t #2, RI                                 | P = 10                                  |                                      |                                                                                          |                |                |                |                |
| D15                                  | D14              | D13             | D12             | D11                         | D10                                                      | D9                                         | D8                                   | D7                                       | D6                                      | D5                                   | D4                                                                                       | D3             | D2             | D1             | D0             |
| 0                                    | 0                | 0               | 0               | 0                           | 0                                                        | 0                                          | 0                                    |                                          |                                         |                                      | Pre                                                                                      | esMin          |                |                |                |
| Interrupt Enable Register Definition |                  |                 |                 |                             |                                                          |                                            |                                      |                                          |                                         |                                      |                                                                                          |                |                |                |                |
| D15                                  | D14              | D13             | D12             | D11                         | D10                                                      | D9                                         | D8                                   | D7                                       | D6                                      | D5                                   | D4                                                                                       | D3             | D2             | D1             | D0             |
|                                      | Number           | of Results      | in FIFO         |                             | Instruc                                                  | ction Numb                                 | er                                   | INT7                                     | INT6                                    | INT5                                 | INT4                                                                                     | INT3           | INT2           | INT1           | INT0           |
|                                      | -                |                 | Wato            | hdog L                      | imit, FIF                                                | O Full (C                                  | onv =                                | 5), and .                                | Auto-Ze                                 | ro Inte                              | errupts E                                                                                | nabled         |                |                |                |
| D15                                  | D14              | D13             | D12             | D11                         | D10                                                      | D9                                         | D8                                   | D7                                       | D6                                      | D5                                   | D4                                                                                       | D3             | D2             | D1             | D0             |
| 0                                    | 0                | 1               | 0               | 1                           | 0                                                        | 0                                          | 0                                    | 0                                        | 0                                       | 0                                    | 1                                                                                        | 0              | 1              | 0              | 1              |
|                                      |                  |                 |                 |                             | C                                                        | Configur                                   | ation R                              | egister                                  | Definitio                               | on                                   |                                                                                          |                |                |                |                |
| D15                                  | D14 D            | 13 D12          | 2 D11           | D10                         | D9                                                       | D8                                         | D7                                   | D6                                       | D5                                      | ;                                    | D4                                                                                       | D3             | D2             | D1             | D0             |
|                                      |                  |                 |                 | I                           |                                                          |                                            |                                      |                                          |                                         |                                      | Ctondby                                                                                  | Full Cal       | Auto Zero      |                | 0              |
|                                      | Don't Car        | e               | Diag            | Test                        | RAM<br>Pointe                                            |                                            | nc I/O                               | A/Z Each                                 | Chan M                                  | /lask                                | Standby                                                                                  | i uli oui      | 71010 2010     | Reset          | Star           |
|                                      | Don't Car        | e               | Diag            |                             | Pointe                                                   | r                                          |                                      |                                          |                                         |                                      |                                                                                          |                |                | Heset          | Star           |
| D15                                  | Don't Car<br>D14 | D13             | Diag<br>D12     |                             |                                                          | r                                          |                                      |                                          |                                         |                                      | NC Out                                                                                   | D3             | D2             | D1             | D0             |
| <b>D15</b>                           | 1                |                 |                 | Co                          | Pointer<br>nfigurati                                     | on Regi                                    | ster Sta                             | rt Comr                                  | nand wi                                 | th SYI                               | NC Out                                                                                   |                |                |                |                |
|                                      | D14              | D13             | D12             | Co<br>D11                   | Pointer<br>nfigurati<br>D10<br>0                         | on Regi<br>D9<br>0                         | ster Sta<br>D8<br>0                  | rt Comr<br>D7                            | nand wi<br>D6<br>0                      | th SYI                               | NC Out                                                                                   | D3             | D2             | D1             | D0             |
|                                      | D14              | D13             | D12             | Co<br>D11                   | Pointer<br>nfigurati<br>D10<br>0                         | on Regi                                    | ster Sta<br>D8<br>0                  | rt Comr<br>D7                            | nand wi<br>D6<br>0                      | th SYI                               | NC Out<br>D4<br>0                                                                        | D3             | D2             | D1             | D0             |
| 0                                    | <b>D14</b><br>0  | <b>D13</b><br>0 | <b>D12</b><br>0 | <b>Co</b><br>D11<br>0       | Pointer<br>nfigurati<br>D10<br>0<br>Con                  | on Regi<br>D9<br>0                         | ster Sta<br>D8<br>0<br>on Regis      | rt Comr<br>D7<br>1<br>ter Res            | nand wi<br>D6<br>0<br>et Com            | th SYI<br>D5<br>0<br>mand            | NC Out<br>D4<br>0                                                                        | <b>D3</b><br>0 | <b>D2</b><br>0 | <b>D1</b><br>0 | <b>D0</b>      |
| 0<br>D15                             | D14<br>0<br>D14  | D13<br>0<br>D13 | D12<br>0<br>D12 | Con<br>D11<br>0<br>D11<br>0 | Pointer<br>nfigurati<br>D10<br>0<br>Con<br>D10<br>0<br>0 | on Regi<br>D9<br>0<br>figuratic<br>D9<br>0 | ster Sta<br>D8<br>0<br>D8<br>D8<br>0 | rt Comr<br>D7<br>1<br>ter Res<br>D7<br>0 | nand wi<br>D6<br>0<br>et Com<br>D6<br>0 | th SYI<br>D5<br>0<br>mand<br>D5<br>0 | NC Out<br>D4<br>0<br>0<br>0<br>0<br>0<br>0                                               | D3<br>0<br>D3  | D2<br>0<br>D2  | D1<br>0<br>D1  | <b>D0</b><br>1 |
| 0<br>D15                             | D14<br>0<br>D14  | D13<br>0<br>D13 | D12<br>0<br>D12 | Con<br>D11<br>0<br>D11<br>0 | Pointer<br>nfigurati<br>D10<br>0<br>Con<br>D10           | on Regi<br>D9<br>0<br>figuratic<br>D9<br>0 | ster Sta<br>D8<br>0<br>D8<br>D8<br>0 | rt Comr<br>D7<br>1<br>ter Res<br>D7<br>0 | nand wi<br>D6<br>0<br>et Com<br>D6<br>0 | th SYI<br>D5<br>0<br>mand<br>D5<br>0 | NC Out<br>D4<br>0<br>D4<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | D3<br>0<br>D3  | D2<br>0<br>D2  | D1<br>0<br>D1  | <b>D0</b><br>1 |

## 3.3 Determining the Throughput Rate

The following table gives the number of clock cycles each instruction takes to execute. The total number of clock cycles may then be used to determine how long it will take for all the instructions to be executed. This will aid in calculating the throughput rate of the DAS.

| Instruction<br>Number | State 0 | State 1 | State 7 | State 6 | State 4 | State 5 | Clock<br>Cycles |
|-----------------------|---------|---------|---------|---------|---------|---------|-----------------|
| 0                     | 1       | 1       | 9       |         |         | 44      | 55              |
| 1                     | 1       | 1       | 9       |         |         | 44      | 55              |
| 2                     | 1       | 1       | 9       |         |         | 44      | 55              |
| 3                     | 1       | 1       | 6       |         |         | 21      | 29              |
| 4                     | 1       | 1       | 2       |         |         | 21      | 25              |
| 5                     | 1       | 1       | 6       | 5       | 1       | 5       | 19              |
| 6                     | 1       | 1       | 2       | 5       | 1       | 5       | 15              |
|                       |         |         | •       |         | •       | Total   | 253             |

Since the timer will be used, an additional 2 clock cycles need to be added to the total 253.

The total time it takes to execute a full instruction loop with a clock frequency (f\_{CLK}) of 5 MHz is:

 $(253 + 2) * 200 \text{ ns} = 51 \ \mu \text{s}$ 

In addition to the instruction loop execution time, there is some delay time added at the end of the instruction loop for each chip select made to the DAS when reading the five conversions stored in the FIFO. Whenever chip select is asserted, all clock dependent activities of the DAS come to a halt. This delay is the total amount of time that chip select has gone low when reading the FIFO. Each chip select cycle is 500 ns long (refer to the timing diagrams). There are five conversions, two bytes each, that will be read. This gives a total of ten chip selects (one chip select per byte). Ten chip selects at 500 ns per chip select gives a total delay time of 5 us, so the time required to complete an instruction loop and read the conversion results is 51  $\mu$ s + 5  $\mu$ s = 56  $\mu$ s. The desired throughput rate is 50 Hz (a sample per channel every 20 ms). This implies that a delay time between instruction loops must be added. The delay time is equal to:

 $20 \text{ ms} - 56 \mu \text{s} = 19.944 \text{ ms}$ 

This time delay may be inserted between instruction loops by setting the timer bit in INSTR0. The amount of the time delay is related to the value stored in the timer register. The following shows how to calculate the value to put in the timer register to give a delay of 19.944 ms:

The number of 5 MHz clock cycles in 19.944 ms is:

19.944 ms \* 5 MHz = 99720 clock cycles

The timer increments every  $2^5$  (32) clock cycles. Therefore, the value to be placed in the timer register is:  $99720/32 = (3116.25)_{base10}$ 

#### = (0C2C)<sub>base16</sub>

The 0.25 fraction is lost when converting (3116.25)<sub>base10</sub> to hexadecimal. This results in decreasing the delay time by eight 5 MHz clock cycles ( $8*200 \text{ ns} = 1.6 \mu s$ ) to 19.9424 ms. So the actual throughput rate is:

$$9.9424 \text{ ms} + 56 \ \mu \text{s} = 19.9984 \text{ ms}$$
  
 $1 = 50.004 \text{ Hz}$ 

 $\frac{19.9984 \text{ ms}}{19.9984 \text{ ms}} = 50.004 \text{ Hz}$ 

#### **4.0 SYSTEM OVERVIEW**

#### 4.1 How to Communicate with the DAS

In developing the software and circuitry to program the DAS for the furnace example, Motorola's EVM development system for emulating the MC68HC11A8 was used. In this application note it is assumed that the reader is already familiar with the architecture and instruction set of the MC68HC11A8. The reader should also be familiar with the LM12(H)454/8 DAS by having previously read the data sheet. In this design the  $\mu$ C's  $E_{clock}$  is 2 MHz and the DAS clock is running at 5 MHz.

The DAS can be selected to run on an 8-bit or a 16-bit data bus. Since we are using an 8-bit  $\mu C$  the DAS must be configured to operate in 8-bit mode. This is done by hardwiring the "BW" pin to a logic 1. The internal registers of the DAS are all 16 bits long, so in order to read from and write to a 16-bit register while in 8-bit mode, data transfer must take place in two cycles. In fact when in 8-bit mode the internal registers are byte addressable. The 68HC11 architecture and instruction set facilitates this transfer of data in two ways. One way is using standard 8-bit reads and writes via the 8-bit accumulators. For example, a 16-bit write to the configuration register:

| LDAA #DAI | TAl ;DATA | l is | the | least | significant |
|-----------|-----------|------|-----|-------|-------------|
|           | ;byte     | (LSB | 5). |       |             |

| STAA | CONFIG1 | ;CONI | FIG1 = | Address  | of | LSB   | of  |
|------|---------|-------|--------|----------|----|-------|-----|
|      |         | ;the  | confi  | guration | re | giste | er. |

- LDAA #DATA2 ;DATA2 is the most significant ;byte (MSB).
- STAA CONFIG2 ;CONFIG2 = Address of MSB of ;the configuration register.

Notice that it takes 4 instructions to do this.

Another way of achieving the same results with half the number of instructions is to use the 68HC11's 16-bit double accumulator D. This accumulator is an actual cascading of ACCA and ACCB. ACCA is the most significant byte of ACCD and ACCB is the least significant byte.  $B_{15}$  ACCD  $B_{0}$   $B_{0}$ 

ACCA ACCB

When using ACCD the instruction set emulates that of a 16-bit processor. The above example becomes:

LDD #DATA ;DATA is 16 bits.

STD CONFIG ;Address of configuration ;register.

This is not a true single 16-bit transfer of data but a succession of 8-bit ones. When using ACCD the user should notice that data is first transferred from ACCA followed by data from ACCB. This plays an important role in determining the data that is sent to and received from the DAS. To demonstrate this let's look at an example that will write #00FFh to the configuration register located at address 0110h. The lower byte at address 0110h should receive #FFh and the upper byte at address 0111h should receive #00h as shown below:



When using ACCD to write data to the DAS, make sure that the ACCD's upper-byte contains the data's lower-byte and its lower-byte contains the data's high-byte. Using ACCD to read from the FIFO and store data in memory results in having the upper and lower bytes of the converted data swapped. This does not cause any problems if the data from memory is interpreted correctly. However, if the user does not want to store the data in this swapped format, ACCD should not be used to write to memory. After the data has been read from the FIFO with the ACCD, accumulators A and B should be used to write the data to memory, not ACCD. Specifically, the data in ACCB should be written to the lower address in memory and the contents of ACCA to the higher address. Now when ACCD is used to read conversion results that are stored in memory, it will have the upper and lower bytes of the data in a more logical format.

#### 4.2 Hardware Description of the Interface Circuitry

The DAS (U7) is seen by the 68HC11 (U1) (Refer to Figure 4) as an I/O device placed at a certain location in memory. The interface consists of standard address decoding circuitry using U2, U3, and U4 and demultiplexing of the  $R/\overline{W}$ signal line with U5 and U6. U2 is an 8-bit latch that is used to demultiplex the lower address byte from the data byte by using the address strobe signal AS. U4 is an 8-bit comparator that compares the upper address byte to the 8-bit value preset by S1. The value set by S1 determines what upper address byte the DAS is placed at. In this example it is set to 01h. The output of U4 enables U3. U3 is a three bit decoder used to generate the chip select of the DAS. ICs U5 and U6 create the RD and WR signals to the DAS. Refer to Figure 3 for the timing diagrams of a read and write cycle. Jumpers J1 and J2 connect the  $V_{\text{ref}}+$  and  $V_{\text{ref}}-$  of the DAS to an external source or the on-board 5V supply. Header HDR1 connects the analog inputs to the DAS. The filter capacitors used for VA+, VD+, Vref+ Vref-, and Vrefout should be as close to their respective pins as possible. Refer to section 5.0 of the data sheet for power supply and ground considerations.



FIGURE 3. Timing Diagrams Showing the E Clock,  $\overline{CS}$ ,  $\overline{RD}$  and  $\overline{WR}$  Signals

1L/H/12050-

The signals in  $\mathit{Figure}\ 3$  were generated by executing the following program:

| Loop | LDAA | \$0100 | ;Reads  | the | DAS |     |
|------|------|--------|---------|-----|-----|-----|
|      | STAA | \$0100 | ;Writes | to  | the | DAS |
|      | BRA  | Loop   |         |     |     |     |

In order to access all the DAS registers, at least twenty seven consecutive memory locations are needed. In this particular example the DAS is placed at address locations 0100h to 011Fh. This address range allows all the DAS registers to be accessed, which are located at addresses 0100h to 011Bh. (Refer to the data sheet for specific addresses of registers.) By selecting the appropriate settings on the dip switch S1, the user can choose the upper address byte the DAS is placed at.

#### 4.3 Description of the Software

In the first part of the program (Figure 5), the DAS is initialized to meet the specifications needed for the furnace example. After the DAS has been initialized and a full auto-calibration is completed, the DAS is reset and instruction execution is started by writing a logic one in the configuration's start bit. The 68HC11 waits for an interrupt. When an interrupt is generated by the DAS, program execution jumps to the interrupt service subroutine. The actions taken by the interrupt service routine are based on which interrupt bits are set in the Interrupt Status Register. The FIFO\_FUL interrupt is the only interrupt that is fully serviced by this program. It is important to note that the Interrupt Status register should not be polled because every time  $\overline{CS}$  is pulled low all internal clock-dependent activities of the DAS stop, e.g. the A/D converter, sequencer and timer. Conditions that need to be serviced must be done on an interrupt basis

When a FIFO full interrupt occurs, the DAS is programmed to empty the five conversions stored in the FIFO starting at the address pointed to by the conversion pointer CONV\_POINT. The CONV\_POINT holds the address of where data is to begin being stored in memory. In this example, the conversion pointer is initialized to point to address.

dress 00h. After reading the five conversions stored in the FIFO and putting them in memory, program execution resumes at the main program following the WAI instruction. This 68HC11 instruction puts the  $\mu C$  in an idle state and waits for an interrupt to occur, at which time program execution will jump to the interrupt service routine. Index register X counts the number of data bytes read from the FIFO and stored in memory. It is also used as an offset to the CONV\_POINT to give the address of where the data byte read from the FIFO is to be stored. The value in X is compared against the value CONV\_BYTES. When it is greater than CONV\_BYTES, program execution is halted. If it is less than CONV\_BYTES, the 68HC11 jumps back to the WAI instruction and waits for another FIFO full interrupt to occur. In this example CONV\_BYTES is equal to sixty. Since the circuit that was used for this example contains no external memory, the on board microcontroller RAM was used. If external memory is needed the software and board can be easily modified. A memory component can be placed at a certain location in the memory map by using one of the seven available signals from the 74H138 to generate the chip select. The conversion pointer. CONV\_POINT needs to be initialized with the beginning address of where converted data is to be stored in memory and CONV\_BYTES needs to be set to twice the desired number of conversions. For example, if 8192 samples are to be taken and are to begin being stored at address 1000h, CONV\_BYTES should be set to 16384 and CONV\_POINT to 1000h.

The DAS\_LIMIT interrupt subroutine is intended to service watchdog conditions. In this furnace example no provisions have been made to deal with a watchdog interrupt except that of acknowledging its occurrence and returning to the main program. The manner in which a watchdog condition is handled is system-dependent and must be user-defined. The purpose of the FUL\_CAL subroutine is to indicate when the DAS has completed its full auto-calibration cycle. The only action taken in the FUL\_CAL interrupt subroutine is a return to the main program.



| INSTRO<br>INSTRI<br>INSTRI<br>INSTR2<br>EQU<br>INSTR4<br>EQU<br>INSTR5<br>EQU<br>INSTR6<br>EQU<br>INT_EN<br>EQU<br>INT_STAT<br>EQU<br>INT_STAT<br>EQU<br>INT_STAT<br>EQU<br>INT_STAT<br>EQU<br>INT_STAT<br>EQU | 00100<br>00100<br>001000<br>0011100<br>00111100<br>00111100<br>00111100<br>00011100<br>00000<br>00000<br>0000<br>0000<br>0000<br>0000<br>0000<br>0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                | 4000<br>4000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000<br>5000 | defined<br>defined<br>defined<br>defined                                                                                 |
| LIMMER_SEL<br>CONV_POINT EQU<br>*<br>CONV_BYTES EQU<br>*<br>FIFO_CNT EQU<br>*                                                                                                                                  | \$2000<br>\$003C<br>\$1E<br>\$1E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | /User defined. Conversions will begin being stored at<br>;this address.<br>:User defined. This example it is decimal 60. |
| ******************                                                                                                                                                                                             | ************                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | **************************************                                                                                   |
| OF<br>************************************                                                                                                                                                                     | ORG \$E000<br>CLI<br>***********************************                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ORG \$E000<br>CLI<br>***********************************                                                                 |
| *                                                                                                                                                                                                              | LDY #\$0000<br>LDX #\$0000<br>STX CONV_POINT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Memory location used to store contents of the interrupt status register.                                                 |
| ***************************************                                                                                                                                                                        | *** Initialization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | of the DAS ***********************************                                                                           |
| : *                                                                                                                                                                                                            | LDD #\$0100<br>STD CONFIG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Resets the DAS AND SETS THE RAM POINTER TO 00                                                                            |
|                                                                                                                                                                                                                | LDD #\$0C2A<br>STD INSTRO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Instruction 0 is used to set watchdog mode for<br>the gas flow measurement with an acquisition delay time set.           |
|                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | FIGURE 5. 68HC11 Assembly Program Listing                                                                                |
|                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                          |

| ÷                                   | LDD INT_STAT                                  | Reads interrupt status register to clear it.                                                                                                    |         |
|-------------------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| < <b>*</b>                          | LDD #\$0800<br>STD CONFIG                     | Starts a full auto-calibration cycle.<br>An interrupt will be generated when done.                                                              |         |
| * * .                               | WAI                                           | Waits for interrupt to occur. When an interrupt is generated program control resumes at the interrupt service routine.                          |         |
| * * * * * * * * * * * * * * * * * * | STARTS CONVERS                                | STARTS CONVERSION ************************************                                                                                          |         |
| * -                                 | LDD #\$0200<br>STD CONFIG                     | Resets the DAS                                                                                                                                  |         |
| k k                                 | CLI<br>LDD #\$8100<br>STD CONFIG              | Enables 68HC11 interrupt.<br>Starts conversion with sync out.                                                                                   |         |
| . * CONV                            | WAI                                           | Waits for interrupt to occur. When an interrupt is generated program control resumes at the interrupt service routine.                          |         |
| Ķ .                                 | CPX #CONV_BYTES<br>BLT CONV<br>STOP           | S Compares number of conversion bytes (value stored in register X) to decimal number 60. Two bytes per conversion. Program execution is halted. |         |
| **************                      | END OF MAIN PROGRAM                           | 0GRAM ************************************                                                                                                      |         |
| * * * * * * * * * * * * * * * * * * | INTERRUPT SERVI                               | INTERRUPT SERVICE ROUTINE ************************************                                                                                  |         |
| * *<br>IRQ                          | LDAA INT_STAT<br>STAA STAT_HOLD               | Reads the lower byte of the interrupt status register<br>and stores the result at address STAT_HOLD.                                            |         |
| ĸ *                                 | LDAA STAT_HOLD<br>ANDA #\$04<br>BGT FIFO_FUL  | Checks bit 2 to determine if FIFO full was<br>the source of the interrupt. If so, continue at FIFO_FUL subroutine.                              |         |
| * *                                 | LDAA STAT_HOLD<br>ANDA #\$01<br>BGT DAS_LIMIT | Checks bit 0 to determine if watchdog limit was the<br>source of the interrupt. If so, resume program at<br>DAS_LIMIT subroutine.               |         |
|                                     | FIG                                           | FIGURE 5.68HC11 Assembly Program Listing (Continued)                                                                                            | 12050-8 |

| * -                  |                                         | ANDA #\$10 Checks<br>BGT FUL_CAL If so,              | Checks bit 4 to determine if full cal limit caused interrupt.<br>If so, continue program control at Ful_Cal subroutine.                      |           |
|----------------------|-----------------------------------------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| * -                  |                                         | RTI                                                  |                                                                                                                                              |           |
| * * * -              | *******                                 | READ_FIFO<br>STORED IN                               | READ_FIFO SUBROUTINE WILL TAKE CONVERSIONS ************************************                                                              |           |
| *<br>FIFO_FUL        |                                         | LDY #\$0000                                          | Index register Y used as a local counter.                                                                                                    |           |
| *<br>LOOP<br>*       |                                         |                                                      | Loads the contents of the FIFO in ACCD and increments the FIFO pointer.                                                                      |           |
| *                    |                                         | STD CONV_POINT,X<br>INX                              |                                                                                                                                              | es.       |
|                      |                                         | INX<br>XNI<br>XNI                                    | pointer to the next memory location where data is to be stored.                                                                              |           |
|                      |                                         | CPY #\$03<br>BLE LOOP                                | Escape from loop when Y counter exceeds 3.                                                                                                   |           |
| * *                  | UNH************************************ |                                                      | OF READ_FIFO SUBROUTINE ************************************                                                                                 |           |
| * * * *              | **********                              |                                                      | DAS_LIMIT SUBROUTINE IS USER DEFINED AND MUST************************************                                                            |           |
| DAS_LIMIT<br>**<br>* | Ð                                       | The .<br>by p<br>acco                                | The user should check to see whether the interrupt was caused<br>by pressure or gas flow exceeding their limits and then act<br>accordingly. |           |
| *<br>*               | *****                                   | RTI<br>*END OF DAS_LIMIT SUB!                        | RTI<br>***************END OF DAS_LIMIT SUBROUTINE ************************************                                                       |           |
| UL_CAL               | *****                                   | *FULL-CAL ROUTINE****:<br>RTI<br>******************* | **************************************                                                                                                       |           |
| * *                  | *****                                   | Ξ                                                    | ND OF INTERRUPT SERVICE ROUTINE ************************************                                                                         |           |
|                      |                                         | FIGURE                                               | FIGURE 5. 68HC11 Assembly Program Listing (Continued)                                                                                        | H/12050-9 |

## LIFE SUPPORT POLICY

NATIONAL'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS WRITTEN APPROVAL OF THE PRESIDENT OF NATIONAL SEMICONDUCTOR CORPORATION. As used herein:

 Life support devices or systems are devices or systems which, (a) are intended for surgical implant into the body, or (b) support or sustain life, and whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user.  A critical component is any component of a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness.

| 2900 Se<br>P.O. Box<br>Santa C<br>Tel: 1(80 | ation         ation           emiconductor Drive         I           x 58090         I           ilara, CA 95052-8090         0           00) 272-9959         1           10) 339-9240         1 | GmbH<br>Livry-Gargan-Str. 10<br>D-82256 Fürstenfeldbruck<br>Germany<br>Tel: (81-41) 35-0<br>Telex: 527649<br>Fax: (81-41) 35-1 | National Semiconductor<br>Japan Ltd.<br>Sumitomo Chemical<br>Engineering Center<br>Bidg. 7F<br>1-7-1, Nakase, Mihama-Ku<br>Chiba-City,<br>Ciba Prefecture 261<br>Tel: (043) 299-2500<br>Fax: (043) 299-2500 | National Semiconductor<br>Hong Kong Ltd.<br>13th Floor, Straight Block,<br>Ocean Centre, 5 Canton Rd.<br>Tsimshatsui, Kowloon<br>Hong Kong<br>Tel: (852) 2737-1600<br>Fax: (852) 2736-9960 | National Semiconductores           Do Brazil Ltda.           Rue Deputado Lacorda Franco           120:34           Sao Paulo-SP           Brazil 05410-000           Telex: 391-125066           Telex: 391-1131931 NSBR BR           Fax: (55-11) 212-1181 | National Semiconductor<br>(Australia) Pty, Ltd.<br>Building 16<br>Business Park Drive<br>Monash Business Park<br>Nottinghil, Melbourne<br>Victoria 3168 Australia<br>Tel: (3) 558-9999<br>Fax: (3) 558-9998 |
|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

National does not assume any responsibility for use of any circuitry described, no circuit patent licenses are implied and National reserves the right at any time without notice to change said circuitry and specifications.