Refactor Decoder.

- Create "DecodedInstruction" data type.
- Convert "DecodedInstruction" module into "DecodeInstruction" function.
- Move Alu, Mlu, Csr, Dvu, Lsu and VCore to ChiselEnum.
- Introduce use of move Valid/Decoupled interfaces.

Change-Id: Ia0f1299b17bcf2e0dd4486b94d516297f9f15fb0
10 files changed
tree: 75f96ff9e94c1cf08994f75a7dd07aff338e546b
  1. doc/
  2. external/
  3. hdl/
  4. lib/
  5. rules/
  6. tests/
  7. third_party/
  8. utils/
  9. .bazelrc
  10. .bazelversion
  11. .gitignore
  12. CONTRIBUTING.md
  13. LICENSE
  14. PREUPLOAD.cfg
  15. README.md
  16. WORKSPACE
README.md

Kelvin

Kelvin is a RISC-V32IM core with a custom instruction set.

Kelvin block diagram

More information on the design can be found in the overview.

Building

Kelvin uses bazel as it's build system. The Verilated simulator for Kelvin can be generated using:

bazel build //tests/verilator_sim:core_sim

The verilog source for the Kelvin core can be generated using:

bazel build //hdl/chisel:core_cc_library_emit_verilog

Verilog source for the Matcha SoC can be generated using:

bazel clean --expunge  # To generate the ToT sha
bazel build //hdl/chisel:matcha_kelvin_verilog