Chiselは、デジタル回路設計用の、オープンソースのハードウェア記述言語 (HDL: Hardware Description Language) の一種である。カリフォルニア大学バークレー校で開発が行われている。Chiselは、Scalaの内部DSLとして実装されている。

概要

Chiselは、Constructing Hardware In a Scala Embedded Language の略とされており、その名の通りScalaの内部DSLで、Scalaのライブラリとして提供されている。また、ハードウェア記述言語というよりも hardware construction language、すなわち構築言語であるとされている。

Chiselのコンパイルは以下のようなパイプラインで行われる:

  1. Chisel3 (Scala) のコードから Firrtl (Flexible Internal Representation for RTL) へ
  2. Firrlt から Verilog へ(ASIC や FPGA ツール向け)
  3. Verilog から C へ(Verilator を使用してシミュレーションやテストを行う)

歴史

開発動機

ハードウェア記述言語の主流は、VHDL、Verilog(および後継言語のSystemVerilog)であるが、これらは、ハードウェアの動作仕様の文書化、およびモデリングやシミュレーションのための言語として開発されたため、論理合成の機能は、シミュレーションのサブセットとなっている。また、これらの言語は、現在のソフトウェア用プログラミング言語の強力な抽象化機能は持っていない。このため、ハードウェアの設計者の生産性が低くなっている。Chiselは、Scalaをベースとして、現代のプログラミング言語の機能を提供する事を目的として開発された。

バージョン履歴

Chisel 2.1
2013年12月
Chisel3
2017年11月

コード例

最小公倍数を求める例を以下に示す。

脚注

関連項目

  • EDA (半導体)
  • ASIC
  • FPGA

外部リンク

  • Chisel公式ウェブサイト

Wood Chisel Tool

Chisel Sharp Steel Free photo on Pixabay

Chisel machine tools stock photo. Image of industry, machine 11033922

Chisel

Teknik Metal Chisel, Size 5 Inch at best price in Mumbai ID 21602200655