Project Log of the OZ-1 Processor - December 19, 2008 to January 26, 2009

Ben Oztalay

Friday, December 19, 2008

I read an article about a person who built his own 8-bit processor from scratch, and after some research, I found a Wikibook on microprocessor design (http://en.wikibooks.org/wiki/Microprocessor\_Design) that I read from front to back. The idea of making a simple 8-bit, single-cycle processor seemed feasible and within reach. While definitely not comfortably within my abilities, it was a challenge I thought would be fun and interesting to face. It seemed like all I needed to do was design a simple 8-bit parallel ALU, and instruction set architecture (ISA), and an instruction decoder.

I quickly started jotting down an overview of the processor I intend to build. The list soon morphed as I thought out various issues, such as if I'd need 8-bit instructions, or 16-bit. Other things to consider were what capabilities the ALU should have, how much RAM, if the processor should have separate instruction and data RAM. If the instruction RAM should actually be ROM so it can be removed for simpler programming, then which type of ROM? Should the processor have input and output pins to interact with outside devices? How many bits should the ALU be able to handle? How many programmer-visible registers should it have? What about the flags register, which flags should the processor include?

After many scratches on a piece of scrap paper, I came up with an almost-finalized overview of the processor. It looks something like this:

- 8-bit, single-cycle processor with 16-bit instructions and an 8-bit address bus

- Capable of addition, subtraction, XOR, OR, and AND operations

- Separate data RAM and instruction EEPROM

-Up to 256 bytes of RAM, as well as 256 bytes of EEPROM for instructions

- 3 programmer-visible registers: A, B and the Flags register, but the Flags register will not be editable and will only contain flags C, Z, and NZ

- Only 1 programmer-invisible register, the Program Counter (PC)

- Will have 16 dedicated output pins, no input pins

- Will be made out of wire-wrapped CMOS logic ICs

- The ALU will be an 8-bit parallel ALU

My reasons for choosing these properties were based almost solely on the goal of making a simple, single-cycle processor. Almost every place I could, I substituted performance for simplicity. I don't need this processor to run at blazing speeds. In fact, the clock frequency will most likely be at around 10Hz so I can see the processor at work.

Anyway, my reason for a single-cycle processor was simplicity. I wanted 16-bit instructions so the last byte in an instruction can be used to define an address or number for use with the main function (i.e., ADD A,87 or LD ($80),A). The 8-bit address bus was used because I'd have to have a 16-bit ALU and 24-bit instructions if I went with a 16-bit address bus. Originally, I was going to shoot for all sorts of logic operations in the ALU, but I toned it down for simplicity. I needed to have separate data RAM and instruction EEPROM to allow the processor to be a single-cycle processor. The low amount of registers was to keep it simple, I didn't want to have a register file system. I wanted only output pins, again, for simplicity. I opted for the wire-wrapped CMOS chips over FPGA because something about electronics that's always interested me is really knowing what's going on in a circuit at the logic gate level, and the epitome of a modern circuit is a processor. And for the last point in the overview, I went with an 8-bit parallel ALU because, after drawing up a basic sketch of my proposed ALU, I learned that an 8-bit ALU requires 30 leads to interface with the other parts of the processor (19 inputs, 11 outputs). I figured that was enough, and this is my first processor. It doesn't need large abilities.

After figuring all of this out, I moved on to a basic block diagram, but all fruits of those labors were discarded because I realized I'd need to create an ISA (Instruction Set Architecture) before I get into the block diagram. I struggled with the ISA for an hour or so before deciding it was a good idea to go to sleep.

Saturday, December 20, 2008

I spent all of today's work on the OZ-1 designing an ISA and writing the machine code. After a few hours of on-and-off struggle, I finally came up with an ISA that I'm happy with, proud of, and fits in 2 bytes. Here's the diagram I drew up:

![](data:image/png;base64,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)

It definitely looks a little nuts, almost every different type of instruction uses different bits in different ways. I did it this way so I could keep the instructions within two bytes. The green sections are for options, and the top half of green sections means, if both bits are 1s, then that option is set. The red sections mean if you're using that type of instruction, the bits that are red must be the 1 or 0 indicated, or the instruction is invalid. Purple is for ALU control.

There's a lot to say about the ISA, I designed it, again, around simplicity. I wanted almost every type of command to be able to have a condition without having a jump to a separate label for them to execute, like many (if not, all) popular assembly language variants. Essentially, this means that you can add two numbers if the Z (zero) flag is set, or the NZ (not zero) flag is set, or do any other command conditionally in that manner, excluding INC A and DEC A. The syntax for the adding example might be: ADD Z,A,B. This means, if the Z flag is set, add registers A and B. It's the same way for the NZ flag. If you want to turn on output pin 5, but only if the NZ flag is set, you'd write: PON NZ,5. So, with this system, the OZ-1 will have 12 main instructions, but a total of 53 instructions with various combinations of Z and NZ and a few other things.

The OZ-1 won't have a direct instruction to tell it to compare register A with a certain number, but rather, the CP command in an assembly code file will be converted to a SUB A,# instruction when assembled. Just thought that might be good to note.

Oh, one last thing, for the ALU, it has three input control leads, which are SUB/ADD, C0 and C1. Here's a truth table for the settings:

SUB/ADD C0 C1 Setting

0 0 0 add

1 0 0 sub

X 0 1 AND

X 1 0 OR

X 1 1 XOR

Anyway, that's all for today. Signing out.

Sunday, December 21, 2008

Alrighty, I was mulling over a few issues after I woke up today. The first was, how on earth am I going to get a 256-byte EEPROM chip? And not only that, it has to be parallel-access. The other was how I'd go about getting a full 2 bytes off of the instruction EEPROM every cycle when it only allows access to one byte at a time. Well, as for the first problem, I posted a question on an electronics forum, DutchForce. For the second one, I decided there were a few ways to go about it, and the simplest way to do it was to have two separate instruction EEPROM modules. The program counter would address them with the same address, so a full instruction might be byte 157 on the first chip and byte 157 on the second chip. I'd load both into a 16-bit instruction register at the same time. The first chip would hold the main chunk of the instructions, the 8-bit opcode. The second chip would hold all of the peripheral numbers and addresses that the instructions would use. I felt this was the best way to go about it, and it doubled my capacity for instructions! Before, the processor would only be able to hold 128 instructions, but now it'll be able to hold a full 256. Like I said before, I don't plan to have this processor do a whole lot. I do plan, however, to build a 16-bit OZ-2. I'm planning to start work on an instruction decoder and rough block diagram today, but seeing as it is December, and it just snowed 8 inches, the driveway calls.

I finalized a design of an instruction decoder later today. I figured the best way to go about it was to have the instruction decoder set certain outputs on the decoder to high depending on what the instruction is telling the processor to do. Then a general 8-bit data bus that connects to every part of the processor that uses data would be controlled with multiplexers using those outputs. If the instruction doesn't use a number or address, the data bus would be disconnected right at the instruction decoder. I came up with this design after having designed an instruction decoder that set the certain pins to high, but had three data bus outputs: one to register A for load instructions, one to RAM for addresses, and one to the ALU. This didn't really work out. The block diagram was rather confusing and inefficient. There were paths crossing each other and general clutter, so I figured there had to be a better way. With the new instruction decoder designed, I plan to draw up a new block diagram.

Also, I've been toiling over how to best do jump instructions if they use a condition that isn't true. Like, ADD Z,A,B, but the Z flag isn't set. Right now, I have it set up so if the condition isn't true, the data bus gets cut off, and the RAM and registers disabled, then the program counter gets advanced one instruction. Essentially, it puts the processor on lockdown until the next cycle. As far as the jump block, I thought about it just setting the program counter to a number specified in the instruction instead of its normal operation of being increased by 1 every cycle.

For instructions that turn output pins on or off, I have a "PON/POFF decoder" block that's hooked up to the data bus and two control lines that are connected straight to the instruction decoder. The pin decoder block takes in a number that's only the first four bits of the data bus, seeing as there are only 16 output pins that I plan to have. If the data bus is carrying a number over 15, nothing will return an error, but the decoder will just ignore the last four bits and the desired result may be different from the actual result.

Monday, December 22, 2008

Well, as I said yesterday, I plan to draw up a new block diagram, which will probably end up looking more like a wiring diagram.

So far today, I've finally settled on a block diagram that I plan to copy on to a computer in something like MS Paint. It's a very simple diagram, hardly any details. There's nothing about control lines for the ALU or any of the other blocks. I'm going to make a new block diagram that'll be much more detailed on the computer, doing that on paper is a bit nuts.

Anyway, about the block diagram I drew up. The general data bus idea has a few exceptions to the rule. First of all, it connects to the ALU so a number can be added to register A, but A is also connected to the data bus, so A needed its own dedicated line to the ALU's other input. Also, many things have several connections to the data bus for different purposes. Mainly, these are separate in/out lines so things like registers A and B can have simpler logic to interface with the rest of the processor. Another thing to note, there's a RAM bus as well that carries data from the RAM to register A and the ALU. One more thing that's prominent about this block diagram is that there's only one visible multiplexer, and that's for the second input on the ALU so it can do things like add a number from RAM or from register B, or just a plain number straight off the data bus. Much of the control logic for the data bus will be done on a relatively internal level inside each block. In reality, there are going to be dozens of lines (actually, just more than two dozen) streaming out of the instruction decoder to tell each area of the processor whether it should be connected or disconnected from the data bus, and which task the ALU should be performing, as well as where it should be getting its data from.

There's also going to be pretty much one line for each block on the diagram coming from the condition block. Remember how I said above that the system I thought of for conditional statements was to put the processor on lockdown until the next cycle? Well, that's what all of those lines would be for. The way I think of it is that each block needs permission from the condition block and instruction decoder to gain access to the data bus. And if the condition block says no, it says no to the whole processor. I'm going to need to figure out some sort of reset logic for the condition block, though, so after the false instruction has passed, the processor continues as it would. Otherwise, Z might not be set, and the whole processor just stops.

So that's where I am as of now. In the future, I'm shooting for designs of the internals of each block, including control inputs from the condition block and instruction decoder and inputs and outputs for the data bus. Before doing that, though, I'm going to make the more extensive version of the block diagram, which will basically be a segmented wiring diagram.

Thursday, January 8, 2009

Through Christmas break, I've been working on internal diagrams of each of the blocks in the block diagram, and I made it through all of them except the condition block, which is fairly simple, I just need to figure out how many lines go where to block everything from the data bus. Then some control logic to lock up the processor when only certain conditions are true. It's just a matter of actually drawing the diagram, which I will some time tonight. Unfortunately, school hit me like a ton of bricks, so I haven't had much time since last Saturday to work on anything that isn't related to school.

Anyway, I had a bit of a breakthrough with single-cycle processor architecture. The new architecture I thought up is based largely off of the OZ-1's architecture, but rearranged to produce a much more efficient system. My idea is to take the data bus arrangement and streamline it. At the top of the "pipe", so to speak, would be 8 bits from the instruction register going to the instruction decoder, and 8 bits into the data bus. The instruction decoder would then control the branches the data bus would take, guiding it to where it's needed. This sounds a lot like the OZ-1's architecture, and the details haven't been worked out yet, but I would design it so the operation that would take the longest would be at the start of the "pipe", and the one that would take the least amount of time would be at the end, so less time can be spent sending data to the longest operation. This would cut down on minimum cycle time. The various operations and related blocks would be organized into groups, i.e., if it's a register operation, branch here, then if it uses register A, branch to here, as opposed to there. I just thought it up on the spot, but I think what I'm going to do is keep everything else, like the instruction decoder and the majority of the blocks I’ve designed, and the ISA of the OZ-1, then just reshape its architecture. This would require a new block diagram, and a lot more thinking, but I want to make a processor that's actually capable of real tasks. After designing this processor as an 8-bit processor, I'm not going to build it, or even get up to arranging an actual circuit diagram, but I'm going to redesign it as a 16-bit processor. Also, I'll add input lines in addition to the already-existing output lines. It's basically going to get a rather beefy upgrade. Also, I'll add more programmer-visible registers, including C and D registers, and organize them in a register file for easier access. As for now, though, much work remains to be done on the 8-bit version of this architecture. All of my current plans are on paper, drawn in pencil, and I plan to keep them, but they won't be of much use any more, at least the ones pertaining to physical arrangement and basic architecture.

Saturday, January 17, 2009

So, mainly I've been working on internal block diagrams for the more extensive block diagram, so to speak. I haven't gotten much further on the new architecture I was hoping to work on; we just finished midterms at school. Anyway, I jotted down a register file system in my notebook, not much else.

One major thing that has happened, though, is I found an amazing program called Logisim. It's a logic circuit simulator, and it's fantastic. It's very extensive, and very easy to use. Most other logic circuit simulators I've come by have been choppy, unpolished, and difficult to use. This one is very intuitive, kind of like how a logic circuit simulator should be. Anyway, moving away from a potential commercial for the program, the most useful thing I've found it does, to me, at least, is let you create what're called subcircuits. For example, I drew up my instruction decoder and debugged it in a circuit called "Instruction Decoder". Then, in the main circuit for the OZ-1 project, I can create an instance of that circuit in block form. It labels all of the inputs and outputs on the block according to their placement and associated label in the subcircuit. It's simply amazing.

I decided to draw up a diagram for an 8-bit register. The program has built-in ones, but I wanted to try it for myself. I made a subcircuit of an edge-triggered D flip-flop, then made 8 of those subcircuits in the register circuit, and wired up some AND gates to the outputs for a "read" input. The write input was hooked up to the enable lines on the flip-flops. I tried out this system, and it didn't quite work. I told the instruction decoder to load register A with a specified number, then wired it up, but unfortunately, race conditions due to the edge-triggered flip-flop made it unfeasible for the register to take input while the enable line is going from low to high. To solve this, I replaced all of the edge-triggered D flip-flops with D latches. D latches aren't edge-triggered. While the enable line is high, their outputs can change at any time according to their inputs. I found this to be the optimal solution, seeing as it wouldn't create any sort of race condition. This worked out great, when I started the simulation the register was loaded with what was on the data bus.

After that, I wanted to try out creating the ALU. Everything in the ALU I drew up myself. I enjoy working with the very basis of circuits; I'm not really a fan of just pretending some sort of magic goes on behind the scenes to make it work. So, I drew up a few subcircuits: a 1x2 multiplexer, a 2x4 multiplexer, and a full adder. The ALU was just a matter of wiring these up correctly. I gotta say, the diagram is a little intimidating because everything in the ALU is in bus format (meaning the data comes in 8-byte chunks, so 8 separate wires are necessary to get the job done correctly). The ALU worked beautifully. I hooked up the ALU to the unofficial data bus and the correct lines on the instruction decoder. I then reset the simulation and started it with the LD A,# instruction, then stopped it and set the instruction to an ADD A,# instruction. It worked perfectly, when the ADD A,# instruction came on, the enable line to the register turned off and the read line turned on, feeding into the ALU. The data bus didn't affect register A because the write line was low, and instead went to the other input on the ALU. The output lines on the ALU read 116. This was great! Register A was holding 110, and the data bus was set to 6. The only thing I didn't do was have the ALU's output be stored in A. This was because I had only drawn up the register, not register A's diagram. There's a difference because register A's diagram involves 3 separate 8-bit inputs that go through a 24 to 8 multiplexer into register A, then the register's output gets demultiplexed into 3 separate 8-bit outputs again. Without the 3 separate inputs, there's no way for the register to differentiate between input from the data bus and input from the ALU.

So, as the detail of my design increases, I've been trying to work out how to take care of race conditions within the processor. When you think about it, if I add register A and a number, then store the result in register A all in one cycle, that's probably going to cause issues. This would mean that the read and write inputs would be enabled, essentially turning register A into a buffer. Questions then arise, such as, would register A's value be changed to the ALU's output before the operation was even complete? Would a loop be created, running the addition operation until the next cycle, instead of just once? What would happen, and how would I go about avoiding it? These are pretty fundamental questions and problems regarding a single-cycle processor.

Monday, January 26, 2009

So, a lot has happened since I last updated this log. Much progress has been made using Logisim. The current state of the processor is: registers A and B and their instructions fully operational, and output pins and RAM pending. Also, everything conditional is working, and the jump instructions work. I have since changed the ISA to exclude INC and DEC instructions, as I had the revelation that they were simply ADD or SUB instructions and purely based on software/programming. I’ll need to run back through and go over the various issues I ran into in the last 9 days.

So, the first thing I did was wire up register A and the ALU. Many of the ensuing problems were caused by unfamiliarity with Logisim. I switched from designing my own registers to using Logisim’s built-in registers, which weren’t plagued by errors due to race conditions within the flip-flops. Then, I had to make them write on the falling-edge so that at the beginning of every cycle that involved writing, the values were set up to write, then when the CLK signal fell, they would write and that would be the end of the cycle. This solved race conditions with writing to registers and various other related issues, mainly ALU operations and storing their results in register A.

Then, I tried clocking the ALU by adding registers to the inputs and outputs and writing them on the rising edge, but that simply didn’t work out. There wasn’t much of a point in clocking the ALU anyway because everything else was clocked.

After getting the ALU and register A set up, I made a new jump system for controlling the program counter. Basically, I lined up 8 full adders with the current program counter value on one input and 1 in the other. The result of this was multiplexed with what was on the data bus, and depending on whether or not the instruction was a jump instruction, one of the results would get through to the program counter, which wrote on the rising edge.

Those were the main issues I came across, and they caused things like register A magically being loaded with whatever was supposed to be on the data bus right at the beginning of the instruction (which was really, really weird). Also, register A getting added to twice in one instruction, instead of just once, causing data corruption. One of the most helpful tools in solving all of this was the logging capabilities of Logisim. I could log the various values of certain inputs and outputs as they changed with the clock signal to see what was going on.

So, at this point I could load numbers in to register A, add to and subtract from register A, jump to various addresses in the instruction ROM, and do everything conditionally. The next step was to add register B, which would greatly expand on the processor’s capabilities.

This went much smoother than expected. Fortunately, the system I had set up with the instruction decoder allowed me to basically just hook up all of the wires and run a simple test program. I was quite pleased. One thing I noted that had to be done was to add controlled buffers on the data bus in various places. This was to protect outputs from being inputted to, like when register B is loaded from register A, which uses the data bus as a way to connect the two. The next step was to connect register B to the ALU, which required multiplexing the data bus and register B through to the second input of the ALU. I designed an 8-bit 3 to 1 multiplexer, which wasn’t exactly a multiplexer. Instead of having control lines that would be decoded internally, they were direct. This means that three data inputs would have 3 control lines. If none of the lines are on, no data gets through. Two control lines being on would cause data corruption. Only one control line is supposed to be on at a time. I found that this was the best way to handle the multiplexing using the signifier system that I set up for the instruction decoder. In short, various signifiers are turned on to tell the processor what the instruction means. This shortens the instruction length, which, in this system, is pretty much the instruction decoder’s sole purpose.

I did catch a few snags going in to this. First of all, register A was outputting to the data bus through a controlled buffer that originally only turned on if the instruction didn’t use the data bus, meaning only registers A and B are in use. This cause an error because if I tried to load A with B, A would try to output to B while B is attempting the same for A. To fix this, I used an AND gate and made sure the buffer only turned on if the data bus wasn’t being used and register B was being loaded from register A. The OZ-1 will only be able to load register B through register A, and only be able to use RAM through register A. I realize that these are large limitations on a processor’s functionality, but I will update and fix these limitations when I design the 16-bit OZ-2. I plan to make the OZ-2 many times more versatile.

Anyway, that was a good summation of the last 9 days of work on the OZ-1. I’m very close to being done with the design in the virtual world, and plan to stop there with the OZ-1 when it’s done. For the OZ-2, I will be building it.

So, enough about the past work on the OZ-1, and on with a little talk about the work I plan to be doing soon. The last two things left in the processor are the input/output pins and access to RAM. I plan to do the pins first. My idea for the pins is not so much and individual control, but treating them as more of an output port. They would be connected to an 8-bit register (so, 8 output pins), and writing the data bus to that register only when the instruction is an output instruction. The pins wouldn’t reset themselves after the cycle; they’d stay on until the program turned them off. I’m not sure what I’d do about input pins, but I have an idea. The system would work kind of like the condition block. Basically, the pins would input to a block that would have 8 other inputs to tell it which to test. If the program is testing pin 4, and pin 4 is on, the block would output a 1. If pin 4 is off, it would output a 0. This would then communicate with the rest of the processor. I don’t plan to add input pins, though, to the OZ-1. It would require a restructuring of the ISA.

Well, today was certainly a good day. I finished the OZ-1. The output pin system works beautifully, although my one regret about it is that you can’t set output pins based on things like register A. It can only be through a fixed number in the instruction that goes to the data bus. The RAM turned out quite well after fixing one minor wiring error. It can be written to and read from, and numbers can be added from it to register A.

Having finished the processor, the next few days will be spent finalizing the ISA and a block diagram, as well as other diagrams. The nomenclature of the diagram in Logisim will be checked and made consistent. Then I’ll take screenshots of the entire processor and each part for future use and documentation.

I figure that here is where I should discuss the project, its benefits, strengths and weaknesses of the processor, etc. I started the OZ-1 processor 38 days ago with a rough outline of the future processor’s statistics and a Wikibook of microprocessor design experience and some basic TI-83+ ASM under my belt. I knew that I wouldn’t be making anything special, and that I’d be making another, but that an 8-bit processor was a good place to start. That’s what Intel started out with, isn’t it? Anyway, I thought this project was great for me. It was fun, and I learned a ton about digital circuitry and logic, processors, and how computers work. I feel much more experienced in the field of digital circuitry now that I’ve finished this project. I’m proud of myself because I came up with 95% of the fundamental concepts behind the OZ-1. While they may not have been original, the fact still remains that I thought of them at some point. I’ll try the same for my next processor, a 16-bit OZ-2. It will be much more versatile and useful. I plan to actually build the OZ-2 out of CMOS logic chips, as I had planned for the OZ-1. I’ll write more about the OZ-2 later.

The OZ-1 certainly is not a very useful processor. I’m going to be frank about it. It only has 2 registers, a very low capacity to keep their values around unless the programmer is very careful (or me, who designed the thing), can hold 256 instructions, and has 256 bytes of RAM. All in all, not very special. Also, it’s a single-cycle processor, which limits its speed, but I found that making it a single-cycle processor was a bit of a challenge in and of itself. I had to figure out how to divide the cycle into two parts, the high and the low clock cycle halves, and how to make everything work off of those two parts in one cycle. Also, the OZ-1 doesn’t even have input pins so other things can communicate with it. I suppose the program counter could be run to two blocks of RAM in a computer, and the instructions run off of there, but still, it would not be very useful or change a whole lot. The output pin system is extremely limited, it can only output based on fixed numbers on the data bus from the instruction. It would be rather easy in concept to fix this and make it more versatile, but in practice, I would have to rewire pretty much everything. The wires are packed pretty tight in Logisim. Also, the ALU is limited to only run operations on register A and one of three other options: a number off of RAM, register B, or the data bus. While it may seem alright, the processor is unable to add register B and the data bus, or a number off of RAM and the data bus. Similar to that, the RAM can’t be loaded with register B, or even something off the data bus. Everything would take twice as many cycles to complete than it should, and register A is almost guaranteed to be destroyed in the process. All of these limitations I plan to correct in the OZ-2.

About the OZ-2, as stated above, it will be 16-bit. That means, it will be able to hold 64 thousand instructions, have 64 kilobytes of RAM, and be able to run operations on numbers up to 65,356.

A big thing about the OZ-2 is that it’ll be many times more versatile than the OZ-1. The OZ-1 could only use specific things for specific operations, whereas the OZ-2 will be able to use almost any medium for holding a number to run any operations that involves numbers.

Also notable will be the OZ-2’s register file of 4 registers: A, B, C, and D. They will still be 8-bit registers, but I hope to be able to implement double-registers, like AB and CD in order to make it easier to run operations on 16-bit numbers. If that doesn’t work out, they’ll end up being 16-bit registers, which seems much more practical in the first place. The flags register will hold more than three flags. I will model the flags off of the flags in the TI-83+ calculator.

The ALU will be more complex by being able to run shift operations. I suspect the instructions may end up being anywhere from 24 to 32 bits long to accommodate the relative complexity of the OZ-2. Oh! I almost forgot. The OZ-2 will have input pins as well as output pins. Two bytes of input pins will be a dedicated data port, as well as two bytes of output pins as a dedicated data port. In addition to those, there will be 8 individually controllable output pins and 8 individually visible input pins. I think that’s about it for the OZ-2. I hope to start work on it from scratch, using the OZ-1 as guidance, after I’m done finalizing the diagrams of the OZ-1.