riscv 文章总览

riscv 官方资料

https://github.com/riscv-non-isa
https://github.com/riscv
http://crva.ict.ac.cn/
https://riscv.org/
  • 其他个人资料
https://zhuanlan.zhihu.com/p/102484084
https://github.com/FengWuCB/RVirt
https://github.com/kvm-riscv

riscv 市场

riscv spec 架构


RISC-V 编译器支持多个 ABI,具体取决于 F 和 D 扩展是否存在。RV32 的 ABI 分别名
为 ilp32,ilp32f 和 ilp32d。ilp32 表示 C 语言的整型(int),长整型(long)和指针(pointer)
都是 32 位,可选后缀表示如何传递浮点参数。在 lip32 中,浮点参数在整数寄存器中传递;
在 ilp32f 中,单精度浮点参数在浮点寄存器中传递;在 ilp32d 中,双精度浮点参数也在浮点
寄存器中传递。
自然,如果想在浮点寄存中传递浮点参数,需要相应的浮点 ISA 添加 F 或 D 扩展(见
第 5 章)。因此要编译 RV32I 的代码(GCC 选项-march=rv32i),必须使用 ilp32 ABI(GCC
选项-mabi=ilp32)。反过来,调用约定并不要求浮点指令一定要使用浮点寄存器,因此
RV32IFD 与 ilp32,ilp32f 和 ilp32d 都兼容。

1. 交叉编译
	链接器检查程序的 ABI 是否和库匹配。
	尽管编译器本身可能支持多种 ABI 和 ISA 扩展的组合,但机器上可能只安装了特定的几种库。
	因此,一种常见的错误是在缺少合适的库的情况下链接程序。
	在这种情况下,链接器不会直接产生有用的诊断信息,它会尝试进行链接,然后提示不兼容。
	这种错误常常在从一台计算机上编译另一台计算机上运行的程序(交叉编译)时发生。
2. 交叉编译后的运行
	
	

参考 riscv-specifications教程

riscv 仿真器

如果你要继续在 qemu 上 做事情 , 例如 加一个 platform , 可以参考
专栏
或者
[qemu官网](TODO

riscv 编译链

riscv的编译链
	1. sifive 				发布的 : riscv64-unknown-elf-gcc
	2. crosstool-ng 		发布的 : riscv64-unknown-elf-gcc
	3. riscv-gnu-toolchain 	发布的 : riscv64-unknown-elf-gcc
	4. andes 				发布的 : win 	:riscv64-linux-gcc/riscv64-elf-gcc/riscv32-linux-gcc/riscv32-elf-gcc
									linux	:riscv64-linux-gcc
								

riscv standalone


riscv RTOS


riscv Freertos

如果你要继续在 freertos 移植 riscv 的话,建议参考freertos在riscv上的port

riscv linux


Guess you like

Origin blog.csdn.net/u011011827/article/details/120063103