| | name: linux-riscv64-cpu-gcc |
| | on: |
| | push: |
| | branches: [master] |
| | paths: |
| | - '.github/workflows/linux-riscv64-cpu-gcc.yml' |
| | - 'toolchains/riscv64-linux-gnu.toolchain.cmake' |
| | - 'toolchains/riscv64-unknown-linux-gnu.toolchain.cmake' |
| | - 'CMakeLists.txt' |
| | - 'cmake/**' |
| | - 'src/*' |
| | - 'src/layer/*' |
| | - 'src/layer/riscv/**' |
| | - 'tests/**' |
| | pull_request: |
| | branches: [master] |
| | paths: |
| | - '.github/workflows/linux-riscv64-cpu-gcc.yml' |
| | - 'toolchains/riscv64-linux-gnu.toolchain.cmake' |
| | - 'toolchains/riscv64-unknown-linux-gnu.toolchain.cmake' |
| | - 'CMakeLists.txt' |
| | - 'cmake/**' |
| | - 'src/*' |
| | - 'src/layer/*' |
| | - 'src/layer/riscv/**' |
| | - 'tests/**' |
| | concurrency: |
| | group: linux-riscv64-cpu-gcc-${{ github.ref }} |
| | cancel-in-progress: true |
| | permissions: |
| | contents: read |
| |
|
| | jobs: |
| | linux-gcc-riscv64: |
| | runs-on: ubuntu-20.04 |
| | steps: |
| | - uses: actions/checkout@v4 |
| |
|
| | - name: cache-qemu |
| | id: cache-qemu |
| | uses: actions/cache@v3 |
| | with: |
| | path: qemu-install |
| | key: qemu-riscv64-install-20220502-4 |
| | - name: install-qemu-build-deps |
| | if: steps.cache-qemu.outputs.cache-hit != 'true' |
| | run: | |
| | sudo apt-get update |
| | sudo apt-get install autoconf automake autotools-dev ninja-build |
| | - name: checkout-qemu |
| | if: steps.cache-qemu.outputs.cache-hit != 'true' |
| | uses: actions/checkout@v4 |
| | with: |
| | repository: qemu/qemu |
| | path: qemu |
| | ref: f5643914a9e8f79c606a76e6a9d7ea82a3fc3e65 |
| | - name: qemu |
| | if: steps.cache-qemu.outputs.cache-hit != 'true' |
| | run: | |
| | cd qemu |
| | 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 |
| | patch -p1 -i 0007-linux-user-Expose-risc-v-V-isa-bit-in-get_elf_hwcap.patch |
| | ./configure --prefix=$GITHUB_WORKSPACE/qemu-install --target-list=riscv64-linux-user --disable-system |
| | make -j2 |
| | make install |
| | |
| | - name: riscv64-gnu-toolchain |
| | run: | |
| | sudo apt-get update |
| | sudo apt-get install g++-riscv64-linux-gnu |
| | |
| | - name: configure |
| | 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 .. |
| | - name: build |
| | run: cmake --build build -j 2 |
| |
|
| | - name: test |
| | run: | |
| | export PATH=$GITHUB_WORKSPACE/qemu-install/bin:$PATH |
| | cd build |
| | TESTS_EXECUTABLE_LOADER=qemu-riscv64 TESTS_EXECUTABLE_LOADER_ARGUMENTS="-L;/usr/riscv64-linux-gnu" ctest --output-on-failure -j 2 |
| | |
| | linux-gcc-riscv64-c906: |
| | runs-on: [self-hosted, linux, centos] |
| | steps: |
| | - uses: actions/checkout@v4 |
| |
|
| | - name: configure |
| | run: | |
| | export RISCV_ROOT_PATH=/data/action/osd/Xuantie-900-gcc-linux-5.10.4-glibc-x86_64-V2.6.1 |
| | mkdir build && cd build |
| | 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 .. |
| | - name: build |
| | run: cmake --build build -j 4 |
| |
|
| | - name: test |
| | run: | |
| | export PATH=/data/action/osd/xuantie-qemu-x86_64-Ubuntu-18.04-20230413-0706/bin:$PATH |
| | cd build |
| | TESTS_EXECUTABLE_LOADER=qemu-riscv64 TESTS_EXECUTABLE_LOADER_ARGUMENTS="-cpu;c906fdv" ctest --output-on-failure -j 4 |
| | |
| | linux-gcc-riscv64-rvv: |
| | runs-on: [self-hosted, linux, centos] |
| | steps: |
| | - uses: actions/checkout@v4 |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| | |
| | |
| | |
| | |
| | |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| | |
| | |
| | |
| |
|
| | - name: configure |
| | 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 .. |
| | - name: build |
| | run: cmake --build build -j 4 |
| |
|
| | - name: test-vlen256 |
| | run: | |
| | export PATH=/data/action/osd/qemu-install/bin:$PATH |
| | cd build |
| | 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 |
| | |
| | - name: test-vlen128 |
| | run: | |
| | export PATH=/data/action/osd/qemu-install/bin:$PATH |
| | cd build |
| | 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 |
| | |