zsc / clash-compiler

Haskell to VHDL/Verilog/SystemVerilog compiler

Home Page:https://www.clash-lang.org/

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Clash - A functional hardware description language

Build Status Hackage Hackage Dependencies

Clash is a functional hardware description language that borrows both its syntax and semantics from the functional programming language Haskell. The Clash compiler transforms these high-level descriptions to low-level synthesizable VHDL, Verilog, or SystemVerilog.

Features of Clash:

  • Strongly typed, but with a very high degree of type inference, enabling both safe and fast prototyping using concise descriptions.

  • Interactive REPL: load your designs in an interpreter and easily test all your component without needing to setup a test bench.

  • Higher-order functions, with type inference, result in designs that are fully parametric by default.

  • Synchronous sequential circuit design based on streams of values, called Signals, lead to natural descriptions of feedback loops.

  • Support for multiple clock domains, with type safe clock domain crossing.

Support

For updates and questions join the mailing list clash-language+subscribe@googlegroups.com or read the forum

About

Haskell to VHDL/Verilog/SystemVerilog compiler

https://www.clash-lang.org/

License:Other


Languages

Language:Haskell 99.5%Language:C 0.2%Language:C++ 0.1%Language:Shell 0.1%Language:Dockerfile 0.1%Language:Roff 0.0%