编译链中的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 
	plugin
	srec
	symbolsrec
	verilog
	tekhex
	binary
	ihex

riscv64-unknown-elf-objdump: supported architectures: 
		riscv		// 该选项 会根据 实际的 .o 来判断 是转成 rv64 还是 rv32
		riscv:rv64
		riscv:rv32
		plugin

The 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 						: 0x10000x101f
		RV32IMA指令
	Floating point registers	: 0x10200x103f
		RV32IMA指令
		RV32FD指令
	CSRs						: 0x00000x0fff
		RVZicsr指令

在这里插入图片描述

在这里插入图片描述

在GCC中,扩展RISC-V指令可以通过添加新的目标处理器选项来实现。以下是一个简单的步骤来扩展RISC-V指令集: 1. 获取RISC-V GCC工具链:首先,你需要获取RISC-V GCC工具链。你可以从RISC-V官方GitHub存储库获取源代码,然后编译工具链。或者,你也可以使用预编译的工具链,例如Sifive提供的Freedom开发平台。 2. 了解GCC寄存器描述文件:GCC使用一种称为“寄存器描述文件(Register Description File)”的文件来描述目标处理器的寄存器指令集。你需要了解这个文件的结构和格式。 3. 修改寄存器描述文件:根据你需要扩展的指令集,你需要修改寄存器描述文件以添加新的指令。你可以定义新的指令格式、操作码和操作数等。 4. 更新GCC源代码:将修改后的寄存器描述文件与GCC源代码一起使用。你需要将该文件放置在正确的目录中,并更新相关的构建系统脚本。 5. 构建和安装GCC:使用修改后的GCC源代码构建新版本的GCC。按照通常的构建过程进行,并确保在构建期间指定新的目标处理器选项。 6. 测试新指令:构建完成后,你可以使用新版本的GCC来编译和运行包含新指令的程序。确保新指令能够正确地被编码和执行。 请注意,这是一个简单的概述,并且具体的步骤可能因你要扩展的指令集和GCC版本而有所不同。在实际操作中,你可能需要更深入地了解GCC的内部结构和相关文档。此外,还要注意遵循RISC-V的指令集架构规范,并确保新指令的正确性和兼容性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值