Unformatted text preview:

University of Toronto ECE532 Digital Hardware Module m10 Fast Simplex Link FSL Interfaces Version for EDK 10 1 03 as of January 7 2009 Goals To learn about the Xilinx Fast Simplex Link FSL Interface To become familiar with the documentation you will need to refer to when designing your own systems with FSLs Requirements Module m01 Building a MicroBlaze System in XPS It is suggested that Modules m02 m03 m04 and m05 also be completed before proceeding Preparation Read the FSL datasheet XILINX EDK hw XilinxProcessorIPLib pcores fsl v20 v2 11 a doc fsl v20 pdf Read the FSL Application Note XAPP529 If you are short on time start reading at the middle of page 6 where they begin to describe the FSL interface in detail Background The Fast Simplex Link FSL is a uni directional point to point connection between two devices It is an abstraction designed to look like a reliable ordered communication channel that essentially wraps a FIFO with a standardized interface The implementation is parameterized to suit the characteristics of the design depending on whether the user needs it to be synchronous both devices run on the same clock or asynchronous the master and slave run on different clocks on the size and on various other parameters that the user can specify As a point to point simplex link a single FSL can connect only one master device to one slave device The master writes into the FSL and the slave reads from it Since we typically want to be able to communicate in both directions FSLs are often used in pairs where each of the two connected devices is a master on one of the FSLs and a slave on the other Important Notes Note that you can only have one master and one slave on a single FSL Note that one bidirectional duplex FSL link is in fact composed of one pair of FSLs If the FSL link connects devices A and B one of the FSLs has device A as the master and B as the slave The other FSL has B as the master and A as the slave Do not write to the FSL when the Full signal is high Doing so will cause the FSL data to be corrupted In the asynchronous FSL doing so will overwrite the word in FSL S Data with the latest data word This is not a concern when doing writes in C code because the MicroBlaze functions take care of checking the FSL Full and Exists lines 1 University of Toronto ECE532 Digital Hardware Module m10 Fast Simplex Link FSL Interfaces Creating the Hardware 1 Create a copy of the lab1 folder and rename to lab10 This will be the working project directory for this lab 2 Download the file m10 zip and unzip it in the directory containing the lab10 folder you just created This file contains an IDCT pcore that we will connect to MicroBlaze using the FSL and the source code for a test application Go into your lab10 code directory and delete lab1 c 3 Return to your lab10 folder and double click on system xmp to open the project 4 In the Project Repository under the IP Catalog section you should find the xil idct v1 00 a user core Add it to the system It should now appear in the System Assembly 5 Add two FSL links which you can find under Bus within the IP Catalog menu 6 Double click on microblaze 0 and under Bus Interfaces set the Number of FSL Links to 2 7 Connect MicroBlaze as a master on fsl v20 0 using MFSL0 and as a slave on fsl v20 1 using SFSL1 8 Connect the xil idct 0 user core as a master on fsl v20 1 using MFSL and as a slave on fsl v20 0 using SFSL 9 In the Ports view expand the xil idct 0 pcore instance Connect Clk to sys clk s and Reset to net gnd 10 Do the same for fsl v20 0 and fsl v20 1 Leave all other connections untouched Creating the Software 11 Remove lab1 c and add system c under Sources in the Applications Tab 12 Click on Build All User Applications to generate the libraries and compile your program Testing the Application 13 Generate the Bitstream and download it to the board 14 Using XMD download the executable and run it Observe the output on the HyperTerminal screen You should see the results of a sample application which tests the IDCT operation on 8 sets of data Read through the sample code system c to see how the software interface to the FSL links works There is a small mistake in the program which is causing the read values to be all zeros It is up to you to find the mistake and correct it hint think about how the FSLs are connected 15 After your system runs correctly try to use the blocking read and write FSL operations instead of the non blocking ones this is trivial 2


View Full Document

Toronto ECE 532 - Module m10 - Fast Simplex Link (FSL) Interfaces

Documents in this Course
Load more
Download Module m10 - Fast Simplex Link (FSL) Interfaces
Our administrator received your request to download this document. We will send you the file to your email shortly.
Loading Unlocking...
Login

Join to view Module m10 - Fast Simplex Link (FSL) Interfaces and access 3M+ class-specific study document.

or
We will never post anything without your permission.
Don't have an account?
Sign Up

Join to view Module m10 - Fast Simplex Link (FSL) Interfaces and access 3M+ class-specific study document.

or

By creating an account you agree to our Privacy Policy and Terms Of Use

Already a member?