



D/A Converter Control

for

Spartan-3E Starter Kit

Ken Chapman Xilinx Ltd 21st February 2006

### Limitations

**Limited Warranty and Disclaimer**. These designs are provided to you "as is". Xilinx and its licensors make and you receive no warranties or conditions, express, implied, statutory or otherwise, and Xilinx specifically disclaims any implied warranties of merchantability, non-infringement, or fitness for a particular purpose. Xilinx does not warrant that the functions contained in these designs will meet your requirements, or that the operation of these designs will be uninterrupted or error free, or that defects in the Designs will be corrected. Furthermore, Xilinx does not warrant or make any representations regarding use or the results of the use of the designs in terms of correctness, accuracy, reliability, or otherwise.

**Limitation of Liability**. In no event will Xilinx or its licensors be liable for any loss of data, lost profits, cost or procurement of substitute goods or services, or for any special, incidental, consequential, or indirect damages arising from the use or operation of the designs or accompanying documentation, however caused and on any theory of liability. This limitation will apply even if Xilinx has been advised of the possibility of such damage. This limitation shall apply not-withstanding the failure of the essential purpose of any limited remedies herein.

This design module is <u>not</u> supported by general Xilinx Technical support as an official Xilinx Product. Please refer any issues initially to the provider of the module.

Any problems or items felt of value in the continued improvement of KCPSM3 or this reference design would be gratefully received by the author.

Ken Chapman Senior Staff Engineer – Spartan Applications Specialist email: chapman@xilinx.com

The author would also be pleased to hear from anyone using KCPSM3 or the UART macros with information about your application and how these macros have been useful.



## **Design Overview**

This design outlines the fundamental operation of the Linear Technology LTC2624 Digital to Analogue (D/A) converter provided on the Spartan-3E Starter Kit and illustrates how it can be controlled using PicoBlaze. It is hoped that the design may form the basis for future PicoBlaze designs as well as provide a general introduction to the A/D converter requirements for other design implementations. Some exercises are suggested to encourage further self study.



There are four analogue outputs provided on J5. As well as providing the SPI communication, PicoBlaze is synthesising different waveforms at a sample rate of 8KHz which can be viewed on an oscilloscope.

Channel A = 2KHz square wave (0.66v to 2.64v)

Channel B = 200Hz triangle wave (0v to 3.29v)

Channel C = 2KHz square wave (0.50v to 2.00v)

Channel D = 770Hz sine wave

(i.e. one of the DTMF tones)

### <u>Try it now – it only takes 30 seconds!</u>

As well as the source design files, a compiled configuration bit file is provided which you can immediately download into the Spartan XC3S500E device on your board. It is recommended that you try this to become familiar with what the design does before continuing to read. To make this task really easy the first time, unzip all the files provided into a directory and then....

### double click on 'install\_picoblaze\_dac\_control.bat'.

Assuming you have the Xilinx software installed, your board connected with the USB cable and the board powered (don't forget the switch), then this should open a DOS window and run iMPACT in batch mode to configure the Spartan-3E with the design.



## D/A Overview

This overview is not intended to replace the Linear Technology data sheet and you are recommended to consult the LTC2624 data sheet to review the full range of features it offers as well as check the operating specifications particularly in relation to analogue outputs.



The device has a **S**erial **P**eripheral Interface (SPI) to allow the digital values to be supplied and each channel to be controlled. There is also a direct reset control. All of these signals link directly to the Spartan-3E using the pins indicated in yellow.

<u>Important hint</u> - The SPI bus signals are shared by other devices on the board.

It is vital that other devices are disabled when communicating with the D/A.



# Digital to Analogue

Each output level is the analogue equivalent of a 12-bit unsigned digital value written to the device via the SPI interface.

The ideal conversion is described by the following simple equation....

<u>Hint</u> – 12-bits can represent values 0 to 4095 (000 to FFF hex).



$$Vo = \frac{D}{4096} \times V_{REF}$$

The reference voltage (V<sub>REF</sub>) is set on the Starter Kit board by REFAB and REFCD connections on J7 but is already provided with a default value (see previous page) by connection to the 3.3v and 2.5v supply rails respectively. Therefore the unmodified board will have the following ideal characteristics...



Note - In practice, the supply voltage will be slightly different and this will modify the actual range of each output. Also any fluctuation or noise present in the supply rails will be reflected in the analogue levels.

The design provides an example of the different analogue levels using the 'A' and 'C' channels. In both cases, the amplitude description for each waveform is identical, but as this plot shows, the 'A' waveform is of a larger amplitude.

PicoBlaze initially sets 'C' channel to have the levels 0.5v and 2.0v.

$$D = \frac{4096}{V_{\text{REE}}} \times V_0$$

$$D = (4096/2.5) \times 0.5 = 819 \text{ (333 hex)}$$

$$D = (4096/2.5) \times 2.0 = 3277 \text{ (CCD hex)}$$

PicoBlaze then uses these same values to set channel 'A' resulting in different levels just because of the difference in reference voltage.

$$V_0 = \frac{D}{4096} \times V_{REF}$$
  $V_0 = (819/4096) \times 3.3 = 0.66v$   $V_0 = (3277/4096) \times 3.3 = 2.64v$ 

### **SPI Communication**

The **S**erial **P**eripheral Interface (SPI) is formally described as being a full-duplex, synchronous, character-oriented channel employing a 4-wire interface. As each bit is transmitted by the master, the slave also transmits a bit allowing one byte to be passed in each direction at the same time. In this case the PicoBlaze in the Spartan-3E is the master and the SPI D/A Converter is the slave.



#### DAC-CS

Communication is only possible with the LTC2624 device when the select signal (DAC-CS) is Low. Therefore the PicoBlaze master is responsible for driving DAC-CS Low before transmitting and receiving a command word and then driving DAC-CS High. It is the act of driving DAC-CS High which actually causes the D/A converter to execute the operation.

Looking specifically at the LTC2624 D/A converter, each communication is formed of 4 bytes or 32-bits. Inside the D/A converter, the SPI interface is formed by a 32-bit shift register. As a new 32-bit command word formed of command, address and data fields is transmitted to it, the 32-bit word previously sent is echoed back to the master. In order to use the D/A converter this response can be ignored, however, it is a useful to confirm correct communication is taking place and it is read back in the supplied PicoBlaze code.



### **SPI Communication Detail**

Each bit is transmitted or received relative to the SCK clock. The system is fully static and any clock rate up to the maximum of 50MHz supported by the LTC2624 is possible\*\*. Remember to check all timing parameters in the LTC2624 data sheet if you intend working at or close to the maximum speed.

\*\*Only applies to transmitting (see page9)

The LTC2624 captures data (SDI) on the rising edge of SCK, so the data needs to be valid for at least ±4ns relative to the rising edge.



The LTC2624 changes the output data (SDO) in response to the falling edge of SCK allowing the master to read the value at or near the next rising edge. It is important to notice that SDO must be read on the first clock following the enable being asserted (DAC-CS='0') otherwise bit 31 will be missed.

In theory the SPI interface allows command words to be transmitted at a rate slightly higher than 1.5 M-words/second. Even if this is used to set all four channels individually, this rate would exceed the conversion rate actually supported by the D/A converter and obviously some spacing between commands would be necessary.

#### Software Exercise

The PicoBlaze code provided (see next page) supports a communication rate of approximately 78 k-words/second. This would be adequate for 8KHz sample rates used in telecommunications but would still occupy over 40% of the processor time just to set 4 channels as well as occupying the SPI bus preventing access to the other devices which share it.

- 1) Remove the ability to read back the echo response from the LTC2624 and calculate/measure the new maximum word rate.
- 2) The LTC2624 can be set using only 24-bit command words (although not ideal if wanting to read the echo response).

  Modify the code to only transmit 24-bit command words without read back and again calculate/measure the new maximum word rate.

### Hardware Exercise

Implement a hardware interface which allows PicoBlaze to OUTPUT and INPUT complete <u>bytes</u> of the command word and accelerates the bit rate of the serial communication. Do NOT implement a 24-bit or 32-bit shift register in hardware which would be unnecessarily large.

### **Software SPI Communication**

PicoBlaze is used to implement the SPI communication 100% in software. The fundamental byte transfer routine is shown below. The 's2' register is used to supply the data for transmission and this will be replaced by the data received from the D/A converter.

```
SPI dac tx rx: LOAD s1, 08
                                                   :8-bits to transmit and receive
next SPI dac bit: OUTPUT s2, SPI output port
                                                   ; output data bit ready to be used on rising edge
                  XOR s0, SPI sck
                                                   :clock High (bit0)
                  OUTPUT s0, SPI control port
                                                   ; drive clock High
                  XOR s0, SPI sck
                                                   ; prepare clock Low (bit0)
                  INPUT s3, SPI input port
                                                   ; read input bit
                  TEST s3, SPI sdi
                                                   :detect state of received bit
                  SLA s2
                                                   : shift new data into result and move to next transmit bit
                  OUTPUT s0, SPI control port
                                                   :drive clock Low
                  SUB s1, 01
                                                   :count bits
                  JUMP NZ, next SPI dac bit
                                                   ; repeat until finished
                  RETURN
```

The routine generates SCK. Since every PicoBlaze instruction executes in 2 clock cycles and the design uses the 50MHz clock source on the board, the actual SPI bit rate can be determined. Although this is not as fast as the hardware can support, it keeps the design small and flexible.





**SPI Communication Signals** 

Oscilloscope trace of the SPI signals observed at the J12 connector shows the timing of the SCK and data signals.

Oscilloscope trace showing analogue output 'A' relative to the SPI signals.

Hint - Always exploit programmable logic during development. In this design, DAC-CS is duplicated to the IO11 pin on J4 to make probe connection easy.



This trace shows the DAC-CS going Low followed by the 32 SCK cycles associated with the command word for the 'A' output. When DAC-CS is driven High, the D/A conversion starts and the analogue output responds. Note that it takes approximately 14 $\mu$ s for the SPI communication of each command and the analogue output takes ~3 $\mu$ s to rise (see data sheet for actual specification). Hint — These factors limit the maximum sample rate.



PicoBlaze is allowing 140ns after the falling edge of SCK before sampling SDO. This allows for the slow rise and fall time of the SDO signal on the board which is mainly due to the low drive strength the LTC2624 device (in the region of  $\pm 100 \mu A$  is implied in the data sheet). The principle purpose of the SDO output on the D/A device is to cascade LTC2624 devices and not really for bidirectional communication.

<u>Hint</u> – Use 24-bit commands and do not implement read back when higher sample rates are required.

# Sample Rate and Timing

The design contains a simple counter which interrupts PicoBlaze at every 125µs (8KHz). Each time PicoBlaze receives an interrupt, it transmits the command words to set 'A', 'B', 'C' and 'D' on the D/A converter.

Because the SPI communication is predicable, each channel will update at the 8KHz sample rate. However, it can be seen that relative to each other, the channels change at a different time as each 32-bit command transfer completes.



DAC-CS is driven Low for each 32-bit command. As it is driven High at the end of each command the corresponding analogue output changes. The square waves on the 'A' and 'C' outputs clearly show the points of change.

#### Exercise

Modify the design such that all analogue outputs change simultaneously. This would be vital when phase relationships are important. Demonstrate your design is working by showing that the square waves are exactly 90° different in phase.

Hint - This design is using the D/A command C[3:0]="0011" which sets and updates each channel immediately. Investigate the command which allows new digital values to be written without updating the analogue output and the command which updates all outputs simultaneously.



## **Design Files**

The source files provided for the reference design are.....



Note: The file shown in **green** is <u>not</u> included with the reference design as it is provided with PicoBlaze download. Please visit the PicoBlaze Web site for your free copy of PicoBlaze, assembler, JTAG\_loader and documentation.

www.xilinx.com/picoblaze



## PicoBlaze Design Size

The images and statistics on this page show that the design occupies just 107 slices and 1 BRAM. This is only 2.5% of the slices and 5% of the BRAMs available in an XC3S500E device and would still be less than 12% of the slices in the smallest XC3S100E device.

### **MAP** report

Number of occupied Slices: 116 out of 4,656 2%
Number of Block RAMs: 1 out of 20 5%

Total equivalent gate count for design: 75,911

PicoBlaze makes extensive use of the distributed memory features of the Spartan-3E device leading to very high design efficiency. If this design was replicated to fill the XC3S500E device, it would represent the equivalent of over 1.5 million gates. Not bad for a device even marketing claims to be 500 thousand gates ©

#### **FPGA Editor view**



### Floorplanner view







### **PicoBlaze Program**

This information is intended to give a guide to the way in which the PicoBlaze assembler code is organised. It is not intended to be a lesson in how to write assembler code or explain how PicoBlaze works. Please refer to the documentation for PicoBlaze (KCPSM3).



## Sine Wave Generation

PicoBlaze is synthesizing the 770Hz sine wave which is output on channel D using a small algorithm. This is a very efficient way of generating sinusoidal

waveforms and avoids the requirement for large sine lookup tables held in memory.

This oscilloscope trace of the 'D' output shows that the fundamental frequency is the specified 770Hz. The waveform looks like 'steps' simply because the 8KHz sample rate means that there are only just over 10 samples per output cycle. Notice how the levels forming are different in each of the cycles.

One way to make the output waveform smoother would be to increased the sample rate. However, a more practical solution is to use a simple analogue low pass filter formed by a resistor and capacitor to act as a smoothing circuit. In audio communications systems, it is often the bandwidth limitations of the system itself which naturally performs the smoothing.

Exercise – Design a suitable R-C low pass filter to smooth this waveform.

The sine wave is generated using a recursive algorithm. The art was to quantise the values to 16-bits; the details of which can be seen in the assembly code.

$$k = \frac{2}{\sqrt{1 + \tan^2 \left(\frac{2.\pi.f_0}{f_e}\right)}}$$



The constant 'k' sets the frequency  $(f_o)$  relative to the sample rate  $(f_s)$ . The current output  $(y_n)$  is delayed by one sample  $(y_{n-1})$  before being subtracted from the product of multiplication. Due to the recursive nature, it needs an initial value for  $y_n$  to start the oscillation. The magnitude of this initial value will determine the peak amplitude of the waveform (but is not the peak value itself!).

Hint 1 - Use Radians when calculating 'k'.

Hint 2 - Remember that Spartan-3E is the fastest simulator. Use JTAG\_loader to reload PicoBlaze and rapidly test different 'k' and initial values.



#### Exercise

Create a DTMF (Dual Tone Multi Frequency) dialler for your home phone number

Each button corresponds to the addition of two unique tones.

