Welcome to Ceramic Hacker
Hardcaml MIPS - Return to blog overview
[14/12] Hardcaml MIPS and I/O
Accessing external IO devices with Hardcaml. Memory-Mapped IO vs Post-Mapped IO. Bus-driven CPU architecture, UART protocol / implementation. Project limitations and hypothetical expansions. Testing design with UART-driven calculator.
[13/12] Running Hardcaml on an Actual FPGA
Deploying Hardcaml on a real Arty-A7 FPGA. Displaying program output with LEDs.
[12/12] MIPS Project Conclusion
Hardcaml MIPS blog conclusion. Hardcaml strengths vs weaknesses analysis, blogging reflections.
[11/x] CPU Functionality Wrap Up
Last MIPS functionality: data hazards, forwarding, stalls, jumps, and branches. Multi-branch if-else using priority muxes.
[10/x] Testing and Debugging Hardcaml
Hardcaml automated testing, ASCII waveforms. Debugging hardware with Hardcaml's interactive waveform viewer.
[9/x] Always DSL and the Control Unit
CPU control unit implementation. Using Hardcaml's Always DSL for imperative logic in Hardcaml design.
[8/x] Design Patterns, Conventions, and Testing
Hardcaml circuit design patterns and automated testing. Using custom functor to assert wire width safety.
[7/x] Registers and Stateful Design
Sequential logic, registers/pipelines, and state in Hardcaml. Using feedback wires to increment instruction fetch program counter.
[6/x] Memory in Hardcaml
Overview of Hardcaml memory primitives, different types of CPU memory. Implementing instruction and data memory with Hardcaml Multiport Memory.
[5/x] Multi Module Circuits in Hardcaml
Building multi-module circuits with Hardcaml's hierarchical interfaces.
[4/x] OCaml Setup, Hardcaml Basics, and Project Plan
Setting up OCaml and Hardcaml using Opam and Dune. Project plan, code layout, and setup for testing, code, and generating Verilog RTL from Hardcaml.
[3/x] Verilog, FPGAs, and why OCaml
Intro to hardware design, verilog pros vs cons, Vivado IDE for synthesis / implementation, OCaml for hardware, and FPGA explanation.
[2/x] A Bit on Computers, Hardware, and CPUs
Intro to digital logic, computers, gates, combinatorial/sequential circuits, the MIPS architecture, and pipelined CPUs.
[1/x] Hardcaml MIPS Intro: What and Why?
Introduction to project designing a MIPS CPU with Hardcaml. Blog post series demonstrating hardware design using OCaml.