# Advance Information # 10-Bit A/D Converters with Serial Interface cmos These ratiometric 10-bit ADCs have serial interface ports to provide communication with MCUs and MPUs. *Either a 10- or 16-bit format can be used.* The 16-bit format can be one continuous 16-bit stream or two intermittent 8-bit streams. The converters operate from a single power supply with no external trimming required. Reference voltages down to 2.5 V are accommodated. The MC145050 has the same pin out as the 8-bit MC145040 which allows an external clock (ADCLK) to operate the dynamic A/D conversion sequence. The MC145051 has the same pin out as the 8-bit MC145041 which has an internal clock oscillator and an end-of-conversion (EOC) output. - 11 Analog Input Channels with Internal Sample-and-Hold - Operating Temperature Range: -40° to 125°C - Successive Approximation Conversion Time: MC145050—21 μs (with 2.1 MHz ADCLK) MC145051—88 μs Maximum - Maximum Sample Rate: MC145050-38 ks/s MC145051-10.7 ks/s - Analog Input Range with 5-Volt Supply: 0 to 5 V - Monotonic with No Missing Codes - Direct Interface to Motorola SPI and National MICROWIRE Serial Data Ports **BLOCK DIAGRAM** - Digital Inputs/Outputs are TTL, NMOS, and CMOS Compatible - Low Power Consumption: 14 mW - Chip Complexity: 1630 Elements (FETs, Capacitors, etc.) # MC145050 MC145051 MICROWIRE is a trademark of National Semiconductor Corp. This document contains information on a new product. Specifications and information herein are subject to change without notice. # MC145050 • MC145051 #### **MAXIMUM RATINGS\*** | Symbol | Parameter | Value | Unit | |------------------|-------------------------------------------------|---------------------------------------------------|------| | V <sub>DD</sub> | DC Supply Voltage (Referenced to VSS) | -0.5 to +6.0 | V | | V <sub>ref</sub> | DC Reference Voltage | VAG to VDD+0.1 | V | | $V_{AG}$ | Analog Ground | V <sub>SS</sub> -0.1 to V <sub>ref</sub> | V | | V <sub>in</sub> | DC Input Voltage, Any Analog or Digital Input | V <sub>SS</sub> - 0.5 to<br>V <sub>DD</sub> + 0.5 | V | | V <sub>out</sub> | DC Output Voltage | V <sub>SS</sub> = 0.5 to<br>V <sub>DD</sub> + 0.5 | ٧ | | lin | DC Input Current, per Pin | ± 20 | mA | | lout | DC Output Current, per Pin | ± 25 | mA | | IDD, ISS | DC Supply Current, VDD and VSS Pins | ±50 | mA | | T <sub>stg</sub> | Storage Temperature | -65 to 150 | °C | | TL | Lead Temperature, 1 mm from Case for 10 Seconds | 260 | °C | This device contains protection circuitry to guard against damage due to high static voltages or electric fields. However, precautions must be taken to avoid applications of any voltage higher than maximum rated voltages to this high-impedance circuit. For proper operation, $V_{in}$ and $V_{out}$ should be constrained to the range $V_{SS} \leq (V_{in})$ or $V_{out}$ $\leq V_{DD}$ . Unused inputs must always be tied to an appropriate logic voltage level (e.g., either VSS or VDD). Unused outputs must be left open. # **OPERATION RANGES** (Applicable to Guaranteed Limits) | Symbol | Parameter | Value | Unit | |------------------------------------|---------------------------------------|------------------------------------------------|------| | V <sub>DD</sub> | DC Supply Voltage, Referenced to VSS | 4.5 to 5.5 | V | | V <sub>ref</sub> | DC Reference Voltage (Note 1) | V <sub>AG</sub> + 2.5 to V <sub>DD</sub> + 0.1 | V | | VAG | Analog Ground (Note 1) | Vss - 0.1 to V <sub>ref</sub> - 2.5 | l · | | VAL | Analog Input Voltage (Note 2) | VAG to V <sub>ref</sub> | v | | V <sub>in</sub> , V <sub>out</sub> | Digital Input Voltage, Output Voltage | V <sub>SS</sub> to V <sub>DD</sub> | v | | TA | Ambient Operating Temperature | - 40 to 125 | °C | #### NOTES: - 1. Reference voltages down to 1.0 V (V<sub>ref</sub> V<sub>AG</sub> = 1.0 V) are functional, but the A/D converter electrical characteristics are not guaranteed. - 2. Analog input voltages greater than V<sub>ref</sub> convert to full scale. Input voltages less than V<sub>AG</sub> convert to zero. See V<sub>ref</sub> and V<sub>AG</sub> pin descriptions. # DC ELECTRICAL CHARACTERISTICS (Voltages Referenced to V<sub>SS</sub>, Full Temperature and Voltage Ranges per Operation Ranges table, unless otherwise indicated) | Symbol | Parameter | Test Conditions | Guaranteed<br>Limit | Unit | |------------------|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------|------| | V <sub>IH</sub> | Minimum High-Level Input Voltage<br>(Din, SCLK, CS, ADCLK) | | 2.0 | V | | V <sub>IL</sub> | Maximum Low-Level Input Voltage (Din, SCLK, CS, ADCLK) | | 0.8 | V | | VOH | Minimum High-Level Output Voltage<br>(D <sub>Out</sub> , EOC) | I <sub>out</sub> = -1.6 mA<br>I <sub>out</sub> = -20 μA | 2.4<br>V <sub>DD</sub> = 0.1 | V | | V <sub>OL</sub> | Maximum Low-Level Output Voltage (Dout, EOC) | I <sub>out</sub> = +1.6 mA<br>I <sub>out</sub> = 20 µA | 0.4<br>0.1 | v | | lin<br> | Maximum Input Leakage Current<br>(Din, SCLK, CS, ADCLK) | Vin=VSS or VDD | ± 2.5 | μА | | loz | Maximum Three-State Leakage Current (Dout) | V <sub>out</sub> =V <sub>SS</sub> or V <sub>DD</sub> | ± 10 | μA | | lDD_ | Maximum Power Supply Current | V <sub>in</sub> = V <sub>SS</sub> or V <sub>DD</sub> , All Outputs Open | 2.5 | mA | | l <sub>ref</sub> | Maximum Static Analog Reference Current (Vref) | V <sub>ref</sub> = V <sub>DD</sub> , V <sub>AG</sub> = V <sub>SS</sub> | 100 | μΑ | | <sup>I</sup> AI | Maximum Analog Mux Input Leakage Current<br>between all deselected inputs and any selected<br>input (AN0-AN10) | VAI = VSS to VDD | ±1 | μΑ | <sup>\*</sup>Maximum Ratings are those values beyond which damage to the device may occur. Functional operation should be restricted to the Operation Ranges below. # A/D CONVERTER ELECTRICAL CHARACTERISTICS (Full Temperature and Voltage Ranges per Operation Ranges table; MC145050: 500 kHz ≤ ADCLK ≤ 2.1 MHz unless otherwise noted.) | Characteristic Definition and Test Conditions | | Guaranteed<br>Limit | Unit | |------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-----------------| | Resolution | Number of bits resolved by the A/D converter | 10 | Bits | | Maximum Nonlinearity | Maximum difference between an ideal and an actual ADC transfer function | ±1 | LSB | | Maximum Zero Error | Difference between the maximum input voltage of an ideal and an actual ADC for zero output code | ±1 | LSB | | Maximum Full-Scale Error | Difference between the minimum input voltage of an ideal and an actual ADC for full-scale output code | | | | Maximum Total Unadjusted Error | Maximum sum of nonlinearity, zero error, and full-scale error | ± 1 | LSB | | Maximum Quantization Error | Quantization Error Uncertainty due to converter resolution | | | | Absolute Accuracy | Difference between the actual input voltage and the full-scale weighted equivalent of the binary output code, all error sources included | | LSB | | Maximum Conversion Time | Total time to perform a single analog-to-digital conversion MC145050 | 44 | ADCLK<br>cycles | | ** | MC145051 | 88 | μS | | Data Transfer Time | Total time to transfer digital serial data into and out of the device | | SCLK<br>cycles | | Sample Acquisition Time | Time Analog input acquisition time window | | SCLK<br>cycles | | Minimum Total Cycle Time Total time to transfer serial data, sample the analog input, and perform the conversion | | | μS | | | MC145050: ADCLK = 2.1 MHz, SCLK = 2.1 MHz<br>MC145051: SCLK = 2.1 MHz | 26<br>93 | | | Maximum Sample Rate | Rate at which analog inputs may be sampled MC145050: ADCLK = 2.1 MHz, SCLK = 2.1 MHz MC145051: SCLK = 2.1 MHz | 38<br>10.7 | ks/s | NOTE: This "typical" graph is not to be used for design purposes but is intended as an indication of the IC's potential performance. Graph 1. Typical Nonlinearity vs Supply Voltage # AC ELECTRICAL CHARACTERISTICS (Full Temperature and Voltage Ranges per Operation Ranges table) | Figure | Symbol | Parameter | | Guaranteed<br>Limit | Unit | |----------|---------------------------------|--------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-------------------------------|-----------------| | 1 | f | Clock Frequency, SCLK<br>Note: Refer to t <sub>wH</sub> , t <sub>wL</sub> below | (10-bit xfer) Min<br>(11- to 16-bit xfer) Min<br>(10- to 16-bit xfer) Max | | MHz | | 1 | f | Clock Frequency, ADCLK<br>Note: Refer to t <sub>wH</sub> , t <sub>wL</sub> below | Minimum<br>Maximum | 1 | kHz<br>MHz | | 1 | t <sub>wH</sub> | Minimum Clock High Time | ADCLK<br>SCLK | | ns | | 1 | twL | Minimum Clock Low Time | ADCLK<br>SCLK | 190<br>190 | ns | | 1, 7 | tPLH, tPHL | Maximum Propagation Delay, SCLK to Dout | | 240 | ns | | 1, 7 | th | Minimum Hold Time, SCLK to Dout | | 10 | ns | | 2, 7 | tPLZ, tPHZ | Maximum Propagation Delay, CS to Dout High-Z | | 150 | ns | | 2, 7 | tPZL, tPZH | Maximum Propagation Delay, CS to Dout Driven MC145050 2<br>MC145051 | | 2 ADCLK cycles + 300<br>4.3 | ΠS<br>μS | | 3 | tsu | Minimum Setup Time, Din to SCLK | | 100 | ns | | 3 | th | Minimum Hold Time, SCLK to Din | - | 0 | ns | | 4, 7, 8 | <sup>t</sup> d | Maximum Delay Time, EOC to Dout (MSB) | MC145051 | 100 | ns | | 5 | t <sub>su</sub> | Minimum Setup Time, CS to SCLK | MC145050<br>MC145051 | 2 ADCLK cycles + 425<br>4.425 | ns<br>μs | | - | tCSd | Minimum Time Required Between 10th SCLK Falling Edge (≤0.8 V) and CS to Allow a Conversion | MC145050<br>MC145051 | 44<br>Note 2 | ADCLK<br>cycles | | _ | <sup>†</sup> CAs | Maximum Delay Between 10th SCLK Falling Edge (≤2 V) and CS to Abort a Conversion | MC145050 | 36 | ADCLK<br>cycles | | | | | MC145051 | 9 | μS | | 5 | t <sub>h</sub> | Minimum Hold Time, Last SCLK to CS | | 0 | ns | | 6, 8 | t <sub>PHL</sub> | Maximum Propagation Delay, 10th SCLK to EOC | MC145051 | 4.35 | μS | | 1 | t <sub>r</sub> , t <sub>f</sub> | Maximum Input Rise and Fall Times | SCLK<br>ADCLK<br>D <sub>in</sub> , CS | 1<br>250<br>10 | ms<br>ns<br>μs | | , 4, 6-8 | tTLH, tTHL | Maximum Output Transition Time, Any Output | | 300 | ns | | | C <sub>in</sub> | Maximum Input Capacitance | AN0-AN10<br>ADCLK, SCLK, CS, D <sub>in</sub> | 55<br>15 | pF | | - | Cout | Maximum Three-State Output Capacitance | D <sub>out</sub> | 15 | pF | ## NOTES: <sup>1.</sup> After the 10th SCLK falling edge (≤2 V), at least 1 SCLK rising edge (≥2 V) must occur within 38 ADCLKs (MC145050) or 18.5 µs (MC145051). <sup>2.</sup> On the MC145051, a $\overline{\text{CS}}$ edge may be received immediately after an active transition on the EOC pin. # SWITCHING WAVEFORMS Figure 1 Figure 3 Figure 5 Figure 7. Test Circuit Figure 2 NOTE: $D_{\mbox{\scriptsize out}}$ is driven only when $\overline{\mbox{\scriptsize CS}}$ is active (low). Figure 4 Figure 6 Figure 8. Test Circuit #### PIN DESCRIPTIONS #### **DIGITAL INPUTS AND OUTPUTS** The various serial bit-stream formats for the MC145050/51 are illustrated in the timing diagrams of Figures 9 through 14. Table 1 assists selection of the appropriate diagram. Note that the ADCs accept 16 clocks which makes them SPI (serial peripheral interface) compatible. **Table 1. Timing Diagram Selection** | No. of Clocks in<br>Serial Transfer | Using<br>CS | Serial Transfer<br>Interval | Figure<br>No. | | |-------------------------------------|-------------|-----------------------------|---------------|--| | 10 | Yes | Don't Care | 9 | | | 10 | No | Don't Care | 10 | | | 11 to 16 | Yes | Shorter than Conversion | 11 | | | 16 | No | Shorter than Conversion | 12 | | | 11 to 16 | Yes | Longer than Conversion | 13 | | | 16 | No | Longer than Conversion | 14 | | #### **CS** (Pin 15) Active-Low Chip Select Input. Chip select initializes the chip to perform conversions and provides 3-state control of the data output pin $(D_{\text{Out}})$ . While inactive high, $\overline{\text{CS}}$ forces $D_{\text{Out}}$ to the high-impedance state and disables the data input $(D_{\underline{\text{in}}})$ and serial clock (SCLK) pins. A high-to-low transition on $\overline{\text{CS}}$ resets the serial data port and synchronizes it to the MPU data stream. $\overline{\text{CS}}$ can remain active during the conversion cycle and can stay in the active low state for multiple serial transfers or $\overline{\text{CS}}$ can be inactive high after each transfer. If $\overline{\text{CS}}$ is kept active low between transfers, the length of each transfer is limited to either 10 or 16 SCLK cycles. If $\overline{\text{CS}}$ is in the inactive high state between transfers, each transfer can be anywhere from 10 to 16 SCLK cycles long. See the SCLK pin description for a more detailed discussion of these requirements. Spurious chip selects caused by system noise are minimized by the internal circuitry. Any transitions on the $\overline{\text{CS}}$ pin are recognized as valid only if the level is maintained for a setup time plus two falling edges of ADCLK after the transition. ## NOTE If CS is inactive high after the 10th SCLK cycle and then goes active low before the A/D conversion is complete, the conversion is aborted and the chip enters the initial state, ready for another serial transfer/conversion sequence. At this point, the output data register contains the result from the conversion before the aborted conversion. Note that the last step of the A/D conversion sequence is to update the output data register with the result. Therefore, if CS goes active low in an attempt to abort the conversion too close to the end of the conversion sequence, the result register may be corrupted and the chip could be thrown out of sync with the processor until CS is toggled again (refer to the AC Electrical Characteristics in the spec tables). #### Dout (Pin 16) Serial Data Output of the A/D Conversion Result. This output is in the high-impedance state when $\overline{\text{CS}}$ is inactive high. When the chip recognizes a valid active low on $\overline{\text{CS}}$ , $D_{\text{Out}}$ is taken out of the high-impedance state and is driven with the MSB of the previous conversion result. (For the first transfer after power-up, data on $D_{\text{Out}}$ is undefined for the entire transfer.) The value on $D_{\text{out}}$ changes to the second most significant result bit upon the first falling edge of SCLK. The remaining result bits are shifted out in order, with the LSB appearing on $D_{\text{Out}}$ upon the ninth falling edge of SCLK. Note that the order of the transfer is MSB to LSB. Upon the 10th falling edge of SCLK, $D_{\text{Out}}$ is immediately driven low (if allowed by $\overline{\text{CS}}$ ) so that transfers of more than 10 SCLKs read zeroes as the unused LSBs. When CS is held active low between transfers, D<sub>Out</sub> is driven from a low level to the MSB of the conversion result for three cases: Case 1—upon the 16th SCLK falling edge if the transfer is longer than the conversion time (Figure 14); Case 2—upon completion of a conversion for a 16-bit transfer interval shorter than the conversion (Figure 12); Case 3—upon completion of a conversion for a 10-bit transfer (Figure 10). #### Din (Pin 17) Serial Data Input. The four-bit serial input stream begins with the MSB of the analog mux address (or the user test mode) that is to be converted next. The address is shifted in on the first four rising edges of SCLK. After the four mux address bits have been received, the data on $D_{\rm in}$ is ignored for the remainder of the present serial transfer. See Table 2 in **Applications Information**. ## SCLK (Pin 18) Serial Data Clock. This clock input drives the internal I/O state machine to perform three major functions: (1) drives the data shift registers to simultaneously shift in the next mux address from the D<sub>in</sub> pin and shift out the previous conversion result on the D<sub>out</sub> pin, (2) begins sampling the analog voltage onto the RC DAC as soon as the new mux address is available, and (3) transfers control to the A/D conversion state machine (driven by ADCLK) after the last bit of the previous conversion result has been shifted out on the D<sub>out</sub> pin. The serial data shift registers are completely static, allowing SCLK rates down to do in a continuous or intermittent mode. There are some cases, however, that require a minimum SCLK frequency as discussed later in this section. SCLK need not be synchronous to ADCLK. At least ten SCLK cycles are required for each simultaneous data transfer. After the serial port has been initiated to perform a serial transfer\*, the new <sup>\*</sup>The serial port can be initiated in three ways: (1) a recognized $\overline{\text{CS}}$ falling edge, (2) the end of an A/D conversion if the port is performing either a 10-bit or a 16-bit "shorter-than-conversion" transfer with $\overline{\text{CS}}$ active low between transfers, and (3) the 16th falling edge of SCLK if the port is performing 16-bit "longer-than-conversion" transfers with $\overline{\text{CS}}$ active low between transfers. mux address is shifted in on the first four rising edges of SCLK, and the previous 10-bit conversion result is shifted out on the first nine falling edges of SCLK. After the fourth rising edge of SCLK, the new mux address is available; therefore, on the next edge of SCLK (the fourth falling edge), the analog input voltage on the selected mux input begins charging the RC DAC and continues to do so until the tenth falling edge of SCLK. After this tenth SCLK edge, the analog input voltage is disabled from the RC DAC and the RC DAC begins the "hold" portion of the A/D conversion sequence. Also upon this tenth SCLK edge, control of the internal circuitry is transferred to ADCLK which drives the successive approximation logic to complete the conversion. If 16 SCLK cycles are used during each transfer, then there is a constraint on the minimum SCLK frequency. Specifically, there must be at least one rising edge on SCLK before the A/D conversion is complete. If the SCLK frequency is too low and a rising edge does not occur during the conversion, the chip is thrown out of sync with the processor and CS needs to be toggled in order to restore proper operation. If 10 SCLKs are used per transfer, then there is no lower frequency limit on SCLK. Also note that if the ADC is operated such that CS is inactive high between transfers, then the number of SCLK cycles per transfer can be anything between 10 and 16 cycles, but the "rising edge" constraint is still in effect if more than 10 SCLKs are used. (If CS stays active low for multiple transfers, the number of SCLK cycles must be either 10 or 16.) # ADCLK (Pin 19, MC145050 Only) This pin clocks the dynamic A/D conversion sequence, and may be asynchronous to SCLK. Control of the chip passes to ADCLK after the tenth falling edge of SCLK. Control of the chip is passed back to SCLK after the successive approximation conversion sequence is complete (44 ADCLK cycles), or after a valid chip select is recognized. ADCLK also drives the CS recognition logic. The chip ignores transitions on CS unless the state remains for a setup time plus two falling edges of ADCLK. The source driving ADCLK must be free running. # EOC (Pin 19, MC145051 Only) End-of-Conversion Output. EOC goes low on the tenth falling edge of SCLK. A low-to-high transition on EOC occurs when the A/D conversion is complete and the data is ready for transfer. ## **ANALOG INPUTS AND TEST MODE** #### AN0 through AN10 (Pins 1-9, 11, 12) Analog Multiplexer Inputs. The input AN0 is addressed by loading \$0 into the mux address register. AN1 is addressed by \$1, AN2 by \$2, ..., AN10 by \$A. Table 2 shows the input format for a 16-bit stream. The mux features a break-before-make switching structure to minimize noise injection into the analog inputs. The source resistance driving these inputs must be $\leq 10 \text{ k}\Omega$ . There are three tests available that verify the functionality of all the control logic as well as the successive approximation comparator. These tests are performed by addressing \$B, \$C, or \$D and they convert a voltage of $(V_{ref} + V_{AG})/2, V_{AG},$ or $V_{ref},$ respectively. The voltages are obtained internally by sampling $V_{ref}$ or $V_{AG}$ onto the appropriate elements of the RC DAC during the sample phase. Addressing \$B, \$C, or \$D produces an output of \$200 (half scale), \$000, or \$3FF (full scale), respectively, if the converter is functioning properly. However, deviation from these values occurs in the presence of sufficient system noise (external to the chip) on $V_{DD}, \, V_{SS}, \, V_{ref}, \,$ or $V_{AG}$ . #### **POWER AND REFERENCE PINS** #### VSS and VDD (Pins 10 and 20) Device Supply Pins. VSS is normally connected to digital ground; VDD is connected to a positive digital supply voltage. Low frequency (VDD – VSS) variations over the range of 4.5 to 5.5 volts do not affect the A/D accuracy. (See the Operations Ranges table for restrictions on Vref and VAG relative to VDD and VSS.) Excessive inductance in the VDD or VSS lines, as on automatic test equipment, may cause A/D offsets $>\pm$ 1 LSB. Use of a 0.1 $\mu\text{F}$ bypass capacitor across these pins is recommended. #### VAG and Vref (Pins 13 and 14) Analog reference voltage pins which determine the lower and upper boundary of the A/D conversion. Analog input voltages $\geq$ $V_{ref}$ produce a full scale output and input voltages $\leq$ VAG produce an output of zero. CAUTION: The analog input voltage must be $\geq$ VSS and $\leq$ VDD. The A/D conversion result is ratiometric to $V_{ref}$ – VAG. $V_{ref}$ and VAG must be as noise-free as possible to avoid degradation of the A/D conversion. Ideally, $V_{ref}$ and VAG should be single-point connected to the voltage supply driving the system's transducers. Use of a 0.2 $\mu$ F bypass capacitor across these pins is strongly urged. Figure 9. Timing for 10-Clock Transfer Using CS\* Figure 10. Timing for 10-Clock Transfer Not Using CS\* NOTES: D9, D8, D7, ..., D0 = the result of the previous A/D conversion. A3, A2, A1, A0 = the mux address for the next A/D conversion. \* This figure illustrates the behavior of the MC145051. The MC145050 behaves identically except there is no EOC signal and the conversion time is 44 ADCLK cycles (user-controlled time). Figure 11. Timing for 11- to 16-Clock Transfer Using $\overline{ ext{CS}}^*$ (Serial Transfer Interval Shorter Than Conversion) Figure 12. Timing for 16-Clock Transfer Not Using CS\* (Serial Transfer Interval Shorter Than Conversion) NOTES: D9, D8, D7, ..., D0 = the result of the previous A/D conversion. A3, A2, A1, A0 = the mux address for the next A/D conversion. \*This figure illustrates the behavior of the MC145051. The MC145050 behaves identically except there is no EOC signal and the conversion time is 44 ADCLK cycles (user-controlled time). Figure 13. Timing for 11- to 16-Clock Transfer Using CS\* (Serial Transfer Interval Longer Than Conversion) Figure 14. Timing for 16-Clock Transfer Not Using CS\* (Serial Transfer Interval Longer Than Conversion) NOTES: D9, D7, . . . , D0 = the result of the previous A/D conversion. A3, A2, A1, A0 = the mux address for the next A/D conversion. \*NOTES: 1. This figure illustrates the behavior of the MC145050. The MC145050 behaves identically except there is no EOC signal and the converison time is 44 ADCLK cycles (user-controlled time). 2. The 11th SCLK rising edge must occur before the conversion is complete. Otherwise the serial port is thrown out of sync with the microprocessor for the remainder of the transfer. # **APPLICATIONS INFORMATION** #### DESCRIPTION This example application of the MC145050/MC145051 ADCs interfaces three controllers to a microprocessor and processes data in real-time for a video game. The standard joystick X-axis (left/right) and Y-axis (up/down) controls as well as engine thrust controls are accommodated. Figure 15 illustrates how the MC145050/MC145051 is used as a cost-effective means to simplify this type of circuit design. Utilizing one ADC, three controllers are interfaced to a CMOS or NMOS microprocessor with a serial peripheral interface (SPI) port. Processors with National Semiconductor's MICROWIRE serial port may also be used. Full duplex operation optimizes throughput for this system. #### **DIGITAL DESIGN CONSIDERATIONS** Motorola's MC68HC05C4 CMOS MCU may be chosen to reduce power supply size and cost. The NMOS MCUs may be used if power consumption is not critical. A VDD to VSS $0.1\,\mu\text{F}$ bypass capacitor should be closely mounted to the ADC. Both the MC145050 and MC145051 accommodate all the analog system inputs. The MC145050, when used with a 2 MHz MCU, takes 27 µs to sample the analog input, perform the conversion, and transfer the serial data at 2 MHz. Forty-four ADCLK cycles (2 MHz at input pin 19) must be provided and counted by the MCU before reading the ADC results. The MC145051 has the end-of-conversion (EOC) signal (at output pin 19) to define when data is ready, but has a slower 93 µs cycle time. However, the 93 µs is constant for serial data rates of 2 MHz independent of the MCU clock frequency. Therefore, the MC145051 may be used with the CMOS MCU operating at reduced clock rates to minimize power consumption without severely sacrificing ADC cycle times, with EOC being used to generate an interrupt. (The MC145051 may also be used with MCUs which do not provide a system clock.) #### **ANALOG DESIGN CONSIDERATIONS** Controllers with output impedances of less than 10 kilohms may be directly interfaced to these ADCs, eliminating the need for buffer amplifiers. Separate lines connect the V<sub>ref</sub> and V<sub>AG</sub> pins on the ADC with the controllers to provide isolation from system noise. Although not indicated in Figure 15, the V<sub>ref</sub> and controller output lines may need to be shielded, depending on their length and electrical environment. This should be verified during prototyping with an oscilloscope. If shielding is required, a twisted pair or foil-shielded wire (not coax) is appropriate for this low frequency application. One wire of the pair or the shield must be VAG. A reference circuit voltage of 5 volts is used for this application. The reference circuitry may be as simple as tying VAG to system ground and V<sub>ref</sub> to the system's positive supply. (See Figure 16.) However, the system power supply noise may require that a separate supply be used for the voltage reference. This supply must provide source current for V<sub>ref</sub> as well as current for the controller potentiometers. A bypass capacitor of approximately 0.22 $\mu$ F across the V<sub>ref</sub> and V<sub>AG</sub> pins is recommended. These pins are adjacent on the ADC package which facilitates mounting the capacitor very close to the ADC. #### SOFTWARE CONSIDERATIONS The software flow for acquisition is straightforward. The nine analog inputs, AN0 through AN8, are scanned by reading the analog value of the previously addressed channel into the MCU and sending the address of the next channel to be read to the ADC, simultaneously. If the design is realized using the MC145050, 44 ADCLK cycles (at pin 19) must be counted by the MCU to allow time for A/D conversion. The designer utilizing the MC145051 has the end-of-conversion signal (at pin 19) to define the conversion interval. EOC may be used to generate an interrupt, which is serviced by reading the serial data from the ADC. The software flow should then process and format the data, and transfer the information to the video circuitry for updating the display. When these ADCs are used with a 16-bit (2-byte) transfer, there are two types of offsets involved. In the first type of offset, the channel information sent to the ADCs is offset by 12 bits. That is, in the 16-bit stream, only the first 4 bits (4 MSBs) contain the channel information. The balance of the bits are don't cares. This results in 3 don't-care nibbles, as shown in Table 2. The second type of offset is in the conversion result returned from the ADCs; this is offset by 6 bits. In the 16-bit stream, the first 10 bits (10 MSBs) contain the conversion results. The last 6 bits are zeroes. The hexadecimal result is shown in the first column of Table 3. The second column shows the result after the offset is removed by a microprocessor routine. Table 2. Programmer's Guide for 16-Bit Transfers: | Input Address Channel To Be | | | | | | |-----------------------------|----------------|----------------------------------|--|--|--| | Input Address<br>in Hex | Converted Next | Comment | | | | | \$0XXX | AN0 | Pin 1 | | | | | \$1XXX | AN1 | Pin 2 | | | | | \$2XXX | AN2 | Pin 3 | | | | | \$3XXX | AN3 | Pin 4 | | | | | \$4XXX | AN4 | Pin 5 | | | | | \$5XXX | AN5 | Pin 6 | | | | | \$6XXX | AN6 | Pin 7 | | | | | \$7XXX | AN7 | Pin 8 | | | | | \$8XXX | AN8 | Pin 9 | | | | | \$9XXX | AN9 | Pin 11 | | | | | \$AXXX | AN10 | Pin 12 | | | | | \$BXXX | AN11 | Half Scale Test: Output = \$8000 | | | | | \$CXXX | AN12 | Zero Test: Output = \$0000 | | | | | \$DXXX | AN13 | Full Scale Test: Output = \$FFC0 | | | | | \$EXXX | None | Not Allowed | | | | | \$FXXX | None | Not Allowed | | | | Table 3. Programmer's Guide for 16-Bit Transfers: Output Code | Conversion Result<br>Without Offset<br>Removed | Conversion Result<br>With Offset<br>Removed | Value | |------------------------------------------------|---------------------------------------------|------------------| | \$0000 | \$0000 | Zero | | \$0040 | \$0001 | Zero + 1 LSB | | \$0080 | \$0002 | Zero + 2 LSBs | | \$00C0 | \$0003 | Zero + 3 LSBs | | \$0100 | \$0004 | Zero + 4 LSBs | | \$0140 | \$0005 | Zero + 5 LSBs | | \$0180 | \$0006 | Zero + 6 LSBs | | \$01C0 | \$0007 | Zero + 7 LSBs | | \$0200 | \$0008 | Zero + 8 LSBs | | \$0240 | \$0009 | Zero + 9 LSBs | | \$0280 | \$000A | Zero + 10 LSBs | | \$02C0 | \$000B | Zero + 11 LSBs | | • | • | • | | • | • | • | | • | • | • | | \$FF40 | \$03FD | Full Scale-2 LSB | | \$FF80 | \$03FE | Full Scale-1 LSB | | \$FFC0 | \$03FF | Full Scale | Figure 16. Alternate Configuration Using the Digital Supply for the Reference Voltage ## Compatible Motorola MCUs/MPUs This is not a complete listing of Motorola's MCUs/MPUs. Contact your Motorola representative if you need additional information. | Instruction | Memory (Bytes) | | SPI ① | Device | | |-------------|----------------|--------|-------|-------------|--| | Set | ROM | EEPROM | SCI ② | Number | | | M6805 | 2096 | _ | _ | MC68HC05C2 | | | | 2096 | _ | Yes | MC68HC05C3 | | | | 4160 | _ | Yes | MC68HC05C4 | | | | 4160_3 | l – | Yes | MC68HSC05C | | | | 8K ③ | _ | Yes | MC68HSC05C | | | | 4160 ④ | _ | Yes | MC68HCL05C | | | | 8K 🛈 | _ | Yes | MC68HCL05C | | | | 7700 | _ | Yes | MC68HC05C8 | | | | - | 4160 | - | MC68HC805C4 | | | M68000 | T _ | | - | MC68HC000 | | - 1 SPI = Serial Peripheral Interface. - 2 SCI = Serial Communications Interface. - (3) High speed. - (4) Low power.