From 85f0e80a0db1e2639c38f8d64bf80b09bb070fe2 Mon Sep 17 00:00:00 2001 From: Troy Alderson <58866654+tfalders@users.noreply.github.com> Date: Fri, 22 Mar 2024 15:33:27 -0600 Subject: [PATCH 1/3] Fix benchmark client built without sparse functionality (#242) (cherry picked from commit 8a499b3a2195891f6a05206c897eac13579661a0) --- clients/benchmarks/CMakeLists.txt | 4 ++++ clients/include/hipsolver_dispatcher.hpp | 7 ++++++- 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/clients/benchmarks/CMakeLists.txt b/clients/benchmarks/CMakeLists.txt index 23d45742..f76c3c72 100644 --- a/clients/benchmarks/CMakeLists.txt +++ b/clients/benchmarks/CMakeLists.txt @@ -55,6 +55,10 @@ target_link_libraries( hipsolver-bench PRIVATE roc::hipsolver ) if( BUILD_WITH_SPARSE ) + set_source_files_properties(client.cpp + PROPERTIES + COMPILE_DEFINITIONS HAVE_HIPSPARSE + ) target_link_libraries( hipsolver-bench PRIVATE roc::hipsparse ) endif( ) if( UNIX ) diff --git a/clients/include/hipsolver_dispatcher.hpp b/clients/include/hipsolver_dispatcher.hpp index f068aa5e..427dcbe6 100644 --- a/clients/include/hipsolver_dispatcher.hpp +++ b/clients/include/hipsolver_dispatcher.hpp @@ -27,7 +27,6 @@ #include #include -#include "testing_csrlsvchol.hpp" #include "testing_gebrd.hpp" #include "testing_gels.hpp" #include "testing_geqrf.hpp" @@ -54,6 +53,10 @@ #include "testing_sytrd_hetrd.hpp" #include "testing_sytrf.hpp" +#ifdef HAVE_HIPSPARSE +#include "testing_csrlsvchol.hpp" +#endif + struct str_less { bool operator()(const char* a, const char* b) const @@ -120,8 +123,10 @@ class hipsolver_dispatcher {"sygvdx", testing_sygvdx_hegvdx}, {"sygvj", testing_sygvj_hegvj}, {"sytrd", testing_sytrd_hetrd}, +#ifdef HAVE_HIPSPARSE {"csrlsvchol", testing_csrlsvchol}, {"csrlsvcholHost", testing_csrlsvchol}, +#endif }; // Grab function from the map and execute From 32c19002ce633d013a0af45a1bcce3f6c1ac1c73 Mon Sep 17 00:00:00 2001 From: Cory Bloor Date: Sat, 23 Mar 2024 00:11:06 -0600 Subject: [PATCH 2/3] Disable sparse build on Windows by default (#246) * Default BUILD_WITH_SPARSE to false on Windows * Use angle-bracket search paths for system includes * Reorder includes for clang-format (cherry picked from commit b2a71b4b56a52459d0c8c58d2c3eca691d933a9a) --- CMakeLists.txt | 2 +- library/src/CMakeLists.txt | 4 ---- library/src/amd_detail/hipsolver_sparse.cpp | 15 +++++++++------ 3 files changed, 10 insertions(+), 11 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 95a23932..3e3044ff 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -110,7 +110,7 @@ option( BUILD_CODE_COVERAGE "Build hipSOLVER with code coverage enabled" OFF ) option( BUILD_HIPBLAS_TESTS "Build additional tests to ensure hipBLAS and hipSOLVER are compatible (requires installed hipBLAS)" OFF ) # BUILD_SHARED_LIBS is a cmake built-in; we make it an explicit option such that it shows in cmake-gui option( BUILD_SHARED_LIBS "Build hipSOLVER as a shared library" ON ) -option( BUILD_WITH_SPARSE "Build hipSOLVER with sparse functionality and tests enabled (requires additional dependencies)" ON ) +option( BUILD_WITH_SPARSE "Build hipSOLVER with sparse functionality and tests enabled (requires additional dependencies)" "${UNIX}" ) option( BUILD_VERBOSE "Output additional build information" OFF ) option( USE_CUDA "Look for CUDA and use that as a backend if found" OFF ) diff --git a/library/src/CMakeLists.txt b/library/src/CMakeLists.txt index ab448f46..ec708df8 100644 --- a/library/src/CMakeLists.txt +++ b/library/src/CMakeLists.txt @@ -136,10 +136,6 @@ if( NOT USE_CUDA ) endif( ) target_link_libraries( hipsolver PRIVATE roc::rocsparse suitesparseconfig cholmod ) - target_include_directories( hipsolver - SYSTEM PRIVATE - $ - ) set_source_files_properties(${hipsolver_source} PROPERTIES COMPILE_DEFINITIONS HAVE_ROCSPARSE diff --git a/library/src/amd_detail/hipsolver_sparse.cpp b/library/src/amd_detail/hipsolver_sparse.cpp index 59ac51ff..dacad4aa 100644 --- a/library/src/amd_detail/hipsolver_sparse.cpp +++ b/library/src/amd_detail/hipsolver_sparse.cpp @@ -1,5 +1,5 @@ /* ************************************************************************ - * Copyright (C) 2023 Advanced Micro Devices, Inc. All rights reserved. + * Copyright (C) 2023-2024 Advanced Micro Devices, Inc. All rights reserved. * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -31,18 +31,21 @@ #include "hipsolver.h" #include "hipsolver_conversions.hpp" -#include "rocblas/internal/rocblas_device_malloc.hpp" -#include "rocblas/rocblas.h" -#include "rocsolver/rocsolver.h" #include #include #include #include #include +#include +#include + +#include +#include +#include #ifdef HAVE_ROCSPARSE -#include "cholmod.h" -#include "rocsparse/rocsparse.h" +#include +#include #endif #undef TRUE From ffe638e18516b0b4ac862f9a8fc15ec99bc4dffb Mon Sep 17 00:00:00 2001 From: Cordell Bloor Date: Thu, 18 Apr 2024 10:28:26 -0600 Subject: [PATCH 3/3] Update changelog and version number --- CHANGELOG.md | 10 +++++++++- CMakeLists.txt | 4 ++-- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 10bc0416..32263207 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,6 +3,14 @@ Full documentation for hipSOLVER is available at [hipsolver.readthedocs.io](https://hipsolver.readthedocs.io/en/latest/). +## hipSOLVER 2.1.1 for ROCm 6.1.1 +### Changed +- `BUILD_WITH_SPARSE` now defaults to OFF on Windows. + +### Fixed +- Fixed benchmark client build when `BUILD_WITH_SPARSE` is OFF. + + ## hipSOLVER 2.1.0 for ROCm 6.1.0 ### Added - Added compatibility API with hipsolverSp prefix @@ -37,7 +45,7 @@ Full documentation for hipSOLVER is available at [hipsolver.readthedocs.io](http ### Fixed - Fixed conflicts between the hipsolver-dev and -asan packages by excluding hipsolver_module.f90 from the latter - + ## hipSOLVER 1.8.1 for ROCm 5.7.0 ### Changed diff --git a/CMakeLists.txt b/CMakeLists.txt index 3e3044ff..52a059ad 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,5 +1,5 @@ # ######################################################################## -# Copyright (C) 2016-2023 Advanced Micro Devices, Inc. All rights reserved. +# Copyright (C) 2016-2024 Advanced Micro Devices, Inc. All rights reserved. # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to deal @@ -89,7 +89,7 @@ include( ROCMInstallSymlinks ) include( ROCMClients ) include( ROCMHeaderWrapper ) -set ( VERSION_STRING "2.1.0" ) +set ( VERSION_STRING "2.1.1" ) rocm_setup_version( VERSION ${VERSION_STRING} ) if( NOT DEFINED ENV{HIP_PATH})