Welcome to Ceramic Hacker

Hi, I'm Alexander (Sasha) Skvortsov. I'm a computer science and math major at Penn State. I'll be using this blog to share some of my projects and thoughts, mainly focused around software engineering and pottery.

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.

Sasha 1

[13/12] Running Hardcaml on an Actual FPGA

Deploying Hardcaml on a real Arty-A7 FPGA. Displaying program output with LEDs.

Sasha 0

[12/12] MIPS Project Conclusion

Hardcaml MIPS blog conclusion. Hardcaml strengths vs weaknesses analysis, blogging reflections.

Sasha 0

[11/x] CPU Functionality Wrap Up

Last MIPS functionality: data hazards, forwarding, stalls, jumps, and branches. Multi-branch if-else using priority muxes.

DoperBeats 0

[10/x] Testing and Debugging Hardcaml

Hardcaml automated testing, ASCII waveforms. Debugging hardware with Hardcaml's interactive waveform viewer.

Sasha 0

[9/x] Always DSL and the Control Unit

CPU control unit implementation. Using Hardcaml's Always DSL for imperative logic in Hardcaml design.

Sasha 0

[8/x] Design Patterns, Conventions, and Testing

Hardcaml circuit design patterns and automated testing. Using custom functor to assert wire width safety.

Sasha 2

[7/x] Registers and Stateful Design

Sequential logic, registers/pipelines, and state in Hardcaml. Using feedback wires to increment instruction fetch program counter.

Sasha 0

[6/x] Memory in Hardcaml

Overview of Hardcaml memory primitives, different types of CPU memory. Implementing instruction and data memory with Hardcaml Multiport Memory.

Sasha 2

[5/x] Multi Module Circuits in Hardcaml

Building multi-module circuits with Hardcaml's hierarchical interfaces.

DoperBeats 0

[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.

Sasha 0

[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.

Sasha 1

[2/x] A Bit on Computers, Hardware, and CPUs

Intro to digital logic, computers, gates, combinatorial/sequential circuits, the MIPS architecture, and pipelined CPUs.

Sasha 0

[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.

Sasha 2