

# Series XMC-SLX150 Spartan 6 Based FPGA XMC Module

# Getting Started with the XMC-SLX Engineering Design Kit

#### **ACROMAG INCORPORATED**

30765 South Wixom Road P.O. BOX 437

Wixom, MI 48393-7037 U.S.A.

Tel: (248) 624-1541 Fax: (248) 624-9234

Copyright 2011, Acromag, Inc., Printed in the USA. Data and specifications are subject to change without notice.

8500-894-A11B000

## **Table of Contents**

| GE | ETTING STARTED                                                   | 2 |
|----|------------------------------------------------------------------|---|
|    | Installing the Board and Device Drivers                          | 2 |
|    | Starting a New Xilinx Project                                    | 3 |
|    | Modifying the Provided VHDL Code                                 |   |
|    | Generating a Programming "MCS" File                              |   |
|    | Differences in VHDL between the XMC-SLX150 and the XMC-SLX150-1M |   |
|    | Xilinx ISE 12.3 Compiler Warnings                                |   |
|    | ······································                           |   |

All trademarks are the property of their respective owners.

You must consider the possible negative effects of power, wiring, component, sensor, or software failure in the design of any type of control or monitoring system. This is very important where property loss or human life is involved. It is important that you perform satisfactory overall system design and it is agreed between you and Acromag, that this is your responsibility.

#### **Getting Started**

The purpose of this document is to provide basic instructions on using the "XMC-SLX Engineering Design Kit" with the XMC-SLX Boards. It will focus on programming the FPGA of the XMC-SLX150 using VHDL, but can be easily modified to use with any model of the SLX line. This document also shows how to use the supplied dll files with a MFC application. It is assumed that the user has a working knowledge of Xilinx, VHDL and Visual C++. Note that this document assumes Windows is used as the operating systems. Linux users can follow the same general procedure but be aware that differences exist that are not noted in this document.

There are small differences in the VHDL between the XMC-SLX150(E) and the XMC-SLX150(E)-1M models due to differences in the SRAM size. Refer to the appendix at the end of this manual for further information on the VHDL differences.

## **Installing the Board** and Device Drivers

For first time users, turn off your computer, and unplug the power cord. Before touching either board, make sure to discharge all static electricity. Then attach the SLX150 to your carrier. Insert the carrier into an empty slot in your computer. When restarting your computer, you will be prompted to insert a CD with the drivers on it. At this point, insert the PCISW-API-WIN CD (software product sold separately from this EDK) into your CD-ROM drive. When the plug and play installation has completed, follow the steps to install the additional PCISW-API-WIN software on your computer. When finished, insert the CD titled **XMC-SLX Engineering Design Kit** and copy the **SLX150** folder to your computer.

Before you start, familiarize yourself with the XMC-SLX User's Manual included on the EDK CD and the PCleSLX Driver Function Reference included on the PCI Win32 Driver Software CD. The user's manual gives the memory addresses of all the registers, and their purposes. The function reference gives information on how to use the DLL file in C/C++, Visual Basic, and LabView (we will be focusing only on using the C/C++ demo program).

The Configuration Xilinx steps 1-13 following are also given in the Readme-SLX150.txt file included on the EDK CD. This file also contains detailed information on the contents of the CD including a description of the contents of the VHDL files. Read this file prior to reading this manual.

This manual assumes that Xilinx ISE Version 12.3 in used. Note that earlier versions are not supported and later versions may have alternate procedures. Also note that VHDL line numbers in this manual may not match the line numbers of the files provided in the EDK due to revisions.

#### **Starting a New Xilinx Project**

- Make a new directory on your computer and call it XC6SLX150.
- From the XC6SLX150 folder, copy the all the vhdl files in into the new XC6SLX150 folder. Then from the XC6SLX150 folder copy the XC6SLX150.ucf file to the XC6SLX150 folder. Note that all of the files are shown in the adjacent figure.
- 3. Start Xilinx's Project
  Navigator from your start
  menu. Xilinx ISE Design
  Suite 12.3 → ISE Design
  Tools → Project Navigator
- Open a new project by selecting File → New Project



 In the Project Name field, type SLX150. In the Location field type the path name where to find the XC6SLX150 folder. Make sure the Top-Level Module Type field is HDL, and click Next.



 Enter the following information if using the SLX150. Then click Next and then Finish.

Family: Spartan6

Device: XC6SLX150

Package: FGG676

Speed: -3



- 7. We will next add the files we copied from the CD. Follow these steps:
  - a. Select Project->Add Source.
  - b. Select the .ucf and all the .vhd files
  - c. Click the **Open** button.
  - d. The association for all files should be *All* for the .vhd files and *Implement* for the .ucf files. There are a total of 6 .vhd files and one .ucf file.
  - e. Click the OK button.
- In the Heirarchy Window, click on XC6SLX150\_arch (XC6SLX150.vhd) to highlight it.





 In the Processes Window, click on Generate
 Programming File so it is also highlighted.



10. Click on **Process** from the menu bar, and click on **Properties.** 

11. Click on the Startup Options tab and verify the following options are selected:

Note that if not all properties are shown change the Property display level from Standard to Advanced.

FPGA Start-up Clock: CCLK

Enable Internal Done Pipe: Not Checked

Done 6
Enable Outputs: 5
Release Write Enable: 5

Wait for DCM and PLL Lock: NoWait
Drive Done Pin High: Checked



- 12. Click on the **Configuration Options** tab. Verify that all options are set to default as shown in the screen shot to the right.
- 13. Click **OK**.



#### **Modifying the Provided VHDL Code**

To revise or add to the provided VHDL code, begin by double clicking on the **XC6SLX150-XC6SLX150\_arch (XC6SLX150.vhd)** file located in the **Hierarchy** window. This will open the VHDL file for editing.

Additional components and signals may be added between the current definitions at line 288..

```
-- Temperature Sensor Signals -----
285
286
    signal TEMP Sen Strobe : STD LOGIC;
    signal TEMP DATA: STD LOGIC VECTOR(12 downto 0);
287
288
289
    component DP SRAM
290
291
    port(
292
     --Global signal -----
293
       CLK: in STD LOGIC;
294
       RESET: in STD LOGIC;
295
296
```

After the **begin** keyword (line 491) additional instantiations for components may be added

```
TEMP SDO: in STD LOGIC -- SPI Data Input.
485
486
487
              );
488
    end component;
489
490
         ____
    begin
491
492
493
     SRR_INTn <= SR_INTn or SR3_INTn;</pre>
     SRR COLn <= SR COLn or SR3 COLn;
494
495
496
     SR3 CE1 <= '1';
     SR1 CE1 <= '1';
497
408
```

For simplicity we suggest starting by adding to or revising the provided VHDL code that is associated with the front I/O. To use the front I/O, begin by double clicking on the **AXM\_Module-AXM\_D\_arch (AXM\_D.vhd)** file located in the **Hierarchy** window. This will open the VHDL file for editing. To use the rear I/O, begin by double clicking on the **Rear\_IO-RearLVDS\_arch (RearLVDS.vhd)** file located in the **Hierarchy** window. This will likewise open the VHDL file associated with the rear I/O for editing

#### **Example Change**

Open XC6SLX150.vhd and scroll down to around line
 205. Add the line of code and accompanying comments as indicated by the box to the right. This

creates a new address strobe for our counter. It will be located in register 0x8020. Below is a simple example of some VHDL that could be used to control five of the SLX150's Front I/O differential channels (via the AXM-D02 or AXM-D04). It is included to show how the code supplied with the Engineering Design Kit can be modified for personal use.

```
signal Int_Polarity_Adr : STD_LOGIC; --0x801C
201

202 --Here we add the decode signal for the
203 --new counter address that we are going to send
204 --to the AXM
205 signal Counter_Adr : STD_LOGIC; --0x8020

206

207 --Rear J4 Connector Address Decode Signals
```

- 2. Around **line 388** insert these two lines of code to the declaration of the AXM\_D component. We will soon be changing the AXM\_D.vhd file to match this declaration.
- 3.Add the following around line 725 our mapping of the Counter\_Adr strobe to the AXM\_D instantiation. Now the AXM\_D component will receive all the information it needs for the design.
- 723 Int\_Polarity\_Adr => Int\_Polarity\_Adr,
  724

  725 |--Our address strobe
  726 | Counter\_Adr=> Counter\_Adr,
  727
  728 | --Write Stobes
- 4. We will now replace a previously unused memory address. Uncomment line 887 and 888 and replace the "NU" with Counter\_Adr. This will be the location in memory to access the counter.

```
LA(3) and LA(2) and Base_Address; <= not LA(8) and not LA(7) and not LA(6) and
                                                                                          --0x801C
886
887
      -- NU
                                                                                              LA(5) and not LA(4) and
                                    not LA(3) and not LA(2) and Base Address;
                                                                                            -0x8020
889
      -- NU
                                 <= not LA(8) and not LA(7) and not \overline{L}A(6) and
                                                                                              LA(5) and not LA(4) and
                                                                                          --0x8024
                                                          LA(2) and Base Address;
                                    not LA(3) and
890
                                                             LA(2) and Base_Address;
                                      not LA(8) and not LA(7) and not LA(6) and not LA(3) and not LA(2) and Base_Address;
                                                                                                LA(5)
```

5.To line 952 add the code in the red box. This is added to strobe the AXM (where the rest of the counter code will be located) when the Counter\_Adr has received a read or write command.

We are finished editing the XC5VLX110T.vhd file and will now be **editing the AXM\_D.vhd** file.

- 6. After opening AXM\_D.vhd, scroll down to line 31 and add the Counter\_Adr port. This is how the counter will be receiving the address strobe from the main vhdl code.
- 7.To line 64 add the write strobe for the counter. This will pulse when a write command is issued the counter address.
- 8. At line 78 add the signals (registers) that the counter will be using. Counter\_EN will enable the counter, Counter\_Inc will determine if the counter is incrementing or not, and Counter\_Reg is the binary counter.
- 9.At around line 231 we will insert the counter's write strobe. This will pulse Counter\_Stb when there is a write command to the Counter\_Adr.

```
950

951 AXM_Strobe <= DiffReg31to0_Adr or DigReg15to0_Adr or DiffDirReg_Adr or DigDirReg_Adr or 952 Int_Enable_Adr or Int_Type_Adr or Int_Polarity_Adr or Counter_Adr;
```

```
Int_Polarity_Adr: in STD_LOGIC; -- Interru

Int_StatClear_Stb0: in STD_LOGIC; -- Interru
```

```
76 signal IOA: STD_LOGIC_VECTOR (7 downto 0);
77
78 -- The Counter's Signals
79 -- Enable the counter for use
80 signal Counter_EN: STD_LOGIC;
81 -- Increment the Counter by one
82 signal Counter_Inc: STD_LOGIC;
83 -- The Counter's Register
84 signal Counter_Reg: STD_LOGIC_Vector(3 downto 0);
85
86 -- I/O component for detection of Change of State Ir
```

```
232
        -- The Counter Register's Write Strobes
233
       process (CLK)
234
            if (CLK'event and CLK = '1') then
235
               Counter Stb <= Counter Adr and not ADS n and
236
237
                              not LBEO n and LW R n;
238
            end if:
239
         end process;
240
241
           -- Interrupt Registers Write Strobes
```

- 10. At line 350 there is the process statement to control the Differential Direction Control Register. Add the red code to cause channels 0-3 to become outputs when there is a write to the counter address, and make sure that channel 4 is an input to handle the increment line.
- 11. Add this process statement at line 434 to handle the enable for the counter. Notice that Counter EN receives its information from the local data bus (LD) bit-5.
- 12. Add this process statement at line 449 to handle the external increment line for the counter. Notice that the Counter Inc receives its information from channel 4. The counter is stopped and started using this input line.
- 13. Add this process statement at line 464 to handle the counter. When the counter is enabled, it will check the Counter\_Inc line to see if it has a positive logic equivalence of '1' every positive clock edge. If it does then the counter will be incremented.

```
--Front I/O Differential Direction Control Register 0x8008
process (CLK, RESET)
begin
    if (RESET = '1') then
       DiffDir Reg(7 downto 0) <= "000000000";
    elsif (CLK event and CLK = '1') then
       if (DiffDirReg_Stb0 = '1') then
          DiffDir Reg(7 downto 0) <= LD(7 downto 0);
       -- If there is a Counter_Stb pre-config the direction
       -- to channel 4 as an input and channels 3-0 as outputs
       elsif (Counter Stb = '1') then
          DiffDir Reg(7 downto 0) <= "00001111";
          DiffDir Reg(7 downto 0) <= DiffDir_Reg(7 downto 0);</pre>
       end if:
    end if:
end process;
435
       -- Counter EN Register 0x8020 bit 5
        -- Turns on the functionality of the Counter
436
437
        process (CLK, RESET)
438
       begin
439
           if (RESET = '1') then
               Counter EN <= '0';
440
           elsif (CLK'event and CLK = '1') then
441
442
              if (Counter Stb = '1') then
443
                  Counter EN <= LD(5);
444
               else
445
                  Counter EN <= Counter EN;
446
               end if:
447
            end if:
448
        end process;
450
        -- Counter Inc determine when to load the counter
451
        -- Register 0x8020 bit 4
452
        process (CLK, RESET)
        begin
453
           if (RESET = '1') then
454
455
              Counter Inc <= '0';
           elsif (CLK'event and CLK = '1') then
456
457
              if (Counter EN = '1') then
458
                 Counter Inc <= IO DIGITAL(4);
459
                 Counter Inc <= Counter Inc;
460
461
              end if:
462
           end if:
463
        end process;
465
        -- Counter_Reg determine when to increment the counter
466
        process (CLK, RESET)
467
        begin
468
          if (RESET = '1') then
             Counter Reg <= "00000";
469
           elsif (CLK'event and CLK = '1') then
470
```

```
471
              if (Counter_EN = '1' and Counter_Inc = '1') then
472
                 Counter Reg <= Counter Reg + 1;
473
474
                 Counter_Reg <= Counter_Reg;
475
              end if;
476
           end if:
477
        end process;
```

14. Add the following lines of red code to the READ\_DATA MUX. This will allow the read and write commands to access the counter address at 8020H.

Bits 3-0 will hold the four bits of the counter, bit 4 will hold the increment line, and bit 5 will hold the enable.

547
548
549
550
551

```
535
     READ DATA(O) <=
              (Counter Reg(O) and Counter Adr) or
537
              (IO_DIFF(0) and DiffReg31toO_Adr) or
538
              (IO DIGITAL(O) and DigReg15toO Adr) or
              (DiffDir_Reg(O) and DiffDirReg_Adr) or
539
540
              (DigDir_Reg(O) and DigDirReg_Adr) or
541
542
              (IntEnA_Reg(0) and Int_Enable_Adr) or
              (IntTypk Reg(0) and Int_Type &dr) or
(IntPolk Reg(0) and Int_Polarity &dr);
543
544
545
546
547
     READ DATA(1) <=
548
              (Counter_Reg(1) and Counter_Adr) or
549
              (IO DIFF(1) and DiffReg31toO Adr) or
              (IO DIGITAL(1) and DigReg15toO Adr) or
551
              (DiffDir_Reg(1) and DiffDirReg_Adr) or
              (DigDir Reg(1) and DigDirReg Adr) or
553
554
              (IntEnA_Reg(1) and Int_Enable_Adr) or
555
              (IntTypk Reg(1) and Int Type Adr) or
556
              (IntPolA_Reg(1) and Int_Polarity_Adr);
559 READ_DATA(2) <=
               (Counter_Reg(2) and Counter_Adr) or
560
               (IO_DIFF(2) and DiffReg31toO_Adr) or
561
562
               (IO DIGITAL(2) and DigReg15toO Adr) or
563
               (DiffDir Reg(2) and DiffDirReg Adr) or
564
               (DigDir Reg(2) and DigDirReg Adr) or
565
566
               (IntEn& Reg(2) and Int Enable Adr) or
567
               (IntTypA_Reg(2) and Int_Type_Adr) or
568
               (IntPolk Reg(2) and Int Polarity Adr);
569
570
571
     READ_DATA(3) <=
572
               (Counter_Reg(3) and Counter_Adr) or
573
               (IO DIFF(3) and DiffReg31toO Adr) or
574
               (IO DIGITAL(3) and DigReg15toO Adr) or
575
               (DiffDir Reg(3) and DiffDirReg Adr) or
               (DigDir Reg(3) and DigDirReg Adr) or
576
577
578
               (IntEnA Reg(3) and Int Enable Adr) or
579
               (IntTypk Reg(3) and Int Type Adr) or
               (IntPola_Reg(3) and Int_Polarity_Adr);
580
      READ_DATA(4) <=
583
584
                (Counter_Inc and Counter_Adr) or
585
                (IO DIFF(4) and DiffReg31toO Adr) or
586
                (IO DIGITAL(4) and DigReg15toO Adr) or
587
                (DiffDir Reg(4) and DiffDirReg Adr) or
588
                (DigDir_Reg(4) and DigDirReg_Adr) or
589
                (IntEnk_Reg(4) and Int_Enable_kdr) or
590
591
                (IntTypk Reg(4) and Int Type Adr) or
592
                (IntPolk Reg(4) and Int Polarity Adr);
593
594
     READ DATA(5) <=
595
                (Counter_EN and Counter_Adr) or
596
                (IO DIFF(5) and DiffReg31toO Adr) or
597
                (IO DIGITAL(5) and DigReg15toO Adr) or
598
                (DiffDir Reg(5) and DiffDirReg Adr) or
599
                (DigDir_Reg(5) and DigDirReg_Adr) or
600
601
                (IntEnà Reg(5) and Int Enable Adr) or
602
                (IntTypk Reg(5) and Int Type Adr) or
                (IntPolk Reg(5) and Int Polarity Adr);
603
```

#### Generating a Programming "MCS" File

The Xilinx "MCS" contains the information to program the X6SLX150 through either FLASH or JTAG. These instructions will talk you through the procedure for creating a MCS file.

- Select XC5VLX110T-XC5VLX110T\_arch (XC5VLX110T.vhd) in the Hierarchy Window.
- Select Generate
   Programming File in the
   Processes Window. Then select Process → Run.

**Note:** If there are any errors, correct them and repeat steps 1 and 2. There may be a few warnings.

3. Right-click on **Generate Target PROM/ACE File,** and click on **Run**.





4. Select OK.



5. Double select Create PROM File (PROM File Formatter)



 Select Generic Parallel PROM and the select the green arrow.



 Select 8M and then select Add Storage Device. Then select the next green arrow.



8. Verify the Output File location and enter an Output File Name. For example SLX150. Leave all other default options and select **OK**.



9. Click OK.



10. Select **xc6slx150.bit** file and then click**Open**.



11. Click NO.



12. Click **OK**.



- 13. Click OK again.
- 14. In the left pane iMPACT Process Windows Double click **Generate File.**



Of the process completed with no errors the *Generate Succeeded* message will be displayed.

### Generate Succeeded

The SLX150.mcs file now resides in the targeted directory. From here the file can be downloaded to FLASH or directly to the FPGA using Acromag's software demonstration program for Windows or Linux. The file can also be downloaded via JTAG via the AXM-EDK adapter board when used in conjunction with a compatible Xilinx download cable.

#### Differences in VHDL between the XMC-SLX150 and the XMC-SLX150-1M

The Dual-Port SRAM on the XMC-SLX150-1M is four times the size as on the base model. The result is that all registers that manage or use the address of the SRAM must have two extra bits. The majority of these registers are defined via a constant declaration on line 93 of DP\_SRAM.vhd. The declaration is **constant addr\_max: integer := 19;** (or 17 for the base model). The registers affected are listed below.

| Register/Counter | Description                                                                                           |
|------------------|-------------------------------------------------------------------------------------------------------|
| DMA0_THRESHOLD   | Register corresponding to 0x8048.                                                                     |
| DMA1_THRESHOLD   | Register corresponding to 0x804C.                                                                     |
| DMA0_RESET       | Register corresponding to 0x8050.                                                                     |
| DMA1_RESET       | Register corresponding to 0x8054.                                                                     |
| SRAM_ADD_Count   | Counter with the current address of the SRAM. Can be set and read via 0x8038 & 0x803C.                |
| ADD_RESET_VALUE  | Counter that contains a reset value for the SRAM which could from either of the RESET registers above |

In addition there are some minor changes to the read logic. All differences are shown on the following page. Please note that there are no differences in the top level *x6slx150.vhd* file.

#### DP\_SRAM.vhd for XMC-SLX150

#### DP\_SRAM.vhd for XMC-SLX150-1M



#### **Xilinx ISE 12.3 Compiler Warnings**

Note that ISE 12.3 will generate the following warnings when compiling the example design. These warnings can be safety ignored as they reference unused signals.

- WARNING:Xst:647 Input <LD<20:30>> is never used. This port will be preserved and left unconnected if it belongs to a top-level block or it belongs to a sub-block and the hierarchy of this sub-block is preserved.
- WARNING:Xst:647 Input <LD<31:30>> is never used. This port will be preserved and left unconnected if it belongs to a top-level block or it belongs to a sub-block and the hierarchy of this sub-block is preserved.
- WARNING:Xst:2677 Node <Latch\_data\_0> of sequential type is unconnected in block <Temp\_sensor>.
- WARNING:Xst:2677 Node <Latch\_data\_1> of sequential type is unconnected in block <Temp\_sensor>.
- WARNING:Xst:2677 Node < Latch data 2> of sequential type is unconnected in block < Temp sensor>.
- WARNING:Xst:2677 Node <Latch\_data\_0> of sequential type is unconnected in block <SPI\_Temp\_Sensor>.
- WARNING:Xst:2677 Node <Latch\_data\_1> of sequential type is unconnected in block <SPI\_Temp\_Sensor>.
- WARNING:Xst:2677 Node < Latch data 2> of sequential type is unconnected in block < SPI Temp Sensor>.