PCB Assembly
I have started assembly of the PCBs but I am waiting on a part.
Instruction Set
I have had time to think about improving the instruction set.
The idea came from the number of steps required to swap out the accumulator to memory. Better if I have a register and a swap opcode.
The idea actually frees up the opcode space as I can use the opcode "data" to specify the register and the registers can serve other purposes (e.g. the page register).
I need to look at how the memory data flow works as well.
Rebuilding the Micro-Architecture
I took the well published academic RISC micro-architecture:
data:image/s3,"s3://crabby-images/43252/43252f16fa00f2686527566b4731194124315e47" alt=""
And derived the CHUMP micro-architecture:
data:image/s3,"s3://crabby-images/923df/923dfb13f8cb530329eac388ffc45a6ba7ac0aef" alt=""
But along the way I saw an alternative memory arrangement:
data:image/s3,"s3://crabby-images/ca901/ca901a6d72c19950233da763da05a42a10bade89" alt=""
This configuration has three benefits:
- The SRAM write logic is simplified (perhaps I over designed the write logic in the first place).
- The opcode logic is unchanged.
- The accumulator data can be written to SRAM in the same instruction cycle (CHUMP does it on the next instruction cycle).
I have tested the new micro-architecture in Logic-Sim (and it works fine.
Adding Registers to the CPU
This allows the inclusion of register read/write logic:
data:image/s3,"s3://crabby-images/9a037/9a037a1a263a4c23227c1aa4cc668c7a231fbfd7" alt=""
In the above drawing I will probably keep the old PC and JNC logic.
Now I can replace the Page opcode with a register(s) read/write opcode.
Working LogiSim Version 7
Have been working on the Version 7, it now has register read/write opcodes. Added four registers of the eight available slots:
- Write Page/(no page read)
- Write Output/Read Input
- Write Reg A/Read Reg A
- Write Reg B/Read Reg B
Swapped the Page opcodes (Ex/Fx) with JNC opcodes (8x/9x).
Replaced the new 8x/9x opcodes with 8r/9r were r is a register constant or memory reference:
- Page: W/X = 0/4
- I/O: W/R = 1/5
- Reg A: W/R = 2/6
- Page: W/R = 3/7
Here is the Top Level:
data:image/s3,"s3://crabby-images/da1d7/da1d7e0ff2a8ac4396442f445be45501c7a756ff" alt=""
The Control Unit:
data:image/s3,"s3://crabby-images/e0bd6/e0bd62f79132d34d62310c242f842dbeb1d94e3c" alt=""
The ALU:
data:image/s3,"s3://crabby-images/b41f4/b41f42c9d68e994c4a905dd90845c3bce4842cf1" alt=""
And the PC:
data:image/s3,"s3://crabby-images/12fcc/12fccb14f571003d36b08536eadc302b85a9bee0" alt=""
Overall a pretty significant improvements on CHUMP V5 and the 4 Bit CPU V6.
Here is the test code (the multiply algorithm):
data:image/s3,"s3://crabby-images/016fb/016fb0e8aff1c0a45e4b48792aa18c0cb9f350a0" alt=""
This algorithm uses the new JNC and REGs opcodes, and multiplies F x E (13 x 14), the result is D2 (210).
Parts have Arrived
The parts have arrived. Finished off one of the Diode ROM boards, next is the CPU board:
data:image/s3,"s3://crabby-images/11c05/11c05694b22b855affc128222229a4df6acef542" alt=""
TBC ...
AlanX
Discussions
Become a Hackaday.io Member
Create an account to leave a comment. Already have an account? Log In.