搜索
bottom↓
回复: 5

一个开源risc-v,make时,为什么要生成rom和ram两个mem的数据

[复制链接]

出0入18汤圆

发表于 7 天前 | 显示全部楼层 |阅读模式
相关源码请参见附件,build里是make脚本文件,risc-v里是verilog源码
make后会生成*rom.mem和*ram.mem两个文件,这个两文件初始化进risc-v对应的rom和ram,程序就可以运行
cpu的ram数据不是应该由rom里的程序指令操作的吗,为什么要上电初始化呢?有没有了解的坛友,帮忙解释一下,感谢!!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

该献的血还是要献的。你不献他不献。难道让我去献? --- 出自坛友:lovejp1981

出0入442汤圆

发表于 7 天前 | 显示全部楼层
要搞清楚这个问题,你首先要搞明白程序里面各个段的作用。这需要对软件有相当程度的了解。当然你可以把ram放到rom后面,上电时加载。这需要一个相对复杂的loader。

出0入18汤圆

 楼主| 发表于 7 天前 来自手机 | 显示全部楼层
wye11083 发表于 2024-8-21 18:30
要搞清楚这个问题,你首先要搞明白程序里面各个段的作用。这需要对软件有相当程度的了解。当然你可以把ram ...
(引用自2楼)

大神,请问一下riscv程序里各个段是怎么分的,作用是什么,能帮忙科普一下吗?常规的51单片机,程序都是在rom里直接运行,都不需要ram初始化

出0入442汤圆

发表于 7 天前 | 显示全部楼层
smbxfdbz 发表于 2024-8-21 18:44
大神,请问一下riscv程序里各个段是怎么分的,作用是什么,能帮忙科普一下吗?常规的51单片机,程序都是 ...
(引用自3楼)

bing,baidu。这些东西是编译原理的一部分。

出0入8汤圆

发表于 7 天前 | 显示全部楼层
smbxfdbz 发表于 2024-8-21 18:44
大神,请问一下riscv程序里各个段是怎么分的,作用是什么,能帮忙科普一下吗?常规的51单片机,程序都是 ...
(引用自3楼)

本质上都有ram初始化的  在main函数之前

出200入2554汤圆

发表于 7 天前 | 显示全部楼层
大多数 cpu 是在 main 之前还有个 startup 函数,负责初始化堆栈、全局/静态变量。

这种 ram 要单独烧写,像 FPGA 是为了调试方便,单纯烧写到 ram 不支持掉电重启
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-8-28 13:18

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表