八位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,各种颜色都有。
买这种引脚在下面的,好插在面包版
已焊接针脚,带usb线
这里包括了所有相关资料和视频
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
这段代码测试条件跳转指令JZ
和JC
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