FPGA dev board that's cheap, simple and supported by OSS toolchain

This page summarizes the projects mentioned and recommended in the original post on news.ycombinator.com

Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
  • UPduino-v3.0

    UPduino 3.0: new 4 layer layout, various other improvements

  • bsc

    Bluespec Compiler (BSC) (by B-Lang-org)

  • FPGA Thread: Bluespec SystemVerilog is now completely open source, very nice HDL although quite opinionated.

    https://github.com/B-Lang-org/bsc

    it's Haskell underneath (https://xkcd.com/356/)

  • WorkOS

    The modern identity platform for B2B SaaS. The APIs are flexible and easy-to-use, supporting authentication, user identity, and complex enterprise features like SSO and SCIM provisioning.

    WorkOS logo
  • WTFpga

    2 hour crash course in FPGAs

  • https://github.com/esden/wtfpga

  • fomu-toolchain

    A collection of tools for developing for Fomu

  • https://github.com/im-tomu/fomu-toolchain

    Workshop:

  • nmigen-tutorial

    Discontinued A tutorial for using nmigen

  • If you are already familiar with Python I could recommend start with this tutorial: https://github.com/RobertBaruch/nmigen-tutorial

  • apio

    :seedling: Open source ecosystem for open FPGA boards

  • if you're more comfortable with the CLI, you should take a look at the apio project (https://github.com/FPGAwars/apio). It neatly bundles all the required tools. Regarding HDLs, I'm still learning so can't offer any good advice on that.

  • linux-on-litex-vexriscv

    Linux on LiteX-VexRiscv

  • "Linux on LiteX-Vexriscv" [1] is an easy way to get started. The readme includes a table of supported boards, as well as the amount of memory and maximum tested clock frequency.

    I played with it on an OrangeCrab [2], and was shocked by how easy it was to get it running and by how well it worked despite the slow clock. The SoC includes peripherals for GPIO, PWM, serial interfaces, etc., and the project includes kernel drivers to talk to them. On the OrangeCrab, everything I thought to try pretty much just worked.

    That being said, this is mostly just a fun exercise in SoC building, and isn't going to give you anywhere close to PC performance.

    [1] https://github.com/litex-hub/linux-on-litex-vexriscv

    [2] https://1bitsquared.com/products/orangecrab

  • InfluxDB

    Power Real-Time Data Analytics at Scale. Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.

    InfluxDB logo
  • stm32cube-database

    STM32Cube database mirror/history tracking repository

  • There's probably no guarantees but in my experience if two devices link to the same version xml file their peripheral registers at least will be identical. Quirks and silicon bugs, you are on your own of course... but then the ref manual doesn't help with that either!

    [1] https://github.com/esden/stm32cube-database/tree/master/db/m...

NOTE: The number of mentions on this list indicates mentions on common posts plus user suggested alternatives. Hence, a higher number means a more popular project.

Suggest a related project

Related posts