Skip to content

Latest commit

 

History

History
30 lines (16 loc) · 3.03 KB

README.md

File metadata and controls

30 lines (16 loc) · 3.03 KB

pir-8

A swashbuckling adventure in making a custom computer! YAAAGH!!!

For a long time I've had the unsettling urge to make a computer, I mean really make it. I don't want to just slap a few bits of modern stuff together, I want to go deeper! Sure, using ICs is all well and good, but that doesn't quite do it for me. I want to go down to the level of making it from individual transistors!

Status/Phase

The ISA is mostly 'finished', this includes details what registers there will be, what instruction I will offer. I say 'finished' as it will change as I develop the hardware, it will, in a sense, be more descriptive than prescriptive.

I have started to develop a simulation of the proposed hardware. For the simulation software, I have using Logisim-Evolution, it's doesn't make sense for me to develop my own full blown logic simulation software. Once I have this simulation at a 'I think this works' level, it'll be added.

Goal

Erm... this is mostly just a bit of fun, so I don't really have a fixed end goal. I'd like to get a 'working' system built in hardware, fully out of transistors. How powerful that computer will be, I don't know, let's just see what happens. Of course, the classic benchmark of running DOOM isn't going to happen any time soon; a more modest aim would be at least Turing complete.

Simulation/Emulation

I started talking about this project with some friends, a couple of them happened to be bored enough to start working on support software for what I am proposing to build. There is a project for a simulator of my hardware. Another has built both an assembler and VM for running code.

Inspiration

One project that I'm glad exists is the Megaprocessor. This huge construction has an aim of trying to show quite visually how all the logic within is put together for educational purposes. In contrast, I shall be looking to shrink parts of the logic down, both in terms of the transistor count and the physical layout.

Another great example of low level CPU design is Ben Eater's YouTube channel. He has a nice mini series where he builds up a very basic CPU on breadboard, though he uses nasty ICs. It's a great example of a neat and tidy system, and really helps you understand how the internal control signals within the CPU can work.

There are lots of other small projects I've seen that have all helped influence me here. I've also taken a look at existing commercial designs, RISC-V to some extent, the iconic 8080 and even PIC.

Contributions

If you see anything wrong, like I've accidentally specified two operations using the same binary code, or I've a design flaw in the adder wrong, I would massively appreciate you giving me a message ASAP. Down the line, when I start looking to write code, contributions would be cool, once I have real hardware I could maybe video it executing; amazing.