SLAS176B - DECEMBER 1997 - REVISED JULY 2002

- Four 10-Bit D/A Converters
- Programmable Settling Time of 3 μs or 9 μs Typ
- TMS320, (Q)SPI<sup>™</sup>, and Microwire<sup>™</sup> Compatible Serial Interface
- Internal Power-On Reset
- Low Power Consumption: 5.5 mW, Slow Mode – 5-V Supply 3.3 mW, Slow Mode – 3-V Supply
- Reference Input Buffers
- Voltage Output Range ... 2× the Reference Input Voltage
- Monotonic Over Temperature
- Dual 2.7-V to 5.5-V Supply (Separate Digital and Analog Supplies)

#### description

The TLV5604 is a quadruple 10-bit voltage output digital-to-analog converter (DAC) with a flexible 4-wire serial interface. The 4-wire serial interface allows glueless interface to TMS320, SPI, QSPI, and Microwire serial ports. The TLV5604 is programmed with a 16-bit serial word comprised of a DAC address, individual DAC control bits, and a 10-bit DAC value.

- Hardware Power Down (10 nA)
- Software Power Down (10 nA)
- Simultaneous Update

#### applications

- Battery Powered Test Instruments
- Digital Offset and Gain Adjustment
- Industrial Process Controls
- Machine and Motion Control Devices
- Communications
- Arbitrary Waveform Generation



The device has provision for two supplies: one digital supply for the serial interface (via pins  $DV_{DD}$  and DGND), and one for the DACs, reference buffers and output buffers (via pins  $AV_{DD}$  and AGND). Each supply is independent of the other, and can be any value between 2.7 V and 5.5 V. The dual supplies allow a typical application where the DAC will be controlled via a microprocessor operating on a 3-V supply (also used on pins  $DV_{DD}$  and DGND), with the DACs operating on a 5-V supply. Of course, the digital and analog supplies can be tied together.

The resistor string output voltage is buffered by a x2 gain rail-to-rail output buffer. The buffer features a Class AB output stage to improve stability and reduce settling time. A rail-to-rail output stage and a power-down mode makes it ideal for single voltage, battery based applications. The settling time of the DAC is programmable to allow the designer to optimize speed versus power dissipation. The settling time is chosen by the control bits within the 16-bit serial input string. A high-impedance buffer is integrated on the REFINAB and REFINCD terminals to reduce the need for a low source impedance drive to the terminal. REFINAB and REFINCD allow DACs A and B to have a different reference voltage then DACs C and D.

The device, implemented with a CMOS process, is available in 16-terminal SOIC and TSSOP packages. The TLV5604C is characterized for operation from 0°C to 70°C. The TLV5604I is characterized for operation from  $-40^{\circ}$ C to 85°C.



Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.

SPI and QSPI are trademarks of Motorola, Inc. Microwire is a trademark of National Semiconductor Corporation.

PRODUCTION DATA information is current as of publication date. Products conform to specifications per the terms of Texas Instruments standard warranty. Production processing does not necessarily include testing of all parameters.



Copyright © 2002, Texas Instruments Incorporated

## TLV5604 2.7-V TO 5.5-V 10-BIT 3- $\mu$ S QUADRUPLE DIGITAL-TO-ANALOG CONVERTERS WITH POWER DOWN

SLAS176B - DECEMBER 1997 - REVISED JULY 2002

| AVAILABLE OPTIONS                 |             |               |  |  |  |  |  |  |  |
|-----------------------------------|-------------|---------------|--|--|--|--|--|--|--|
|                                   | PACKAGE     |               |  |  |  |  |  |  |  |
| TA                                | SOIC<br>(D) | TSSOP<br>(PW) |  |  |  |  |  |  |  |
| 0°C to 70°C                       | TLV5604CD   | TLV5604CPW    |  |  |  |  |  |  |  |
| $-40^{\circ}$ C to $85^{\circ}$ C | TLV5604ID   | TLV5604IPW    |  |  |  |  |  |  |  |

#### functional block diagram





TLV5604 2.7-V TO 5.5-V 10-BIT 3-µS QUADRUPLE DIGITAL-TO-ANALOG CONVERTERS WITH POWER DOWN

SLAS176B - DECEMBER 1997 - REVISED JULY 2002

#### **Terminal Functions**

| TERMIN           | MINAL |     |                                                                                                                                                                                       |
|------------------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME             | NO.   | 1/0 | DESCRIPTION                                                                                                                                                                           |
| AGND             | 9     |     | Analog ground                                                                                                                                                                         |
| AV <sub>DD</sub> | 16    |     | Analog supply                                                                                                                                                                         |
| CS               | 6     | I   | Chip select. This terminal is active low.                                                                                                                                             |
| DGND             | 8     |     | Digital ground                                                                                                                                                                        |
| DIN              | 4     | Ι   | Serial data input                                                                                                                                                                     |
| DVDD             | 1     |     | Digital supply                                                                                                                                                                        |
| FS               | 7     | I   | Frame sync input. The falling edge of the frame sync pulse indicates the start of a serial data frame shifted out to the TLV5604.                                                     |
| PD               | 2     | I   | Power-down pin. Powers down all DACs (overriding their individual power down settings), and all output stages.<br>This terminal is active low.                                        |
| LDAC             | 3     | I   | Load DAC. When the LDAC signal is high, no DAC output updates occur when the input digital data is read into the serial interface. The DAC outputs are only updated when LDAC is low. |
| REFINAB          | 15    | I   | Voltage reference input for DACs A and B.                                                                                                                                             |
| REFINCD          | 10    | I   | Voltage reference input for DACs C and D.                                                                                                                                             |
| SCLK             | 5     | I   | Serial Clock input                                                                                                                                                                    |
| OUTA             | 14    | 0   | DAC A output                                                                                                                                                                          |
| OUTB             | 13    | 0   | DAC B output                                                                                                                                                                          |
| OUTC             | 12    | 0   | DAC C output                                                                                                                                                                          |
| OUTD             | 11    | 0   | DAC D output                                                                                                                                                                          |

#### absolute maximum ratings over operating free-air temperature range (unless otherwise noted)<sup>†</sup>

| Supply voltage, (DV <sub>DD</sub> , AV <sub>DD</sub> to GND)       |                                    |
|--------------------------------------------------------------------|------------------------------------|
| Supply voltage difference, (AV <sub>DD</sub> to DV <sub>DD</sub> ) |                                    |
| Digital input voltage range                                        |                                    |
| Reference input voltage range                                      | –0.3 V to AV <sub>DD</sub> + 0.3 V |
| Operating free-air temperature range, T <sub>A</sub> : TLV5604C    | 0°C to 70°C                        |
| TLV5604I                                                           | –40°C to 85°C                      |
| Storage temperature range, T <sub>stg</sub>                        | −65°C to 150°C                     |
| Lead temperature 1,6 mm (1/16 inch) from case for 10 seconds       |                                    |

<sup>†</sup> Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.



## TLV5604 2.7-V TO 5.5-V 10-BIT 3-μS QUADRUPLE DIGITAL-TO-ANALOG CONVERTERS WITH POWER DOWN

SLAS176B - DECEMBER 1997 - REVISED JULY 2002

#### recommended operating conditions

|                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                            | MIN                   | NOM   | MAX                   | UNIT |
|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------|-----------------------|------|
| $\Omega_{\rm M}$                                                 | 5-V supply                                                                                                                                                                                                                                                                                                                                                                                                                 | 4.5                   | 5     | 5.5                   | v    |
| Supply voltage, AV <sub>DD</sub> , DV <sub>DD</sub>              | 3-V supply                                                                                                                                                                                                                                                                                                                                                                                                                 | 2.7                   | 3     | 3.3                   | v    |
|                                                                  | DV <sub>DD</sub> = 2.7 V                                                                                                                                                                                                                                                                                                                                                                                                   | 2                     |       |                       | v    |
| High-level digital liput voltage, vIH                            | DV <sub>DD</sub> = 5.5 V                                                                                                                                                                                                                                                                                                                                                                                                   | 2.4                   |       |                       | Ň    |
|                                                                  | DV <sub>DD</sub> = 2.7 V                                                                                                                                                                                                                                                                                                                                                                                                   |                       |       | 0.6                   | v    |
| Low-level digital input voltage, VIL                             | DV <sub>DD</sub> = 5.5 V                                                                                                                                                                                                                                                                                                                                                                                                   |                       |       | 1                     | v    |
|                                                                  | 5-V supply (see Note 1)                                                                                                                                                                                                                                                                                                                                                                                                    | 0                     | 2.048 | AV <sub>DD</sub> -1.5 | v    |
| Reference voltage, v <sub>ref</sub> to REFINAB, REFINED terminal | AV DD, DV DD       3-V supply       2.7       3       3.3         1 input voltage, V <sub>IH</sub> $DV_{DD} = 2.7 V$ 2       2         input voltage, V <sub>IL</sub> $DV_{DD} = 5.5 V$ 2.4       2         ge, V <sub>ref</sub> to REFINAB, REFINCD terminal $DV_{DD} = 5.5 V$ 2       4         RL $5-V$ supply (see Note 1)       0 $2.048$ $AV_{DD}$ e, CL $2$ $10$ $1.024$ $AV_{DD}$ in temperature $TLV5604C$ 0 $70$ | AV <sub>DD</sub> -1.5 | v     |                       |      |
| Load resistance, RL                                              |                                                                                                                                                                                                                                                                                                                                                                                                                            | 2                     | 10    |                       | kΩ   |
| Load capacitance, CL                                             |                                                                                                                                                                                                                                                                                                                                                                                                                            |                       |       | 100                   | pF   |
| Serial clock rate, SCLK                                          |                                                                                                                                                                                                                                                                                                                                                                                                                            |                       |       | 20                    | MHz  |
| Operating free air temperature                                   | TLV5604C                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                     |       | 70                    | °C   |
| Operating free-air temperature                                   | TLV5604I                                                                                                                                                                                                                                                                                                                                                                                                                   | -40                   |       | 85                    |      |

NOTE 1: Voltages greater than AV<sub>DD</sub>/2 will cause output saturation for large DAC codes.

#### electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

#### static DAC specifications

|                 | PARAMETER                           |                 | TEST CONDITIONS   | MIN | TYP  | MAX  | UNIT              |  |
|-----------------|-------------------------------------|-----------------|-------------------|-----|------|------|-------------------|--|
|                 | Resolution                          |                 |                   | 10  |      |      | bits              |  |
|                 | Integral nonlinearity (INL), end p  | pint adjusted   | See Note 2        |     |      | ±1   | LSB               |  |
|                 | Differential nonlinearity (DNL)     |                 | See Note 3        |     | ±0.1 | ±1   | LSB               |  |
| E <sub>ZS</sub> | Zero scale error (offset error at z | ero scale)      | See Note 4        |     |      | ±12  | mV                |  |
|                 | Zero scale error temperature coe    | efficient       | See Note 5        |     | 10   |      | ppm/°C            |  |
| EG              | Gain error                          |                 | See Note 6        |     |      | ±0.6 | %of FS<br>voltage |  |
|                 | Gain error temperature coefficier   | nt              | See Note 7        |     | 10   |      | ppm/°C            |  |
| PSRR            |                                     | Zero scale gain | See Notes 8 and 9 |     | -80  |      | dB                |  |
| FORR            | Power supply rejection ratio        | Gain            |                   |     | -80  |      | uВ                |  |

NOTES: 2. The relative accuracy or integral nonlinearity (INL) sometimes referred to as linearity error, is the maximum deviation of the output from the line between zero and full scale excluding the effects of zero code and full-scale errors.

3. The differential nonlinearity (DNL) sometimes referred to as differential error, is the difference between the measured and ideal 1 LSB amplitude change of any two adjacent codes. Monotonic means the output voltage changes in the same direction (or remains constant) as a change in the digital input code.

4. Zero-scale error is the deviation from zero voltage output when the digital input code is zero.

5. Zero-scale-error temperature coefficient is given by:  $E_{ZS} TC = [E_{ZS} (T_{max}) - E_{ZS} (T_{min})]/V_{ref} \times 10^6/(T_{max} - T_{min})$ . 6. Gain error is the deviation from the ideal output ( $2V_{ref} - 1 LSB$ ) with an output load of 10 k $\Omega$  excluding the effects of the zero-error.

7. Gain temperature coefficient is given by:  $E_G TC = [E_G(T_{max}) - E_G (T_{min})]/V_{ref} \times 10^6/(T_{max} - T_{min})$ .

8. Zero-scale-error rejection ratio (EZS-RR) is measured by varying the AVDD from 5 ±0.5 V and 3 ±0.3 V dc, and measuring the proportion of this signal imposed on the zero-code output voltage.

Gain-error rejection ratio (EG-RR) is measured by varying the AVDD from 5 ±0.5 V and 3 ±0.3 V dc and measuring the proportion 9. of this signal imposed on the full-scale output voltage after subtracting the zero scale change.



# electrical characteristics over recommended operating free-air temperature range (unless otherwise noted) (continued)

#### individual DAC output specifications

|    | PARAMETER                       | TEST CONDITIONS                | MIN | TYP | MAX                   | UNIT               |
|----|---------------------------------|--------------------------------|-----|-----|-----------------------|--------------------|
| Vo | Voltage output                  | RL = 10 kΩ                     | 0   |     | AV <sub>DD</sub> -0.4 | V                  |
|    | Output load regulation accuracy | R <sub>L</sub> = 2 kΩ vs 10 kΩ |     | 0.1 | 0.25                  | % of FS<br>voltage |

#### reference input (REFINAB, REFINCD)

|    | PARAMETER                 | TEST CONDITIONS                                                  | MIN  | TYP | MAX | UNIT                  |     |
|----|---------------------------|------------------------------------------------------------------|------|-----|-----|-----------------------|-----|
| VI | Input voltage range       | See Note 10                                                      |      | 0   |     | AV <sub>DD</sub> -1.5 | V   |
| RI | Input resistance          |                                                                  |      |     | 10  |                       | MΩ  |
| Cl | Input capacitance         |                                                                  |      |     | 5   |                       | pF  |
|    | Reference feed through    | REFIN = 1 V <sub>pp</sub> at 1 kHz + 1.024 V dc<br>(see Note 11) |      |     | -75 |                       | dB  |
|    | Reference input bandwidth | PEEIN = 0.2  V = 1.024  V  do                                    | Slow |     | 0.5 |                       | MHz |
|    | Reference input bandwidth | REFIN = $0.2 V_{pp} + 1.024 V dc$                                | Fast |     | 1   |                       |     |

NOTES: 10. Reference input voltages greater than VDD/2 will cause output saturation for large DAC codes.

11. Reference feedthrough is measured at the DAC output with an input code = 000 hex and a V<sub>ref</sub>(REFINAB or REFINCD) input = 1.024 Vdc + 1 V<sub>pp</sub> at 1 kHz.

#### digital inputs (D0–D11, CS, WEB, LDAC, PD)

|                 | PARAMETER                        | TEST CONDITIONS | MIN | TYP | MAX | UNIT |
|-----------------|----------------------------------|-----------------|-----|-----|-----|------|
| Iн              | High-level digital input current | $V_I = DV_{DD}$ |     |     | ±1  | μΑ   |
| Ι <sub>ΙL</sub> | Low-level digital input current  | $V_{I} = 0 V$   |     |     | ±1  | μA   |
| Cl              | Input capacitance                |                 |     | 3   |     | pF   |

#### power supply

|     | PARAMETER                                   | TEST CONDITIONS                    | MIN  | TYP | MAX | UNIT |     |
|-----|---------------------------------------------|------------------------------------|------|-----|-----|------|-----|
|     |                                             | 5-V supply, No load, Clock running | Slow |     | 1.4 | 2.2  | mA  |
|     | Power supply surrent                        | 5-V supply, No load, Clock furning | Fast |     | 3.5 | 5.5  | ША  |
| IDD | Power supply current                        | 2 Maurahy, Na land, Clask supping  |      |     | 1   | 1.5  | ~^^ |
|     |                                             | 3-V supply, No load, Clock running | Fast |     | 3   | 4.5  | mA  |
|     | Power down supply current,<br>See Figure 12 |                                    |      |     | 10  |      | nA  |



## electrical characteristics over recommended operating free-air temperature range (unless otherwise noted) (continued)

#### analog output dynamic performance

|                   | PARAMETER                          | TEST CONDITIONS                                                    | TEST CONDITIONS |  |     |    |        |
|-------------------|------------------------------------|--------------------------------------------------------------------|-----------------|--|-----|----|--------|
| SR                |                                    | $C_{L} = 100 \text{ pF}, R_{L} = 10 \text{ k}\Omega,$              | Fast            |  | 5   |    | V/µs   |
| эк                | Output slew rate                   | V <sub>O</sub> = 10% to 90%,<br>V <sub>ref</sub> = 2.048 V, 1024 V | Slow            |  | 1   |    | V/µs   |
|                   | Output pottling time               | To $\pm 0.5$ LSB, C <sub>L</sub> = 100 pF,                         | Fast            |  | 2.5 | 4  |        |
| t <sub>S</sub>    | Output settling time               | $R_L = 10 \text{ k}\Omega$ , See Notes 12 and 14                   | Slow            |  | 8.5 | 18 | μs     |
| t= (=)            | Output settling time, code to code | To $\pm 0.5$ LSB, C <sub>L</sub> = 100 pF,                         | Fast            |  | 1   |    |        |
| <sup>t</sup> s(c) |                                    | $R_{L} = 10 \text{ k}\Omega$ , See Note 13                         | Slow            |  | 2   |    | μs     |
|                   | Glitch energy                      | Code transition from 7FF to 800                                    |                 |  | 10  |    | nV-sec |
| SNR               | Signal-to-noise ratio              | Sinewave generated by DAC,                                         |                 |  | 68  |    |        |
| S/(N+D)           | Signal to noise + distortion       | Reference voltage = $1.024$ at 3 V and 2 $f_s = 400$ KSPS,         | .048 at 5 V,    |  | 65  |    |        |
| THD               | Total harmonic Distortion          | f <sub>OUT</sub> = 1.1 kHz sinewave,                               |                 |  | -68 |    | dB     |
| SFDR              | Spurious free dynamic range        | $C_L = 100 \text{ pF},$ $R_L = 10 \text{ k}\Omega,$<br>BW = 20 kHz |                 |  | 70  |    |        |

NOTES: 12. Settling time is the time for the output signal to remain within ± 0.5LSB of the final measured value for a digital input code change of 020 hex to 3FF hex or 3FF hex to 020 hex.

13. Settling time is the time for the output signal to remain within ± 0.5LSB of the final measured value for a digital input code change of one count, 1FF hex to 200 hex.

14. Limits are ensured by design and characterization, but are not production tested.



# electrical characteristics over recommended operating free-air temperature range (unless otherwise noted) (continued)

#### digital input timing requirements

|                         |                                                                                                                                                                                                                                                        | MIN | NOM | MAX | UNIT |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-----|------|
| <sup>t</sup> su(CS–FS)  | Setup time, $\overline{\text{CS}}$ low before FS $\downarrow$                                                                                                                                                                                          | 10  |     |     | ns   |
| <sup>t</sup> su(FS–CK)  | Setup time, FS low before first negative SCLK edge                                                                                                                                                                                                     | 8   |     |     | ns   |
| <sup>t</sup> su(C16–FS) | Setup time, sixteenth negative SCLK edge after FS low on which bit D0 is sampled before rising edge of FS                                                                                                                                              | 10  |     |     | ns   |
| <sup>t</sup> su(C16–CS) | Setup time. The first positive SCLK edge after D0 is sampled before $\overline{CS}$ rising edge. If FS is used instead of the SCLK positive edge to update the DAC, then the setup time is between the FS rising edge and $\overline{CS}$ rising edge. | 10  |     |     | ns   |
| <sup>t</sup> wH         | Pulse duration, SCLK high                                                                                                                                                                                                                              | 25  |     |     | ns   |
| <sup>t</sup> wL         | Pulse duration, SCLK low                                                                                                                                                                                                                               | 25  |     |     | ns   |
| <sup>t</sup> su(D)      | Setup time, data ready before SCLK falling edge                                                                                                                                                                                                        | 8   |     |     | ns   |
| <sup>t</sup> h(D)       | Hold time, data held valid after SCLK falling edge                                                                                                                                                                                                     | 5   |     |     | ns   |
| <sup>t</sup> wH(FS)     | Pulse duration, FS high                                                                                                                                                                                                                                | 20  |     |     | ns   |







### **TLV5604** 2.7-V TO 5.5-V 10-BIT 3-μS QUADRUPLE DIGITAL-TO-ANALOG CONVERTERS WITH POWER DOWN

SLAS176B - DECEMBER 1997 - REVISED JULY 2002

#### **TYPICAL CHARACTERISTICS**





TLV5604 2.7-V TO 5.5-V 10-BIT 3-µS QUADRUPLE DIGITAL-TO-ANALOG CONVERTERS WITH POWER DOWN

SLAS176B - DECEMBER 1997 - REVISED JULY 2002

#### **TYPICAL CHARACTERISTICS**





#### **TYPICAL CHARACTERISTICS**





SLAS176B - DECEMBER 1997 - REVISED JULY 2002





Figure 14



#### general function

The TLV5604 is a 10-bit single supply DAC based on a resistor string architecture. The device consists of a serial interface, speed and power-down control logic, a reference input buffer, a resistor string, and a rail-to-rail output buffer.

The output voltage (full scale determined by external reference) is given by:

2 REF 
$$\frac{\text{CODE}}{2^n}$$
 [V]

Where REF is the reference voltage and CODE is the digital input value within the range of  $0_{10}$  to  $2^{n}-1$ , where n=10 (bits). The 16-bit data word, consisting of control bits and the new DAC value, is illustrated in the *data format* section. A power-on reset initially resets the internal latches to a defined state (all bits zero).

#### serial interface

Explanation of data transfer: First, the device has to be enabled with  $\overline{CS}$  set to low. Then, a falling edge of FS starts shifting the data bit-per-bit (starting with the MSB) to the internal register on the falling edges of SCLK. After 16 bits have been transferred or FS rises, the content of the shift register is moved to the DAC latch, which updates the voltage output to the new level.

The serial interface of the TLV5604 can be used in two basic modes:

- Four wire (with chip select)
- Three wire (without chip select)

Using chip select (four wire mode), it is possible to have more than one device connected to the serial port of the data source (DSP or microcontroller). The interface is compatible with the TMS320 family. Figure 15 shows an example with two TLV5604s connected directly to a TMS320 DSP.



Figure 15. TMS320 Interface



#### serial interface (continued)

If there is no need to have more than one device on the serial bus, then  $\overline{CS}$  can be tied low. Figure 16 shows an example of how to connect the TLV5604 to a TMS320, SPI, or Microwire port using only three pins.



Figure 16. Three-Wire Interface

Notes on SPI and Microwire: Before the controller starts the data transfer, the software has to generate a falling edge on the I/O pin connected to FS. If the word width is 8 bits (SPI and Microwire), two write operations must be performed to program the TLV5604. After the write operation(s), the DAC output is updated automatically on the next positive clock edge following the sixteenth falling clock edge.

#### serial clock frequency and update rate

The maximum serial clock frequency is given by:

$$f_{SCLKmax} = \frac{1}{t_{wH(min)} + t_{wL(min)}} = 20 \text{ MHz}$$

The maximum update rate is:

$$f_{UPDATEmax} = \frac{1}{16 \left( t_{wH(min)} + t_{wL(min)} \right)} = 1.25 \text{ MHz}$$

Note that the maximum update rate is a theoretical value for the serial interface since the settling time of the TLV5604 has to be considered also.

#### data format

The 16-bit data word for the TLV5604 consists of two parts:

- Control bits (D15...D12)
- New DAC value (D11 . . . D0)

| D15 | D14 | D13 | D12 | D11 | D10                     | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|-----|-----|-----|-----|-----|-------------------------|----|----|----|----|----|----|----|----|----|----|
| A1  | A0  | PWR | SPD |     | New DAC value (10 bits) |    |    |    |    |    |    | Х  | Х  |    |    |

X: don't care

SPD: Speed control bit.  $1 \rightarrow$  fast mode PWR: Power control bit.  $1 \rightarrow$  power down

 $0 \rightarrow$  slow mode  $0 \rightarrow$  normal operation



In power down mode, all amplifiers within the TLV5604 are disabled. A particular DAC (A, B, C, D) of the TLV5604 is selected by A1 and A0 within the input word.

| A1 | A0 | DAC |
|----|----|-----|
| 0  | 0  | A   |
| 0  | 1  | В   |
| 1  | 0  | С   |
| 1  | 1  | D   |

#### TLV5604 interfaced to TMS320C203 DSP

#### Hardware interfacing

Figure 17 shows an example of how to connect the TLV5604 to a TMS320C203 DSP. The serial port is configured in burst mode, with FSX generated by the TMS320C203 to provide the Frame Sync (FS) input to the TLV5604. Data is transmitted on the DX line, with the serial clock input on the CLKX line. The general-purpose input/output port bits IO0 and IO1 are used to generate the Chip Select ( $\overline{CS}$ ) and DAC Latch Update ( $\overline{LDAC}$ ) inputs to the TLV5604. The active low Power Down ( $\overline{PD}$ ) is pulled high all the time to ensure the DACs are enabled.



Figure 17. TLV5604 Interfaced with TMS320C203

#### Software

The application example generates a differential in-phase (sine) signal between the VOUTA and VOUTB pins, and it is quadrature (cosine) signal as the differential signal between VOUTC and VOUTD.

The on-chip timer is used to generate interrupts at a fixed frequency. The related interrupt service routine pulses LDAC low to update all 4 DACs simultaneously, then fetches and writes the next sample to all 4 DACs. The samples are stored in a look-up table, which describes two full periods of a sine wave.

The synchronous serial port of the DSP is used in burst mode. In this mode, the processor generates an FS pulse preceding the MSB of every data word. If multiple, contiguous words are transmitted, a violation of the tsu(C16-FS) timing requirement will occur. To avoid this, the program waits until the transmission of the previous word has been completed.



2.7-V TO 5.5-V 10-BIT 3-µS QUADRUPLE DIGITAL-TO-ANALOG CONVERTERS WITH POWER DOWN

SLAS176B - DECEMBER 1997 - REVISED JULY 2002

TLV5604

#### **APPLICATION INFORMATION**

-------; Processor: TMS320C203 runnning at 40 MHz; ; Description: ; This program generates a differential in-phase (sine) on (OUTA-OUTB) and it's ; quadrature (cosine) as a differential signal on (OUTC-OUTD). ; The DAC codes for the signal samples are stored as a table of 64 12-bit values, ; describing 2 periods of a sine function. A rolling pointer is used to address the ; table location in the first period of this waveform, from which the DAC A samples are ; read. The samples for the other 3 DACs are read at an offset to this rolling pointer: ; DAC Function Offset from rolling pointer; ; А sine 0 16 В inverse sine : С cosine 8 ; inverse cosine 24 ; D ; The on-chip timer is used to generate interrupts at a fixed rate. The interrupt ; service routine first pulses LDAC low to update all DACs simultaneously with the ; values which were written to them in the previous interrupt. Then all  $ilde{4}$  DAC values are ; fetched and written out through the synchronous serial interface. Finally, the ; rolling pointer is incremented to address the next sample, ready for the next ; interrupt. ; © 1998, Texas Instruments Incorporated -----: ; -----I/O and memory mapped regs -----I/O and memory mapped regs ------I/O .include "regs.asm" ; -----jump vectors-----\_\_\_\_\_ 0h .ps b start b int1 b int23 b timer\_isr ------ variables -----temp .equ 0060h .equ .equ .equ 0061 r\_ptr iosr\_stat 0062h DACa\_ptr 0063h .equ DACb\_ptr 0064h DACc\_ptr 0065h .equ DACd\_ptr 0066h .equ ;----- constants ------; DAC control bits to be OR'ed onto data ; all fast mode DACa\_control .equ 01000h .equ DACb\_control 05000h 09000h .equ DACc\_control .equ 0d000h DACd\_control ;----- tables -----.ds 02000h sinevals .word 00800h 0097Ch .word 00AE9h .word .word 00C3Ah .word 00D61h 00E53h .word .word 00F07h 00F76h .word 00F9Ch .word .word 00F76h 00F07h .word 00E53h .word 00D61h .word 00C3Ah .word



|             | .word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word | 00AE9h<br>0097Ch<br>00800h<br>00517h<br>003C6h<br>0029Fh<br>001ADh<br>000F9h<br>0008Ah<br>00064h<br>0008Ah<br>000F9h<br>001ADh<br>0029Fh<br>003C6h<br>00517h<br>00684h<br>00261h<br>00F07h<br>00F76h<br>00F76h<br>00F76h<br>00F76h<br>00F76h<br>00F76h<br>00F76h<br>00F76h<br>00F76h<br>00F76h<br>00F77h<br>00F76h<br>00F77h<br>00F76h<br>00F77h<br>00F76h<br>00F77h<br>00F77h<br>00F76h<br>00F77h<br>00F76h<br>00F77h<br>00F76h<br>00F77h<br>00F77h<br>00F77h<br>00F76h<br>00F77h<br>00F92Ch<br>00F77h<br>00F92h<br>00517h<br>00800h<br>00517h<br>00800h<br>00684h<br>00059h<br>003C6h<br>0029Fh<br>001ADh<br>000F9h<br>0008Ah<br>000F9h<br>0008Ah |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| ;           | .word<br>.word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 00517h<br>00684h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| ; Main<br>; | Program                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |

.ps 1000h .entry

#### start ;---

; disable interrupts

;-----setc INTM ; disable maskable interrupts
splk #0ffffh, IFR ; clear all interrupts
splk #0004h, IMR ; timer interrupts unmasked



\_\_\_\_\_

\_\_\_\_\_

TLV5604 2.7-V TO 5.5-V 10-BIT 3-µS QUADRUPLE DIGITAL-TO-ANALOG CONVERTERS WITH POWER DOWN

SLAS176B - DECEMBER 1997 - REVISED JULY 2002

#### **APPLICATION INFORMATION**

; \_ \_ \_ \_\_\_\_\_ set up the timer timer period set by values in PRD and TDDR ; period = (CLKOUT1 period) × (1+PRD) × (1+TDDR) examples for TMS320C203 with 40 MHz main clock PRD ; Timer rate TDDR 80 kHz 9 24 (18h) 50 kHz 9 39 (27h) \_\_\_\_\_ 0018h prd\_val.equ tcr\_val.equ 0029h splk #0000h, temp ; clear timer out temp, TIM #prd\_val, temp ; set PRD splk out temp, PRD #tcr\_val, temp ; set TDDR, and TRB=1 for auto-reload splk temp, TCR out ;-----\_\_\_\_\_ ; Configure IO0/1 as outputs to be : ; IOO CS - and set high ; IO1 LDAC - and set high in temp, ASPCR ; configure as output temp lacl or #0003h sacl temp temp, ASPCR out in temp, IOSR ; set them high temp lacl #0003h or sacl temp temp, IOSR out ;----\_\_\_\_\_ ; set up serial port for ; SSPCR.TXM=1 Transmit mode - generate FSX ; SSPCR.MCM=1 Clock mode - internal clock source ; SSPCR.FSM=1 Burst mode ;-----\_\_\_\_\_ splk #0000Eh, temp temp, SSPCR ; reset transmitter out splk #0002Eh, temp temp, SSPCR out ;-----------\_\_\_\_\_ ; reset the rolling pointer ;----lacl #000h saclr\_ptr ;\_\_\_\_\_\_ ; enable interrupts ;-----clrc INTM ; enable maskable interrupts ;\_\_\_\_\_\_ ; loop forever! ;----next idle ;wait for interrupt b next ;------; all else fails stop here ; \_ \_ \_ \_ \_ \_\_\_\_\_ \_\_\_\_\_ done b done ; hang there



TLV5604 2.7-V TO 5.5-V 10-BIT 3- $\mu\text{S}$  QUADRUPLE DIGITAL-TO-ANALOG CONVERTERS WITH POWER DOWN

SLAS176B - DECEMBER 1997 - REVISED JULY 2002

**APPLICATION INFORMATION** 

```
;------
                           _____
; Interrupt Service Routines
; ___
   _____
                                  _____
int1 ret ; do nothing and return
int23 ret ; do nothing and return
timer_isr:
           iosr_stat, IOSR ; store IOSR value into variable space
     in
     lacl iosr_stat ; load acc with iosr status
           #0FFFDh
     and
                       ; reset IO1 - LDAC low
     sacl
          temp
          temp, IOSR ;
     out
     or
          #0002h
                      ; set IO1 - LDAC high
     sacl temp
                       ;
          temp, IOSR
     out
                      ;
                      ; reset IOO - CS low
           #0FFFEh
     and
     sacl temp
                      ;
     out
          temp, IOSR
                        ;
     laclr_ptr; load rolling pointer to accumulatoradd#sinevals; add pointer to table startsaclDACa_ptr; to get a pointer for next DAC a sample
     add #08h
                        ; add 8 to get to DAC C pointer
     sacl DACc_ptr
     add #08h
                        ; add 8 to get to DAC B pointer
     sacl DACb_ptr
     add
          #08h
                        ; add 8 to get to DAC D pointer
         DACd_ptr
     sacl
           *,ar0
     mar
                        ; set ar0 as current AR
     ; DAC A
             ar0, DACa_ptr; ar0 points to DAC a sample
     lar
             * ; get DAC a sample into accumulator
     lacl
             #DACa_control; OR in DAC A control bits
     or
             temp
     sacl
                        ;
            temp, SDTR ; send data
     out
; We must wait for transmission to complete before writing next word to the SDTR.
; TLV5604 interface does not allow the use of burst mode with the full packet rate, as
; we need a CLKX -ve edge to clock in last bit before FS goes high again, to allow SPI
; compatibility.
#016h ; wait long enough for this configuration
     rpt
                        ; of MCLK/CLKOUT1 rate
     nop
     ; DAC B
     lar
             ar0, DACb_ptr; ar0 points to DAC a sample
             * ; get DAC a sample into accumulator
     lacl
     or
             #DACb_control; OR in DAC B control bits
     sacl
             temp
                        ;
             temp, SDTR ; send data
     out
             #016h ; wait long enough for this configuration
     rpt
                        ; of MCLK/CLKOUT1 rate
     nop
```



| ; DAC C       |               |    |                                         |
|---------------|---------------|----|-----------------------------------------|
| lar           | ar0, DACc_ptr | ;  | ar0 points to DAC a sample              |
| lacl          | *             | ;  | get DAC a sample into accumulator       |
| or            | #DACc_control | ;  | OR in DAC C control bits                |
| sacl          | temp          | ;  |                                         |
| out           | temp, SDTR    | ;  | send data                               |
| rpt           | #016h         | ;  | wait long enough for this configuration |
| nop           |               | ;  | of MCLK/CLKOUT1 rate                    |
| ; DAC D       |               |    |                                         |
| lar           | ar0, DACd_ptr | ;  | ar0 points to DAC a sample              |
| lacl          | * ;           | qe | et DAC a sample into accumulator        |
| or            | #DACd_control | ;  | OR in DAC D control bits                |
| sacl          | temp          | ;  |                                         |
| out           | temp, SDTR    | ;  | send data                               |
| lacl          | r_ptr         | ;  | load rolling pointer to accumulator     |
| add           | #1h           | ;  | increment rolling pointer               |
| and           | #001Fh        | ;  | count 0-31 then wrap back round         |
| sacl          | r_ptr         | ;  | store rolling pointer                   |
| rpt           | #016h         | ;  | wait long enough for this configuration |
| nop           |               | ;  | of MCLK/CLKOUT1 rate                    |
| ; now take CS | 5 high again  |    |                                         |
| lacl          | iosr_stat     | ;  | load acc with iosr status               |
| or            | #0001h        | ;  | set IOO - CS high                       |
| sacl          | temp          | ;  |                                         |
| out           | temp, IOSR    | ;  |                                         |
| clrc          | intm          | ;  | re-enable interrupts                    |
| ret           |               | ;  | return from interrupt                   |
| nd            |               |    |                                         |

.end



#### TLV5604 interfaced to MCS®51 microcontroller

#### hardware interfacing

Figure 18 shows an example of how to connect the TLV5604 to an MCS<sup>®</sup>51 Microcontroller. The serial DAC input data and external control signals are sent via I/O Port 3 of the controller. The serial data is sent on the RxD line, with the serial clock output on the TxD line. Port 3 bits 3, 4, and 5 are configured as outputs to provide the DAC latch update (LDAC), chip select ( $\overline{CS}$ ) and frame sync (FS) signals for the TLV5604. The active low power down pin ( $\overline{PD}$ ) of the TLV5604 is pulled high to ensure that the DACs are enabled.



Figure 18. TLV5604 Interfaced with MCS<sup>®</sup>51

#### software

The example is the same as for the TMS320C203 in this datasheet, but adapted for a MCS®51 controller. It generates a differential in-phase (sine) signal between the VOUTA and VOUTB pins, and it's quadrature (cosine) signal as the differential signal between VOUTC and VOUTD.

The on-chip timer is used to generate interrupts at a fixed frequency. The related interrupt service routine pulses  $\overline{\text{LDAC}}$  low to update all 4 DACs simultaneously, then fetches and writes the next sample to all 4 DACs. The samples are stored as a look-up table, which describes one full period of a sine wave.

The serial port of the controller is used in Mode 0, which transmits 8 bits of data on RxD, accompanied by a synchronous clock on TxD. Two writes concatenated together are required to write a complete word to the TLV5604. The  $\overline{CS}$  and FS signals are provided in the required fashion through control of IO port 3, which has bit addressable outputs.

MCS is a registered trademark of Intel Corporation.



TLV5604 2.7-V TO 5.5-V 10-BIT 3-µS QUADRUPLE DIGITAL-TO-ANALOG CONVERTERS

SLAS176B – DECEMBER 1997 – REVISED JULY 2002

#### **APPLICATION INFORMATION**

; Processor: 80C51 ; Description: ; This program generates a differential in-phase (sine) on (OUTA-OUTB) and it's quadrature (cosine) as a differential signal on (OUTC-OUTD). © 1998, Texas Instruments Incorporated ; NAME GENIO SEGMENT CODE MAIN SEGMENT CODE ISR SINTBL SEGMENT CODE DATA VAR1 SEGMENT SEGMENT IDATA STACK ;\_\_\_\_\_\_ ; Code start at address 0, jump to start :-----\_\_\_\_\_ CSEG AT 0 LJMP start ; Execution starts at address 0 on power-up. ;\_\_\_\_\_\_ ; Code in the timer0 interrupt vector CSEG AT OBH LJMP timer0isr ; Jump vector for timer 0 interrupt is 000Bh :------; Global variables need space allocated ;\_\_\_\_\_\_ RSEG VAR1 DS 1 Temp\_ptr: rolling\_ptr: \_\_\_\_\_ ; Interrupt service routine for timer 0 interrupts ;------RSEG ISR timer0isr: PUSH PSW PUSH ACC CLR TNT1 ; pulse LDAC low ; to latch all 4 previous values at the same time SETB TNT1 ; 1st thing done in timer isr => fixed period CLR т0 ; set CS low ; The signal to be output on each DAC is a sine function. ; One cycle of a sine wave is held in a table @ sinevals as 32 samples of msb, lsb pairs (64 bytes). We have one pointer which rolls round this table, ; ; rolling\_ptr, incrementing by 2 bytes (1 sample) on each interrupt (at the end of ; this routine). ; The DAC samples are read at an offset to this rolling pointer: ; DAC Function Offset from rolling\_ptr Α sine 0 ; ; В inverse sine 32 С cosine 16 ; 48 inverse cosine ; D ; set DPTR to the start of the sine table ; R7 holds the pointer into the sine table MOV DPTR, #sinevals ; set DPTR to the start of the table of sine signal values R7,rolling\_ptr MOV MOV A,R7 ; get DAC A msb MOVC A,@A+DPTR ; msb of DAC A is in the ACC ; transmit it - set FS low т1 CLR MOV SBUF,A ; send it out the serial port ; increment the pointer in R7 ; to get the next byte from the table INC R7 MOV A,R7 ; which is the lsb of this sample, now in ACC MOVC A,@A+DPTR



TLV5604 2.7-V TO 5.5-V 10-BIT 3-μS QUADRUPLE DIGITAL-TO-ANALOG CONVERTERS WITH POWER DOWN SLAS176B - DECEMBER 1997 - REVISED JULY 2002

**APPLICATION INFORMATION** 

| A_MSB_TX:<br>JNB<br>CLR<br>MOV | TI,A_MSB_TX<br>TI                           | ; wait for transmit to complete<br>; clear for new transmit<br>; and send out the lsb of DAC A                                                                                                            |
|--------------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ; DAC                          | nis gives a co<br>A,R7                      | d be taken from 16 bytes (8 samples) further on in the sine table<br>sine function<br>; pointer in R7<br>; add 15 - already done one INC<br>; wrap back round to 0 if > 64<br>; pointer back in R7        |
| MOVC<br>ORL                    | A,@A+DPTR<br>A,#01H                         | ; get DAC C msb from the table<br>; set control bits to DAC C address                                                                                                                                     |
| A_LSB_TX:                      |                                             |                                                                                                                                                                                                           |
| JNB<br>SETB<br>CLR             |                                             | ; wait for DAC A lsb transmit to complete<br>; toggle FS                                                                                                                                                  |
| CLR<br>MOV                     | TI<br>SBUF,A                                | ; clear for new transmit<br>; and send out the msb of DAC C                                                                                                                                               |
| INC<br>MOV<br>MOVC             | A,R7                                        | ; increment the pointer in R7<br>; to get the next byte from the table<br>; which is the lsb of this sample, now in ACC                                                                                   |
| C_MSB_TX:                      |                                             |                                                                                                                                                                                                           |
| JNB                            |                                             | ; wait for transmit to complete                                                                                                                                                                           |
| CLR                            |                                             | ; clear for new transmit                                                                                                                                                                                  |
| MOV                            | SBUF,A                                      | ; and send out the lsb of DAC C                                                                                                                                                                           |
| ; DAC                          | the sine table<br>A,R7<br>A,#0FH<br>A,#03FH | d be taken from 16 bytes (8 samples) further on<br>- this gives an inverted sine function<br>; pointer in R7<br>; add 15 - already done one INC<br>; wrap back round to 0 if > 64<br>; pointer back in R7 |
| MOVC                           |                                             | ; get DAC B msb from the table                                                                                                                                                                            |
| ORL                            | д #02н                                      | ; set control bits to DAC B address                                                                                                                                                                       |
| OILE                           | 117    0 211                                | , see concror sreb to she s address                                                                                                                                                                       |
| C_LSB_TX:                      |                                             |                                                                                                                                                                                                           |
| JNB                            | TI,C_LSB_TX                                 | ; wait for DAC C lsb transmit to complete                                                                                                                                                                 |
| SETB                           | T1                                          | ; toggle FS                                                                                                                                                                                               |
| CLR                            | <br>T1                                      |                                                                                                                                                                                                           |
| CLR                            | TI                                          | ; clear for new transmit                                                                                                                                                                                  |
| MOV                            | SBUF,A                                      | ; and send out the msb of DAC B<br>; get DAC B LSB                                                                                                                                                        |
| INC                            | R7                                          | ; increment the pointer in R7                                                                                                                                                                             |
| MOV                            | A,R7                                        | ; to get the next byte from the table                                                                                                                                                                     |
| MOVC                           | A,@A+DPTR                                   | ; which is the lsb of this sample, now in ACC                                                                                                                                                             |
|                                |                                             |                                                                                                                                                                                                           |
| B_MSB_TX:                      |                                             |                                                                                                                                                                                                           |
| JNB                            | TI,B_MSB_TX                                 | ; wait for transmit to complete                                                                                                                                                                           |
| CLR                            | TI                                          | ; clear for new transmit                                                                                                                                                                                  |
| MOV                            | SBUF,A                                      | ; and send out the lsb of DAC B                                                                                                                                                                           |



| ; DA     | C D next            |                                                                        |
|----------|---------------------|------------------------------------------------------------------------|
| ; DA     | C D codes should be | taken from 16 bytes (8 samples) further on in the sine table           |
| ; –      | this gives an inver | ted cosine function                                                    |
| MOV      | A,R7                | ; pointer in R7                                                        |
| ADD      | A,#0FH              | ; add 15 - already done one INC                                        |
| ANL      | A,#03FH             | ; wrap back round to 0 if > 64                                         |
| MOV      | R7,A                | ; pointer back in R7                                                   |
| MOVC     | A,@A+DPTR           | ; get DAC D msb from the table                                         |
| ORL      | A,#03H              | ; set control bits to DAC D address                                    |
| B_LSB_TX | ζ:                  |                                                                        |
| JNB      | TI,B_LSB_TX         | ; wait for DAC B lsb transmit to complete                              |
| SETB     | T1                  | ; toggle FS                                                            |
| CLR      | Т1                  |                                                                        |
| CLR      | TI                  | ; clear for new transmit                                               |
| MOV      | SBUF,A              | ; and send out the msb of DAC D                                        |
| INC      | R7                  | ; increment the pointer in R7                                          |
| MOV      | A,R7                | ; to get the next byte from the table                                  |
| MOVC     | A,@A+DPTR           | ; which is the lsb of this sample, now in ACC                          |
| D_MSB_TX |                     |                                                                        |
| JNB      | TI,D_MSB_TX         | ; wait for transmit to complete                                        |
| CLR      | TI                  | ; clear for new transmit                                               |
| MOV      | SBUF,A              | ; and send out the lsb of DAC D                                        |
|          |                     | pointer to point to the next sample                                    |
|          | ady for the next in | terrupt                                                                |
|          | A,rolling_ptr       | · add 2 to the welling printer                                         |
|          | A,#02H              | ; add 2 to the rolling pointer                                         |
| ANL      | A, #U3FH            | ; wrap back round to 0 if > 64<br>; store in memory again              |
| MOV      | rolling_ptr,A       | ; store in memory again                                                |
| D_LSB_T  |                     |                                                                        |
|          | 'I,D_LSB_TX         | ; wait for DAC D lsb transmit to complete<br>; clear for next transmit |
| CLR      | TI                  | ; clear for next transmit                                              |
| SETB     |                     | ; FS high                                                              |
| SETB     |                     | ; CS high                                                              |
| POP      |                     |                                                                        |
| POP      | PSW                 |                                                                        |
| RETI.    |                     |                                                                        |
| ;; Stack | needs definition    |                                                                        |
| ,R       |                     |                                                                        |
| D        | S 10h               | ; 16 Byte Stack!                                                       |



#### ;-----; Main program code RSEG MAIN start: MOV SP,#STACK-1 ; first set Stack Pointer CLR Α ; set serial port 0 to mode 0 SCON,A MOV TMOD,#02H TH0,#038H ; set timer 0 to mode 2 - auto-reload MOV MOV ; set THO for 5 kHs interrupts SETB INT1 ; set LDAC = 1т1 ; set FS = 1 SETB SETB т0 ; set CS = 1 ; enable timer 0 interrupts SETB ET0 SETB ΕA ; enable all interrupts MOV rolling\_ptr,A ; set rolling pointer to 0 SETB TRO ; start timer 0

|         | JEID IK   | .0           | / Start tin    | ET 0    |  |
|---------|-----------|--------------|----------------|---------|--|
| always  | JMPalways | 5            | ; while(1) !   |         |  |
|         | RET       |              |                |         |  |
| ;       |           |              |                |         |  |
| ; Tab.  |           | ine wave sam | ples used as I | AC data |  |
| ,       | RSEG      | SINTBL       |                |         |  |
| sineva  |           | SINIDE       |                |         |  |
| 0111010 |           | 01000H       |                |         |  |
|         | DW        | 0903EH       |                |         |  |
|         | DW        | 05097H       |                |         |  |
|         | DW        | 0305CH       |                |         |  |
|         | DW        | 0B086H       |                |         |  |
|         | DW        | 070CAH       |                |         |  |
|         | DW        | OFOEOH       |                |         |  |
|         | DW        | OFOGEH       |                |         |  |
|         | DW        | 0F039H       |                |         |  |
|         | DW        | OFO6EH       |                |         |  |
|         | DW        | OFOEOH       |                |         |  |
|         | DW        | 070CAH       |                |         |  |
|         | DW        | 0B086H       |                |         |  |
|         | DW        | 0305CH       |                |         |  |
|         | DW        | 05097H       |                |         |  |
|         | DW        | 0903EH       |                |         |  |
|         | DW        | 01000H       |                |         |  |
|         | DW        | 06021H       |                |         |  |
|         | DW        | 0A0E8H       |                |         |  |
|         | DW        | 0C063H       |                |         |  |
|         | DW        | 040F9H       |                |         |  |
|         | DW        | 080B5H       |                |         |  |
|         | DW        | 0009FH       |                |         |  |
|         | DW        | 00051H       |                |         |  |
|         | DW        | 00026H       |                |         |  |

END

DW DW

DW

DW

DW

DW DW 00051H

0009FH

080B5H

040F9H 0C063H

0A0E8H

06021H



SLAS176B - DECEMBER 1997 - REVISED JULY 2002

#### MECHANICAL DATA

#### PLASTIC SMALL-OUTLINE PACKAGE

#### D (R-PDSO-G\*\*) 14 PIN SHOWN



NOTES: A. All linear dimensions are in inches (millimeters).

- B. This drawing is subject to change without notice.
- C. Body dimensions do not include mold flash or protrusion, not to exceed 0.006 (0,15).
- D. Falls within JEDEC MS-012



# TLV5604 2.7-V TO 5.5-V 10-BIT 3- $\mu$ S QUADRUPLE DIGITAL-TO-ANALOG CONVERTERS WITH POWER DOWN

SLAS176B - DECEMBER 1997 - REVISED JULY 2002

**MECHANICAL DATA** 

PLASTIC SMALL-OUTLINE PACKAGE

#### PW (R-PDSO-G\*\*) 14 PIN SHOWN



NOTES: A. All linear dimensions are in millimeters.

B. This drawing is subject to change without notice.

C. Body dimensions do not include mold flash or protrusion not to exceed 0,15.

D. Falls within JEDEC MO-153



#### **IMPORTANT NOTICE**

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed.

TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third–party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation.

Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

Mailing Address:

Texas Instruments Post Office Box 655303 Dallas, Texas 75265

Copyright © 2002, Texas Instruments Incorporated