OpenHarmony-Risc-V上运行openBLAS中的benchmark

OpenHarmony-Risc-V上运行openBLAS中的benchmark


文章目录


前言

参考https://zhuanlan.zhihu.com/p/18825495043实现了在Risc-V架构设备上的OpenHarmony-5.0.0环境中运行openBlas的benchmark。


一、编译openBLAS

1.源码下载

自行扶墙或者使用github下载站。使用默认的develop分支。

git clone https://github.com/OpenMathLib/OpenBLAS.git

2.工具链下载

Xuantie-900-gcc-linux-6.6.0-glibc-x86_64-V3.0.1

  • 获取玄铁支持rvv1.0的gcc工具链。
    参考原文中有一处描述错误,由于当时没仔细看,下载的是V2.10.2版本,该版本仅支持RISC-V Vector extension 0.7.1,导致编译OpenBLAS的x280时会有以下报错:

    使用2.10.2版本编译open BLAS的C910V正常。
  • 解压后配置环境变量(以下命令根据自己环境对应的目录进行修改)

export PATH=/opt/liusai/github/Xuantie-900-gcc-linux-6.6.0-glibc-x86_64-V3.0.1/bin:$PATH

3.编译并安装openBLAS

  • 编译

cd OpenBLAS

make HOSTCC=gcc TARGET=x280 CC=riscv64-unknown-linux-gnu-gcc FC=riscv64-unknown-linux-gnu-gfortran

正常编译成功结算画面如下:

如产生编译错误,纠正后重新编译请使用"make clean"。

  • 安装

mkdir build

make PREFIX=./build install

产物如下:

二、编译open BLAS中的benchmark

以benchmark中的gemm.c为例

javascript 复制代码
cd benchmark
../../../Xuantie-900-gcc-linux-6.6.0-glibc-x86_64-V3.0.1/bin/riscv64-unknown-linux-gnu-gcc gemm.c -o gemm_test_3.0.1 -I ../ -L ../build/lib -lopenblas -lpthread -lgfortran -O2 -Wall 

../../../Xuantie-900-gcc-linux-6.6.0-glibc-x86_64-V3.0.1/bin/riscv64-unknown-linux-gnu-gcc gemm.c -o gemm_test_3.0.1V -I ../ -L ../build/lib -lopenblas -lpthread -lgfortran -O2 -Wall -march=rv64gcv 

../../../Xuantie-900-gcc-linux-6.6.0-glibc-x86_64-V2.10.2/bin/riscv64-unknown-linux-gnu-gcc -o gemm_test_2.10.2 -I ../build/include -L ../build/lib -lopenblas -lpthread -lgfortran -O2 -Wall

/opt/liusai/musepaper-5.0.0/prebuilts/gcc/linux-x86/riscv64/spacemit-riscv-gcc/bin/riscv64-unknown-linux-gnu-gcc gemm.c -o gemm_test_spacemit -I ../ -L ../build/lib -lopenblas -lpthread -lgfortran -O2 -Wall

使用了三种工具链,编译出不同的gemm_test,可以在运行过程中进行比较。

三、上设备运行

使用的是进迭时空的musepaper,提前烧录OH-5.0.0版本。

  • 通过HDC将需要的文件拷至设备的/lib目录

hdc target mount

hdc file send .\openblas\spacemit\libpthread.so.0 /lib/

hdc file send .\openblas\ld-linux-riscv64-lp64d.so.1 /lib/

hdc file send .\openblas\gemm_test_3.0.1 /lib/

hdc file send .\openblas\libopenblas.so.0 /lib/

hdc file send .\openblas\libc.so.6 /lib/

注意:运行不同工具链编译的产物时,链接器ld-linux-riscv64-lp64d.so.1、libpthread.so.0、libc.so.6不可混用,否则会报错不可运行。这些均可以在工具链的安装目录中找到。

  • 配置环境变量

export LD_LIBRARY_PATH=/lib:$LD_LIBRARY_PATH

  • 运行

直接./gemm_test_3.0.1即可。

运行gemm_test_spacemit时有"./gemm_test_spacemit: /lib/libc.so.6: version 'GLIBC_2.34' not found (required by ./gemm_test_spacemit)"报错,请将对应工具链的libc.so.6拷贝至/lib下。

运行效果如下:


总结

  • 后续就是llama.cpp通过openBLAS提升运行效率。
  • ldd命令仅支持查看相同架构的可执行程序或者库文件,比如在X86_84的ubuntu环境中使用ldd查看risc-v架构的gemm_test会产生"not a dynamic executable"。
  • 使用patchelf命令也可以查看依赖。

patchelf gemm_test_spacemit --print-needed

相关推荐
钛态18 小时前
Flutter 三方库 ethereum_addresses 的鸿蒙化适配指南 - 掌控区块链地址资产、精密校验治理实战、鸿蒙级 Web3 专家
flutter·harmonyos·鸿蒙·openharmony·ethereum_addresses
Industio_触觉智能19 小时前
触觉智能Purple Pi OH开发板已适配OpenHarmony6.1,将作为LTS长期支持版,附API参考说明
鸿蒙·鸿蒙系统·openharmony·lts·开源鸿蒙·鸿蒙开发板·openharmony6.1
雷帝木木1 天前
Flutter 组件 http_interop 的适配 鸿蒙Harmony 深度进阶 - 驾驭多级拦截器链、实现鸿蒙端标准化通讯审计与流量路由中继方案
flutter·harmonyos·鸿蒙·openharmony·http_interop
左手厨刀右手茼蒿2 天前
Flutter 三方库 klutter 的鸿蒙化适配指南 - 掌握 Kotlin Multiplatform (KMP) 互操作技术、助力鸿蒙应用构建极致复用且高性能的跨端业务逻辑共享体系
flutter·harmonyos·鸿蒙·openharmony
亚历克斯神2 天前
Flutter 组件 genkit 的适配 鸿蒙Harmony 深度进阶 - 驾驭模型幻觉审计、实现鸿蒙端多维 RAG 向量对齐与端云协同 AI 指挥中心方案
flutter·harmonyos·鸿蒙·openharmony
小白学鸿蒙2 天前
一加6T 如何刷openharmony6.1系统
openharmony·一加6t
加农炮手Jinx2 天前
Flutter 组件 conventional 适配鸿蒙 HarmonyOS 实战:约定式提交标准,构建自动化版本治理与 CI/CD 质量治理架构
flutter·harmonyos·鸿蒙·openharmony
王码码20352 天前
Flutter 三方库 appstream 的鸿蒙化适配指南 - 驾驭 Linux 生态元数据规范,打造高性能、标准化、国际化的 OpenHarmony 桌面应用商店分发基石
flutter·harmonyos·鸿蒙·openharmony
特立独行的猫a4 天前
HarmonyOS鸿蒙PC的QT应用开发:QT项目运行原理与 EmbeddedUIExtensionAbility介绍
qt·华为·harmonyos·openharmony·鸿蒙pc
爱分享的阿Q4 天前
RISC-V驱动开发合规解析
驱动开发·risc-v