

# Drigmorn2 User Manual

Issue -1.0

#### **Kit Contents**

You should receive the following items with your Drigmorn2 development kit:

- 1 Drigmorn2 Board
- 2 Programming Cable
- 3- USB lead.

#### **Foreword**

PLEASE READ THIS ENTIRE MANUAL BEFORE PLUGGING IN OR POWERING UP YOUR DRIGMORN2 BOARD.
PLEASE TAKE SPECIAL NOTE OF THE WARNINGS WITHIN THIS MANUAL.

#### **Trademarks**

Spartan-3A, ISE, Webpack, EDK, COREGEN, Xilinx are the registered trademarks of Xilinx Inc, San Jose, California, US.

Drigmorn2 is a trademark of Enterpoint Ltd.

### **Contents**

| Kit Contents                    | 2  |
|---------------------------------|----|
| Foreword                        | 2  |
| Trademarks                      | 2  |
| Drigmorn2 Board                 | 4  |
| Introduction                    | 5  |
| Getting Started                 | 6  |
| FPGA                            | 8  |
| <u>SPI FLASH</u>                | 9  |
| SDRAM MEMORY                    | 10 |
| <u>DIL HEADERS</u>              | 12 |
| USB                             | 14 |
| LCD DISPLAY                     | 16 |
| <u>LEDS</u>                     | 17 |
| OSCILLATOR                      | 19 |
| SWITCHES                        | 20 |
| INPUT POWER CONNECTIONS         | 21 |
| POWER REGULATORS                | 22 |
| PROGRAMMING DRIGMORN2           | 23 |
| MECHANICAL                      | 25 |
| Medical and Safety Critical Use | 26 |
| Warranty                        | 26 |
| Support                         | 26 |
| <del>- 11</del>                 |    |

## Drigmorn 2



#### Introduction

Welcome to your Drigmorn2 board. Drigmorn2 is Enterpoint's low cost Spartan-3A development board. It offers a flexible and low cost approach to prototyping FPGA and System designs.

The aim of this manual is to assist in using the main features of Drigmorn2. There are features that are beyond the scope of the manual. Should you need to use these features then please email <a href="mailto:support@enterpoint.co.uk">support@enterpoint.co.uk</a> for detailed instructions.

Drigmorn2 currently comes with a XC3S1400A-4FTG256C Spartan-3A. Other variants may be offered at a later date or as an OEM product. Smaller Spartan-3A parts in the FT256 Package can be fitted to this board. Please contact us on <a href="mailto:boardsales@enterpoint.co.uk">boardsales@enterpoint.co.uk</a> should you need further information.

Drigmorn2 is supported by a wide range of add-on modules. Some examples of these include:

**ADC 7927 MODULE** LED DOT MATRIX MODULE BUTTONS/SWITCHES/SATA/MEMORY MODULE RS232 AND RS485 HEADER MODULES DP83816 ETHERNET MODULE SD CARD MODULE DDR2 MODULE IDE/5V TOLERANT CPLD MODULE **USB MODULE** D/A CONVERTER MODULE ADV70202 MODULE GIGABIT ETHERNET PHY MODULE LTC2248 MODULE MICTOR MODULE **OPTO-ISOLATOR MODULE** FT4232 QUAD USB MODULE NAND FLASH MODULE RTC MODULE ACCELEROMETER MODULE OVM CAMERA MODULE IDT5V19EE901 CLOCK MODULE

We can also offer custom DIL Header modules should you require a function not covered by our current range of modules. Typical turn around for this service is 6-8 weeks depending upon quantity ordered and availability of components.

#### **Getting Started**



Your Drigmorn2 will be supplied un-programmed. Unless you have bought an OEM product your board will be supplied with either a Prog2 parallel port programming cable or a Prog3 USB port programming cable.

The Spartan-3A FPGA on board is supported by the free ISE Webpack available from Xilinx, which provides all the tools to enter and build a design. Using this tool in conjunction with your supplied programming cable you will also be able to program the Spartan-3A, and the supporting SPI Flash, that are on Drigmorn2.

ISE Webpack can be obtained directly from the Xilinx website at <a href="http://www.xilinx.com/ise">http://www.xilinx.com/ise</a>. Registration will be necessary to complete the download.

Once you have obtained your ISE Webpack tools:

- (1) Connect your programming cable to the board and your PC hosting the Xilinx software.
- (2) Connect the Drigmorn2 board to either a USB connector of a PC, or a USB power supply using the supplied USB lead. Note that some Laptops and desktop computer USB ports have a current limit of 100mA. Drigmorn2 can exceed this in some circumstances and should you have a problem a powered USB hub or external mains to USB adaptor are recommended solutions.
- (3) If using an external power brick switch on your power source.

#### **FPGA**



Drigmorn2 supports Spartan-3A devices in the FTG256 package. Drigmorn2 is normally available with commercial grade -2 speed devices fitted in the XC3S700A-4FTG256C size. For OEM customers we can offer a range of alternatives from XC3S400A to XC3S1400A as custom BOM variants.

Should you have an application that needs industrial, faster speed grades, or bigger parts please contact sales for a quote at boardsales@enterpoint.co.uk.

#### **SPI FLASH MEMORY**



The M25P128 SPI flash memory device configures the FPGA when it is powered providing a suitable bitstream is programmed into the device. The M25P128 has a capacity of 128Mbits with a single configuration bitstream for Drigmorn2 taking 2.7Mbits (XC3S700A) . Any remaining space can be used for alternative configurations or code and data storage.

After configuration the SPI Flash can be accessed via the following pins of the FPGA:

| M25P128  | FPGA PIN |
|----------|----------|
| FUNCTION |          |
| CCLK     | R14      |
| MOSI     | P10      |
| WRITE    | H16      |
| DIN      | T14      |
| CSO_B    | T2       |

The HOLD pin of this memory device is permanently connected to 3.3V.

#### **SDRAM MEMORY**



Drigmorn2 has a 256MBIT SDRAM ISSI IS42S32800B-7BL device as standard. This device is organised as 2 Meg x 32 x 4 banks. The SDRAM has 12 address lines and 32 data lines to address all the available memory, which can be accessed at a clock rate OF 166/143 Mhz. More details can be found in <a href="http://www.issi.com/pdf/42s32800b.pdf">http://www.issi.com/pdf/42s32800b.pdf</a>

The SDRAM site has the following connections to the FPGA:

| SDRAM FUNCTION | FPGA PIN | SDRAM FUNCTION | FPGA PIN |
|----------------|----------|----------------|----------|
| SDRAM_A0       | A0       | SDRAM_DQ4      | D1       |
| SDRAM_A1       | A3       | SDRAM_DQ5      | G13      |
| SDRAM_A2       | A7       | SDRAM_DQ6      | G14      |
| SDRAM_A3       | D10      | SDRAM_DQ7      | C2       |
| SDRAM_A4       | B12      | SDRAM_DQ8      | F13      |
| SDRAM_A5       | A12      | SDRAM_DQ9      | D9       |
| SDRAM_A6       | F14      | SDRAM_DQ10     | E13      |
| SDRAM_A7       | A13      | SDRAM_DQ11     | D14      |
| SDRAM_A8       | B14      | SDRAM_DQ12     | D13      |
| SDRAM_A9       | C7       | SDRAM_DQ13     | B15      |
| SDRAM_A10      | J13      | SDRAM_DQ14     | С9       |
| SDRAM_A11      | C4       | SDRAM_DQ15     | C13      |
| SDRAM_A12      | D11      | SDRAM_DQ16     | В3       |
| SDRAM_BA0      | F1       | SDRAM_DQ17     | В6       |
| SDRAM_BA1      | D4       | SDRAM_DQ18     | A6       |
| SDRAM_CAS_N    | H13      | SDRAM_DQ19     | B4       |
| SDRAM_CS_N     | E3       | SDRAM_DQ20     | A5       |
| SDRAM_RAS_N    | D3       | SDRAM_DQ21     | A4       |
| SDRAM_WE_N     | E1       | SDRAM_DQ22     | C6       |
| SDRAM_DQM0     | E2       | SDRAM_DQ23     | C5       |
| SDRAM_DQM1     | C15      | SDRAM_DQ24     | B10      |
| SDRAM_DQM2     | F3       | SDRAM_DQ25     | A9       |
| SDRAM_DQM3     | C12      | SDRAM_DQ26     | A11      |
| SDRAM_CKE      | C11      | SDRAM_DQ27     | C10      |
| SDRAM_CLK      | A14      | SDRAM_DQ28     | A10      |
| SDRAM_DQ0      | E7       | SDRAM_DQ29     | B8       |
| SDRAM_DQ1      | D8       | SDRAM_DQ30     | A8       |
| SDRAM_DQ2      | C1       | SDRAM_DQ31     | C8       |
| SDRAM_DQ3      | D7       |                |          |

#### **DIL HEADERS**

|     | LEFT COLUMNS |     | RIG   | HT COLUMNS |           |     |
|-----|--------------|-----|-------|------------|-----------|-----|
|     | OUTER PINS   |     |       |            | OUTER PI  |     |
|     |              | S3A | INNER | INNER      |           | S3A |
| ROW | FUNCTION     | PIN | PINS  | PINS       | FUNCTION  | PIN |
| 1   | IO_L10N_2    | T8  | 0V    | 3.3V       | IO_L08P_2 | P7  |
| 2   | IO_L12N_2    | T9  | 0V    | 3.3V       | IO_L06N_2 | T6  |
| 3   | IO_L12P_2    | R9  | 0V    | 3.3V       | IO_L03P_2 | R5  |
| 4   | IO_L11N_2    | P9  | 0V    | 3.3V       | IO_L03P_2 | R3  |
| 5   | IO_L15N_2    | R11 | 0V    | 3.3V       | IO_L22P_3 | N2  |
| 6   | IO_L17N_2    | P12 | 0V    | 3.3V       | IO_L23N_3 | P2  |
| 7   | IO_L18N_2    | R13 | 0V    | 3.3V       | IO_L05P_2 | T4  |
| 8   | IO_L15P_2    | T11 | 0V    | 3.3V       | IO_L10P_2 | P8  |
| 9   | IO_L02P_1    | R15 | 0V    | 3.3V       | IO_L09P_2 | R7  |
| 10  | IO_L18P_2    | T13 | 0V    | 3.3V       | IO_L09N_2 | T7  |
| 11  | IO_L16P_2    | P11 | 0V    | 3.3V       | IO_L08N_2 | N8  |
| 12  | IO_L14P_2    | T10 | 0V    | 3.3V       | IO_L06P_2 | T5  |
| 13  | IO_L24P_1    | C16 | 0V    | 3.3V       | IO_L16P_3 | L1  |
| 14  | IO_L22N_1    | D15 | 0V    | 3.3V       | IO_L15N_3 | K1  |
| 15  | IO_L22P_1    | D16 | 0V    | 3.3V       | IO_L15P_3 | K3  |
| 16  | IO_L18N_1    | F15 | 0V    | 3.3V       | IO_L14N_3 | J1  |
| 17  | IO_L15P_1    | H15 | 0V    | 3.3V       | IO_L14P_3 | J2  |
| 18  | IO_L16P_1    | G16 | 0V    | 3.3V       | IO_L11N_3 | H1  |
| 19  | IO_L16N_1    | F16 | 0V    | 3.3V       | IO_L12N_3 | J3  |
| 20  | IO_L18P_2    | E16 | 0V    | 3.3V       | IO_L08N_3 | G1  |

The DIL Headers provide a simple mechanical and electrical interface for add-on modules. There are twenty I/O on each side of the DIL Header giving a total of 40 I/O available. Each of these I/O pins is protected by bus switch technology to facilitate 5V tolerance on all of these pins. Bus switch technology has a minimal effect on I/O timing with propagation times of less than 250ps through these devices.

The DIL Headers support the use of add-on modules enhancing the capabilities of your Drigmorn2 board. Enterpoint has a wide range of modules suitable for the DIL Header. We can also offer custom design modules should our standard range not cover your requirement. The DIL Headers will also support the use of crude prototype circuits using stripboard or other prototype materials.

The DIL Header connectors are arranged on a standard 0.1inch (2.54mm) pitch. The horizontal pitch of the DIL Headers is 1.6 inches between the outer rows of the headers. The inner pins of the header form continuous power strips allowing a range of modules to be used together in one header subject to sufficient pins being available. The right hand side header has an inner column of 3.3V pins. The LHS header has an inner column of DGND (0V).

#### **USB**



The USB interface on the Drigmorn2 is achieved using an FT232R USB to serial UART interface. The datasheet and drivers for this device are available from <a href="http://www.ftdichip.com">http://www.ftdichip.com</a>. When appropriate drivers are installed the Drigmorn2 USB port should be detected as a serial port. Alternative data optimised drivers are also available from FTDI.

The FT232R is connected to the Spartan-3A and provided that a simple UART, or other converter, is implemented then the data sent over the USB serial port can be used either as control and/or data information. This allows a host computer to act in a number of ways including system control and data storage functions.

The FT232R can also supply a clock to the Spartan-3A FPGA using CBUS4 I/O. This I/O can be programmed by tools available from FTDI to output different frequencies or other functions. The FT232R can provide clock frequencies of 6/12/24/48MHz.

The connections between the USB device and the FPGA are shown below:

| FT232R | FPGA PIN |
|--------|----------|
| CBUS4  | E4       |
| CTS#   | G3       |
| DCD#   | Н3       |
| DSR#   | K4       |
| RI#    | L4       |
| RTS#   | L3       |
| DTR#   | M3       |
| TXD    | N3       |
| RXD    | F4       |

The FT232R connections CBUS0 to CBUS3 are routed via a resistor array site (resistor array not fitted) to the JTAG connector for future use in reconfiguring the FPGA via a USB interface, a scenario which is theoretically possible but not so far established. These connections, were the resistor array to be fitted, would be as shown below:

| FT232R | JTAG   |
|--------|--------|
|        | SIGNAL |
| CBUS0  | TDO    |
| CBUS1  | TDI    |
| CBUS2  | TMS    |
| CBUS3  | TCK    |

#### **LCD DISPLAY**



The standard Drigmorn2 LCD display is an LCM-S01602DTR/M display, which is 16x2 alpha-numerical display with a Hitachi HD44780 compatible chipset. More information on this at <a href="http://www.lumex.com/specs/LCM-S01602DTR%20M.pdf">http://www.lumex.com/specs/LCM-S01602DTR%20M.pdf</a>.

For OEM applications this LCD can be replaced by a 2x17 IDC header allowing remote location of the LCD or even reuse of the interface for other I/O functions. For these applications the 8 data signals are passed through bus switches giving 5V tolerance. The remaining signals of this interface are not protected for 5V operation and should only be used with voltages less than 3.3V.

The IO pins used for the display are shown in the table below:

| FUNCTION | FPGA PIN |
|----------|----------|
| D7       | P15      |
| D6       | N16      |
| D5       | N14      |
| D4       | M16      |
| D3       | M15      |
| D2       | L16      |
| D1       | L14      |
| D0       | K16      |
| EN       | N13      |
| R/W      | P13      |
| RS       | P16      |

#### **LEDS**



Drigmorn2 has 13 LEDs. There is a single red LED in the centre of the board just above the FPGA, and 12 LEDs arranged into 4 blocks of three, one of each block being red, orange and green. This is to enable users to simulate a traffic light sequence. The LEDS may turn on dimly when power is applied to the board. The relevant IO pin for an LED needs to be asserted high to ensure the specific LED turns on, and High impedance 'Z' to turn them off.

The LEDS are connected to the FPGA as indicated below:

| LED | FPGA PIN | COLOUR       |  |
|-----|----------|--------------|--|
| 1   | E14      | RED          |  |
| 2   | J16      | ORANGE       |  |
| 3   | K13      | GREEN        |  |
| 4   | K14      | GREEN        |  |
| 5   | L13      | ORANGE       |  |
| 6   | K15      | RED          |  |
| 7   | L2       | RED          |  |
| 8   | M1       | ORANGE       |  |
| 9   | N3 GREEN |              |  |
| 10  | N1 GREEN |              |  |
| 11  | P1       | ORANGE       |  |
| 12  | R1       | RED          |  |
| D2  | N12      | RED (SINGLE) |  |

#### **OSCILLATOR**



The main oscillator on the Drigmorn2 is an ASEM 25MHz oscillator. The oscillator is situated as shown and is connected to the FPGA on **PIN N9**, which is a global clock pin on the FPGA.

The Spartan-3A has Digital Clock Managers to produce multiples, divisions and phases of the clock for specific application requirements. Please consult the Spartan-3A datasheet available from the Xilinx website at <a href="http://www.xilinx.com">http://www.xilinx.com</a> if multiple clock signals are required.

#### **SWITCHES**



The Drigmorn2 has two push button switches and one 16 position hexadecimal rotary switch. To use these switches it is necessary to set the IO pins connected to the switches to have a pull up resistor in the FPGA. This is set in FPGA constraints file. Any switches pressed, or made, will then give a LOW signal at the FPGA, otherwise a HIGH is seen. The two push button switches are connected to the following IO pins.

| SW1 (LOWER) | SW3 (UPPER) |  |
|-------------|-------------|--|
| J4          | G4          |  |

The 16 position hexadecimal rotary switch bits are connected to the following IO pins.

| ROT_SW1(MSB) | ROT_SW2 | ROT_SW3 | ROT_SW4(LSB) |
|--------------|---------|---------|--------------|
| J14          | M11     | M13     | M14          |

#### **INPUT POWER CONNECTIONS**



Drigmorn2 is powered from the USB connector. The board should be plugged via a cable into the USB socket of a PC, Laptop or USB hub. Some USB ports may not be able to supply greater than 100mA and either a powered USB hub or a mains wall brick is suggested for these cases.

Drigmorn2 also has an ancillary 2 pin header site with DGND(0V) and 5V pickup points. This connector normally not fitted but can used as a power output or input depending on your design needs. The pickup point is aligned to the main DIL Headers on a 01inch/2.54mm grid.

Whatever power supply is used care should be taken not to exceed 5.5V input as this can cause damage to the Drigmorn2.

#### **POWER REGULATORS**



Drigmorn2 has two regulators supplying 3.3V and 1.2V power rails.

WARNING – REGULATORS CAN BECOME HOT IN NORMAL OPERATION ALONG WITH THE BOARDS THERMAL RELIEF. PLEASE DO NOT TOUCH OR PLACE HIGHLY FLAMABLE MATERIALS NEAR THESE DEVICES WHILST THE DRIGMORN2 BOARD IS IN OPERATION.

An Empirion EP5388QI regulator supplies 3.3V with a maximum current available of 800mA. This powers the FPGA general I/O, SDRAM, DIL Headers and other devices such the Ethernet controller and Real Time Clock.

A Micrel MIC33050 regulator supplies 1.2V with a maximum current of 600mA for the core voltage of the FPGA .

If you are using these power rails to provide power to add-on modules or your own circuitry via the DIL headers you should always ensure that you do not exceed the maximum current output of these regulators.

#### **Programming Drigmorn2**



The programming of the FPGA and SPI Flash parts on Drigmorn2 is achieved using the JTAG interface. Principally it is anticipated that a JTAG connection will be used in conjunction with Xilinx ISE software. The free Webpack version of the Xilinx tools can be used to program the Drigmorn2.

There is a single JTAG chain on Drigmorn2. The JTAG chain allows the programming of the Spartan-3A and the SPI Flash device.

The JTAG connector has a layout as follows (top view):

| GND |
|-----|-----|-----|-----|-----|-----|-----|
| NC  | NC  | TDI | TDO | TCK | TMS | 3V3 |

Using iMPACT Boundary Scan the JTAG chain appears like this:



#### 1. Programming the FPGA directly.

Direct JTAG programming of the Spartan-3A FPGA is volatile and the FPGA will lose its configuration every time the board power is cycled. For sustained use of an FPGA design programming the design into the Flash memory is recommended (see 2 and 3 below).

Direct JTAG programming using .bit files is useful for fast, temporary programming during development of FPGA programs. Right click the icon representing the Spartan-3A FPGA and choose 'Assign New Configuration File'. Navigate to your .bit file and choose 'OPEN'. The next dialogue box will offer to add a flash memory and you should decline. Right click the icon representing the Spartan-3A FPGA and choose 'Program'. On the next dialogue box ensure that the 'Verify' box is not checked. (If it is you should uncheck it, failure to do this will result in error messages being displayed). Click OK. The Spartan-3A will program. This process is very quick (typically one second)

#### 2. Programming the SPI flash memory using Boundary Scan.

Once the SPI Flash memory has been programmed, the Spartan-3A device will automatically load from the Flash memory at power up. Generation of suitable Flash memory files (.mcs) can be achieved using ISE iMPACT's Prom File Formatter. Right click on the icon representing the Spartan-3A and choose 'Add SPI/BPI Flash' Navigate to your programming file (.mcs) and click OPEN. Use the next dialogue box to select SPI flash and M25P128. Data width should be set to 1. The flash memory should appear as shown below.



Right click on the icon representing the flash memory and choose program to load your program into the device. It is recommended that options to 'Verify' and 'Erase before programming' are chosen. Otherwise all defaults can be accepted. The programming operation will take some time (at least 3 or 4 minutes)

#### MECHANICAL ARRANGEMENT

The Dimensions on the drawing below are millimetres (mm). All sizes quoted are subject to manufacturing tolerances and should only be used as a general guide.



The heights of the components, measured from the lower surface of the board are as follows:

Upper surface of LCD display: 12.5mm The PCB is 1.6mm thick

#### **Mechanical Arrangement of DIL headers**

The socket pins on the DIL headers are arranged on a 2.45mm (0.1inch) pitch

#### **Medical and Safety Critical Use**

Drigmorn2 boards are not authorised for the use in, or use in the design of, medical or other safety critical systems without the express written person of the Board of Enterpoint. If such use is allowed the said use will be entirely the responsibility of the user. Enterpoint Ltd will accept no liability for any failure or defect of the Drigmorn2 board, or its design, when it is used in any medical or safety critical application.

#### **Warranty**

Drigmorn2 comes with a 90 day return to base warranty. Do not attempt to solder connections to the Drigmorn2. Enterpoint reserves the right not honour a warranty if the failure is due to soldering or other maltreatment of the Drigmorn2 board.

Outside warranty Enterpoint offers a fixed price repair or replacement service. We reserve the right not to offer this service where a Drigmorn2 has been maltreated or otherwise deliberately damaged. Please contact support if you need to use this service.

Other specialised warranty programs can be offered to users of multiple Enterpoint products. Please contact sales on <a href="mailto:boardsales@enterpoint.co.uk">boardsales@enterpoint.co.uk</a> if you are interested in these types of warranty,

#### **Support**

Telephone and email support is offered during normal United Kingdom working hours (GMT or GMT + 1) 9.00am to 5.00pm.

Telephone - +44 (0) 121 288 3945 Email - support@enterpoint.co.uk