1
name: linux-riscv64-cpu-gcc
6
- '.github/workflows/linux-riscv64-cpu-gcc.yml'
7
- 'toolchains/riscv64-linux-gnu.toolchain.cmake'
8
- 'toolchains/riscv64-unknown-linux-gnu.toolchain.cmake'
13
- 'src/layer/riscv/**'
18
- '.github/workflows/linux-riscv64-cpu-gcc.yml'
19
- 'toolchains/riscv64-linux-gnu.toolchain.cmake'
20
- 'toolchains/riscv64-unknown-linux-gnu.toolchain.cmake'
25
- 'src/layer/riscv/**'
28
group: linux-riscv64-cpu-gcc-${{ github.ref }}
29
cancel-in-progress: true
37
- uses: actions/checkout@v4
41
uses: actions/cache@v4
44
key: qemu-riscv64-install-20220502-4
45
- name: install-qemu-build-deps
46
if: steps.cache-qemu.outputs.cache-hit != 'true'
49
sudo apt-get install autoconf automake autotools-dev ninja-build
51
if: steps.cache-qemu.outputs.cache-hit != 'true'
52
uses: actions/checkout@v4
56
ref: f5643914a9e8f79c606a76e6a9d7ea82a3fc3e65
58
if: steps.cache-qemu.outputs.cache-hit != 'true'
61
wget https://raw.githubusercontent.com/nihui/ncnn-assets/master/qemu-patches/0007-linux-user-Expose-risc-v-V-isa-bit-in-get_elf_hwcap.patch
62
patch -p1 -i 0007-linux-user-Expose-risc-v-V-isa-bit-in-get_elf_hwcap.patch
63
./configure --prefix=$GITHUB_WORKSPACE/qemu-install --target-list=riscv64-linux-user --disable-system
67
- name: riscv64-gnu-toolchain
70
sudo apt-get install g++-riscv64-linux-gnu
73
run: mkdir build && cd build && cmake -DCMAKE_TOOLCHAIN_FILE=../toolchains/riscv64-linux-gnu.toolchain.cmake -DNCNN_BUILD_TOOLS=OFF -DNCNN_BUILD_EXAMPLES=OFF -DNCNN_BUILD_TESTS=ON ..
75
run: cmake --build build -j $(nproc)
79
export PATH=$GITHUB_WORKSPACE/qemu-install/bin:$PATH
81
TESTS_EXECUTABLE_LOADER=qemu-riscv64 TESTS_EXECUTABLE_LOADER_ARGUMENTS="-L;/usr/riscv64-linux-gnu" ctest --output-on-failure -j $(nproc)
83
linux-gcc-riscv64-c906:
84
runs-on: [self-hosted, linux, centos]
86
- uses: actions/checkout@v4
90
export RISCV_ROOT_PATH=/data/action/osd/Xuantie-900-gcc-linux-5.10.4-glibc-x86_64-V2.6.1
91
mkdir build && cd build
92
cmake -DCMAKE_TOOLCHAIN_FILE=../toolchains/c906-v226.toolchain.cmake -DCMAKE_BUILD_TYPE=release -DNCNN_OPENMP=OFF -DNCNN_THREADS=OFF -DNCNN_RUNTIME_CPU=OFF -DNCNN_RVV=ON -DNCNN_SIMPLEOCV=ON -DNCNN_BUILD_EXAMPLES=ON -DNCNN_BUILD_TESTS=ON ..
94
run: cmake --build build -j 4
98
export PATH=/data/action/osd/xuantie-qemu-x86_64-Ubuntu-18.04-20230413-0706/bin:$PATH
100
TESTS_EXECUTABLE_LOADER=qemu-riscv64 TESTS_EXECUTABLE_LOADER_ARGUMENTS="-cpu;c906fdv" ctest --output-on-failure -j 4
102
linux-gcc-riscv64-rvv:
103
runs-on: [self-hosted, linux, centos]
105
- uses: actions/checkout@v4
109
#uses: actions/cache@v4
112
#key: qemu-riscv64-install-20220502-3
113
#- name: install-qemu-build-deps
114
#if: steps.cache-qemu.outputs.cache-hit != 'true'
117
#sudo apt-get install autoconf automake autotools-dev ninja-build
118
#- name: checkout-qemu
119
#if: steps.cache-qemu.outputs.cache-hit != 'true'
120
#uses: actions/checkout@v4
122
#repository: qemu/qemu
124
#ref: f5643914a9e8f79c606a76e6a9d7ea82a3fc3e65
126
#if: steps.cache-qemu.outputs.cache-hit != 'true'
129
#wget https://raw.githubusercontent.com/nihui/ncnn-assets/master/qemu-patches/0007-linux-user-Expose-risc-v-V-isa-bit-in-get_elf_hwcap.patch
130
#patch -p1 -i 0007-linux-user-Expose-risc-v-V-isa-bit-in-get_elf_hwcap.patch
131
#./configure --prefix=$GITHUB_WORKSPACE/qemu-install --target-list=riscv64-linux-user --disable-system
137
#uses: actions/cache@v4
139
#path: rv64gcv-install-next
140
#key: rv64gcv-linux-install-20210504
142
#- name: install-riscv-build-deps
143
#if: steps.cache-riscv.outputs.cache-hit != 'true'
146
#sudo apt-get install autoconf automake autotools-dev curl python3 libmpc-dev libmpfr-dev libgmp-dev gawk build-essential bison flex texinfo gperf libtool patchutils bc zlib1g-dev libexpat-dev device-tree-compiler
148
#- name: checkout-riscv-gnu-toolchain
149
#if: steps.cache-riscv.outputs.cache-hit != 'true'
150
#uses: actions/checkout@v4
152
#repository: riscv/riscv-gnu-toolchain
153
#path: riscv-gnu-toolchain
154
#ref: da01ba455ce3802ffa84fdca3a089079996dbfc3
155
#- name: checkout-riscv-gnu-toolchain-submodules
156
#if: steps.cache-riscv.outputs.cache-hit != 'true'
158
#cd riscv-gnu-toolchain
159
#git submodule update --init --recursive --depth 1 glibc
160
#git submodule update --init --recursive --depth 1 newlib
161
#git submodule update --init --recursive --depth 1 riscv-binutils
162
#git submodule update --init --recursive --depth 1 riscv-gcc
163
#git submodule update --init --recursive --depth 1 riscv-dejagnu
164
#git submodule update --init --recursive --depth 1 riscv-gdb
165
#- name: riscv-gnu-toolchain
166
#if: steps.cache-riscv.outputs.cache-hit != 'true'
168
#cd riscv-gnu-toolchain
169
#sed -i '/__OBSOLETE_MATH/d' newlib/newlib/libm/common/math_errf.c
170
#./configure --prefix=$GITHUB_WORKSPACE/rv64gcv-install-next --with-arch=rv64gcv_zfh
173
#- name: riscv-strip-install
174
#if: steps.cache-riscv.outputs.cache-hit != 'true'
175
#run: find $GITHUB_WORKSPACE/rv64gcv-install-next -type f | xargs -i strip -g {} || true
178
run: export RISCV_ROOT_PATH=/data/action/osd/rv64gcv-install-next && mkdir build && cd build && cmake -DCMAKE_TOOLCHAIN_FILE=../toolchains/riscv64-unknown-linux-gnu.toolchain.cmake -DNCNN_BUILD_TOOLS=OFF -DNCNN_BUILD_EXAMPLES=OFF -DNCNN_BUILD_TESTS=ON ..
180
run: cmake --build build -j 4
184
export PATH=/data/action/osd/qemu-install/bin:$PATH
186
TESTS_EXECUTABLE_LOADER=qemu-riscv64 TESTS_EXECUTABLE_LOADER_ARGUMENTS="-cpu;rv64,v=true,Zfh=true,vlen=256,elen=64,vext_spec=v1.0;-L;/data/action/osd/rv64gcv-install-next/sysroot" ctest --output-on-failure -j 4
190
export PATH=/data/action/osd/qemu-install/bin:$PATH
192
TESTS_EXECUTABLE_LOADER=qemu-riscv64 TESTS_EXECUTABLE_LOADER_ARGUMENTS="-cpu;rv64,v=true,Zfh=true,vlen=128,elen=64,vext_spec=v1.0;-L;/data/action/osd/rv64gcv-install-next/sysroot" ctest --output-on-failure -j 4