OpenHarmony-Risc-V上运行openBLAS中的benchmark
文章目录
- OpenHarmony-Risc-V上运行openBLAS中的benchmark
- 前言
- 一、编译openBLAS
- [二、编译open BLAS中的benchmark](#二、编译open BLAS中的benchmark)
- 三、上设备运行
- 总结
前言
参考https://zhuanlan.zhihu.com/p/18825495043实现了在Risc-V架构设备上的OpenHarmony-5.0.0环境中运行openBlas的benchmark。
一、编译openBLAS
1.源码下载
自行扶墙或者使用github下载站。使用默认的develop分支。
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
