- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi,
I have an image loaded on a Stratix V FPGA which includes a PCIe core and DDR3 controller as an end point. The FPGA is of course on a PCIe card. I would like to write a C program which runs on the host Linux PC and writes data to the card over PCIe. The idea is to have a program write data to the on-board DDR3 RAM. What is the best way to do this? Are there any libraries provided to communicate with a PCIe device? Thanks in advance.Link Copied
2 Replies
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
There are lots of examples lurking.
Linux has a /dev entry for each BAR of every PCI slave, so it is as simple as identifying the correct entry, opening the device, and using read(), write() or mmap(). These transfers will be relatively slow because each memory access will be a separate PCIe transfer and they take a long time. Fine for program load and debug, not really any use for transferring 'real' data.- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi,
Just search for "Quartus PCIe DMA reference designs". One of the reference designs that pops up is this: http://www.altera.com/support/refdesigns/ip/interface/ref-pciexpress-avalonmm-hp.html There is a section that explains how to access the devices from Linux. Thanks, Evgeni
Reply
Topic Options
- Subscribe to RSS Feed
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Bookmark
- Subscribe
- Printer Friendly Page