我感觉很难受
计算机系统Ⅰ¶
约 1497 个字 29 行代码 5 张图片 预计阅读时间 5 分钟
成绩组成
- 作业 10%
- Projects 共60%
- Lab0 - 实验准备 6%
- Lab1 - 多路选择器+七段数码管 10%
- Lab2 - 加减法器 6%
- Lab3 - 时序电路 8%
- Lab4 - 卷积核 8%
- Lab5 - 汇编实现 10%
- 大程 - Single Cycle CPU 12%
- Bonus - Multi-Cycle CPU 10%
- Final 30%
理论课部分¶
Von Neumann架构:I/O System \(\leftrightarrows\) CPU \(\leftrightarrows\) Memory
Instructions: 0/1 binaries
编译型高级语言 \(\underrightarrow{\text{Compiler}}\) 汇编语言 \(\underrightarrow{\text{Assembler}}\) 机器语言
解释型高级语言 \(\underrightarrow{\text{Interpreter}}\) 机器语言
进制转换¶
例:\(1011.101_2 = 2^3 + 2^1 + 2^0 + 2^{-1} + 2^{-3} = 11.6875_{10}\)
数据的表示¶
用n个bit的的二进制数编码一个真值(true value)为X的数字,编码后得到机器数(machine number)
\(X = X_{n-1}X_{n-2}\dots X_1X_0\)
无符号整数(unsigned integer)范围: \(0 \le X \le 2^n - 1\)
有符号整数(signed integer)范围: 编码方式不同,有不同的范围
- 原码(original code):最高位为符号位,0为正,1为负
- 缺点:0有两种表示,+0和-0,导致可表示的范围减小1
- Hardware Complexity
- 二进制加法失效
- 反码(one's complement):正数的反码与原码相同,负数的反码是对应正数的原码的每一位取反
- 优点:二进制加法后,将进位加到最后一位上即可得到正确结果
- 缺点:0还是有两种表示,+0和-0
- 补码(two's complement):正数的补码与原码相同,负数的补码是对应正数的原码的每一位取反,然后加1
- 优点:0只有一种表示
- 缺点:最小的负数没有对应的正数
- 二进制加法后,将溢出位丢弃即可得到正确结果
- 已知A(用补码表示),那么-A的补码就是A按位取反(包括符号位)然后加1
- 补码的减法就是把减数取反加1,然后加到被减数上
- 补码的范围:\(-2^{n-1} \le X \le 2^{n-1} - 1\), n为位数
Modulo Operation
If \(A,B,M\) satisfy \(A = B + K \times M\), then \(A \equiv B \pmod M\)
浮点数的表示(IEEE 754 Standard)
s为符号位,exp为指数位,frac为尾数位。见https://zhuanlan.zhihu.com/p/107106675
\(V = (-1)^s \times M \times 2^{E - bias}\)
其中 \(E\) 为指数位对应的十进制数,\(M\) 为\(1.尾数\)
对任意浮点数,\(E-bias\)是固定值,因此根据一种位数下的表示与所给的偏移量可计算出另一位数表示下其指数位的值。(很绕,见作业)
单精度(32位):1 位符号位,8 位指数位,23 位尾数位
双精度(64位):1 位符号位,11 位指数位,52 位尾数位
布尔代数¶
- 与:\(A \cdot B\)
- 或:\(A + B\)
- 非:\(\overline{A}\)
- 优先级:非 > 与 > 或
K-map¶
\(n\)个变量对应的K-map是一个\(2^n\)个元素的表格,每个元素对应一个变量组合。
尽可能画一个大的框,框中元素个数为\(2^n(n\ge 1)\)
例
作业
纸质作业可供复习(疑似有错)
ISA¶
ISA(Instruction Set Architecture)是指令集架构,是计算机硬件与软件之间的接口。
通俗来讲就是,规定了寄存器个数,可运行的指令,哪些寄存器是干啥的,数据的单位类型和占据的大小(比特字节字这种)等等。设计者只要设计满足这些特性的程序,都可以在这种架构的计算机上运行。
Verilog补天¶
Basic¶
这一段代码表示一个叫做main
的电路module
(模块),先声明I1、I2、I3、O这几个输入/输出的引脚序列。注意main
后小括号里只能放输入输出引脚,可以类比函数,只关心它的输入是哪些。
wire的电气特性:必须被有且仅有一个assign输入,可以有0个或者多个assign输出。
运算符:&
表示按位与,|
表示按位或,^
表示异或,~
表示非。
如果没声明过一个变量a的类型,直接有assign a = I0
,a默认为wire,可以在文件头加上`default_nettype none
来查找这个错误。
Vectors¶
类似数组,wire [3:0] a = 4b'1011;
声明四根“捆在一块的线”,相当于一个位宽为4的二进制数
如果这时候直接assign b = a
,b默认是1bit的wire,导致隐式转换,b被赋值为a的最低位1。
还可以写二维数组,wire [3:0] a [1:0]
表明有两个unpacked element,每个element都是一个4bit的wire。
用{变量1,变量2, ...}
创建位宽为其元素之和的向量,因此变量需要指明位宽,如{4'b1011, 4'b1100}
是合法的,但{11, 12}
是不合法的。
位数较小赋值给位数较大,先填充低位,高位补0。位数较大赋值给位数较小,优先保留低位,高位舍弃。
二选一多路选择器¶
\(O = S \cdot I_0 + \overline{S} \cdot I_1\)
其中,\(S\)为选择信号,\(I_0\)和\(I_1\)为输入信号,\(O\)为输出信号。
点乘号表示逻辑与,加号表示逻辑或,横线表示逻辑非。
使用代码实现:
四选一多路选择器¶
\(O = \overline{S_1} \cdot \overline{S_0} \cdot I_0 + S_0 \cdot \overline{S_1} \cdot I_1 + \overline{S_0} \cdot S_1 \cdot I_2 + S_1 \cdot S_0 \cdot I_3\)
实现:使用三个二选一多路选择器实现。(封装两个二选一多路选择器模块)
\(Mux(I0, I1, S) = S \cdot I_1 + \overline{S} \cdot I_0\)
\(O = Mux(Mux(I_0, I_1, S_0), Mux(I_2, I_3, S_0), S_1)\)
module mux4to1(
input I0,
input I1,
input I2,
input I3,
input S0,
input S1,
output O
);
wire w1, w2;
mux2to1 Mux1(I0, I1, S0, w1);
mux2to1 Mux2(I2, I3, S0, w2);
mux2to1 Mux3(w1, w2, S1, O);
endmodule
lab2 - 加减法器¶
全加减器¶
N位二进制的加减法是\(\mod 2^N\)下的加减法。
A的解释
lab3 - 时序电路¶
史
lab5 - riscvs汇编¶
快速入门:https://blog.csdn.net/m0_62730135/article/details/126799687
https://zhuanlan.zhihu.com/p/502146080
学长笔记:https://note.tonycrane.cc/cs/pl/riscv/unprivileged/
函数返回值默认存在a0寄存器中,jr ra
就能返回,ret
也能返回。
sd a0, x(sp)
:memory[sp+x] = a0
ld a0, x(sp)
:a0 = memory[sp+x]
编译器优化:https://oi-wiki.org/lang/optimizations/