C语言模拟RS结构CPU

源代码

一、说明

C语言实现CPU仿真,可编程,可扩展

编程模板在template.txt

程序默认载入测试程序文档test.txt

提供测试文件
1、==test.txt ==斐波那契数列
2、testFAC.txt阶乘

操作方法

编译运行SmuCPU.c文件即可

运行结果会展示CPU完整的寄存器组和主存的代码区数据区自定义标识符映射表

编程方法

way_1.在test.txt文件中编写汇编代码即可
way_2.在template.txt写入汇编代码后,在SmuCPU.c修改路径即可

	fp=fopen("test.txt", "r");//第231行

二、指令集

RISC指令集

erum OrderSet={ "MOV","ADD","SUB","INC","DEC","MUL","DIV","XOR",
"PUSH","POP","CMP","JE","CALL","RET" }

三、测试代码说明(test.txt)

1、题目(斐波那契数列——递归子函数)

递归子程序设计

给定一个正数N≥1存放在NUM单元中,试编制一递归子程序计算FIB(N),并将结果存入RESULT单元中。
Fibonacci数的定义如下:
FIB(1)= 1
FIB(2)= 1
FIB(n)= FIB(n-2)+ FIB(n-1) n>2
数据段中至少需要定义以下内容:
(1)ID db xxH, yyH, zzH (说明:以学号2186123456为例,其中的xx为12,yy为34,zz为56)
(2)定义NUM、RESULT的内存单元

2、题解

即为test.txt的内容

SSEG SEGMENT
	ID DW 41,26,35
	NUM DW 10
	RESULT DW 0
SSEG ENDS

CSEG SEGMENT
	ASSUME CS:CSEG,DS:SSEG
	FIB PROC NEAR
		CMP BX ,1
		JE FIB1
		CMP BX,2
		JE FIB2
		PUSH BX
		DEC BX
		CALL FIB
		POP BX
		MOV CX,AX
		ADD AX,DX
		MOV DX,CX
		RET
	FIB1:
		MOV AX,1
		RET
	FIB2:
		MOV AX,1
		MOV DX,1
		RET
	FIB ENDP
	
	MAIN PROC far
	START:
		XOR BX,BX
		MOV BX, NUM
		CALL FIB
		MOV RESULT,AX
	MAIN ENDP
CSEG ENDS
END START

3、DOS系统运行结果

以NUM=5为例子

运行前

在这里插入图片描述

运行后

在这里插入图片描述

4、C语言仿真CPU运行结果

运行前

在这里插入图片描述

运行后

在这里插入图片描述

NUM的值可以在test.txt文件中自由更改

eg1:
在这里插入图片描述
eg2:
在这里插入图片描述

5、gcc编译

gcc version 9.3.0 (Ubuntu 9.3.0-17ubuntu1~20.04)

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值