

# Campbell (MAXREFDES4#) Nexys 3 Quick Start Guide

Rev 0; 1/13



Maxim Integrated cannot assume responsibility for use of any circuitry other than circuitry entirely embodied in a Maxim Integrated product. No circuit patent licenses are implied. Maxim Integrated reserves the right to change the circuitry and specifications without notice at any time.

Maxim Integrated 160 Rio Robles, San Jose, CA 95134 USA 1-408-601-1000

# **Table of Contents**

| 1. | Required Equipment                              | 3    |
|----|-------------------------------------------------|------|
|    | Overview                                        |      |
|    | Included Files                                  |      |
|    | Procedure                                       |      |
| 5. | Code Documentation                              | . 18 |
| 6. | Appendix A: Project Structure and Key Filenames | . 19 |
| 7. | Trademarks                                      | . 19 |
| 8. | Revision History                                | . 20 |

## 1. Required Equipment

- PC with Windows® OS with Xilinx® ISE®/SDK version 13.4 or later and two USB ports
- License for Xilinx EDK/SDK version 13.4 or later
- Campbell (MAXREFDES4#) board
- Nexys™3 development kit
- Industrial sensor or signal source

#### 2. Overview

Below is a high-level overview of the steps required to quickly get the Campbell design running by downloading and running the FPGA project. Detailed instructions for each step are provided in the following pages. The Campbell (MAXREFDES4#) subsystem reference design will be referred to as Campbell throughout this document.

- 1) Connect the Campbell board to the JB1 port of a Nexys 3 development kit as shown in Figure 1. Ensure the connector is aligned as shown in Figure 2.
- 2) Download the latest RD4V01\_00.ZIP file located at the Campbell page.
- Extract the RD4V01\_00.ZIP file to a directory on your PC.
- 4) Open the Xilinx SDK.
- 5) Download the bitstream (.BIT) file to the board. This bitstream contains the FPGA hardware design and software bootloader.
- 6) Open a terminal program to communicate with FPGA board.
- 7) Use Xilinx SDK to download and run the executable file (.ELF) on the MicroBlaze $^{\text{TM}}$ .



Figure 1. Campbell Board Connected to Nexys 3 Development Kit



Figure 2. Pmod™ Connector Alignment

#### 3. Included Files

The top level of the hardware design is a Xilinx ISE Project Navigator Project (.XISE) for Xilinx ISE version 13.4. The Verilog-based HDL design instantiates the MicroBlaze core, the support hardware required to run the MicroBlaze, and the peripherals that interface to the Pmod ports. This is supplied as a Xilinx software development kit (SDK) project that includes a demonstration software application to evaluate the Campbell subsystem reference design. The lower level c-code driver routines are portable to the user's own software project.



Figure 3. Block Diagram of FPGA Hardware Design

#### 4. Procedure

**Note:** In the following sections, software-related items are identified by bolding. Text in **bold** refers to items directly from the EV kit software. Text in **bold and underlined** refers to items from the Windows operating system.

- Connect the Campbell board to the JB1 port of a Nexys 3 development kit as shown on the first page of this document. Power up the Nexys 3 development kit. The Campbell board is completely powered from the Nexys 3 development kit and no external power is required.
- Download the latest RD4V01\_00.ZIP file located at <u>www.maximintegrated.com/AN5562</u>. All files available for download are available at the bottom of the page.
- 3. Extract the RD4V01\_00.ZIP file to a directory on your PC. The location is arbitrary but the path prior to where you extract the .ZIP file must not exceed 82 characters due to the Windows 250-character total path limitation. For example, this 90-character preceding path would be an example of a path that would be too long:

C:\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\0123456789\01234567

(This path is too long.)

In addition, the Xilinx tools require the path to not contain any spaces.

C:\Do Not Use Spaces In The Path\RD4V01\_00.ZIP (This path has spaces.)

For the purposes of this document, it will be **C:\designs\maxim\RD4V01\_00\**. See **Appendix A: Project Structure and Key Filenames** in this document for the project structure and key filenames.

4. Open the Xilinx Software Development Kit (SDK) from the Windows <u>Start</u> menu.



5. SDK will prompt for a workspace directory, which is the location where the software project is located. For this example, it is

#### C:\designs\maxim\RD4V01 00\RD4 NEXYS3 V01 00\Design Files\sdkWorkspace

Click **OK** and SDK will open. The Xilinx SDK is based on an Eclipse<sup>™</sup>-based IDE, so it will be a familiar flow for many software developers.



6. Review the SDK IDE. The **Project Explorer** in the upper left tab should have three components as shown in the image below. If all three subfolders are present, you can skip the next step.



7. If the Project Explorer does not contain these three subfolders, launch the File | Import menu, expand the General folder, and select Existing Projects into Workspace. Click Next. Set the root directory to:

#### C:\designs\maxim\RD4V01\_00\RD4\_NEXYS3\_V01\_00\Design\_Files\sdkWorkspace

and the missing projects should appear in SDK **Project Explorer** with their checkboxes checked.

Click **Finish** to import the projects.



8. To download the bitstream (.BIT) file to the board, click on the **Program FPGA** icon (which looks like a green chain of devices):



The **Program FPGA** dialog box appears. From here, an FPGA bitstream (.BIT) file is selected as well as an FPGA BMM (.BMM) file. Be sure to select the .BIT file and the .BMM by using the paths below.

#### Bitstream:

C:\designs\maxim\RD4V01\_00\RD4\_NEXYS3\_V01\_00\Design\_Files\ sdkWorkspace\system\_hw\_platform\system.bit

#### BMM File:



Additionally, make sure **bootloop** is selected as shown, then press **Program**.

It takes approximately 10 seconds to download the FPGA then a message box indicating "FPGA configuration complete" appears.

9. Set up the terminal program to run on the PC using the following steps. Before loading the executable firmware file on the FPGA, the terminal program on the PC should be running. The example firmware running on the FPGA communicates with the PC via a USB port set up to emulate a serial port (UART). To establish this communication link, the PC must be configured with the appropriate Windows drivers. A suitable terminal program such as Tera Term or HyperTerminal should be invoked.

The Nexys 3 utilizes the FTDI FT232 USB-UART bridge IC, so you need to install FTDI's virtual COM port (VCP) driver for their FT232 device family. Make sure to choose the driver that supports a **Virtual Com Port**, also known as VCP. These can be obtained from the FTDI website (<u>www.ftdichip.com</u>).

Once installed, Windows assigns a previously unused COM port. Use the Windows <u>Control Panel</u> | <u>System</u> | <u>Device Manager</u> to determine the COM port number. (It will be named **USB Serial Port**). Make a note of which COM port this is. That information is needed in the next step.

Next, a terminal emulation program needs to be installed and launched. For Windows XP® and earlier systems, the HyperTerminal program is the usual choice. However, since HyperTerminal was eliminated from Windows 7, it may

be necessary to locate an alternative. Several are available; one good choice is called Tera Term (<a href="http://ttssh2.sourceforge.jp/">http://ttssh2.sourceforge.jp/</a>). Whatever terminal program you choose, the communication should be set up by opening the COM port number previously described above and the port configured as:

bits per second: 460,800;

data bits: 8;

parity: none;

stop bits: 1;

flow control: none.

10. Use the Xilinx SDK to download and run the executable ELF (.ELF) file on the MicroBlaze using the following steps.

Right-click the mouse while the **MAXREFDES4 C** project is selected, choose the **Run As** menu, and then **Run Configurations...** menu as shown below.







## Next, press the Search Project button.



## Double-click on the **MAXREFDES4.elf** binary.





Verify the application is selected and press the **Run** button.

Once the Debug/MAXREFDES4 configuration is set up once, you just need to press the **Run** button if you ever want to run the program again.



At this point, the application is running on the MicroBlaze and the terminal program should show the menu below. Make the desired selections by pressing the appropriate keys on the keyboard. For example, to select continuous sampling, press **0**.



#### 5. Code Documentation

Code documentation can be found at:

C:\...\RD4V01 00\RD4 NEXYS3 V01 00\Code Documentation\



To view the code documentation in HTML format with a browser, open the **MainPage.html** file.

To view the code documentation in PDF format with a PDF reader, open the MAXREFDES4\_Code\_Documentation.pdf file.

## 6. Appendix A: Project Structure and Key Filenames



#### 7. Trademarks

Eclipse is a trademark of Eclipse Foundation, Inc.

MicroBlaze is a trademark of Xilinx, Inc.

Nexys is a trademark of Digilent, Inc.

Pmod is a trademark of Digilent, Inc.

Spartan is a registered trademark of Xilinx, Inc.

Windows is a registered trademark and registered service mark and Windows XP is a registered trademark of Microsoft Corporation.

Xilinx is a registered trademark and registered service mark of Xilinx, Inc.

## 8. Revision History

| REVISION<br>NUMBER | REVISION DATE | DESCRIPTION     | PAGES<br>CHANGED |
|--------------------|---------------|-----------------|------------------|
| 0                  | 1/13          | Initial release |                  |