Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/sunmpicomm #370

Merged
merged 196 commits into from
Nov 28, 2023
Merged
Show file tree
Hide file tree
Changes from 22 commits
Commits
Show all changes
196 commits
Select commit Hold shift + click to select a range
354e4cb
remove deprecated arkode code
balos1 Oct 26, 2023
4a3a323
remove direct and spils header files
balos1 Oct 26, 2023
c3c4b28
remove kinsol deprecated code
balos1 Oct 26, 2023
9a43a8a
more changes for the removal of spils and direct
balos1 Oct 26, 2023
511f7b9
remove more deprecated code
balos1 Oct 26, 2023
269c00a
realtype --> sunrealtype
balos1 Oct 26, 2023
7557be4
update sunrealtype related macros
balos1 Oct 26, 2023
42bf5a4
add old types into a different header for backwards compatibility
balos1 Oct 26, 2023
f51efc4
booleantype --> sunbooleantype
balos1 Oct 26, 2023
c9de095
changelog note
balos1 Oct 26, 2023
08a4a43
fix redefinition
balos1 Oct 26, 2023
c9db3f5
regen swig
balos1 Oct 26, 2023
e70954d
update swig
balos1 Oct 26, 2023
ec557bc
Merge branch 'develop' into feature/remove-deprecated-code
balos1 Oct 27, 2023
bde3811
Apply suggestions from code review
balos1 Oct 27, 2023
f96e164
Feature: Fortran interface for lapack dense solver (#353)
balos1 Oct 27, 2023
a212472
Feature/new tables (#359)
drreynolds Oct 28, 2023
b548855
remove implementation of SUNLinsSol and SUNNonlinSol printinfo functions
balos1 Oct 30, 2023
e252417
replace use of SetDiagnostics in some arkode examples
balos1 Oct 31, 2023
9939d98
make INFO level the default for logging
balos1 Oct 31, 2023
28e931e
change arkode INFO logging to DEBUG
balos1 Nov 2, 2023
37b4948
add debugging filename
balos1 Nov 2, 2023
ba66c1e
clean up use of removed functions
balos1 Nov 3, 2023
f555583
Merge remote-tracking branch 'origin/develop' into feature/remove-dep…
balos1 Nov 3, 2023
7a6347e
Merge branch 'feature/remove-deprecated-code' into feature/remove-dep…
balos1 Nov 3, 2023
d445aa5
remove deprecated arkode code
balos1 Oct 26, 2023
e57f71c
remove direct and spils header files
balos1 Oct 26, 2023
106901b
remove kinsol deprecated code
balos1 Oct 26, 2023
5934bf2
more changes for the removal of spils and direct
balos1 Oct 26, 2023
7091261
remove more deprecated code
balos1 Oct 26, 2023
0388073
update swig
balos1 Oct 26, 2023
b77a568
Apply suggestions from code review
balos1 Oct 27, 2023
bce63fb
Feature: Fortran interface for lapack dense solver (#353)
balos1 Oct 27, 2023
1c76c85
remove implementation of SUNLinsSol and SUNNonlinSol printinfo functions
balos1 Oct 30, 2023
841a6d9
replace use of SetDiagnostics in some arkode examples
balos1 Oct 31, 2023
5179287
make INFO level the default for logging
balos1 Oct 31, 2023
196c32a
change arkode INFO logging to DEBUG
balos1 Nov 2, 2023
e47a8c3
add debugging filename
balos1 Nov 2, 2023
32501fa
clean up use of removed functions
balos1 Nov 3, 2023
3ebc682
clean removed functions in benchmarks
balos1 Nov 3, 2023
1652153
remove _spils and _direct references
balos1 Nov 3, 2023
3841cd5
remove cpodes script
balos1 Nov 3, 2023
b816971
cleanup use of removed PREC_ macro
balos1 Nov 3, 2023
3cd7a85
remove unused flag
balos1 Nov 5, 2023
454203a
Merge branch 'feature/remove-deprecated-code' into feature/remove-dep…
balos1 Nov 5, 2023
7764a5b
regen fortran
balos1 Nov 5, 2023
22c9bf3
clean up more use of Diagnostics
balos1 Nov 5, 2023
1af246d
Merge branch 'feature/remove-deprecated-code' into feature/remove-dep…
balos1 Nov 5, 2023
31d3115
remove sundials_lapack.h from install list
balos1 Nov 6, 2023
1212aea
Merge branch 'feature/remove-deprecated-code' into feature/remove-dep…
balos1 Nov 6, 2023
a10585b
use SUN_RCONST
balos1 Nov 6, 2023
2b39a12
remove KINSetInfofile
balos1 Nov 6, 2023
7f6f328
Merge branch 'develop' into feature/remove-deprecated-code
balos1 Nov 6, 2023
1cbfa1f
remove warnings to stdout
balos1 Nov 6, 2023
447eafa
Merge remote-tracking branch 'origin/develop' into feature/remove-dep…
balos1 Nov 7, 2023
5806bc6
Merge branch 'feature/remove-deprecated-code' into feature/remove-dep…
balos1 Nov 7, 2023
752c350
update action to sunrealtype
balos1 Nov 7, 2023
787fd87
rename sundials_generic to sundials_core
balos1 Nov 6, 2023
e72774f
always link to sundials_core rather than include its objects
balos1 Nov 6, 2023
52ac7c6
update N_VGetCommunicator to use SUN_Comm
balos1 Nov 6, 2023
573e35c
update GetCommunicator docs
balos1 Nov 6, 2023
9fd7103
update swig
balos1 Nov 6, 2023
1a8d35e
use SUN_Comm in profiler and logger
balos1 Nov 6, 2023
1c85937
rename sundials_fgeneric to sundials_fcore
balos1 Nov 6, 2023
74a8b60
fix comm use with logger in fortran
balos1 Nov 6, 2023
66571a6
update signatures in docs and recent changes
balos1 Nov 7, 2023
04efe89
fix typo
balos1 Nov 7, 2023
5f02834
update types section to be in the "Using SUNDIALS" section
balos1 Nov 7, 2023
d202111
remove DFID
balos1 Nov 7, 2023
f16bc3c
remove KINInfoHandler
balos1 Nov 7, 2023
820a6f6
Merge remote-tracking branch 'origin/develop' into feature/remove-dep…
balos1 Nov 8, 2023
afbc36f
remove unused variable
balos1 Nov 8, 2023
a2be7dc
Merge branch 'develop' into feature/remove-deprecated-code
balos1 Nov 9, 2023
83f2c7c
remove unused variables
balos1 Nov 9, 2023
6fcb7cb
Update examples/arkode/CXX_xbraid/ark_heat2D_hypre_pfmg_xbraid.cpp
balos1 Nov 9, 2023
4e1a6ec
doc fixes
balos1 Nov 9, 2023
8d5e784
address more small comments
balos1 Nov 9, 2023
4741472
fix translation of commptr to comm
balos1 Nov 10, 2023
b771e51
SUN_Comm to SUNComm for consistency with other types
balos1 Nov 10, 2023
7e78db8
update vectors I missed before
balos1 Nov 10, 2023
da8d24f
Fixed broken builds due to incorrect usage of SUNLogger_Create
drreynolds Nov 10, 2023
10f3796
change SUNContext_Create to accept SUN_Comm
balos1 Nov 9, 2023
4243820
find and replace SUNContext_Create with NULL to use SUN_COMM_NULL
balos1 Nov 9, 2023
2f43654
find and replace passing of comm pointer to SUNContext_Create with pa…
balos1 Nov 9, 2023
3e0b632
SUN_Comm to SUNComm for consistency with other types
balos1 Nov 10, 2023
7440e5a
post merge fix
balos1 Nov 10, 2023
303ab8e
change comm NULL check
balos1 Nov 10, 2023
aadc4b2
Fix fortran interface to MPI_Comm, address calls to MPI functions bef…
balos1 Nov 10, 2023
86ddddb
fix C++ interface to SUNContext
balos1 Nov 10, 2023
09ff282
fix a call to SUNProfiler_Create
balos1 Nov 10, 2023
b683c61
fix typo
balos1 Nov 10, 2023
4cff0ae
remove delted functions from soruce
balos1 Nov 10, 2023
b601820
remove unused kinsol parts
balos1 Nov 10, 2023
9690f3d
remove use of printfl
balos1 Nov 10, 2023
4a8ad53
change default logging level
balos1 Nov 10, 2023
dbf7f3f
remove more unused stuff in arkode
balos1 Nov 10, 2023
6ebf949
fix some C++ calls to SUNContext_Create
balos1 Nov 10, 2023
89dcad3
remove uses of ark_mem->report
balos1 Nov 10, 2023
a0502e3
build with different logging levels and profiling on/off
balos1 Nov 10, 2023
4e38f35
remove broken line
balos1 Nov 10, 2023
90b0924
rename GitHub actions CI jobs
balos1 Nov 10, 2023
6e17a61
update log levels cycles through
balos1 Nov 10, 2023
1ef6287
dont automatically include sundials_context.hpp
balos1 Nov 10, 2023
c125409
add recent changes
balos1 Nov 10, 2023
aede7e5
fix indentation
balos1 Nov 10, 2023
4d3ed8f
undo removal of include
balos1 Nov 10, 2023
5224893
dont fail fast
balos1 Nov 10, 2023
3d4661d
fix logging statements in arkode_adapt broken in merge
balos1 Nov 11, 2023
40f5135
fix compiler warning
balos1 Nov 11, 2023
97a3fbd
Merge branch 'feature/remove-deprecated-code' into feature/remove-dep…
balos1 Nov 11, 2023
07f73cc
post merge fixes
balos1 Nov 11, 2023
2f3773b
post-merge fix: change RCONST to SUN_RCONST
balos1 Nov 11, 2023
004191f
another spot where we need to supress warning of set but unused
balos1 Nov 11, 2023
075105f
Merge branch 'feature/remove-deprecated-code' into feature/remove-dep…
balos1 Nov 11, 2023
314e8e0
Merge branch 'feature/remove-deprecated-code-types' into feature/sunm…
balos1 Nov 11, 2023
765e947
regen fortran
balos1 Nov 11, 2023
d42fdd7
Update doc/shared/nvectors/NVector_Description.rst
balos1 Nov 11, 2023
8dd9c82
Merge remote-tracking branch 'origin/develop' into feature/remove-dep…
balos1 Nov 12, 2023
52efca3
Merge branch 'feature/remove-deprecated-code' into feature/remove-dep…
balos1 Nov 12, 2023
953f17e
Merge branch 'feature/remove-deprecated-code-types' into feature/sunm…
balos1 Nov 12, 2023
dbb6994
fix some more SUNContext_Create calls
balos1 Nov 12, 2023
45bec60
remove left over debugging print statements
balos1 Nov 12, 2023
8bd2335
use SUN_COMM_NULL
balos1 Nov 13, 2023
8062c1f
doc grammar
balos1 Nov 13, 2023
b59f074
doc fix
balos1 Nov 13, 2023
e7a6e66
need to use types mode for SUN_COMM_NULL
balos1 Nov 13, 2023
6a74d14
fix MPI linking for sunadaptcontroller
balos1 Nov 13, 2023
4228b22
Merge remote-tracking branch 'origin/develop' into feature/remove-dep…
balos1 Nov 13, 2023
6c32318
Merge branch 'feature/remove-deprecated-code-types' into feature/sunm…
balos1 Nov 13, 2023
0e01058
a bad solution to SUN_COMM_NULL fortran mapping
balos1 Nov 13, 2023
b5f1b52
remove unused variable
balos1 Nov 14, 2023
86ad845
possible workaround for MPI in installed examples
balos1 Nov 14, 2023
826594b
fix references to sundials_core_obj
balos1 Nov 14, 2023
6c6462e
add details about linking libsundials_core in docs
balos1 Nov 14, 2023
29e5178
link to core in templates
balos1 Nov 14, 2023
b7468ef
fix doc build
gardner48 Nov 14, 2023
93132b1
Update CHANGELOG.md
balos1 Nov 14, 2023
b59256e
rename sundials_types_old
balos1 Nov 14, 2023
50a90ed
update recent changes
balos1 Nov 14, 2023
bcfc49a
fix tables
gardner48 Nov 14, 2023
28043ea
fix typo
gardner48 Nov 14, 2023
edb4bb0
install sundials_types_deprecated.h
gardner48 Nov 14, 2023
2b16b8c
Apply suggestions for READMEs
balos1 Nov 14, 2023
a779c70
Apply suggestions from code review
balos1 Nov 14, 2023
7baeafe
Update doc/shared/sunmatrix/SUNMatrix_SLUNRloc.rst
balos1 Nov 14, 2023
4e891f7
Update doc/shared/nvectors/NVector_SYCL.rst
balos1 Nov 14, 2023
f0f6260
Merge remote-tracking branch 'origin/feature/remove-deprecated-code-t…
balos1 Nov 14, 2023
32c827b
add mpi to SUNDIALSConfig
balos1 Nov 14, 2023
32e997e
Merge remote-tracking branch 'origin/develop' into feature/sunmpicomm
balos1 Nov 14, 2023
76ad50e
add core lib to xbraid cmake template
balos1 Nov 14, 2023
b2c07d5
fix install doc includes
gardner48 Nov 14, 2023
41bc80e
fix install guide build
gardner48 Nov 14, 2023
819090b
fix IDAS doc build
gardner48 Nov 14, 2023
7d93083
fix Ginkgo matrix include in KINSOL docs
gardner48 Nov 14, 2023
1b24df2
replace NULL with SUN_COMM_NULL
gardner48 Nov 15, 2023
6dab7f6
link cvode fused ops to core
balos1 Nov 15, 2023
7a15da4
link sunmemory to core
balos1 Nov 15, 2023
b680e30
use MPI_Comm where we can
balos1 Nov 15, 2023
581941a
add sundials_core to makefile templates
balos1 Nov 15, 2023
b3a9c0f
Merge branch 'develop' into feature/sunmpicomm
gardner48 Nov 16, 2023
5642da8
fix cmake templates
balos1 Nov 20, 2023
4b07244
Merge remote-tracking branch 'origin/develop' into feature/sunmpicomm
balos1 Nov 20, 2023
86f163e
move core lib to later in link list
balos1 Nov 20, 2023
882eb6a
add mpi paths to config
balos1 Nov 21, 2023
a7c60e5
try MPIEXEC_EXECUTABLE
balos1 Nov 21, 2023
ea352d8
need core lib in second loop
balos1 Nov 21, 2023
e4efcc9
link header defined libraries to core
balos1 Nov 21, 2023
34afa95
remove unused variable
balos1 Nov 21, 2023
c0c5f5e
update docs with info on sundials_core
balos1 Nov 21, 2023
cfd2d46
Update doc/shared/sundials/Install.rst
balos1 Nov 23, 2023
c6931fa
update changelog according to PR comments
balos1 Nov 27, 2023
edb7894
use MPI_C_COMPILER instead of MPIEXEC_EXECUTABLE for finding MPI in S…
balos1 Nov 27, 2023
426fb40
cmake fixes as per commentd
balos1 Nov 27, 2023
faeb30d
more doc fixes based on comments
balos1 Nov 27, 2023
64dc7ce
move cmake code for setting _EXAMPLES_lang_COMPILER variables to exam…
balos1 Nov 27, 2023
8cbd218
quote MPI variables in example templates
balos1 Nov 27, 2023
7034f3e
dont link to sundials_core in kokkos example
balos1 Nov 27, 2023
d6fee47
fix formatting in f90 examples
balos1 Nov 27, 2023
ea5c1bf
add quotes to @_EXAMPLES_CXX_COMPILER@
balos1 Nov 27, 2023
fe04993
move sundials_core in makefile templates
balos1 Nov 27, 2023
ce32b37
formatting
balos1 Nov 27, 2023
529ccfe
make sundials_fcore_mod library and use it instead of object lib
balos1 Nov 27, 2023
c59520e
Fix c2f fortran case
balos1 Nov 27, 2023
d8ef554
fixes in logger and profiler related to freeing comm
balos1 Nov 27, 2023
5dbf04c
remove duplicate swig code
balos1 Nov 27, 2023
d53aaf9
recent change fixes
balos1 Nov 27, 2023
98de540
insert copyright into sundials_types_mod
balos1 Nov 27, 2023
cf80c3b
make suggested change in manyvector
balos1 Nov 27, 2023
718caaa
use cmake 3.18.6 for testing
gardner48 Nov 27, 2023
21d17a8
fix f2003 example templates
balos1 Nov 27, 2023
69cacf8
fix typo
balos1 Nov 27, 2023
e701e91
Update CHANGELOG.md
balos1 Nov 28, 2023
b4894c7
return success instead of an error when pointer is null in destroy fu…
balos1 Nov 28, 2023
4f1b1a8
update docs as requested
balos1 Nov 28, 2023
d402e85
more doc fixes
balos1 Nov 28, 2023
418c725
Merge remote-tracking branch 'origin/feature/sunmpicomm' into feature…
balos1 Nov 28, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 7 additions & 5 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -63,13 +63,13 @@ This fixes https://github.com/LLNL/sundials/issues/312.
**Breaking change**
We have replaced the use of a type-erased (i.e., `void*`) pointer to a
communicator in place of `MPI_Comm` throughout the SUNDIALS API with a
:c:type:`SUNComm`, which is just a typedef to an `int` in builds without MPI
`SUNComm`, which is just a typedef to an `int` in builds without MPI
and a typedef to a `MPI_Comm` in builds with MPI. Here is what this means:

balos1 marked this conversation as resolved.
Show resolved Hide resolved
- All users will need to update their codes because the call to
`SUNContext_Create` now takes a :c:type:`SUNComm` instead
`SUNContext_Create` now takes a `SUNComm` instead
of type-erased pointer to a communicator. For non-MPI codes,
pass :c:type:`SUN_COMM_NULL` to the `comm` argument instead of
pass `SUN_COMM_NULL` to the `comm` argument instead of
`NULL`. For MPI codes, pass the `MPI_Comm` directly.
The required change should be doable with a find-and-replace.

Expand All @@ -81,14 +81,16 @@ and a typedef to a `MPI_Comm` in builds with MPI. Here is what this means:
`N_VGetCommunicator`, since it now returns a `SUNComm`.

The change away from type-erased pointers for `SUNComm` fixes problems like the
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>`.
one described in `[GitHub Issue #275](https://github.com/LLNL/sundials/issues/275)`.
balos1 marked this conversation as resolved.
Show resolved Hide resolved

**Breaking change**
Functions, types and header files that were previously deprecated have been
removed.
removed. Additionally, the `SUNDIALS_LOGGING_ENABLE_MPI` macro was removed.
balos1 marked this conversation as resolved.
Show resolved Hide resolved

**Breaking change**
Users now need to link to `sundials_core` in addition to the libraries already linked to.
balos1 marked this conversation as resolved.
Show resolved Hide resolved
balos1 marked this conversation as resolved.
Show resolved Hide resolved
This will be picked up automatically in projects that use the SUNDIALS CMake target.
The library `sundials_generic` has been superceded by `sundials_core` and is no longer available.

## Changes to SUNDIALS in release 6.6.1

Expand Down
2 changes: 1 addition & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
# Initial setup.
# ===============================================================

cmake_minimum_required(VERSION 3.12)
cmake_minimum_required(VERSION 3.18)

# Project SUNDIALS (initially only C supported)
# sets PROJECT_SOURCE_DIR and PROJECT_BINARY_DIR variables.
Expand Down
2 changes: 1 addition & 1 deletion cmake/SUNDIALSConfig.cmake.in
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ endforeach()
### ------- Create TPL imported targets

if("@ENABLE_MPI@" AND NOT TARGET MPI::MPI_C)
set(MPIEXEC_EXECUTABLE "@MPIEXEC_EXECUTABLE@")
set(MPI_C_COMPILER "@MPI_C_COMPILER@")
find_dependency(MPI)
endif()

Expand Down
2 changes: 1 addition & 1 deletion cmake/SundialsSetupCompilers.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -414,7 +414,7 @@ endforeach()
# ===============================================================

foreach(lang ${_SUNDIALS_ENABLED_LANGS})
if((SUNDIALS_BUILD_WITH_PROFILING) AND ENABLE_MPI)
if(ENABLE_MPI)
if(DEFINED MPI_${lang}_COMPILER)
set(_EXAMPLES_${lang}_COMPILER "${MPI_${lang}_COMPILER}" CACHE INTERNAL "${lang} compiler for installed examples")
endif()
Expand Down
2 changes: 1 addition & 1 deletion cmake/SundialsSetupCuda.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ message(STATUS "CUDA Separable Compilation: ${CMAKE_CUDA_SEPARABLE_COMPILATION}"
# Configure compiler for installed examples
# ===============================================================

if((SUNDIALS_BUILD_WITH_PROFILING) AND ENABLE_MPI)
if(ENABLE_MPI)
set(_EXAMPLES_CUDA_HOST_COMPILER "${MPI_CXX_COMPILER}" CACHE INTERNAL "${lang} compiler for installed examples")
else()
set(_EXAMPLES_CUDA_HOST_COMPILER "${CMAKE_CUDA_HOST_COMPILER}" CACHE INTERNAL "${lang} compiler for installed examples")
Expand Down
10 changes: 0 additions & 10 deletions cmake/macros/SundialsAddLibrary.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -268,16 +268,6 @@ macro(sundials_add_library target)
target_link_libraries(${_actual_target_name} ${sundials_add_library_LINK_LIBRARIES})
endif()

if(SUNDIALS_BUILD_WITH_PROFILING)
if(ENABLE_MPI AND MPI_C_FOUND)
# Workaround issues with sundials_core object library dependency on
# MPI not getting propagated when building examples.
# Workaround bug in CMake < 3.17.3 when using MPI::MPI_C and CUDA
target_include_directories(${_actual_target_name} PUBLIC ${MPI_C_INCLUDE_DIRS})
target_link_libraries(${_actual_target_name} PUBLIC ${MPI_C_LIBRARIES})
endif()
endif()

if(SUNDIALS_BUILD_WITH_PROFILING)
balos1 marked this conversation as resolved.
Show resolved Hide resolved
if(ENABLE_CALIPER)
target_link_libraries(${_actual_target_name} PUBLIC caliper)
Expand Down
7 changes: 4 additions & 3 deletions doc/arkode/guide/source/Introduction.rst
balos1 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -209,14 +209,15 @@ and a typedef to a ``MPI_Comm`` in builds with MPI. Here is what this means:
``N_VGetCommunicator``, since it now returns a ``SUNComm``.

The change away from type-erased pointers for :c:type:`SUNComm` fixes problems like the
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>`.
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>_`.

**Breaking change**
Functions, types and header files that were previously deprecated have been
removed.
removed. Additionally, the `SUNDIALS_LOGGING_ENABLE_MPI` macro was removed.

**Breaking change**
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
This will be picked up automatically in projects that use the SUNDIALS CMake target. The library ``sundials_generic`` has been superceded by ``sundials_core`` and is no longer available.


Changes in v5.6.1
Expand Down
7 changes: 4 additions & 3 deletions doc/cvode/guide/source/Introduction.rst
balos1 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -161,14 +161,15 @@ and a typedef to a ``MPI_Comm`` in builds with MPI. Here is what this means:
``N_VGetCommunicator``, since it now returns a ``SUNComm``.

The change away from type-erased pointers for :c:type:`SUNComm` fixes problems like the
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>`.
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>_`.

**Breaking change**
Functions, types and header files that were previously deprecated have been
removed.
removed. Additionally, the `SUNDIALS_LOGGING_ENABLE_MPI` macro was removed.

**Breaking change**
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
This will be picked up automatically in projects that use the SUNDIALS CMake target. The library ``sundials_generic`` has been superceded by ``sundials_core`` and is no longer available.

Changes in v6.6.1
-----------------
Expand Down
7 changes: 4 additions & 3 deletions doc/cvodes/guide/source/Introduction.rst
balos1 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -164,14 +164,15 @@ and a typedef to a ``MPI_Comm`` in builds with MPI. Here is what this means:
``N_VGetCommunicator``, since it now returns a ``SUNComm``.

The change away from type-erased pointers for :c:type:`SUNComm` fixes problems like the
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>`.
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>_`.

**Breaking change**
Functions, types and header files that were previously deprecated have been
removed.
removed. Additionally, the `SUNDIALS_LOGGING_ENABLE_MPI` macro was removed.

**Breaking change**
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
This will be picked up automatically in projects that use the SUNDIALS CMake target. The library ``sundials_generic`` has been superceded by ``sundials_core`` and is no longer available.

Changes in v6.6.1
-----------------
Expand Down
7 changes: 4 additions & 3 deletions doc/ida/guide/source/Introduction.rst
balos1 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -122,14 +122,15 @@ and a typedef to a ``MPI_Comm`` in builds with MPI. Here is what this means:
``N_VGetCommunicator``, since it now returns a ``SUNComm``.

The change away from type-erased pointers for :c:type:`SUNComm` fixes problems like the
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>`.
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>_`.

**Breaking change**
Functions, types and header files that were previously deprecated have been
removed.
removed. Additionally, the `SUNDIALS_LOGGING_ENABLE_MPI` macro was removed.

**Breaking change**
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
This will be picked up automatically in projects that use the SUNDIALS CMake target. The library ``sundials_generic`` has been superceded by ``sundials_core`` and is no longer available.

Changes in v6.6.1
-----------------
Expand Down
7 changes: 4 additions & 3 deletions doc/idas/guide/source/Introduction.rst
balos1 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -139,14 +139,15 @@ and a typedef to a ``MPI_Comm`` in builds with MPI. Here is what this means:
``N_VGetCommunicator``, since it now returns a ``SUNComm``.

The change away from type-erased pointers for :c:type:`SUNComm` fixes problems like the
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>`.
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>_`.

**Breaking change**
Functions, types and header files that were previously deprecated have been
removed.
removed. Additionally, the `SUNDIALS_LOGGING_ENABLE_MPI` macro was removed.

**Breaking change**
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
This will be picked up automatically in projects that use the SUNDIALS CMake target. The library ``sundials_generic`` has been superceded by ``sundials_core`` and is no longer available.

Changes in v5.6.1
-----------------
Expand Down
7 changes: 4 additions & 3 deletions doc/kinsol/guide/source/Introduction.rst
balos1 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -131,14 +131,15 @@ and a typedef to a ``MPI_Comm`` in builds with MPI. Here is what this means:
``N_VGetCommunicator``, since it now returns a ``SUNComm``.

The change away from type-erased pointers for :c:type:`SUNComm` fixes problems like the
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>`.
one described in `GitHub Issue #275 <https://github.com/LLNL/sundials/issues/275>_`.

**Breaking change**
Functions, types and header files that were previously deprecated have been
removed.
removed. Additionally, the `SUNDIALS_LOGGING_ENABLE_MPI` macro was removed.

**Breaking change**
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
Users now need to link to ``sundials_core`` in addition to the libraries already linked to.
This will be picked up automatically in projects that use the SUNDIALS CMake target. The library ``sundials_generic`` has been superceded by ``sundials_core`` and is no longer available.

Changes in v6.6.1
-----------------
Expand Down
4 changes: 2 additions & 2 deletions doc/shared/nvectors/NVector_Operations.rst
Original file line number Diff line number Diff line change
Expand Up @@ -154,7 +154,7 @@ operations below.

.. c:function:: SUNComm N_VGetCommunicator(N_Vector v)

Returns the ``SUNComm`` (which is just an ``MPI_Comm`` when SUNDIALS is built
Returns the :c:type:`SUNComm` (which is just an ``MPI_Comm`` when SUNDIALS is built
with MPI, otherwise it is an ``int``) associated with the vector (if
applicable). For MPI-unaware vector implementations, this should return
``SUN_COMM_NULL``.
Expand All @@ -165,7 +165,7 @@ operations below.

MPI_Comm comm = N_VGetCommunicator(v); // Works if MPI is enabled
int comm = N_VGetCommunicator(v); // Works if MPI is disabled
SUNComm = N_VGetCommunicator(v); // Works with or without MPI
SUNComm comm = N_VGetCommunicator(v); // Works with or without MPI


.. c:function:: sunindextype N_VGetLength(N_Vector v)
Expand Down
7 changes: 3 additions & 4 deletions doc/shared/sundials/Install.rst
Original file line number Diff line number Diff line change
Expand Up @@ -1670,12 +1670,11 @@ header files.
Using SUNDIALS in your prpject
------------------------------

After building and installing SUNDIALS, you probably want to include SUNDIALS in
your application. This involves two steps: including the right header files, and
linking to the right libraries.
After building and installing SUNDIALS, using SUNDIALS in your application involves
two steps: including the right header files and linking to the right libraries.

Depending on what features of SUNDIALS that your application uses, the header
files needed will vary. E.g., if you want to use CVODE for serial computations
files needed will vary. For example, if you want to use CVODE for serial computations
you need the following includes:

.. code-block:: c
Expand Down
27 changes: 13 additions & 14 deletions examples/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -16,21 +16,20 @@

# We need this to ensure the installed templates have MPI when ENABLE_MPI=TRUE,
# at least until we convert all of the templates to use the SUNDIALS CMake target.
if(ENABLE_MPI)
if(MPI_C_COMPILER)
set(_EXAMPLES_C_COMPILER ${MPI_C_COMPILER})
endif()
if(MPI_CXX_COMPILER)
set(_EXAMPLES_CXX_COMPILER ${MPI_CXX_COMPILER})
endif()
if(MPI_Fortran_COMPILER)
set(_EXAMPLES_Fortran_COMPILER ${MPI_Fortran_COMPILER})

# ===============================================================
# Configure compilers for installed examples
# ===============================================================

foreach(lang ${_SUNDIALS_ENABLED_LANGS})
if(ENABLE_MPI)
if(DEFINED MPI_${lang}_COMPILER)
set(_EXAMPLES_${lang}_COMPILER "${MPI_${lang}_COMPILER}" CACHE INTERNAL "${lang} compiler for installed examples")
endif()
else()
set(_EXAMPLES_${lang}_COMPILER "${CMAKE_${lang}_COMPILER}" CACHE INTERNAL "${lang} compiler for installed examples")
endif()
else()
set(_EXAMPLES_C_COMPILER ${CMAKE_C_COMPILER})
set(_EXAMPLES_CXX_COMPILER ${CMAKE_CXX_COMPILER})
set(_EXAMPLES_Fortran_COMPILER ${CMAKE_Fortran_COMPILER})
endif()
endforeach()

# Set variables used in generating CMake and Makefiles for examples
if(EXAMPLES_INSTALL)
Expand Down
25 changes: 16 additions & 9 deletions examples/arkode/F2003_parallel/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -29,17 +29,14 @@ else()
include_directories(${MPI_INCLUDE_PATH})
endif()

# Specify libraries to link against
set(ARKODE_LIBS
sundials_arkode
# Set-up linker flags and link libraries
set(SUNDIALS_LIBS sundials_arkode
sundials_farkode_mod
sundials_nvecmpiplusx
sundials_fnvecmpiplusx_mod
sundials_nvecmpimanyvector
sundials_fnvecmpimanyvector_mod)

# Set-up linker flags and link libraries
set(SUNDIALS_LIBS ${ARKODE_LIBS} ${EXE_EXTRA_LINK_LIBS})
sundials_fnvecmpimanyvector_mod
${EXE_EXTRA_LINK_LIBS})

# Add the build and install targets for each example
foreach(example_tuple ${FARKODE_examples})
Expand Down Expand Up @@ -110,10 +107,20 @@ if(EXAMPLES_INSTALL)
set(SOLVER "ARKODE")

# Makefile: convert semi-colon separated target list to space separated string
list2string(ARKODE_LIBS EXAMPLE_LIBS)
set(EXAMPLE_LIBS_LIST
sundials_farkode_mod
sundials_arkode
sundials_fnvecmpiplusx_mod
sundials_nvecmpiplusx
sundials_fnvecmpimanyvector_mod
sundials_nvecmpimanyvector
sundials_fcore_mod
sundials_core)

list2string(EXAMPLE_LIBS_LIST EXAMPLE_LIBS)

# CMakeLists: replace sundials_ prefix and convert to space separted string
list(TRANSFORM ARKODE_LIBS REPLACE "sundials_" "SUNDIALS::"
list(TRANSFORM EXAMPLE_LIBS_LIST REPLACE "sundials_" "SUNDIALS::"
OUTPUT_VARIABLE EXAMPLES_CMAKE_TARGETS_tmp)
list2string(EXAMPLES_CMAKE_TARGETS_tmp EXAMPLES_CMAKE_TARGETS)

Expand Down
1 change: 0 additions & 1 deletion examples/sunlinsol/kokkos/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,6 @@ foreach(example_tuple ${examples_list})
# libraries to link against
target_link_libraries(${example_target}
PRIVATE
sundials_core
sundials_nveckokkos
sundials_sunmatrixkokkosdense
sundials_sunlinsolkokkosdense
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ integer(C_INT) function unit_tests() result(retval)
use fnvector_serial_mod
use fsunnonlinsol_fixedpoint_mod
use fsundials_types_mod
use fsundials_context_mod
use fsundials_context_mod

implicit none

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ module test_fsunnonlinsol_newton
integer(C_INT) function unit_tests() result(retval)
use, intrinsic :: iso_c_binding
use fsundials_types_mod
use fsundials_context_mod
use fsundials_context_mod
use fsundials_nvector_mod
use fsundials_matrix_mod
use fsundials_linearsolver_mod
Expand Down
6 changes: 3 additions & 3 deletions examples/templates/cmakelists_CUDA_MPI_ex.in
Original file line number Diff line number Diff line change
Expand Up @@ -60,15 +60,15 @@ set(CMAKE_CUDA_HOST_COMPILER

# Set cache variables for MPI compiler and executable
set(MPI_C_COMPILER
@MPI_C_COMPILER@
"@MPI_C_COMPILER@"
CACHE FILEPATH "MPI C compiler")

set(MPI_CXX_COMPILER
@MPI_CXX_COMPILER@
"@MPI_CXX_COMPILER@"
CACHE FILEPATH "MPI C++ compiler")

set(MPIEXEC_EXECUTABLE
@MPIEXEC_EXECUTABLE@
"@MPIEXEC_EXECUTABLE@"
CACHE FILEPATH "MPI executable")

# Specify project name and languages
Expand Down
6 changes: 3 additions & 3 deletions examples/templates/cmakelists_CXX_MPI_ex.in
Original file line number Diff line number Diff line change
Expand Up @@ -44,15 +44,15 @@ set(CMAKE_CXX_STANDARD

# Set cache variables for MPI compiler and executable
set(MPI_C_COMPILER
@MPI_C_COMPILER@
"@MPI_C_COMPILER@"
CACHE FILEPATH "MPI C compiler")

set(MPI_CXX_COMPILER
@MPI_CXX_COMPILER@
"@MPI_CXX_COMPILER@"
CACHE FILEPATH "MPI C++ compiler")

set(MPIEXEC_EXECUTABLE
@MPIEXEC_EXECUTABLE@
"@MPIEXEC_EXECUTABLE@"
CACHE FILEPATH "MPI executable")

# Specify project name and languages
Expand Down
6 changes: 3 additions & 3 deletions examples/templates/cmakelists_HIP_MPI_ex.in
Original file line number Diff line number Diff line change
Expand Up @@ -48,15 +48,15 @@ set(AMDGPU_TARGETS

# Set cache variables for MPI compiler and executable
set(MPI_C_COMPILER
@MPI_C_COMPILER@
"@MPI_C_COMPILER@"
CACHE FILEPATH "MPI C compiler")

set(MPI_CXX_COMPILER
@MPI_CXX_COMPILER@
"@MPI_CXX_COMPILER@"
CACHE FILEPATH "MPI C++ compiler")

set(MPIEXEC_EXECUTABLE
@MPIEXEC_EXECUTABLE@
"@MPIEXEC_EXECUTABLE@"
CACHE FILEPATH "MPI executable")

# Specify project name and languages
Expand Down
Loading