diff --git a/CHANGELOG.md b/CHANGELOG.md index f246a840d5..17333cb454 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,10 @@ # SUNDIALS Changelog +## Changes to SUNDIALS in release 6.6.2 + +Fixed the build system support for MAGMA when using a NVIDIA HPC SDK installation of CUDA +and fixed the targets used for rocBLAS and rocSPARSE. + ## Changes to SUNDIALS in release 6.6.1 Updated the Tpetra NVector interface to support Trilinos 14. diff --git a/CITATIONS.md b/CITATIONS.md index 091e71c6f2..ef2fcbbff9 100644 --- a/CITATIONS.md +++ b/CITATIONS.md @@ -66,7 +66,7 @@ they are using rather than the combined SUNDIALS online guide: author = {Daniel R. Reynolds and David J. Gardner and Carol S. Woodward and Cody J. Balos}, title = {User Documentation for ARKODE}, year = {2023}, - note = {v5.6.1} + note = {v5.6.2} } ``` @@ -75,7 +75,7 @@ they are using rather than the combined SUNDIALS online guide: author = {Alan C. Hindmarsh and Radu Serban and Cody J. Balos and David J. Gardner and Daniel R. Reynolds and Carol S. Woodward}, title = {User Documentation for CVODE}, year = {2023}, - note = {v6.6.1} + note = {v6.6.2} } ``` @@ -84,7 +84,7 @@ they are using rather than the combined SUNDIALS online guide: author = {Alan C. Hindmarsh and Radu Serban and Cody J. Balos and David J. Gardner and Daniel R. Reynolds and Carol S. Woodward}, title = {User Documentation for CVODES}, year = {2023}, - note = {v6.6.1} + note = {v6.6.2} } ``` @@ -93,7 +93,7 @@ they are using rather than the combined SUNDIALS online guide: author = {Alan C. Hindmarsh and Radu Serban and Cody J. Balos and David J. Gardner and Daniel R. Reynolds and Carol S. Woodward}, title = {User Documentation for IDA}, year = {2023}, - note = {v6.6.1} + note = {v6.6.2} } ``` @@ -102,7 +102,7 @@ they are using rather than the combined SUNDIALS online guide: author = {Radu Serban and Cosmin Petra and Alan C. Hindmarsh and Cody J. Balos and David J. Gardner and Daniel R. Reynolds and Carol S. Woodward}, title = {User Documentation for IDAS}, year = {2023}, - note = {v5.6.1} + note = {v5.6.2} } ``` @@ -111,6 +111,6 @@ they are using rather than the combined SUNDIALS online guide: author = {Alan C. Hindmarsh and Radu Serban and Cody J. Balos and David J. Gardner and Daniel R. Reynolds and Carol S. Woodward}, title = {User Documentation for KINSOL}, year = {2023}, - note = {v6.6.1} + note = {v6.6.2} } ``` diff --git a/CMakeLists.txt b/CMakeLists.txt index 7c937443af..cf35f0db98 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -42,7 +42,7 @@ include(FindPackageHandleStandardArgs) # Set some variables with info on the SUNDIALS project set(PACKAGE_BUGREPORT "sundials-users@llnl.gov") set(PACKAGE_NAME "SUNDIALS") -set(PACKAGE_STRING "SUNDIALS 6.6.1") +set(PACKAGE_STRING "SUNDIALS 6.6.2") set(PACKAGE_TARNAME "sundials") # Set SUNDIALS version numbers @@ -52,7 +52,7 @@ message(STATUS "SUNDIALS_GIT_VERSION: ${SUNDIALS_GIT_VERSION}") # (use "" for the version label if none is needed) set(PACKAGE_VERSION_MAJOR "6") set(PACKAGE_VERSION_MINOR "6") -set(PACKAGE_VERSION_PATCH "1") +set(PACKAGE_VERSION_PATCH "2") set(PACKAGE_VERSION_LABEL "") if(PACKAGE_VERSION_LABEL) @@ -67,37 +67,37 @@ endif() # Specify the VERSION and SOVERSION for shared libraries -set(arkodelib_VERSION "5.6.1") +set(arkodelib_VERSION "5.6.2") set(arkodelib_SOVERSION "5") -set(cvodelib_VERSION "6.6.1") +set(cvodelib_VERSION "6.6.2") set(cvodelib_SOVERSION "6") -set(cvodeslib_VERSION "6.6.1") +set(cvodeslib_VERSION "6.6.2") set(cvodeslib_SOVERSION "6") -set(idalib_VERSION "6.6.1") +set(idalib_VERSION "6.6.2") set(idalib_SOVERSION "6") -set(idaslib_VERSION "5.6.1") +set(idaslib_VERSION "5.6.2") set(idaslib_SOVERSION "5") -set(kinsollib_VERSION "6.6.1") +set(kinsollib_VERSION "6.6.2") set(kinsollib_SOVERSION "6") set(cpodeslib_VERSION "0.0.0") set(cpodeslib_SOVERSION "0") -set(nveclib_VERSION "6.6.1") +set(nveclib_VERSION "6.6.2") set(nveclib_SOVERSION "6") -set(sunmatrixlib_VERSION "4.6.1") +set(sunmatrixlib_VERSION "4.6.2") set(sunmatrixlib_SOVERSION "4") -set(sunlinsollib_VERSION "4.6.1") +set(sunlinsollib_VERSION "4.6.2") set(sunlinsollib_SOVERSION "4") -set(sunnonlinsollib_VERSION "3.6.1") +set(sunnonlinsollib_VERSION "3.6.2") set(sunnonlinsollib_SOVERSION "3") set(sundialslib_VERSION diff --git a/README.md b/README.md index 02922a3323..fb3f77704d 100644 --- a/README.md +++ b/README.md @@ -1,5 +1,5 @@ # SUNDIALS: SUite of Nonlinear and DIfferential/ALgebraic equation Solvers # -### Version 6.6.1 (Sep 2023) ### +### Version 6.6.2 (Nov 2023) ### **Center for Applied Scientific Computing, Lawrence Livermore National Laboratory** diff --git a/cmake/tpl/FindMAGMA.cmake b/cmake/tpl/FindMAGMA.cmake index d244c504b4..258d7106e3 100644 --- a/cmake/tpl/FindMAGMA.cmake +++ b/cmake/tpl/FindMAGMA.cmake @@ -66,24 +66,42 @@ if(MAGMA_LIBRARY AND MAGMA_INCLUDE_DIR) list(SUBLIST _libraries_list 1 -1 _libraries_list) # remove 'Libs:' part set(_interface_libraires ) + + if(SUNDIALS_MAGMA_BACKENDS MATCHES "HIP") + if(NOT TARGET roc::hipblas) + find_package(hipblas REQUIRED) + endif() + if(NOT TARGET roc::hipsparse) + find_package(hipsparse REQUIRED) + endif() + # MAGMA does not reliably include these in the pkgconfig file + list(APPEND _interface_libraires "roc::hipblas;roc::hipsparse") + endif() + + if(SUNDIALS_MAGMA_BACKENDS MATCHES "CUDA") + if (NOT TARGET CUDA::cudart) + find_package(CUDAToolkit REQUIRED) + endif() + endif() + foreach(lib ${_libraries_list}) if(NOT (lib STREQUAL "-lmagma" OR lib STREQUAL "-lmagma_sparse" OR lib STREQUAL "-L\${libdir}" OR lib STREQUAL "") ) - - # Remove -l only from the beginning of the string - string(REPLACE "^-l" "" lib ${lib}) - list(APPEND _interface_libraires ${lib}) - - # Check if we need to find roc::hipblas or roc::hipsparse - if(SUNDIALS_MAGMA_BACKENDS MATCHES "HIP") - if((lib STREQUAL "roc::hipblas") AND (NOT TARGET roc::hipblas)) - find_package(hipblas REQUIRED) + + # Check if we need to find cusparse or cublas + if(SUNDIALS_MAGMA_BACKENDS MATCHES "CUDA") + # Replace cublas, cusparse with the CMake targets because the library path in + # the magma pkgconfig is not reliable. Sepcifically, the path is wrong on systems + # like Perlmutter where the NVIDIA HPC SDK is used. + if(lib STREQUAL "-lcublas") + set(lib CUDA::cublas) endif() - if((lib STREQUAL "roc::hipsparse") AND (NOT TARGET roc::hipsparse)) - find_package(hipsparse REQUIRED) + if(lib STREQUAL "-lcusparse") + set(lib CUDA::cusparse) endif() endif() - + + list(APPEND _interface_libraires ${lib}) endif() endforeach() diff --git a/doc/arkode/guide/source/Introduction.rst b/doc/arkode/guide/source/Introduction.rst index 9bc832af85..2e7bae4f92 100644 --- a/doc/arkode/guide/source/Introduction.rst +++ b/doc/arkode/guide/source/Introduction.rst @@ -130,6 +130,12 @@ provided with SUNDIALS, or again may utilize a user-supplied module. Changes from previous versions ============================== +Changes in v5.6.2 +----------------- + +Fixed the build system support for MAGMA when using a NVIDIA HPC SDK installation of CUDA +and fixed the targets used for rocBLAS and rocSPARSE. + Changes in v5.6.1 ----------------- diff --git a/doc/cvode/guide/source/Introduction.rst b/doc/cvode/guide/source/Introduction.rst index ca4c41b3de..9cf52e4b73 100644 --- a/doc/cvode/guide/source/Introduction.rst +++ b/doc/cvode/guide/source/Introduction.rst @@ -111,6 +111,12 @@ implementations. Changes from previous versions ============================== +Changes in v6.6.2 +----------------- + +Fixed the build system support for MAGMA when using a NVIDIA HPC SDK installation of CUDA +and fixed the targets used for rocBLAS and rocSPARSE. + Changes in v6.6.1 ----------------- diff --git a/doc/cvodes/guide/source/Introduction.rst b/doc/cvodes/guide/source/Introduction.rst index 1fde2952fb..8801381fdf 100644 --- a/doc/cvodes/guide/source/Introduction.rst +++ b/doc/cvodes/guide/source/Introduction.rst @@ -111,6 +111,12 @@ Fortran. Changes from previous versions ============================== +Changes in v6.6.2 +----------------- + +Fixed the build system support for MAGMA when using a NVIDIA HPC SDK installation of CUDA +and fixed the targets used for rocBLAS and rocSPARSE. + Changes in v6.6.1 ----------------- diff --git a/doc/ida/guide/source/Introduction.rst b/doc/ida/guide/source/Introduction.rst index 9d18bd826a..a7535365a9 100644 --- a/doc/ida/guide/source/Introduction.rst +++ b/doc/ida/guide/source/Introduction.rst @@ -72,6 +72,12 @@ systems. Changes from previous versions ============================== +Changes in v6.6.2 +----------------- + +Fixed the build system support for MAGMA when using a NVIDIA HPC SDK installation of CUDA +and fixed the targets used for rocBLAS and rocSPARSE. + Changes in v6.6.1 ----------------- diff --git a/doc/idas/guide/source/Introduction.rst b/doc/idas/guide/source/Introduction.rst index ba71498036..ef03902031 100644 --- a/doc/idas/guide/source/Introduction.rst +++ b/doc/idas/guide/source/Introduction.rst @@ -86,6 +86,12 @@ integrate any final-condition ODE dependent on the solution of the original IVP Changes from previous versions ============================== +Changes in v5.6.2 +----------------- + +Fixed the build system support for MAGMA when using a NVIDIA HPC SDK installation of CUDA +and fixed the targets used for rocBLAS and rocSPARSE. + Changes in v5.6.1 ----------------- diff --git a/doc/kinsol/guide/source/Introduction.rst b/doc/kinsol/guide/source/Introduction.rst index 039eed6918..85e260518c 100644 --- a/doc/kinsol/guide/source/Introduction.rst +++ b/doc/kinsol/guide/source/Introduction.rst @@ -88,6 +88,12 @@ applications written in Fortran. Changes from previous versions ============================== +Changes in v6.6.2 +----------------- + +Fixed the build system support for MAGMA when using a NVIDIA HPC SDK installation of CUDA +and fixed the targets used for rocBLAS and rocSPARSE. + Changes in v6.6.1 ----------------- diff --git a/doc/shared/History.rst b/doc/shared/History.rst index d078d42e0b..7a06c592c9 100644 --- a/doc/shared/History.rst +++ b/doc/shared/History.rst @@ -21,6 +21,8 @@ Appendix: SUNDIALS Release History +----------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+ | Date | SUNDIALS | ARKODE | CVODE | CVODES | IDA | IDAS | KINSOL | +==========+===================+===================+===================+===================+===================+===================+===================+ +| Nov 2023 | 6.6.2 | 5.6.2 | 6.6.2 | 6.6.2 | 6.6.2 | 5.6.2 | 6.6.2 | ++----------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+ | Sep 2023 | 6.6.1 | 5.6.1 | 6.6.1 | 6.6.1 | 6.6.1 | 5.6.1 | 6.6.1 | +----------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+ | Jul 2023 | 6.6.0 | 5.6.0 | 6.6.0 | 6.6.0 | 6.6.0 | 5.6.0 | 6.6.0 | diff --git a/doc/shared/sundials.bib b/doc/shared/sundials.bib index 7972a7b814..15586bd01f 100644 --- a/doc/shared/sundials.bib +++ b/doc/shared/sundials.bib @@ -27,7 +27,7 @@ % @techreport{arkode_ug, author = {Daniel R. Reynolds and David J. Gardner and Carol S. Woodward and Rujeko Chinomona and Cody J. Balos}, -title = {{User Documentation for ARKODE v5.6.1}}, +title = {{User Documentation for ARKODE v5.6.2}}, institution = {LLNL}, number = {LLNL-SM-668082}, year = 2023 @@ -37,7 +37,7 @@ @techreport{arkode_ug % @techreport{arkode_ex, author = {Daniel R. Reynolds}, -title = {{Example Programs for ARKODE v5.6.1}}, +title = {{Example Programs for ARKODE v5.6.2}}, institution = {Southern Methodist University}, year = 2023 } @@ -46,7 +46,7 @@ @techreport{arkode_ex % @techreport{cvode_ug, author = {Alan C. Hindmarsh and Radu Serban and Cody J. Balos and David J. Gardner and Daniel R. Reynolds and Carol S. Woodward}, -title = {{User Documentation for CVODE v6.6.1}}, +title = {{User Documentation for CVODE v6.6.2}}, institution = {LLNL}, number = {UCRL-SM-208108}, year = 2023 @@ -56,7 +56,7 @@ @techreport{cvode_ug % @techreport{cvode_ex, author = {Alan C. Hindmarsh and Radu Serban}, -title = {{Example Programs for CVODE v6.6.1}}, +title = {{Example Programs for CVODE v6.6.2}}, institution = {LLNL}, note = {UCRL-SM-208110}, year = 2023 @@ -66,7 +66,7 @@ @techreport{cvode_ex % @techreport{cvodes_ug, author = {Alan C. Hindmarsh and Radu Serban and Cody J. Balos and David J. Gardner and Daniel R. Reynolds and Carol S. Woodward}, -title = {{User Documentation for CVODES v6.6.1}}, +title = {{User Documentation for CVODES v6.6.2}}, institution = {LLNL}, note = {UCRL-SM-208111}, year = 2023 @@ -76,7 +76,7 @@ @techreport{cvodes_ug % @techreport{cvodes_ex, author = {Radu Serban and Alan C. Hindmarsh}, -title = {{Example Programs for CVODES v6.6.1}}, +title = {{Example Programs for CVODES v6.6.2}}, institution = {LLNL}, number = {UCRL-SM-208115}, year = 2023 @@ -86,7 +86,7 @@ @techreport{cvodes_ex % @techreport{ida_ug, author = {Alan C. Hindmarsh and Radu Serban and Cody J. Balos and David J. Gardner and Daniel R. Reynolds and Carol S. Woodward}, -title = {{User Documentation for IDA v6.6.1}}, +title = {{User Documentation for IDA v6.6.2}}, institution = {LLNL}, number = {UCRL-SM-208112}, year = 2023 @@ -96,7 +96,7 @@ @techreport{ida_ug % @techreport{ida_ex, author = {Alan C. Hindmarsh and Radu Serban and Aaron Collier}, -title = {{Example Programs for IDA v6.6.1}}, +title = {{Example Programs for IDA v6.6.2}}, institution = {LLNL}, number = {UCRL-SM-208113}, year = 2023 @@ -106,7 +106,7 @@ @techreport{ida_ex % @techreport{idas_ug, author = {Radu Serban and Cosmin Petra and Alan C. Hindmarsh and Cody J. Balos and David J. Gardner and Daniel R. Reynolds and Carol S. Woodward}, -title = {{User Documentation for IDAS v5.6.1}}, +title = {{User Documentation for IDAS v5.6.2}}, institution = {LLNL}, number = {UCRL-SM-234051}, year = 2023 @@ -116,7 +116,7 @@ @techreport{idas_ug % @techreport{idas_ex, author = {Radu Serban and Alan C. Hindmarsh}, -title = {{Example Programs for IDAS v5.6.1}}, +title = {{Example Programs for IDAS v5.6.2}}, institution = {LLNL}, number = {LLNL-TR-437091}, year = 2023 @@ -126,7 +126,7 @@ @techreport{idas_ex % @techreport{kinsol_ug, author = {Alan C. Hindmarsh and Radu Serban and Cody J. Balos and David J. Gardner and Daniel R. Reynolds and Carol S. Woodward}, -title = {{User Documentation for KINSOL v6.6.1}}, +title = {{User Documentation for KINSOL v6.6.2}}, institution = {LLNL}, number = {UCRL-SM-208116}, year = 2023 @@ -136,7 +136,7 @@ @techreport{kinsol_ug % @techreport{kinsol_ex, author = {Aaron M. Collier and Radu Serban}, -title = {{Example Programs for KINSOL v6.6.1}}, +title = {{Example Programs for KINSOL v6.6.2}}, institution = {LLNL}, number = {UCRL-SM-208114}, year = 2023 diff --git a/doc/shared/versions.py b/doc/shared/versions.py index 40927baf29..ff5e511dcc 100644 --- a/doc/shared/versions.py +++ b/doc/shared/versions.py @@ -9,11 +9,11 @@ # SPDX-License-Identifier: BSD-3-Clause # SUNDIALS Copyright End # ---------------------------------------------------------------- -sundials_version = 'v6.6.1' -arkode_version = 'v5.6.1' -cvode_version = 'v6.6.1' -cvodes_version = 'v6.6.1' -ida_version = 'v6.6.1' -idas_version = 'v5.6.1' -kinsol_version = 'v6.6.1' +sundials_version = 'v6.6.2' +arkode_version = 'v5.6.2' +cvode_version = 'v6.6.2' +cvodes_version = 'v6.6.2' +ida_version = 'v6.6.2' +idas_version = 'v5.6.2' +kinsol_version = 'v6.6.2' year = '2023' diff --git a/doc/sundials/biblio.bib b/doc/sundials/biblio.bib index 7a5e653b7e..7ed6e16f6f 100644 --- a/doc/sundials/biblio.bib +++ b/doc/sundials/biblio.bib @@ -16,7 +16,7 @@ @techreport{arkode_ug, author={Daniel R. Reynolds and David J. Gardner and Alan C. Hindmarsh and Carol S. Woodward and Jean M. Sexton}, -title={{User Documentation for ARKODE v5.6.1}}, +title={{User Documentation for ARKODE v5.6.2}}, institution={LLNL}, number={LLNL-SM-668082}, year = 2023 @@ -26,7 +26,7 @@ @techreport{arkode_ug % @techreport{arkode_ex, author={Daniel R. Reynolds}, -title={{Example Programs for ARKODE v5.6.1}}, +title={{Example Programs for ARKODE v5.6.2}}, institution={Southern Methodist University}, year = 2023 } @@ -35,7 +35,7 @@ @techreport{arkode_ex % @techreport{cvode_ug, author={A. C. Hindmarsh and R. Serban}, -title={{User Documentation for CVODE v6.6.1}}, +title={{User Documentation for CVODE v6.6.2}}, institution={LLNL}, number={UCRL-SM-208108}, year = 2023 @@ -45,7 +45,7 @@ @techreport{cvode_ug % @techreport{cvode_ex, author={A. C. Hindmarsh and R. Serban and D. R. Reynolds}, -title={{Example Programs for CVODE v6.6.1}}, +title={{Example Programs for CVODE v6.6.2}}, institution={LLNL}, note={UCRL-SM-208110}, year = 2023 @@ -55,7 +55,7 @@ @techreport{cvode_ex % @techreport{cvodes_ug, author={A. C. Hindmarsh and R. Serban}, -title={{User Documentation for CVODES v6.6.1}}, +title={{User Documentation for CVODES v6.6.2}}, institution={LLNL}, note={UCRL-SM-208111}, year = 2023 @@ -65,7 +65,7 @@ @techreport{cvodes_ug % @techreport{cvodes_ex, author={R. Serban and A. C. Hindmarsh}, -title={{Example Programs for CVODES v6.6.1}}, +title={{Example Programs for CVODES v6.6.2}}, institution={LLNL}, number={UCRL-SM-208115}, year = 2023 @@ -75,7 +75,7 @@ @techreport{cvodes_ex % @techreport{ida_ug, author={A. C. Hindmarsh and R. Serban and A. Collier}, -title={{User Documentation for IDA v6.6.1}}, +title={{User Documentation for IDA v6.6.2}}, institution={LLNL}, number={UCRL-SM-208112}, year = 2023 @@ -85,7 +85,7 @@ @techreport{ida_ug % @techreport{ida_ex, author={A. C. Hindmarsh and R. Serban and A. Collier}, -title={{Example Programs for IDA v6.6.1}}, +title={{Example Programs for IDA v6.6.2}}, institution={LLNL}, number={UCRL-SM-208113}, year = 2023 @@ -95,7 +95,7 @@ @techreport{ida_ex % @techreport{idas_ug, author={R. Serban and C. Petra and A. C. Hindmarsh}, -title={{User Documentation for IDAS v5.6.1}}, +title={{User Documentation for IDAS v5.6.2}}, institution={LLNL}, number={UCRL-SM-234051}, year = 2023 @@ -105,7 +105,7 @@ @techreport{idas_ug % @techreport{idas_ex, author={R. Serban and A. C. Hindmarsh}, -title={{Example Programs for IDAS v5.6.1}}, +title={{Example Programs for IDAS v5.6.2}}, institution={LLNL}, number={LLNL-TR-437091}, year = 2023 @@ -115,7 +115,7 @@ @techreport{idas_ex % @techreport{kinsol_ug, author={A. M. Collier and A. C. Hindmarsh and R. Serban and C.S. Woodward}, -title={{User Documentation for KINSOL v6.6.1}}, +title={{User Documentation for KINSOL v6.6.2}}, institution={LLNL}, number={UCRL-SM-208116}, year = 2023 @@ -125,7 +125,7 @@ @techreport{kinsol_ug % @techreport{kinsol_ex, author={A. M. Collier and R. Serban}, -title={{Example Programs for KINSOL v6.6.1}}, +title={{Example Programs for KINSOL v6.6.2}}, institution={LLNL}, number={UCRL-SM-208114}, year = 2023 diff --git a/doc/sundials/ug.tex b/doc/sundials/ug.tex index c2108f6103..34be474cca 100644 --- a/doc/sundials/ug.tex +++ b/doc/sundials/ug.tex @@ -59,29 +59,29 @@ %----- VERSIONS AND UCRL NUMBERS OF SUNDIALS CODES -\newcommand{\sunrelease}{v6.6.1} +\newcommand{\sunrelease}{v6.6.2} -\newcommand{\cvrelease}{v6.6.1} +\newcommand{\cvrelease}{v6.6.2} \newcommand{\cvucrlug}{UCRL-SM-208108} \newcommand{\cvucrlex}{UCRL-SM-208110} -\newcommand{\cvsrelease}{v6.6.1} +\newcommand{\cvsrelease}{v6.6.2} \newcommand{\cvsucrlug}{UCRL-SM-208111} \newcommand{\cvsucrlex}{UCRL-SM-208115} -\newcommand{\idarelease}{v6.6.1} +\newcommand{\idarelease}{v6.6.2} \newcommand{\idaucrlug}{UCRL-SM-208112} \newcommand{\idaucrlex}{UCRL-SM-208113} -\newcommand{\idasrelease}{v5.6.1} +\newcommand{\idasrelease}{v5.6.2} \newcommand{\idasucrlug}{UCRL-SM-234051} \newcommand{\idasucrlex}{LLNL-TR-437091} -\newcommand{\kinrelease}{v6.6.1} +\newcommand{\kinrelease}{v6.6.2} \newcommand{\kinucrlug}{UCRL-SM-208116} \newcommand{\kinucrlex}{UCRL-SM-208114} -\newcommand{\arkrelease}{v5.6.1} +\newcommand{\arkrelease}{v5.6.2} \newcommand{\arkucrlug}{LLNL-SM-668082} \newcommand{\arkucrlex}{????-??-??????} diff --git a/scripts/shared b/scripts/shared index 2a9cef1731..2af50abff3 100755 --- a/scripts/shared +++ b/scripts/shared @@ -246,6 +246,8 @@ $tar $tarfile $distrobase/src/sundials/sundials_band.c $tar $tarfile $distrobase/src/sundials/sundials_context_impl.h $tar $tarfile $distrobase/src/sundials/sundials_context.c $tar $tarfile $distrobase/src/sundials/sundials_cuda.h +$tar $tarfile $distrobase/src/sundials/sundials_cusolver.h +$tar $tarfile $distrobase/src/sundials/sundials_cusparse.h $tar $tarfile $distrobase/src/sundials/sundials_cuda_kernels.cuh $tar $tarfile $distrobase/src/sundials/sundials_debug.h $tar $tarfile $distrobase/src/sundials/sundials_dense.c diff --git a/scripts/tarscript b/scripts/tarscript index d0cfd79f78..dc5768ad44 100755 --- a/scripts/tarscript +++ b/scripts/tarscript @@ -56,13 +56,13 @@ function print_usage # VERSION NUMBERS #--------------------------------------------------------- -SUN_VER="6.6.1" -CV_VER="6.6.1" -CVS_VER="6.6.1" -IDA_VER="6.6.1" -IDAS_VER="5.6.1" -KIN_VER="6.6.1" -ARK_VER="5.6.1" +SUN_VER="6.6.2" +CV_VER="6.6.2" +CVS_VER="6.6.2" +IDA_VER="6.6.2" +IDAS_VER="5.6.2" +KIN_VER="6.6.2" +ARK_VER="5.6.2" #--------------------------------------------------------- # Test if the script is executed from within its directory diff --git a/scripts/updateVersion.sh b/scripts/updateVersion.sh index 5d484f179d..b27a958dc3 100755 --- a/scripts/updateVersion.sh +++ b/scripts/updateVersion.sh @@ -20,7 +20,7 @@ # releases the label string is "". sun_major=${1:-6} sun_minor=${2:-6} -sun_patch=${3:-1} +sun_patch=${3:-2} sun_label=${4:-""} month=${5:-$(date +"%b")} year=${6:-$(date +"%Y")} diff --git a/src/arkode/README.md b/src/arkode/README.md index 9e8be1dcd4..b4e64bca49 100644 --- a/src/arkode/README.md +++ b/src/arkode/README.md @@ -1,5 +1,5 @@ # ARKODE -### Version 5.6.1 (Sep 2023) +### Version 5.6.2 (Nov 2023) **Daniel R. Reynolds, Department of Mathematics, SMU** @@ -44,8 +44,8 @@ the "SUNDIALS Release History" appendix of the ARKODE User Guide. ## References * D. R. Reynolds, D. J. Gardner, C. S. Woodward, and C. J. Balos, - "User Documentation for ARKODE v5.6.1," LLNL technical report - LLNL-SM-668082, Sep 2023. + "User Documentation for ARKODE v5.6.2," LLNL technical report + LLNL-SM-668082, Nov 2023. -* D. R. Reynolds, "Example Programs for ARKODE v5.6.1," Technical Report, - Southern Methodist University Center for Scientific Computation, Sep 2023. +* D. R. Reynolds, "Example Programs for ARKODE v5.6.2," Technical Report, + Southern Methodist University Center for Scientific Computation, Nov 2023. diff --git a/src/cvode/README.md b/src/cvode/README.md index cf77e62b01..95a591cc0d 100644 --- a/src/cvode/README.md +++ b/src/cvode/README.md @@ -1,5 +1,5 @@ # CVODE -### Version 6.6.1 (Sep 2023) +### Version 6.6.2 (Nov 2023) **Alan C. Hindmarsh, Radu Serban, Cody J. Balos, David J. Gardner, and Carol S. Woodward, Center for Applied Scientific Computing, LLNL** @@ -47,11 +47,11 @@ the "SUNDIALS Release History" appendix of the CVODE User Guide. ## References * A. C. Hindmarsh, R. Serban, C. J. Balos, D. J. Gardner, D. R. Reynolds - and C. S. Woodward, "User Documentation for CVODE v6.6.1," - LLNL technical report UCRL-SM-208108, Sep 2023. + and C. S. Woodward, "User Documentation for CVODE v6.6.2," + LLNL technical report UCRL-SM-208108, Nov 2023. -* A. C. Hindmarsh and R. Serban, "Example Programs for CVODE v6.6.1," - LLNL technical report UCRL-SM-208110, Sep 2023. +* A. C. Hindmarsh and R. Serban, "Example Programs for CVODE v6.6.2," + LLNL technical report UCRL-SM-208110, Nov 2023. * S.D. Cohen and A.C. Hindmarsh, "CVODE, a Stiff/nonstiff ODE Solver in C," Computers in Physics, 10(2), pp. 138-143, 1996. diff --git a/src/cvodes/README.md b/src/cvodes/README.md index a3f736233d..f936f124ef 100644 --- a/src/cvodes/README.md +++ b/src/cvodes/README.md @@ -1,5 +1,5 @@ # CVODES -### Version 6.6.1 (Sep 2023) +### Version 6.6.2 (Nov 2023) **Alan C. Hindmarsh, Radu Serban, Cody J. Balos, David J. Gardner, and Carol S. Woodward, Center for Applied Scientific Computing, LLNL** @@ -44,11 +44,11 @@ the "SUNDIALS Release History" appendix of the CVODES User Guide. ## References * A. C. Hindmarsh, R. Serban, C. J. Balos, D. J. Gardner, D. R. Reynolds - and C. S. Woodward, "User Documentation for CVODES v6.6.1," - LLNL technical report UCRL-SM-208111, Sep 2023. + and C. S. Woodward, "User Documentation for CVODES v6.6.2," + LLNL technical report UCRL-SM-208111, Nov 2023. -* A. C. Hindmarsh and R. Serban, "Example Programs for CVODES v6.6.1," - LLNL technical report UCRL-SM-208115, Sep 2023. +* A. C. Hindmarsh and R. Serban, "Example Programs for CVODES v6.6.2," + LLNL technical report UCRL-SM-208115, Nov 2023. * R. Serban and A. C. Hindmarsh, "CVODES: the Sensitivity-Enabled ODE solver in SUNDIALS," Proceedings of IDETC/CIE 2005, Sept. 2005, diff --git a/src/ida/README.md b/src/ida/README.md index bc4ac0569c..a019d385b2 100644 --- a/src/ida/README.md +++ b/src/ida/README.md @@ -1,5 +1,5 @@ # IDA -### Version 6.6.1 (Sep 2023) +### Version 6.6.2 (Nov 2023) **Alan C. Hindmarsh, Radu Serban, Cody J. Balos, David J. Gardner, and Carol S. Woodward, Center for Applied Scientific Computing, LLNL** @@ -47,11 +47,11 @@ the "SUNDIALS Release History" appendix of the IDA User Guide. ## References * A. C. Hindmarsh, R. Serban, C. J. Balos, D. J. Gardner, D. R. Reynolds - and C. S. Woodward, "User Documentation for IDA v6.6.1," - LLNL technical report UCRL-SM-208112, Sep 2023. + and C. S. Woodward, "User Documentation for IDA v6.6.2," + LLNL technical report UCRL-SM-208112, Nov 2023. -* A. C. Hindmarsh, R. Serban, and A. Collier, "Example Programs for IDA v6.6.1," - LLNL technical report UCRL-SM-208113, Sep 2023. +* A. C. Hindmarsh, R. Serban, and A. Collier, "Example Programs for IDA v6.6.2," + LLNL technical report UCRL-SM-208113, Nov 2023. * A. C. Hindmarsh, P. N. Brown, K. E. Grant, S. L. Lee, R. Serban, D. E. Shumaker, and C. S. Woodward, "SUNDIALS, Suite of Nonlinear and diff --git a/src/idas/README.md b/src/idas/README.md index 0f2653d892..8d36a0db56 100644 --- a/src/idas/README.md +++ b/src/idas/README.md @@ -1,5 +1,5 @@ # IDAS -### Version 5.6.1 (Sep 2023) +### Version 5.6.2 (Nov 2023) **Radu Serban, Cosmin Petra, Alan C. Hindmarsh, Cody J. Balos, David J. Gardner, and Carol S. Woodward, Center for Applied Scientific Computing, LLNL** @@ -43,11 +43,11 @@ the "SUNDIALS Release History" appendix of the IDAS User Guide. ## References * R. Serban, C. Petra, A. C. Hindmarsh, C. J. Balos, D. J. Gardner, - D. R. Reynolds and C. S. Woodward, "User Documentation for IDAS v5.6.1," - LLNL technical report UCRL-SM-234051, Sep 2023. + D. R. Reynolds and C. S. Woodward, "User Documentation for IDAS v5.6.2," + LLNL technical report UCRL-SM-234051, Nov 2023. -* R. Serban and A.C. Hindmarsh, "Example Programs for IDAS v5.6.1," - LLNL technical report LLNL-TR-437091, Sep 2023. +* R. Serban and A.C. Hindmarsh, "Example Programs for IDAS v5.6.2," + LLNL technical report LLNL-TR-437091, Nov 2023. * A. C. Hindmarsh, P. N. Brown, K. E. Grant, S. L. Lee, R. Serban, D. E. Shumaker, and C. S. Woodward, "SUNDIALS, Suite of Nonlinear and diff --git a/src/kinsol/README.md b/src/kinsol/README.md index 5aa01a924e..c2a0e6c880 100644 --- a/src/kinsol/README.md +++ b/src/kinsol/README.md @@ -1,5 +1,5 @@ # KINSOL -### Version 6.6.1 (Sep 2023) +### Version 6.6.2 (Nov 2023) **Alan C. Hindmarsh, Radu Serban, Cody J. Balos, David J. Gardner, and Carol S. Woodward, Center for Applied Scientific Computing, LLNL** @@ -48,11 +48,11 @@ the "SUNDIALS Release History" appendix of the KINSOL User Guide. * A. C. Hindmarsh, R. Serban, C. J. Balos, D. J. Gardner, D. R. Reynolds and C. S. Woodward, - "User Documentation for KINSOL v6.6.1," LLNL technical report - UCRL-SM-208116, Sep 2023. + "User Documentation for KINSOL v6.6.2," LLNL technical report + UCRL-SM-208116, Nov 2023. -* A. M. Collier and R. Serban, "Example Programs for KINSOL v6.6.1," - LLNL technical report UCRL-SM-208114, Sep 2023. +* A. M. Collier and R. Serban, "Example Programs for KINSOL v6.6.2," + LLNL technical report UCRL-SM-208114, Nov 2023. * A. C. Hindmarsh, P. N. Brown, K. E. Grant, S. L. Lee, R. Serban, D. E. Shumaker, and C. S. Woodward, "SUNDIALS, Suite of Nonlinear and diff --git a/src/sundials/sundials_cuda.h b/src/sundials/sundials_cuda.h index 244e6e76ef..75c0749da4 100644 --- a/src/sundials/sundials_cuda.h +++ b/src/sundials/sundials_cuda.h @@ -21,8 +21,6 @@ #include #include -#include -#include #include @@ -38,8 +36,6 @@ extern "C" { * ---------------------------------------------------------------------------*/ #define SUNDIALS_CUDA_VERIFY(cuerr) SUNDIALS_CUDA_Assert(cuerr, __FILE__, __LINE__) -#define SUNDIALS_CUSPARSE_VERIFY(cuerr) SUNDIALS_CUSPARSE_Assert(cuerr, __FILE__, __LINE__) -#define SUNDIALS_CUSOLVER_VERIFY(cuerr) SUNDIALS_CUSOLVER_Assert(cuerr, __FILE__, __LINE__) #define SUNDIALS_KERNEL_NAME(...) __VA_ARGS__ #ifndef SUNDIALS_DEBUG_CUDA_LASTERROR @@ -75,42 +71,9 @@ inline booleantype SUNDIALS_CUDA_Assert(cudaError_t cuerr, const char *file, int return SUNTRUE; /* Assert OK */ } -inline booleantype SUNDIALS_CUSPARSE_Assert(cusparseStatus_t status, const char *file, int line) -{ - if (status != CUSPARSE_STATUS_SUCCESS) - { -#ifdef SUNDIALS_DEBUG - fprintf(stderr, - "ERROR in cuSPARSE runtime operation: cusparseStatus_t = %d %s:%d\n", - status, file, line); -#ifdef SUNDIALS_DEBUG_ASSERT - assert(false); -#endif -#endif - return SUNFALSE; /* Assert failed */ - } - return SUNTRUE; /* Assert OK */ -} - -inline booleantype SUNDIALS_CUSOLVER_Assert(cusolverStatus_t status, const char *file, int line) -{ - if (status != CUSOLVER_STATUS_SUCCESS) - { -#ifdef SUNDIALS_DEBUG - fprintf(stderr, - "ERROR in cuSOLVER runtime operation: cusolverStatus_t = %d %s:%d\n", - status, file, line); -#ifdef SUNDIALS_DEBUG_ASSERT - assert(false); -#endif -#endif - return SUNFALSE; /* Assert failed */ - } - return SUNTRUE; /* Assert OK */ -} #ifdef __cplusplus /* wrapper to enable C++ usage */ } #endif -#endif /* _SUNDIALS_CUDA_H */ \ No newline at end of file +#endif /* _SUNDIALS_CUDA_H */ diff --git a/src/sundials/sundials_cusolver.h b/src/sundials/sundials_cusolver.h new file mode 100644 index 0000000000..b1aee9b266 --- /dev/null +++ b/src/sundials/sundials_cusolver.h @@ -0,0 +1,68 @@ +/* + * ----------------------------------------------------------------- + * Programmer(s): Cody J. Balos @ LLNL + * ----------------------------------------------------------------- + * SUNDIALS Copyright Start + * Copyright (c) 2002-2023, Lawrence Livermore National Security + * and Southern Methodist University. + * All rights reserved. + * + * See the top-level LICENSE and NOTICE files for details. + * + * SPDX-License-Identifier: BSD-3-Clause + * SUNDIALS Copyright End + * ----------------------------------------------------------------- + * This header files defines internal utility functions and macros + * for working with CUDA. + * ----------------------------------------------------------------- + */ + +#include +#include + +#include +#include +#include + +#include + +#ifndef _SUNDIALS_CUSOLVER_H +#define _SUNDIALS_CUSOLVER_H + +#ifdef __cplusplus /* wrapper to enable C++ usage */ +extern "C" { +#endif + +/* --------------------------------------------------------------------------- + * Utility macros + * ---------------------------------------------------------------------------*/ + +#define SUNDIALS_CUSOLVER_VERIFY(cuerr) SUNDIALS_CUSOLVER_Assert(cuerr, __FILE__, __LINE__) + + +/* --------------------------------------------------------------------------- + * Utility functions + * ---------------------------------------------------------------------------*/ + +inline booleantype SUNDIALS_CUSOLVER_Assert(cusolverStatus_t status, const char *file, int line) +{ + if (status != CUSOLVER_STATUS_SUCCESS) + { +#ifdef SUNDIALS_DEBUG + fprintf(stderr, + "ERROR in cuSOLVER runtime operation: cusolverStatus_t = %d %s:%d\n", + status, file, line); +#ifdef SUNDIALS_DEBUG_ASSERT + assert(false); +#endif +#endif + return SUNFALSE; /* Assert failed */ + } + return SUNTRUE; /* Assert OK */ +} + +#ifdef __cplusplus /* wrapper to enable C++ usage */ +} +#endif + +#endif /* _SUNDIALS_CUSOLVER_H */ diff --git a/src/sundials/sundials_cusparse.h b/src/sundials/sundials_cusparse.h new file mode 100644 index 0000000000..3f9c3ae493 --- /dev/null +++ b/src/sundials/sundials_cusparse.h @@ -0,0 +1,66 @@ +/* + * ----------------------------------------------------------------- + * Programmer(s): Cody J. Balos @ LLNL + * ----------------------------------------------------------------- + * SUNDIALS Copyright Start + * Copyright (c) 2002-2023, Lawrence Livermore National Security + * and Southern Methodist University. + * All rights reserved. + * + * See the top-level LICENSE and NOTICE files for details. + * + * SPDX-License-Identifier: BSD-3-Clause + * SUNDIALS Copyright End + * ----------------------------------------------------------------- + * This header files defines internal utility functions and macros + * for working with CUDA. + * ----------------------------------------------------------------- + */ + +#include +#include + +#include +#include + +#include + +#ifndef _SUNDIALS_CUSPARSE_H +#define _SUNDIALS_CUSPARSE_H + +#ifdef __cplusplus /* wrapper to enable C++ usage */ +extern "C" { +#endif + +/* --------------------------------------------------------------------------- + * Utility macros + * ---------------------------------------------------------------------------*/ + +#define SUNDIALS_CUSPARSE_VERIFY(cuerr) SUNDIALS_CUSPARSE_Assert(cuerr, __FILE__, __LINE__) + +/* --------------------------------------------------------------------------- + * Utility functions + * ---------------------------------------------------------------------------*/ + +inline booleantype SUNDIALS_CUSPARSE_Assert(cusparseStatus_t status, const char *file, int line) +{ + if (status != CUSPARSE_STATUS_SUCCESS) + { +#ifdef SUNDIALS_DEBUG + fprintf(stderr, + "ERROR in cuSPARSE runtime operation: cusparseStatus_t = %d %s:%d\n", + status, file, line); +#ifdef SUNDIALS_DEBUG_ASSERT + assert(false); +#endif +#endif + return SUNFALSE; /* Assert failed */ + } + return SUNTRUE; /* Assert OK */ +} + +#ifdef __cplusplus /* wrapper to enable C++ usage */ +} +#endif + +#endif /* _SUNDIALS_CUSPARSE_H */ diff --git a/src/sunlinsol/cusolversp/sunlinsol_cusolversp_batchqr.cu b/src/sunlinsol/cusolversp/sunlinsol_cusolversp_batchqr.cu index d7a351f974..915f6163e9 100644 --- a/src/sunlinsol/cusolversp/sunlinsol_cusolversp_batchqr.cu +++ b/src/sunlinsol/cusolversp/sunlinsol_cusolversp_batchqr.cu @@ -23,6 +23,7 @@ #include #include "sundials_cuda.h" +#include "sundials_cusolver.h" #include "sundials_debug.h" #define ZERO RCONST(0.0) diff --git a/src/sunlinsol/magmadense/CMakeLists.txt b/src/sunlinsol/magmadense/CMakeLists.txt index 116dc2d425..ed186d064d 100644 --- a/src/sunlinsol/magmadense/CMakeLists.txt +++ b/src/sunlinsol/magmadense/CMakeLists.txt @@ -19,7 +19,7 @@ if(SUNDIALS_MAGMA_BACKENDS MATCHES "CUDA") set(_libs_needed sundials_sunmatrixmagmadense sundials_nveccuda) elseif(SUNDIALS_MAGMA_BACKENDS MATCHES "HIP") set_source_files_properties(sunlinsol_magmadense.cpp PROPERTIES LANGUAGE CXX) - set(_libs_needed sundials_sunmatrixmagmadense sundials_nvechip) + set(_libs_needed sundials_sunmatrixmagmadense sundials_nvechip hip::device) endif() # Add the sunlinsol_magmadense library diff --git a/src/sunmatrix/cusparse/CMakeLists.txt b/src/sunmatrix/cusparse/CMakeLists.txt index 21ee8a88f5..2efa8a8f7a 100644 --- a/src/sunmatrix/cusparse/CMakeLists.txt +++ b/src/sunmatrix/cusparse/CMakeLists.txt @@ -28,8 +28,7 @@ sundials_add_library(sundials_sunmatrixcusparse sundials_generic_obj sundials_sunmemcuda_obj LINK_LIBRARIES - PUBLIC CUDA::cusparse - PRIVATE CUDA::cusolver + PUBLIC CUDA::cusparse CUDA::cusolver OUTPUT_NAME sundials_sunmatrixcusparse VERSION diff --git a/src/sunmatrix/cusparse/sunmatrix_cusparse.cu b/src/sunmatrix/cusparse/sunmatrix_cusparse.cu index a986fe7041..70fbc47da9 100644 --- a/src/sunmatrix/cusparse/sunmatrix_cusparse.cu +++ b/src/sunmatrix/cusparse/sunmatrix_cusparse.cu @@ -24,6 +24,7 @@ #include #include "sundials_cuda.h" +#include "sundials_cusparse.h" #include "sundials_debug.h" #include "cusparse_kernels.cuh" diff --git a/src/sunmatrix/magmadense/CMakeLists.txt b/src/sunmatrix/magmadense/CMakeLists.txt index 40612e4ae8..91968550fb 100644 --- a/src/sunmatrix/magmadense/CMakeLists.txt +++ b/src/sunmatrix/magmadense/CMakeLists.txt @@ -16,7 +16,7 @@ install(CODE "MESSAGE(\"\nInstall SUNMATRIX_MAGMADENSE with ${SUNDIALS_MAGMA_BAC if(SUNDIALS_MAGMA_BACKENDS MATCHES "CUDA") set_source_files_properties(sunmatrix_magmadense.cpp PROPERTIES LANGUAGE CUDA) - set(_libs_needed sundials_nveccuda ${CUDA_CUBLAS_LIBRARIES}) + set(_libs_needed sundials_nveccuda) elseif(SUNDIALS_MAGMA_BACKENDS MATCHES "HIP") set_source_files_properties(sunmatrix_magmadense.cpp PROPERTIES LANGUAGE CXX) set(_libs_needed sundials_nvechip hip::device)