mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
194 lines
12 KiB
Markdown
194 lines
12 KiB
Markdown
<p align="center"><img src="https://raw.githubusercontent.com/enjoy-digital/litex/master/doc/litex.png"></p>
|
|
|
|
```
|
|
Copyright 2012-2021 / Enjoy-Digital & LiteX developers
|
|
```
|
|
[data:image/s3,"s3://crabby-images/1d36e/1d36e660e0640a59827a73041de8c31a9a871a66" alt=""](https://github.com/enjoy-digital/litex/actions)
|
|
data:image/s3,"s3://crabby-images/5046b/5046be1fa7f366ab18b6b706d530d6a4a1660482" alt="License"
|
|
|
|
# Welcome to LiteX!
|
|
|
|
|
|
The LiteX framework provides a convenient and efficient infrastructure to create FPGA Cores/SoCs, to explore various digital design architectures and create [full FPGA based systems](https://github.com/enjoy-digital/litex/wiki/Projects).
|
|
|
|
**Want to get started and/or looking for documentation? Make sure to visit the [Wiki](https://github.com/enjoy-digital/litex/wiki)!**
|
|
|
|
**A question or want to get in touch? Our IRC channel is [#litex at irc.libera.chat]**.
|
|
|
|
LiteX provides all the common components required to easily create an FPGA Core/SoC:
|
|
- :heavy_check_mark: Buses and Streams (Wishbone, AXI, Avalon-ST) and their interconnect.
|
|
- :heavy_check_mark: Simple cores: RAM, ROM, Timer, UART, JTAG, etc….
|
|
- :heavy_check_mark: Complex cores through the ecosystem of cores: [LiteDRAM](https://github.com/enjoy-digital/litedram), [LitePCIe](https://github.com/enjoy-digital/litepcie), [LiteEth](https://github.com/enjoy-digital/liteeth), [LiteSATA](https://github.com/enjoy-digital/litesata), etc...
|
|
- :heavy_check_mark: Various CPUs & ISAs: RISC-V, OpenRISC, LM32, Zynq, X86 (through a PCIe), etc...
|
|
- :heavy_check_mark: Mixed languages support with VHDL/Verilog/(n)Migen/Spinal-HDL/etc... integration capabilities.
|
|
- :heavy_check_mark: Powerful debug infrastructure through the various [bridges](https://github.com/enjoy-digital/litex/wiki/Use-Host-Bridge-to-control-debug-a-SoC) and [Litescope](https://github.com/enjoy-digital/litescope).
|
|
- :heavy_check_mark: Direct/Fast simulation through [Verilator](https://www.veripool.org/verilator/).
|
|
- :heavy_check_mark: Build backends for open-source and vendors toolchains.
|
|
- :heavy_check_mark: And a lot more... :)
|
|
|
|
By combining LiteX with the ecosystem of cores, creating complex SoCs becomes a lot easier than with traditional approaches while providing better portability and flexibility: Here is for example a Multi-core Linux Capable SoC based on VexRiscv-SMP CPU, LiteDRAM, LiteSATA built and integrated with LiteX, running on a cheap repurposed [Acorn CLE215+ Mining Board](https://github.com/enjoy-digital/litex/wiki/Use-LiteX-on-the-Acorn-CLE-215):
|
|
data:image/s3,"s3://crabby-images/bfc30/bfc306de3e357071f0840bf40f2f22f6bd5b4edf" alt=""
|
|
For more info, have a look at [Linux-on-LiteX-Vexriscv](https://github.com/litex-hub/linux-on-litex-vexriscv) project and try running Linux on your FPGA board!
|
|
|
|
LiteX's digital logic is currently described with [Migen](https://github.com/m-labs/migen) which does not prevent users to create mixed language projects:
|
|
- It's very common and easy to integrate VHDL/Verilog/SystemVerilog/nMigen/Spinal-HDL code in LiteX!
|
|
- It's also very common to do the opposite and generate the LiteX design as a verilog file and integrate it in a traditional flow.
|
|
|
|
|
|
LiteX was initially developed by [Enjoy-Digital](http://enjoy-digital.fr/) to create projects for clients (and we are still using it for that :)) and trying to take the different clients' requirements/needs consideration made, we think, the framework very flexible:
|
|
- Some users only want to use it to easily interconnect their existing VHDL/Verilog/SV cores.
|
|
- Some users are only interested to reuse the PCIe/Ethernet/SATA/etc cores as regular core and just integrate them in their traditional flow.
|
|
- Some users with a hardware background start with the above approaches and then switch later to the full Python flow since find it more efficient.
|
|
- Some users with a software background and fluent with Python start playing with FPGAs while they would probably never touch FPGA otherwise :)
|
|
- Etc...
|
|
|
|
We are well aware that everyone has a different background, so it's up to you to pick the right approach with LiteX that will be convenient for you!
|
|
|
|
To get started we encourage you to read the [wiki](https://github.com/enjoy-digital/litex/wiki).
|
|
|
|
You already have a FPGA board(s)? Visit [LiteX-Boards](https://github.com/litex-hub/litex-boards) to see if your board(s) is already supported!
|
|
|
|
The framework is also far from perfect and we'll be happy to have your [feedback or/and contributions](https://github.com/enjoy-digital/litex/wiki/Feedback-Contribution-Support).
|
|
|
|
Have fun! :wink:
|
|
|
|
# Typical LiteX design flow:
|
|
```
|
|
+---------------+
|
|
|FPGA toolchains|
|
|
+----^-----+----+
|
|
| |
|
|
+--+-----v--+
|
|
+-------+ | |
|
|
| Migen +--------> |
|
|
+-------+ | | Your design
|
|
| LiteX +---> ready to be used!
|
|
| |
|
|
+----------------------+ | |
|
|
|LiteX Cores Ecosystem +--> |
|
|
+----------------------+ +-^-------^-+
|
|
(Eth, SATA, DRAM, USB, | |
|
|
PCIe, Video, etc...) + +
|
|
board target
|
|
file file
|
|
```
|
|
LiteX already supports various softcores CPUs: VexRiscv, Rocket, LM32, Mor1kx, PicoRV32, BlackParrot and is compatible with the LiteX's Cores Ecosystem:
|
|
|
|
| Name | Build Status | Description |
|
|
| ------------------------------------------------------------ | ---------------------------------------------------------------------------------------------------------------------------------- | ------------------------- |
|
|
| [LiteX-Boards](http://github.com/litex-hub/litex-boards) | [data:image/s3,"s3://crabby-images/640b4/640b4c6df4a993800cf1be7b7ea0050a5d7e2f4d" alt=""](https://github.com/litex-hub/litex-boards/actions) | Boards support |
|
|
| [LiteDRAM](http://github.com/enjoy-digital/litedram) | [data:image/s3,"s3://crabby-images/f4779/f47791d7fe27ff6f1be988bbbb1c50c8623c3656" alt=""](https://github.com/enjoy-digital/litedram/actions) | DRAM |
|
|
| [LiteEth](http://github.com/enjoy-digital/liteeth) | [data:image/s3,"s3://crabby-images/1b7e3/1b7e3793be828b6991e23563096e54a6b4758882" alt=""](https://github.com/enjoy-digital/liteeth/actions) | Ethernet |
|
|
| [LitePCIe](http://github.com/enjoy-digital/litepcie) | [data:image/s3,"s3://crabby-images/03722/037224e458c19304e7025cb9f6ee6bd5a267669b" alt=""](https://github.com/enjoy-digital/litepcie/actions) | PCIe |
|
|
| [LiteSATA](http://github.com/enjoy-digital/litesata) | [data:image/s3,"s3://crabby-images/0be65/0be65912708efd45ec497958520052df2a803370" alt=""](https://github.com/enjoy-digital/litesata/actions) | SATA |
|
|
| [LiteSDCard](http://github.com/enjoy-digital/litesdcard) | [data:image/s3,"s3://crabby-images/085ce/085ce42936830d1648bd8b1d3b46fed2a47152cb" alt=""](https://github.com/enjoy-digital/litesdcard/actions) | SD card |
|
|
| [LiteICLink](http://github.com/enjoy-digital/liteiclink) | [data:image/s3,"s3://crabby-images/f2eb0/f2eb0cb961f3434609e0ae454f813dc8a535e871" alt=""](https://github.com/enjoy-digital/liteiclink/actions) | Inter-Chip communication |
|
|
| [LiteJESD204B](http://github.com/enjoy-digital/litejesd204b) | [data:image/s3,"s3://crabby-images/0ef93/0ef93748e6fcebee4debbd09c7be4c53ce06a2dd" alt=""](https://github.com/enjoy-digital/litejesd204b/actions) | JESD204B |
|
|
| [LiteSPI](http://github.com/litex-hub/litespi) | [data:image/s3,"s3://crabby-images/9051e/9051e48263d766e01bc584ec2feff70d32d53c53" alt=""](https://github.com/litex-hub/litespi/actions) | SPI/SPIFlah |
|
|
| [LiteHyperBus](http://github.com/litex-hub/litehyperbus) | [data:image/s3,"s3://crabby-images/c64e1/c64e151a018ac6a1b11c747e65958b73a602c3ee" alt=""](https://github.com/litex-hub/litehyperbus/actions) | HyperBus/HyperRam |
|
|
| [LiteScope](http://github.com/enjoy-digital/litescope) | [data:image/s3,"s3://crabby-images/6e143/6e143f3d422eeffb217431a31de3aff2bfb89cbf" alt=""](https://github.com/enjoy-digital/litescope/actions) | Logic analyzer |
|
|
|
|
# Examples of designs built with LiteX:
|
|
Custom PCIe SDI Capture/Playback board built around LitePCIe and integrated with LiteX, allowing full control of the SDI flow and very low latency.
|
|
data:image/s3,"s3://crabby-images/2e6c0/2e6c0ed1494582eb49cfe9464a1f8b3a48a85e1f" alt=""
|
|
Alternative firmware/gateware for the SDS1104X-E Scope:
|
|
data:image/s3,"s3://crabby-images/d45a7/d45a712da2ba80bf61109d56c9924bb848c872b4" alt="enter image description here"
|
|
HBM2 test infrastructure on Forest Kitten 33:
|
|
data:image/s3,"s3://crabby-images/4949a/4949a0858e7bc8465612893c66432fb352e4b27e" alt="enter image description here"
|
|
|
|
To discover more products/projects built with LiteX, visit the [projects page](https://github.com/enjoy-digital/litex/wiki/Projects) on the Wiki.
|
|
|
|
# Papers, Presentations, Tutorials, Links
|
|
**FPGA lessons/tutorials:**
|
|
- https://github.com/enjoy-digital/fpga_101
|
|
|
|
**Migen tutorial:**
|
|
- https://m-labs.hk/migen/manual
|
|
|
|
**OSDA 2019 paper/slides:**
|
|
- https://osda.gitlab.io/19/1.1.pdf
|
|
- https://osda.gitlab.io/19/1.1-slides.pdf
|
|
|
|
**Linux on LiteX-Vexriscv:**
|
|
- https://github.com/litex-hub/linux-on-litex-vexriscv
|
|
|
|
**RISC-V Getting Started Guide:**
|
|
- https://risc-v-getting-started-guide.readthedocs.io/en/latest/
|
|
|
|
**LiteX vs. Vivado First Impressions:**
|
|
- https://www.bunniestudios.com/blog/?p=5018
|
|
|
|
**35C3 - Snakes and Rabbits - How CCC shaped an open hardware success:**
|
|
- https://www.youtube.com/watch?v=AlmVxR0417c
|
|
|
|
**Tim has to many projects - LatchUp Edition:**
|
|
https://www.youtube.com/watch?v=v7WrTmexod0
|
|
|
|
|
|
# Sub-packages
|
|
**litex.gen**
|
|
Provides specific or experimental modules to generate HDL that are not integrated in Migen.
|
|
|
|
**litex.build:**
|
|
Provides tools to build FPGA bitstreams (interface to vendor toolchains) and to simulate HDL code or full SoCs.
|
|
|
|
**litex.soc:**
|
|
Provides definitions/modules to build cores (bus, bank, flow), cores and tools to build a SoC from such cores.
|
|
|
|
# Quick start guide
|
|
1. Install Python 3.6+ and FPGA vendor's development tools and/or [Verilator](http://www.veripool.org/).
|
|
2. Install Migen/LiteX and the LiteX's cores:
|
|
|
|
```sh
|
|
$ wget https://raw.githubusercontent.com/enjoy-digital/litex/master/litex_setup.py
|
|
$ chmod +x litex_setup.py
|
|
$ ./litex_setup.py --init --install --user (--user to install to user directory)
|
|
```
|
|
Later, if you need to update all repositories:
|
|
```sh
|
|
$ ./litex_setup.py --update
|
|
```
|
|
|
|
> **Note:** On MacOS, make sure you have [HomeBrew](https://brew.sh) installed. Then do, ``brew install wget``.
|
|
|
|
> **Note:** On Windows, it's possible you'll have to set `SHELL` environment variable to `SHELL=cmd.exe`.
|
|
|
|
3. Install a RISC-V toolchain (Only if you want to test/create a SoC with a CPU):
|
|
```sh
|
|
$ pip3 install meson ninja
|
|
$ ./litex_setup.py --gcc=riscv
|
|
```
|
|
|
|
4. Build the target of your board...:
|
|
|
|
Go to litex-boards/litex_boards/targets and execute the target you want to build.
|
|
|
|
5. ... and/or install [Verilator](http://www.veripool.org/) and test LiteX directly on your computer without any FPGA board:
|
|
|
|
On Linux (Ubuntu):
|
|
```sh
|
|
$ sudo apt install libevent-dev libjson-c-dev verilator
|
|
$ lxsim --cpu-type=vexriscv
|
|
```
|
|
|
|
On MacOS:
|
|
```sh
|
|
$ brew install json-c verilator libevent
|
|
$ brew cask install tuntap
|
|
$ lxsim --cpu-type=vexriscv
|
|
```
|
|
|
|
6. Run a terminal program on the board's serial port at 115200 8-N-1.
|
|
|
|
You should get the BIOS prompt like the one below.
|
|
|
|
<p align="center"><img src="https://raw.githubusercontent.com/enjoy-digital/litex/master/doc/bios_screenshot.png"></p>
|
|
|
|
# Community
|
|
|
|
<p align="center"><img src="https://raw.githubusercontent.com/enjoy-digital/litex/master/doc/litex-hub.png" width="400"></p>
|
|
|
|
Over the years a friendly community has grown around LiteX and the ecosystem of cores. Feedbacks and contributions have already greatly improved the project, EnjoyDigital still leads the development but it is now a community project and collaborative projects created around/with LiteX can be found at https://github.com/litex-hub.
|
|
|
|
# Contact
|
|
E-mail: florent@enjoy-digital.fr
|