2015-02-22 12:19:05 -05:00
|
|
|
__ _ __ ___ ___ ___ __ ___
|
|
|
|
/ / (_) /____ / _ \/ _ \/ _ | / |/ /
|
|
|
|
/ /__/ / __/ -_) // / , _/ __ |/ /|_/ /
|
|
|
|
/____/_/\__/\__/____/_/|_/_/ |_/_/ /_/
|
|
|
|
|
2018-02-22 04:10:54 -05:00
|
|
|
Copyright 2015-2018 / EnjoyDigital
|
2015-02-22 12:19:05 -05:00
|
|
|
|
|
|
|
A small footprint and configurable DRAM core
|
2018-02-22 04:10:54 -05:00
|
|
|
powered by LiteX & Migen
|
2015-02-22 12:19:05 -05:00
|
|
|
|
|
|
|
[> Intro
|
2017-06-22 10:57:14 -04:00
|
|
|
--------
|
2015-02-22 12:19:05 -05:00
|
|
|
LiteDRAM provides a small footprint and configurable DRAM core.
|
|
|
|
|
|
|
|
LiteDRAM is part of LiteX libraries whose aims are to lower entry level of
|
|
|
|
complex FPGA cores by providing simple, elegant and efficient implementations
|
2018-02-22 04:10:54 -05:00
|
|
|
of components used in today's SoC such as Ethernet, SATA, PCIe, SDRAM Controller...
|
2015-02-22 12:19:05 -05:00
|
|
|
|
|
|
|
Since Python is used to describe the HDL, the core is highly and easily
|
|
|
|
configurable.
|
|
|
|
|
2018-02-22 04:10:54 -05:00
|
|
|
LiteDRAM is built using LiteX and uses technologies developed in partnership with
|
|
|
|
M-Labs Ltd:
|
2015-02-22 12:19:05 -05:00
|
|
|
- Migen enables generating HDL with Python in an efficient way.
|
|
|
|
- MiSoC provides the basic blocks to build a powerful and small footprint SoC.
|
|
|
|
|
2018-02-22 04:10:54 -05:00
|
|
|
LiteDRAM can be used as LiteX library or can be integrated with your standard
|
|
|
|
design flow by generating the verilog rtl that you will use as a standard core.
|
2015-02-22 12:19:05 -05:00
|
|
|
|
|
|
|
[> Features
|
|
|
|
-----------
|
2016-05-03 19:13:00 -04:00
|
|
|
PHY:
|
|
|
|
- Generic SDRAM PHY (vendor agnostic, tested on Xilinx, Altera, Lattice)
|
|
|
|
- Spartan6 DDR/LPDDR/DDR2/DDR3 PHY (1:2 or 1:4 frequency ratio)
|
|
|
|
- Kintex7 DDR3 PHY (1:4 frequency ratio)
|
|
|
|
- Artix7 DDR3 PHY (1:4 frequency ratio)
|
|
|
|
Core:
|
|
|
|
- Fully pipelined, high performance.
|
|
|
|
- Configurable commands depth on bankmachines.
|
2018-08-29 10:34:53 -04:00
|
|
|
- Auto-Precharge.
|
2016-05-03 19:13:00 -04:00
|
|
|
Frontend:
|
|
|
|
- Configurable crossbar (simply declare your crossbar and use crossbar.get_port() to add a new port!)
|
|
|
|
- Ports arbitration transparent to the user.
|
2018-08-29 10:34:53 -04:00
|
|
|
- Native, AXI-MM or Wishbone user interface.
|
2016-05-03 19:13:00 -04:00
|
|
|
- DMA reader/writer.
|
|
|
|
- BIST.
|
2015-02-22 12:19:05 -05:00
|
|
|
|
2018-02-22 04:10:54 -05:00
|
|
|
[> FPGA Proven
|
|
|
|
---------------
|
|
|
|
LiteDRAM is already used in commercial and open-source designs:
|
|
|
|
- HDMI2USB: http://hdmi2usb.tv/home/
|
|
|
|
- and others commercial designs...
|
|
|
|
|
2015-02-22 12:19:05 -05:00
|
|
|
[> Possible improvements
|
2017-06-22 10:57:14 -04:00
|
|
|
------------------------
|
2018-08-29 10:34:53 -04:00
|
|
|
- add Avalon-ST interface.
|
2016-05-03 19:13:00 -04:00
|
|
|
- add support for Altera PHYs.
|
|
|
|
- add support for Lattice PHYs.
|
2018-02-22 04:10:54 -05:00
|
|
|
- add more documentation
|
2015-02-22 12:19:05 -05:00
|
|
|
- ... See below Support and consulting :)
|
|
|
|
|
|
|
|
If you want to support these features, please contact us at florent [AT]
|
2018-02-22 04:10:54 -05:00
|
|
|
enjoy-digital.fr.
|
2015-02-22 12:19:05 -05:00
|
|
|
|
2018-02-22 04:10:54 -05:00
|
|
|
[> Getting started
|
2015-02-22 12:19:05 -05:00
|
|
|
------------------
|
2018-03-01 04:42:34 -05:00
|
|
|
1. Install Python 3.5, Migen and FPGA vendor's development tools.
|
|
|
|
Get Migen from: https://github.com/m-labs/migen
|
2015-02-22 12:19:05 -05:00
|
|
|
|
2017-06-22 10:57:14 -04:00
|
|
|
2. Obtain LiteX and install it:
|
|
|
|
git clone https://github.com/enjoy-digital/litex --recursive
|
|
|
|
cd litex
|
2018-02-22 04:10:54 -05:00
|
|
|
python3 setup.py develop
|
2017-06-22 10:57:14 -04:00
|
|
|
cd ..
|
2015-02-22 12:19:05 -05:00
|
|
|
|
2018-02-22 04:10:54 -05:00
|
|
|
3. TODO: add/describe example design(s)
|
|
|
|
|
|
|
|
[> Tests
|
|
|
|
--------
|
|
|
|
Unit tests are available in ./test/.
|
|
|
|
To run all the unit tests:
|
|
|
|
./setup.py test
|
|
|
|
Tests can also be run individually:
|
|
|
|
python3 -m unittest test.test_name
|
2015-02-22 12:19:05 -05:00
|
|
|
|
|
|
|
[> License
|
2017-06-22 10:57:14 -04:00
|
|
|
----------
|
2015-02-22 12:19:05 -05:00
|
|
|
LiteDRAM is released under the very permissive two-clause BSD license. Under
|
|
|
|
the terms of this license, you are authorized to use LiteDRAM for closed-source
|
|
|
|
proprietary designs.
|
|
|
|
Even though we do not require you to do so, those things are awesome, so please
|
|
|
|
do them if possible:
|
|
|
|
- tell us that you are using LiteDRAM
|
|
|
|
- cite LiteDRAM in publications related to research it has helped
|
|
|
|
- send us feedback and suggestions for improvements
|
|
|
|
- send us bug reports when something goes wrong
|
|
|
|
- send us the modifications and improvements you have done to LiteDRAM.
|
|
|
|
|
|
|
|
[> Support and consulting
|
2017-06-22 10:57:14 -04:00
|
|
|
-------------------------
|
2015-02-22 12:19:05 -05:00
|
|
|
We love open-source hardware and like sharing our designs with others.
|
|
|
|
|
2018-02-22 04:10:54 -05:00
|
|
|
LiteDRAM is developed and maintained by EnjoyDigital.
|
2015-02-22 12:19:05 -05:00
|
|
|
|
|
|
|
If you would like to know more about LiteDRAM or if you are already a happy
|
|
|
|
user and would like to extend it for your needs, EnjoyDigital can provide standard
|
|
|
|
commercial support as well as consulting services.
|
|
|
|
|
|
|
|
So feel free to contact us, we'd love to work with you! (and eventually shorten
|
|
|
|
the list of the possible improvements :)
|
|
|
|
|
|
|
|
[> Contact
|
2017-06-22 10:57:14 -04:00
|
|
|
----------
|
2015-02-22 12:19:05 -05:00
|
|
|
E-mail: florent [AT] enjoy-digital.fr
|