编译链中的riscv指令集与寄存器

2024-05-27 15:18

本文主要是介绍编译链中的riscv指令集与寄存器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • 编译链
https://blog.csdn.net/u011011827/article/details/120086961
$ which riscv64-unknown-elf-gcc
/home/suweishuai/x-tools/riscv64-unknown-elf/bin/riscv64-unknown-elf-gcc
  • code
FreeRTOSv202111.00/FreeRTOS/Demo/RISC-V-Qemu-virt_GCC 编译选项.c
-D__riscv_float_abi_soft  // define 宏 ,在本例中没用到
-DportasmHANDLE_INTERRUPT=handle_trap // 在 Source/portable/GCC/RISC-V/portASM.S 被 jal
-march=rv32ima 	//	Specify the name of the target architecture and, optionally, one or more feature modifiers.// 对于armv8 , 可填入 armv8-a, armv8.1-a, armv8.2-a, armv8.3-a, armv8.4-a, armv8.5-a// 对于armv7 , 可填入 armv7-a+vfpv4// 对于riscv , 可填入 RV32IMAFDC// 表示要生成哪一类 汇编指令
-mabi=ilp32 // Generate code for the specified ABI.  // Permissible values are: apcs-gnu, atpcs, aapcs, aapcs-linux and iwmmxt.// 表示要遵循的 ABI 调用标准(Calling Convention)// RISC-V 编译器支持多个 ABI,具体取决于 F 和 D 扩展是否存在。RV32 的 ABI 分别名 为 ilp32,ilp32f 和 ilp32d// RISC-V-Reader-Chinese-v2p1.pdf P49// 参考 https://blog.csdn.net/zoomdy/article/details/79353313
-mcmodel=medany 
-Wall 				// turns on the following warning flags
-fmessage-length=0  // 尝试格式化错误消息,使其适合大约n个字符的行。如果n为零,则不进行换行;每条错误消息显示在一行上。这是所有前端的默认设置。
-ffunction-sections //如果目标支持任意节,则将每个函数或数据项放入输出文件中自己的节中。函数名或数据项名决定了输出文件中节的名称。
-fdata-sections //如果目标支持任意节,则将每个函数或数据项放入输出文件中自己的节中。函数名或数据项名决定了输出文件中节的名称。
-fno-builtin-printf // 不使用编译器内建的 printf 函数链接
-O2  // 参考 https://blog.csdn.net/u011011827/article/details/121077950
-MMD  // 只用用户头文件,而不是系统头文件 , 且生成.d文件
-MP // .d 文件的格式 
-I ..编译选项.S
-D__riscv_float_abi_soft 
-DportasmHANDLE_INTERRUPT=handle_trap
-march=rv32ima 
-mabi=ilp32 
-mcmodel=medany // Generate code for the medium-any code model. The program and its statically defined symbols must be within any single 2 GiB address range. Programs can be statically or dynamically linked.
-MMD 
-MP
-I ..链接选项
riscv64-unknown-elf-gcc
-nostartfiles
-Tfake_rom.lds 
-Xlinker --gc-sections 
-Xlinker --defsym=__stack_size=300  
xxx.o  
-o 
build/RTOSDemo.axf
  • dump
riscv64-unknown-elf-objdump: supported targets: elf64-littleriscv elf32-littleriscv elf64-little elf64-big elf32-little elf32-big pluginsrecsymbolsrecverilogtekhexbinaryihexriscv64-unknown-elf-objdump: supported architectures: riscv		// 该选项 会根据 实际的 .o 来判断 是转成 rv64 还是 rv32riscv:rv64riscv:rv32pluginThe following RISC-V-specific disassembler options are supported for use with the -M switch (multiple options should be separated by commas):以下RISC-V特定反汇编程序选项支持与-M开关一起使用(多个选项应以逗号分隔):numeric       Print numeric register names, rather than ABI names.数字打印数字寄存器名称,而不是ABI名称。no-aliases    Disassemble only into canonical instructions, rather than into pseudoinstructions.没有别名只能分解为规范指令,而不是伪指令。
  • riscv64-unknown-elf-gcc 可编译的 汇编格式
// riscv64-unknown-elf-objdump 							-D  build/RTOSDemo.axf  > build/RTOSDemo.asm
// riscv64-unknown-elf-objdump -M no-aliases -M numeric -D  build/RTOSDemo.axf  > build/RTOSDemo.no-aliases-numeric.asm
寄存器 字符串1. 默认				:	ABI 名称的 寄存器(zero ra sp gp 等) RISC-V-Reader-Chinese-v2p1.pdf P30 2. "-M numeric" 	: 	X0 X1 类似名称
指令 字符串1. 默认:			: 	标准指令+伪指令(TODO) // 伪指令和编译器强相关 // RISC-V-Reader-Chinese-v2p1.pdf P117 有所有的标准指令和伪指令2. "-M no-aliases"	: 	标准指令 RISC-V-Reader-Chinese-v2p1.pdf P3 P4
寄存器的访问GPRs 						: 0x10000x101fRV32IMA指令Floating point registers	: 0x10200x103fRV32IMA指令RV32FD指令CSRs						: 0x00000x0fffRVZicsr指令

在这里插入图片描述

在这里插入图片描述

这篇关于编译链中的riscv指令集与寄存器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1007837

相关文章

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

Windows环境利用VS2022编译 libvpx 源码教程

libvpx libvpx 是一个开源的视频编码库,由 WebM 项目开发和维护,专门用于 VP8 和 VP9 视频编码格式的编解码处理。它支持高质量的视频压缩,广泛应用于视频会议、在线教育、视频直播服务等多种场景中。libvpx 的特点包括跨平台兼容性、硬件加速支持以及灵活的接口设计,使其可以轻松集成到各种应用程序中。 libvpx 的安装和配置过程相对简单,用户可以从官方网站下载源代码

Golang test编译使用

创建文件my_test.go package testsimport "testing"func TestMy(t *testing.T) {t.Log("TestMy")} 通常用法: $ go test -v -run TestMy my_test.go=== RUN TestMyTestMy: my_test.go:6: TestMy--- PASS: TestMy (0.

C++/《C/C++程序编译流程》

程序的基本流程如图:   1.预处理        预处理相当于根据预处理指令组装新的C/C++程序。经过预处理,会产生一个没有宏定义,没有条件编译指令,没有特殊符号的输出文件,这个文件的含义同原本的文件无异,只是内容上有所不同。 读取C/C++源程序,对其中的伪指令(以#开头的指令)进行处理将所有的“#define”删除,并且展开所有的宏定义处理所有的条件编译指令,如:“#if”、“

编译linux内核出现 arm-eabi-gcc: error: : No such file or directory

external/e2fsprogs/lib/ext2fs/tdb.c:673:29: warning: comparison between : In function 'max2165_set_params': -。。。。。。。。。。。。。。。。。。 。。。。。。。。。。。。。 。。。。。。。。 host asm: libdvm <= dalvik/vm/mterp/out/Inte

QT 编译报错:C3861: ‘tr‘ identifier not found

问题: QT 编译报错:C3861: ‘tr’ identifier not found 原因 使用tr的地方所在的类没有继承自 QObject 类 或者在不在某一类中, 解决方案 就直接用类名引用 :QObject::tr( )

hector_quadrotor编译总结 | ubuntu 16.04 ros-kinetic版本

hector_quadrotor编译总结 | ubuntu 16.04 ros-kinetic版本 基于Ubuntu 16.04 LTS系统所用ROS版本为 Kinetic hector_quadrotor ROS包主要用于四旋翼无人机的建模、控制和仿真。 1.安装依赖库 所需系统及依赖库 Ubuntu 16.04|ros-kinetic|Gazebo|gazebo_ros_pkgs|ge

hector_quadrotor编译总结 | ubuntu 14.04 ros-indigo版本

hector_quadrotor编译总结 | ubuntu 14.04 ros-indigo版本 基于Ubuntu 14.04 LTS系统所用ROS版本为 Indigo hector_quadrotor ROS包主要用于四旋翼无人机的建模、控制和仿真。 备注:两种安装方式可选:install the binary packages | install the source files

编译和链接那点事下

http://www.0xffffff.org/?p=357 上回书我们说到了链接以前,今天我们来研究最后的链接问题。         链接这个话题延伸之后完全可以跑到九霄云外去,为了避免本文牵扯到过多的话题导致言之泛泛,我们先设定本文涉及的范围。我们今天讨论只链接进行的大致步骤及其规则、静态链接库与动态链接库的创建和使用这两大块的问题。至于可执行文件的加载、可执行文件的运行时

编译和链接那点事上

http://www.0xffffff.org/?p=323  有位学弟想让我说说编译和链接的简单过程,我觉得几句话简单说的话也没什么意思,索性写篇博文稍微详细的解释一下吧。其实详细的流程在经典的《Linkers and Loaders》和《深入理解计算机系统》中均有描述,也有国产的诸如《程序员的自我修养——链接、装载与库》等大牛著作。不过,我想大家恐怕很难有足够的时间去研读这些厚如