Skip to content

ejunjsh/mycpu

Repository files navigation

mycpu

八位cpu, 5个寄存器(A,B,指令,显示,标志flag),11条指令

准备

材料

一个cpu基本有几个组件拼接起来的,所以视频在每个组件开始搭建之前都会做一些实验,下面材料不包括这些实验用到的材料,所以如果你想做实验,那就再买一些

数量 名字
15 面包板
1 5V1A 电源和线 (推荐5V2A)
1 镀锡铜线(规格22AWG,单芯)
10 1kΩ 电阻
9 10kΩ 电阻
1 100kΩ 电阻
24 220Ω 电阻
1 1MΩ 电阻
1 1MΩ 电位器
6 0.01µF 电容
16 0.1µF 电容
1 1µF 电容
4 555定时芯片
2 74LS00 (NAND 与非门)
1 74LS02 (NOR 或非门)
5 74LS04 (NOT 非门)
3 74LS08 (AND 与门)
1 74LS32 (OR 或门)
1 74LS76 (JK触发器)
2 74LS86 (XOR异或门)
1 74LS138 (3位译码电路)
1 74LS139 (2位译码电路)
4 74LS157 (二选一电路)
2 74LS161 (4位计数器)
8 74LS173 (4位寄存器)
2 74LS189 (64bit内存)
6 74LS245 (三态门)
1 74LS273 (8位D触发器)
2 74LS283 (4 位加法器)
2 74HC595(8位移位寄存器)
3 28C16 EEPROM
3 按钮开关(自锁)
3 轻触开关(6mm)
1 8位拨码开关
1 四位拨码开关
44 红色 LED
8 黄色 LED
12 绿色 LED
21 蓝色 LED
4 共阴数码管(一位)
1 Arduino Nano

注意事项

面包版

电源

如果家有苹果的五福一安电源就够了,再淘宝买个usb转公线就可以了

电阻

淘宝上买一袋袋的电阻,里面个种阻值都有

电位器

下图那种就可以了,但是这种扭起来不算很顺,你可以看看其他类似上面有颗比较大一点的旋钮的,这样扭起来好扭

电容

这个买103,104,105的电容就好,分别代表0.01µF ,0.1µF ,1µF ,淘宝也是一袋袋买的

电线相关

买个剥线钳,因为电线是AWG 22 规格,所以要买能剥这种线的

电线记得买 单芯 的ok线,规格是AWG22.最好买各种颜色的,好看哈哈😄

如果需要买点面包版跳线,用来做实验好

芯片

上面芯片的数量是搭建cpu用到的芯片数量,如果是那种只有一个的芯片,最好买多个,这样你可以在有问题的时候,能够确定是不是芯片的问题

按钮开关(自锁)

轻触开关

拨码开关

LED

淘宝买一袋袋的LED,各种颜色都有。

数码管

买这种引脚在下面的,好插在面包版

Arduino Nano

已焊接针脚,带usb线

看视频,开始搭建

英文

https://eater.net/8bit

这里包括了所有相关资料和视频

中文

https://www.bilibili.com/video/BV1BJ411R7s5

中文配音,背景知识讲解

实例代码

下面视频里面的指令程序都是可以跑在这个cpu上的

加法

0:LDA 14   0000:0001 1110
1:ADD 15   0001:0010 1111
2:OUT      0010:1110 0000
3:HLT      0011:1111 0000 
14:1       1110:0000 0001
15:1       1111:0000 0001

上面代码相当于地址14里面的值和15里面的值相加, 然后显示2

累加

0:LDI 1    0000:0101 0001
1:STA 15   0001:0100 1111
2:LDI 0    0010:0101 0000
3:ADD 15   0011:0010 1111
4:OUT      0100:1110 0000
5:JMP 3    0101:0110 0011

上面代码相当于i++

条件跳转测试

0:OUT      0000:1110 0000
1:ADD 15   0001:0010 1111
2:JC 4     0010:0111 0100
3:JMP 0    0011:0110 0000
4:SUB 15   0100:0011 1111
5:OUT      0101:1110 0000
6:JZ 0     0110:1000 0000
7:JMP 4    0111:0110 0100
15:1       1111:0000 0001

这段代码测试条件跳转指令JZJC

乘法

0:LDA 14   0000:0001 1110
1:SUB 12   0001:0011 1100
2:JC 6     0010:0111 0110
3:LDA 13   0011:0001 1101
4:OUT      0100:1110 0000
5:HLT      0101:1111 0000
6:STA 14   0110:0100 1110
7:LDA 13   0111:0001 1101
8:ADD 15   1000:0010 1111
9:STA 13   1001:0100 1101
10:JMP 0   1010:0110 0000
11:
12:1       1100:0000 0001
13:product 1101:0000 0000
14:x       1110:0000 0010
15:y       1111:0000 0101

这里相当于x = 2 ; y = 5 ; product = x * y, 并显示product


EOF

About

8 bit cpu, 5 regesters, 11 instructions

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages