计算机基础系列 —— 汇编器

"The Analytical Engine might act upon other things besides numbers... Suppose, for instance, that the fundamental relations of pitched sounds in the science of harmony and of musical composition were susceptible of such expression and adaptations... If so, the engine might compose elaborate and scientific pieces of music of any degree of complexity." ------ Ada Lovelace(诗人拜伦的女儿在 1840 年的看法)

文中提到的所有实现都可以参考:nand2tetris_sol,但是最好还是自己学习课程实现一遍,理解更深刻。

之前的文章介绍了 Hacker 和汇编语言,如果要让汇编语言运行在 Hacker 上,我们还需要一个汇编器程序,把汇编语言翻译成机器语言,才能使得汇编语言运行。

A 指令

C 指令

如上图,A 指令和 C 指令的翻译很简单。每条指令都可以一对一翻译成 16-bits 的 01 串。

空格、注释和缩进

汇编器直接忽略掉就好。

符号

预定义符号

这里有些符号在后面的文章里会用到,对于预定义符号直接把 symbol 替换成 value,就和上面的指令翻译是一样的了。

标签符号

标签符号对应的 value 就是和标签相邻的下一条指令的行数,对应的就是 ROM 里的指令行数。

变量符号

变量符号就简单一些,除了预定义的 15 个变量,新定义的变量从 RAM[16] 依次存储,变量的映射关系存储在汇编器的 Symble table 里,如下图:

接下来我们就可以用自己喜欢的语言 Python、C++ etc... 实现按上面的过程实现这个汇编器啦,实际上最早的汇编器使用机器语言写的,重要的不是用什么语言写汇编器,重要的是理解汇编器的核心思想 ------ 把指令集翻译成机器语言。

后面的文章,我们还会实现自己的操作系统,高级语言,VMCode Translator。

相关推荐
添砖java‘’1 天前
Linux信号机制详解:从产生到处理
linux·c++·操作系统·信号处理
元亓亓亓1 天前
考研408--操作系统--day9--I/O设备(上)
考研·操作系统·i/o·408
法欧特斯卡雷特1 天前
如何解决 Kotlin/Native 在 Windows 下 main 函数的 args 乱码?
后端·操作系统·编程语言
小林up1 天前
【MIT-OS6.S081作业-4-2】Lab4-traps-Backtrace
操作系统·xv6
fakerth2 天前
【OpenHarmony】USB服务组件
操作系统·openharmony
悄悄敲敲敲2 天前
Linux:信号(二)
linux·操作系统·信号
青春pig头少年2 天前
决战408:OS大题我拿拿拿(非PV)
操作系统·学习笔记·408
Logic1012 天前
深入理解C语言if语句的汇编实现原理:从条件判断到底层跳转
c语言·汇编语言·逆向工程·底层原理·条件跳转·编译器原理·x86汇编
fakerth2 天前
【OpenHarmony】日志服务hilog_lite
操作系统·日志·openharmony