Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
D
DM1000
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸大学计算机学院
教师群组
赵鹏翀-zpc
DM1000
提交
aa7b47b9
提交
aa7b47b9
12月 17, 2018
创建
作者:
李川
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'ret' into 'master'
修改调用指令微程序 See merge request
engintime/Dream-Logic/Project-Template/DM1000/DM1000!14
上级
af5ed2ee
f4ee406d
全部展开
显示空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
118 行增加
和
90 行删除
+118
-90
rom.dbg
rom.dbg
+0
-0
rom.lst
rom.lst
+98
-84
rom.masm
rom.masm
+18
-4
rom.rxm
rom.rxm
+2
-2
没有找到文件。
rom.dbg
浏览文件 @
aa7b47b9
没有这种文件类型的预览
rom.lst
浏览文件 @
aa7b47b9
差异被折叠。
点击展开。
rom.masm
浏览文件 @
aa7b47b9
...
...
@@ -371,11 +371,15 @@ dup 16, null
;=======================================================================
;子程序调用返回指令
; ret
; 返回地址出栈
path sp, mar ;将栈指针(栈顶地址)传送到 MAR
path sp, csp ;
path sp_inc, csp ;
path [mar], pc ;将返回地址加载到PC
; 出栈时,栈顶向高地址方向生长,sp+1指向新的栈顶
path sp, csp
path sp_inc, csp
path csp, sp ;SP = SP + 1,出栈,更新栈顶
path [mar], pc ;将调用返回地址加载到PC,转移到调用处的下一条指令继续执行
reset upc
dup 2, null
...
...
@@ -428,14 +432,24 @@ dup 5, null
;=============================================================
;子程序调用指令,双字节指令,第二个字节是调用子程序标号,该标号实质为一个地址,所指存储单元中就是被调用子程序的入口地址(起始地址)
; call symbol
; 将子程序入口地址保存到辅助寄存器asr中
inc pc ;PC+1
path [pc], asr ;将PC指向存储单元内容写入辅助寄存器ASR中,也就是将被调用子程序的入口地址暂存到ASR中
; pc+1,得到返回地址
inc pc ;PC+1,指向下一条指令,即返回地址
; sp-1,为返回地址入栈分配一个新的空间,入栈时,栈顶向低地址方向生长
path sp, csp
path sp_dec, csp
path csp, sp ;返回地址入栈前,先将SP-1,指向新的栈顶
; 返回地址入栈
path sp, mar
inc pc ;PC+1,指向下一条指令,即返回地址
path pc, [mar] ;将PC(返回地址)入栈
; 将调用子程序入库地址加载到PC,实现子程序调用
path asr, pc ;将ASR寄存器的值加载到PC,也就是将调用子程序的入口地址加载到PC,转移到子程序处执行
reset upc
...
...
rom.rxm
浏览文件 @
aa7b47b9
没有这种文件类型的预览
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论