RuyiSDK V0.9 版本已于今日发布。 RuyiSDK 完成了对矽速现有 RISC-V 全产品线的调研,并在设备系统安装器中添加支持,除RISCV FPGA 系列中无RISC-V硬核的开发板,均已集成到RuyiSDK中。同时,完成了对 嘉楠勘智 K510 的支持。
近期提交了基于17.0.6版本添加xtheadvector支持的LLVM工具链,这一支持后续也将集成到RuyiSDK中。此外,包管理器工具针对开发板镜像或SDK格式多元化的特点,修复了多文件压缩包下载时的bug,增加lz4压缩格式解包等。RuyiSDK更多进展细节详见下方详情,欢迎大家试用并提供反馈和建议。
下一个开发版本 RuyiSDK V0.10 版本将在 5 月 14 日发布。
RuyiSDK 0.9 对应的包管理器版本也为 0.9.0,已于今日发布。您可移步 GitHub Releases 或 ISCAS 镜像源下载体验。
本次 RuyiSDK 包管理器的更新主要包含了以下内容:
- 支持解包 LZ4 格式的压缩文件了。
本次 RuyiSDK 软件源的更新主要包含了以下内容:
- 支持矽速(Sipeed)全线 RISC-V 产品。Ruyi 设备安装器现已新增支持以下设备型号:
- Sipeed LicheeRV Nano
- Sipeed Lichee Cluster 4A
- Sipeed Lichee Console 4A
- Sipeed Maix-I
- Sipeed Tang Mega 138K Pro
欢迎试用或来上游围观;您的需求是我们迭代开发的目标和动力。
本期暂无进展。
继续维护RUYISDK GCC的版本支持,修复了gcc12构建时的一些问题,正在同步最新的GCC14 release特性。
- 继续完善 LLVM intrinsic 函数,自上次更新以来,新支持了这些类别下的函数:
- 15.1. Vector Single-Width Integer Reduction Operations
- 15.2. Vector Widening Integer Reduction Operations
- 15.3. Vector Single-Width Floating-Point Reduction Operations
- 15.4. Vector Widening Floating-Point Reduction Operations
- 16.1. Vector Mask-Register Logical Operations
- 16.2. Vector mask population count vpopc
- 16.3. vfirst find-first-set mask bit
- 16.4. vmsbf.m set-before-first mask bit
- 16.5. vmsif.m set-including-first mask bit
- 16.6. vmsof.m set-only-first mask bit
- 16.7. Vector Iota Operations
- 16.8. Vector Element Index Operations
- 继续完善 Clang intrinsic 函数,自上次更新以来,新支持了这些类别下的函数:
- 16.1. Vector Mask-Register Logical Operations
- 16.2. Vector mask population count vpopc
- 16.3. vfirst find-first-set mask bit
- 16.4. vmsbf.m set-before-first mask bit
- 16.5. vmsif.m set-including-first mask bit
- 16.6. vmsof.m set-only-first mask bit
- 16.7. Vector Iota Operations
- 16.8. Vector Element Index Operations
- Proposed JDK-mainline PRs:
- openjdk/jdk#18558 (8329355: Test compiler/c2/irTests/TestIfMinMax.java fails on RISC-V)
- openjdk/jdk#18611 (8329641: RISC-V: Enable some tests related to SHA-2 instrinsic)
- openjdk/jdk#18668 (8329823: RISC-V: Need to sync CPU features with related JVM flags)
- openjdk/jdk22u#135 (8329823: RISC-V: Need to sync CPU features with related JVM flags)
- openjdk/jdk21u-dev#472 (8315652: RISC-V: Features string uses wrong separator for jtreg)
- openjdk/jdk17u-dev#2377 (8315652: RISC-V: Features string uses wrong separator for jtreg)
- openjdk/riscv-port-jdk11u#16 (8291893: riscv: remove fence.i used in user space)
- openjdk/riscv-port-jdk11u#17 (8284937: riscv: should not allocate special register for temp)
- openjdk/riscv-port-jdk11u#18 (8285303: riscv: Incorrect register mask in call_native_base)
- Reviewed JDK-mainline PRs:
- openjdk/jdk#17745 (8321010: RISC-V: C2 RoundVF)
- openjdk/jdk#18040 (8321021: RISC-V: C2 VectorUCastB2X)
- openjdk/jdk#18175 (8327716: RISC-V: Change type of vector_length param of several assembler functions from int to uint)
- openjdk/jdk#18191 (8327794: RISC-V: enable extension features based on impid (Rivos specific change))
- openjdk/jdk#18370 (8328404: RISC-V: Fix potential crash in C2_MacroAssembler::arrays_equals)
- openjdk/jdk#18435 (8326960: GHA: RISC-V sysroot cannot be debootstrapped due to ongoing Debian t64 transition)
- openjdk/jdk#18382 (8317720: RISC-V: Implement Adler32 intrinsic)
- openjdk/jdk#18599 (8329083: RISC-V: Update profiles supported on riscv)
- openjdk/jdk#18611 (8329641: RISC-V: Enable some tests related to SHA-2 instrinsic)
- openjdk/jdk#18668 (8329823: RISC-V: Need to sync CPU features with related JVM flags)
- openjdk/jdk#18445 (8327743: JVM crash in hotspot/share/runtime/javaThread.cpp - failed: held monitor count should be equal to jni: 0 != 1)
解决了指针压缩开启后,32位指针与0比较时依然使用64位比较指令的bug。 使用RISC-V提供的sys_riscv_hwprobe 系统调用来进行运行时指令集的探测。
本期暂无进展。
新增对 Canaan Kendryte K510、Sipeed Tang Mega 138K Pro 等开发板的系统支持情况调研。基于矽速各开发板展开测试验证,输出测试报告。 内容详见:https://github.com/ruyisdk/support-matrix