Mk-S 1.0 CPU [My First CPU]
0 Stars     2 Views    

Author: JOHN RAY HERNANDEZ

Forked from: Dylan Baer/Mk-S 1.0 CPU [My First CPU]

Project access type: Public

Description:

So this is the first CPU I have ever built. It's my own personal design. I know it's messy and it looks like I don't know what I'm doing, mainly because I actually don't know what I'm doing. Here's a reference of instructions:

00000 - No Operation

00001 - Addition [Sets register O to the sum of register A and register B]

00010 - Subtraction [Sets register O to the difference of register A and register B]

00011 - Increment [Sets register O to register A plus one]

00100 - Decrement [Sets register O to register A minus one]

00101 - Not [Sets register O to not register A]

00110 - And [Sets register O to register A and register B]

00111 - Or [Sets register O to register A or register B]

01000 - Shift Left [Sets register O to register A shifted left]

01001 - Shift Right Logically [Sets register O to register A shifted right logically]

01010 - Shift Right Arithmetic [Sets register O to register A shifted right arithmetically]

01011 - Greater Than [Sets register O to the truth value of register A is greater than register B.   0 = False, 1 = True]

01100 - Less Than [Sets register O to the truth value of register A is less than register B.   0 = False, 1 = True]

01101 - Is Zero [If register A is zero, register O is set to true. Otherwise, register O is set to false.   0 = False, 1 = True]


01110 - Put in Register A [Puts the input into register A]

01111 - Put in Register B [Puts the input into register B]

10000 - Clear Register A [Sets register A to zero]

10001 - Clear Register B [Sets register B to zero]

10010 - Clear Register O [Sets register O to zero]


Note: The register must be cleared before assigning it new variable.

Created: Jul 18, 2024

Updated: Jul 18, 2024


Comments

You must login before you can post a comment.