[RISC-V MCU 创新应用比赛] RISC-V MCU开发 (四):编译配置

[复制链接]
754|1
手机看帖
扫描二维码
随时随地手机跟帖
laocuo1142|  楼主 | 2021-10-8 11:32 | 显示全部楼层 |阅读模式
嵌入式开发中,当我们完成了工程创建、代码编辑等操作之后,就可以开始进行工程编译。 对于使用内置工程模板创建或外部导入的项目,MounRiver® Studio(MRS)会根据对应芯片内核自动配置好目标工具链(riscv-none-embed-gcc或arm-none-eabi-gcc),同时,目标平台、优化等级、调试等级以及文件引用等编译配置也会自动设置完毕。

   MRS最新V1.51版本安装包获取方式:www.mounriver.com

【工程属性页】在资源管理器窗口选中要编译的工程,点击工具栏上的工程属性配置按钮,或者点击右键菜单中的”Properties”进入编译选项属性页面。
133312rflyd83l40tz6ful.png.thumb.jpg

【目标处理器】用于指定目标指令架构、扩展函数等参数。

  • Architecture是指令集架构,rv32i是RISC-V 基础整数指令集
  • RVM表示支持乘除法扩展,RVA表示支持原子扩展,RVF表示单精度浮点数扩展,RVD为双精度浮点数扩展,RVC为压缩指令扩展。
  • IntegerABI 为RISC-V应用程序整数二进制接口,Floating point ABI为RISC-V应用程序浮点数二进制接口,RISC-V 编译器支持多个 ABI,具体取决于 F 和 D 扩展是否存在。RV32 的 ABI 分别名为 ilp32,ilp32f 和 ilp32d。ilp32 表示 C 语言的整型(int),长整型(long)和指针(pointer) 都是 32 位,可选后缀表示如何传递浮点参数。在 ilp32 中,浮点参数在整数寄存器中传递; 在 ilp32f中,单精度浮点参数在浮点寄存器中传递;在 ilp32d中,双精度浮点参数也在浮点寄存器中传递。自然,如果想在浮点寄存中传递浮点参数,需要相应的浮点ISA 添加 F 或 D 扩展。因此要编译 RV32I 的代码(GCC 选项-march=rv32i),必须使用 ilp32ABI(GCC选项-mabi=ilp32)。反过来,调用约定并不要求浮点指令一定要使用浮点寄存器,因此RV32IFD与 ilp32,ilp32f和 ilp32d都兼容。
  • Tuning 由微架构优化给定处理器的输出,默认是rocket。
  • Code model主要有两种模式:-mcmodel=medlow:程序及其静态定义的符号必须位于单个2 GiB地址范围内,并且必须位于绝对地址-2 GiB和+2 GiB之间。程序可以静态或动态链接。这是默认的代码模型。-mcmodel=medany:程序及其静态定义的符号可以任何单个2 GiB地址范围内。程序可以静态或动态地连接。
  •   Align 中-mstrict-align-mno-strict-align 取决于处理器是否支持内存的非对齐访问。
  • Small data limit 在某些目标上将小于n字节的全局和静态变量放进一个特殊的段。

【优化等级】主要是配置GCC的优化选项,想要添加其他优化选项可以写在下方other optimizationflags中。
133349qictnwydewfd0j1r.png.thumb.jpg

  •   -O0:无优化(默认)
  • -O、-O1:使用能减少目标文件大小以及执行时间并且不会使编译时间明显增加的优化.在编译大型程序的时候会显著增加编译时内存的使用.
  •   -O2: 包含-O1的优化并增加了不需要在目标文件大小和执行速度上进行折衷的优化.编译器不执行循环展开以及函数内联.此选项将增加编译时间和目标文件的执行性能.
  • -Os:专门优化目标文件大小,执行所有的不增加目标文件大小的-O2优化选项.并且执行专门减小目标文件大小的优化选项.
  •   -O3: 打开所有-O2的优化选项并且增加部分参数。



使用特权

评论回复

相关帖子

laocuo1142|  楼主 | 2021-10-8 11:35 | 显示全部楼层
【警告等级】用于设置GCC的警告参数选项。

133353a53m33hzmd36dlgj.png.thumb.jpg




  • -fsyntax-only:检查代码中的语法错误,但除此之外不要做任何事情。
  • -fmax-errors=n:将错误消息的最大数量限制为n ,此时GCC会缓存,而不是尝试继续处理源代码。 如果n为0(默认值),则生成的错误消息数量不受限制。 如果还指定了-Wfatal-errors ,则重大错误优先于此选项。
  •   -w:禁止所有警告消息。
  • -Werror:使所有的警告进入错误
  • -pedantic:允许发出ANSI/ISO C标准所列出的所有警告
  •   -pedantic-errors:允许发出ANSI/ISO C标准所列出的错误
  • -Wfatal-errors:遇到第一个错误就停止,减少查找错误时间



【调试等级】红框中的-g设置GDB调试信息,注意生成静态库时将红框中调为None,否则生成的库会包含调试信息,导致库文件过大。
133355n813v48mqa881wfh.png.thumb.jpg


【汇编、头文件添加】红框中的位置分别为添加汇编、头文件接口,点击右侧方框上绿色的加号去添加文件路径。
133357ruifzcyq9rsdql7z.png.thumb.jpg


【链接脚本文件添加】红框中的位置分别为添加链接脚本文件接口,点击右侧方框上绿色的加号去添加文件路径。
133359a4ht77m7ethxty78.png.thumb.jpg


【库文件添加】
-L添加库文件的路径,-l添加库名,注意库名要去掉前缀和后缀,例如libtest.a,只需要填写test。

133401d1dv65vt1v1vu6uc.png.thumb.jpg




【链接其他文件】Other objects 可以添加想要参与链接的.o或者.lib文件。

133403vg656yv6rgwzg5vj.png.thumb.jpg




【输出文件格式】右侧红框中可点击下拉框选择编译后输出BIN文件或者HEX文件。


133406ra8hr8kcrftvunsh.png.thumb.jpg

【输出类型】图示位置可选择生成可执行文件或者静态库文件。

133408kn93h84onhrlu8un.png.thumb.jpg


以上就是MRS常用的编译配置,编译之后生成的文件会存在工程目录中obj文件中,其中.list和.map文件可用于对程序分析。


一键分析设计隐患,首款国产PCB DFM分析软件免费用!
地址下载(电脑端下载):
https://dfm.**/uploads/software/promoter/hqdfm_wanghemu.zip

无需安装 !手机即可在线查看+文件共享 ↓ ↓ ↓
Web端地址(直接点击):
https://dfm.**/viewer/?from=wanghemu
想了解更多的详细介绍可以百度搜索“华秋DFM”官方链接











使用特权

评论回复
您需要登录后才可以回帖 登录 | 注册

本版积分规则

我要发帖 我要提问 投诉建议 申请版主

本版热帖

本版活跃用户

优质原创写原创,赢大奖

编辑推荐

  • 1 呐咯密密 得到打赏 ¥310.00
  • 2 qbwww 得到打赏 ¥265.00
  • 3 yanzhengxin1 得到打赏 ¥200.00
  • 4 full_stack 得到打赏 ¥100.00
  • 5 laocuo1142 得到打赏 ¥55.00
  • 6 二哲科技 得到打赏 ¥50.00
  • 7 zhangjiantao 得到打赏 ¥50.00
  • 8 改名了 得到打赏 ¥50.00
  • 9 小叶三千 得到打赏 ¥50.00
  • 10 cjseng 得到打赏 ¥50.00
在线客服 快速回复 返回顶部 返回列表