对于RISV -V处理器,详解 gcc 编译器,Makefile中gcc编译器参数的含义

GCC编译器的版本:


1:以“riscv64/32-unknown-linux-gnu-”为前缀的版本

       riscv64-unknown-linux-gnu-gcc(编译器)

       riscv64-unknown-linux-gnu-gdb (调试器)

       riscv64-unknown-linux-gnu-ar (文件归档,制作库文件,用于静态链接库或者动态链接库)

       riscv64-unknown-elf-objdump   (反汇编器)

       riscv64-unknown-elf-objcopy   (将elf文件转化位hex或者ihex文件)

       ................................................

riscv64-unknown-linux-gnu-”前缀表示该版本的工具链是64位架构的Linux版本工具链。注意:此Linux不是指当前版本工具链一定要运行在Linux操作系统的电脑上,此Linux是指该GCC工具链会使用Linux的Glibc作为C运行库。此处的前缀riscv64(还有riscv32的版本)与运行在64位或者32位电脑上毫无关系,此处的64和32是指如果没有通过-march和-mabi选项指定RISC-V架构的位宽,默认将会按照64位还是32位的RISC-V架构来编译程序。有关-march和-mabi选项的含义。


2: 以“riscv64-unknown-elf-”为前缀的版本

同上

以“riscv64-unknown-elf-”为前缀的版本表示该版本为非Linux(Non-linux)版本的工具链,此Non-Linux不是指当前版本工具链一定不能运行在Linux操作系统的电脑上,此Non-Linux是指该GCC工具链会使用newlib作为C运行库。同上理,此处的前缀riscv64(还有riscv32的版本)与运行在64位或者32位电脑上毫无关系,此处的64和32是指如果没有通过-march和-mabi选项指定RISC-V架构的位宽,默认将会按照64位还是32位的RISC-V架构来编译程序。有关-march和-mabi选项的含义。


3:以“riscv-none-embed-”为前缀的版本 

同上

以“riscv-none-embed-”为前缀的版本 表示是最新为裸机(bare-metal)嵌入式系统而生成的交叉编译工具链,所谓裸机(bare-metal)是嵌入式领域的一个常见形态,表示不运行操作系统的系统。该版本使用新版本的newlib作为C运行库,并且支持newlib-nano,能够为嵌入式系统生成更加优化的代码体积(Code Size)。 


RISV-V处理器中gcc编译器参数的含义:


-march: 

由于RISC-V的指令集是模块化的指令集,因此在为目标RISC-V平台进行交叉编译之时,需要通过选项指定目标RISC-V平台所支持的模块化指令集组合,该选项为(-march=),有效的选项值如下:    

  1.         rv32i[m][a][f[d]][c]
  2.         rv32g[c]
  3.         rv64i[m][a][f[d]][c]
  4.         rv64g[c]

在上述选项中rv32表示目标平台是32位架构,rv64表示目标平台是64位架构,其他i/m/a/f/d/c/g分别代表了RISC-V模块化指令子集的字母简称。


-mabi

由于RISC-V的指令集是模块化的指令集,因此在为目标RISC-V平台进行交叉编译之时,需要通过选项指定嵌入式RISC-V目标平台所支持的ABI函数调用规则(有关ABI函数调用规则的相关信息请参见RISC-V中文书籍《手把手教你设计CPU——RISC-V处理器篇》中附录A的图A-1)。RISC-V定义了两种整数的ABI调用规则和三种浮点ABI调用规则,通过选项(-abi=)指明,有效的选项值如下:

  1.         ilp32
  2.         ilp32f
  3.         ilp32d
  4.         lp64
  5.         lp64f
  6.         lp64d

细节解析参考:https://blog.csdn.net/qq_39507748/article/details/115347636?spm=1001.2101.3001.6650.13&utm_medium=distribute.pc_relevant.none-task-blog-2~default~CTRLIST~Rate-13-115347636-blog-126669424.topnsimilarv1&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2~default~CTRLIST~Rate-13-115347636-blog-126669424.topnsimilarv1&utm_relevant_index=14


-mcmodel

目前RISC-V GCC工具链认为,在实际的情形中,一个程序的大小一般不会超过4GB的大小,因此在程序内部的寻址空间不能超过4GB的空间。而在64位的架构中,地址空间的大小远远的大于4GB的空间,因此针对RV64架构而言,RISC-V GCC工具链定义了(–mcmodel=)选项用于指定寻址范围的模式,使得编译器在编译阶段能够按照相应的策略编译生成代码。其有效的选项值如下

        -mcmodel=medlow

        -mcmodel==medlow 选项用于指示该程序的寻址范围固定只能在-2GB至+2GB的空间内。注意:地址区间没有负数可言,-2GB是指整个64位地址空间最高2GB地址区间。
由于此模式的寻址空间是固定的-2GB至+2GB的空间内,因此编译器能够相对生成比较高效的代码,但是由于寻址空间固定,对于整个64位的大多数地址空间都无法访问到。

         -mcmodel=medany

        -mcmodel==medlow 选项用于指示该程序的寻址范围可以在任意的一个4G空间内。由于此模式的寻址空间不是固定的,所以相对比较灵活。

 细节解析参考:

https://blog.csdn.net/qq_39507748/article/details/115347636?spm=1001.2101.3001.6650.13&utm_medium=distribute.pc_relevant.none-task-blog-2~default~CTRLIST~Rate-13-115347636-blog-126669424.topnsimilarv1&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2~default~CTRLIST~Rate-13-115347636-blog-126669424.topnsimilarv1&utm_relevant_index=14


 -ffunction-section  -fdata-section

有时我们的程序会定义一些暂时使用不上的功能和函数,虽然我们不使用这些功能和函数,但它们往往会浪费我们的 ROM 和 RAM 的空间。这在使用静态库时,体现的更为严重。有时,我们只使用了静态库仅有的几个功能,但是系统默认会自动把整个静态库全部链接到可执行程序中,造成可执行程序的大小大大增加。

为了解决前面分析的问题,我们引入了标题中的几个参数。GCC 链接操作是以 section 作为最小的处理单元,只要一个 section 中的某个符号被引用,该 section 就会被加入到可执行程序中去。

因此,GCC 在编译时可以使用 -ffunction-sections 和 -fdata-sections 将每个函数或符号创建为一个 sections,其中每个 sections 名与 function 或 data 名保持一致。而在链接阶段, -Wl,–gc-sections 指示链接器去掉不用的section(其中-wl, 表示后面的参数 -gc-sections 传递给链接器),这样就能减少最终的可执行程序的大小了。

细节解析参考:https://blog.csdn.net/itworld123/article/details/124465741 


--specs=nano.specs

-specs 的作用

原来咱们执行的 gcc 并不是真正的编译器,而是 driver ,即驱动器,gcc 驱动器根据命令行的参数再调用真正的编译器(cc1,cc1plus)、汇编器(as)、链接器(ld)。gcc 驱动器调用 cc1、as、ld 时遵循一定的规则,这个规则就叫做 specs,gcc 有一套自带的 specs

如果命令行中没有指定 -specs=file 参数,那么 gcc 就使用自带的 specs,如果指定了 -specs=file 参数,那么在处理完自带的 specs 后,继续处理参数给出的 specs 文件,而且可以通过多个 -specs=file 参数指定多个 specs 文件,gcc 会按出现的次序依次处理。后面的 specs 文件可以覆盖、修改、删除前面的 specs 中的规则。

nona.specs 将 -lc 替换成 -lc_nano,即:使有精简版的C库替代标准C库。精简的C库有些特性是被排除掉的,比如 printf* 系列函数不支持浮点数的格式化,因为做了精简,因此最终生成的程序映像要比使用标准C库要小一些。如果没有用到这部分特性,就可以通过 -specs=nano.specs 节约有限的代码空间,如果使用了该参数后发现有些C库函数行为不符合预期,比如 sprintf 没有格式化浮点数,那么将这个参数去掉。

细节解析参考:https://blog.csdn.net/zoomdy/article/details/100727279


-D

请参考我的另一篇文章:在Makefile文件中,gcc -D的作用_ESWIN5204的博客-CSDN博客 

  • 4
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RISC-V(Reduced Instruction Set Computer - Five)是一种开源的指令集架构(ISA),它具有以下几个好处: 1. 开放性和自由度高:RISC-V是一个开源的指令集架构,任何人都可以免费使用、设计和定制。这使得RISC-V非常适合于教育、研究和创新,同时也促进了硬件和软件的生态系统的发展。 2. 简洁而灵活的指令集:RISC-V采用了精简的指令集设计,使得指令集更加简洁和易于理解。同时,RISC-V还提供了可选的扩展指令集,可以根据需求进行定制,从而满足不同应用场景的需求。 3. 跨平台兼容性:RISC-V的指令集架构是与特定硬件实现无关的,这意味着可以在不同的处理器架构上实现RISC-V指令集,并且可以在不同的操作系统上运行RISC-V程序。这种跨平台兼容性使得RISC-V成为了一个通用的指令集架构。 4. 高性能和低功耗:由于RISC-V采用了精简的指令集设计,使得指令执行更加高效。同时,RISC-V还支持硬件流水线和超标量技术,可以提高指令的并行执行能力,从而提高处理器的性能。此外,RISC-V还支持动态电压频率调节(DVFS)等功耗优化技术,可以降低处理器的功耗。 5. 可扩展性和可定制性:RISC-V提供了可选的扩展指令集,可以根据应用需求进行定制。这种可扩展性和可定制性使得RISC-V非常适合于各种不同的应用场景,包括嵌入式系统、物联网设备、高性能计算等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值