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与SBI与ABI及[常见的ABI问题]
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 仿真器
如果你要继续在 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
-
[rt-thread/bsp/rv32m1_vega]
-
[rt-thread/bsp/qemu-riscv-virt64]
riscv Freertos
- FreeRTOS 中 RISC-V-Qemu-virt_GCC 的 启动流程
- FreeRTOS 中 RISC-V-Qemu-virt_GCC 的 运行流程
- FreeRTOS 中 RISC-V-Qemu-virt_GCC 的 运行流程 的栈分析
- FreeRTOS 中 RISC-V-Qemu-virt_GCC 的 运行流程 的Mode分析
- FreeRTOS 中 RISC-V-Qemu-virt_GCC 的 运行流程 的异常分析
如果你要继续在 freertos 移植 riscv 的话,建议参考freertos在riscv上的port
riscv linux