/spmv-acc

HIP acceleration of SpMV solver

Primary LanguageC++Apache License 2.0Apache-2.0

spmv-acc

HIP acceleration for SpMV solver.

Citing SpMV-acc

Please cite SpMV-acc in your publications if it helps your research:

# For github user: you can also click the link in this repository landing page at the right sidebar, with the label "Cite this repository."
@inproceedings{chu_spmv_gpu:_2023,
 title = {Efficient Algorithm Design of Optimizing SpMV on GPU},
 isbn = {979-8-4007-0155-9/23/06},
 url = {http://doi.org/10.1145/3588195.3593002},
 doi = {10.1145/3588195.3593002},
 language = {en},
 urldate = {2023-6-20},
 booktitle = {Proceedings of the 32nd International Symposium on High-Performance Parallel and Distributed Computing (HPDC '23), June 16--23, 2023, Orlando, FL, USA},
 publisher = {ACM Press},
 author = {Chu, Genshen and He, Yuanjie and Dong, Lingyu and Ding, Zhezhao and Chen, Dandan and Bai, He and Wang, Xuesong and Hu, Changjun},
 year = {2023},
 numpages = {14},
 series = {HPDC '23},
 address = {Orlando, Florida},
 location = {Orlando, FL, USA},
 pages = {1--14},
}

Build

Pre-requirements

  • ROCM: version 3.x or higher. For example: module load compiler/rocm/3.9.1
  • HIP
  • CMake: version 3.6 or higher.

Download dependency

Before building, we need to download clipp for command line arguments processing.

cd third-party
./get_clipp.sh
cd ../

Build steps

  • Build and verify on GPU side. (Note: make sure lib rocsparse is loaded and its version must be greater/equal than "1.19.4 for ROCm 4.1.0"):
CC=clang CXX=hipcc cmake -DDEVICE_SIDE_VERIFY_FLAG=ON -DCMAKE_BUILD_TYPE=Release -B./build-hip -S./
cmake --build ./build-hip
./build-hip/bin/spmv-hip examples/data/rajat03.csr
  • Build and verify on CPU side:
CC=clang CXX=hipcc cmake -DCMAKE_BUILD_TYPE=Release -B./build-hip -S./
cmake --build ./build-hip
./build-hip/bin/spmv-hip examples/data/rajat03.csr
  • Build by specifying a kernel strategy (e.g., use strategy Adaptive):
CC=clang CXX=hipcc cmake -DKERNEL_STRATEGY=ADAPTIVE -DCMAKE_BUILD_TYPE=Release -B./build-hip-adaptive -S./
cmake --build ./build-hip-adaptive
./build-hip-adaptive/bin/spmv-hip examples/data/rajat03.csr

For Developers

Add a new kernel strategy

A kernel strategy is an algorithm for calculating SpMV on device side.
You can specific another kernel strategy (algorithm) by following rules:

  1. Edit src/configure.cmake to add a kernel strategy checking (e.g. add a strategy named awesome_spmv).

    +elseif (KERNEL_STRATEGY_LOWER MATCHES "awesome_spmv")
    +    set(KERNEL_STRATEGY_AWESOME_SPMV ON)
    else ()
        MESSAGE(FATAL_ERROR "unsupported kernel strategy ${KERNEL_STRATEGY}")
    endif ()
  2. Edit src/building_config.h.in for generating C/C++ Macro defines of the corresponding strategy.

    #cmakedefine KERNEL_STRATEGY_DEFAULT
    +#cmakedefine KERNEL_STRATEGY_AWESOME_SPMV
  3. Edit file src/acc/CMakeLists.txt and add the kernel strategy name, then CMake can find the source files of the kernel strategy. e.g.,

    # all enabled strategies
    set(ENABLED_STRATEGIES
        default
    +   awesome_spmv
  4. Create a new directory named hip-awesome-spmv (replace '_' in strategy name to '-') under src/acc directory and place your code for the new strategy to this directory.

  5. Add file source_list.cmake to directory src/acc/hip-awesome-spmv to include the source files of the new strategy. Please refer to file src/acc/hip/source_list.cmake for more details.

  6. Edit file src/acc/strategy_picker.cpp to call the entry function of the corresponding strategy. e.g.,

    void sparse_spmv(int trans, const int alpha, const int beta, int m, int n, const int *rowptr, const int *colindex,
                     const double *value, const double *x, double *y) {
    #ifdef KERNEL_STRATEGY_DEFAULT
    default_sparse_spmv(trans, alpha, beta, m, n, rowptr, colindex, value, x, y);
    #endif
    +#ifdef KERNEL_STRATEGY_AWESOME_SPMV
    +awesome_sparse_spmv(trans, alpha, beta, m, n, rowptr, colindex, value, x, y);
    +#endif