diff --git a/CMakeLists.txt b/CMakeLists.txt index e3b1b3be6fa2fd70eaf82d98b7c0625ef0c2c74f..53d8023f0ee52a3b62c7ebd39c23bfa554b300e9 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -250,16 +250,21 @@ set(LIBGMSHDG_SOURCES src/gmsh_io.cpp src/connectivity.cpp src/entity_data.cpp src/kernels_cpu.cpp - src/kernels_gpu_mi.cpp - src/kernels_cuda.cu src/maxwell_interface.cpp src/maxwell_cpu.cpp - src/maxwell_gpu.cpp - src/maxwell_kernels_cuda.cu src/maxwell_common.cpp src/param_loader.cpp ) +if (OPT_ENABLE_GPU_SOLVER) + set(LIBGMSHDG_SOURCES ${LIBGMSHDG_SOURCES} + src/maxwell_gpu.cpp + src/maxwell_kernels_cuda.cu + src/kernels_gpu_mi.cpp + src/kernels_cuda.cu + ) +endif() + add_library(gmshdg SHARED ${LIBGMSHDG_SOURCES}) target_link_libraries(gmshdg ${LINK_LIBS}) diff --git a/include/maxwell_interface.h b/include/maxwell_interface.h index 27d62b495f59c4b5ff92e2052e34ef5707f8100f..29e163e98aba0cea50705910765b2aa8cae3dd70 100644 --- a/include/maxwell_interface.h +++ b/include/maxwell_interface.h @@ -12,7 +12,10 @@ #include "gmsh_io.h" #include "types.h" + +#ifdef ENABLE_GPU_SOLVER #include "gpu_support.hpp" +#endif /* ENABLE_GPU_SOLVER */ #ifndef HIDE_THIS_FROM_NVCC #include "param_loader.h" @@ -255,14 +258,14 @@ struct solver_state_gpu #ifndef HIDE_THIS_FROM_NVCC void init_from_model(const model&, solver_state&); void init_matparams(const model&, solver_state&, const parameter_loader&); -void apply_operator(solver_state&, const field&, field&); +//void apply_operator(solver_state&, const field&, field&); void export_to_silo(const model&, const solver_state&, const std::string&); void timestep(solver_state&); #ifdef ENABLE_GPU_SOLVER void init_from_model(const model&, solver_state_gpu&); void init_matparams(const model&, solver_state_gpu&, const parameter_loader&); -void apply_operator(solver_state_gpu&, const field_gpu&, field_gpu&); +//void apply_operator(solver_state_gpu&, const field_gpu&, field_gpu&); void export_to_silo(const model&, const solver_state_gpu&, const std::string&); void timestep(solver_state_gpu&); #endif /* ENABLE_GPU_SOLVER */ diff --git a/include/param_loader.h b/include/param_loader.h index ac216b3c89b3a92649fef256ca4dc461db94353d..20630eeff1c02a95b997a4db6431e9b59158d4f7 100644 --- a/include/param_loader.h +++ b/include/param_loader.h @@ -1,6 +1,10 @@ #pragma once +#pragma clang diagnostic push +#pragma clang diagnostic ignored "-Weverything" #include "sol/sol.hpp" +#pragma clang diagnostic pop + #include "gmsh_io.h" class parameter_loader_base diff --git a/src/entity_data.cpp b/src/entity_data.cpp index b616b0510fcf01142faea3755b25e9e570a892e1..2e8a5b1ca4cd7dcc90fba351d83bb060ce202f45 100644 --- a/src/entity_data.cpp +++ b/src/entity_data.cpp @@ -1,5 +1,6 @@ #include "entity_data.h" +#ifdef ENABLE_GPU_SOLVER entity_data_gpu::entity_data_gpu() { } @@ -89,3 +90,4 @@ entity_data_gpu::~entity_data_gpu() { } +#endif /* ENABLE_GPU_SOLVER */ \ No newline at end of file diff --git a/src/maxwell_cpu.cpp b/src/maxwell_cpu.cpp index c8ffddb7d6eebf63fab84eb599cbce73d3669e1e..e3c3c96d965af10996bf8806de5ab49684881c0b 100644 --- a/src/maxwell_cpu.cpp +++ b/src/maxwell_cpu.cpp @@ -181,7 +181,8 @@ eval_interface_sources(const model& mod, const parameter_loader& mpl, } } -void init_from_model(const model& mod, solver_state& state) +void +init_from_model(const model& mod, solver_state& state) { state.emf_curr.resize( mod.num_dofs() ); state.emf_next.resize( mod.num_dofs() ); @@ -211,7 +212,8 @@ void init_from_model(const model& mod, solver_state& state) state.curr_timestep = 0; } -void compute_curls(solver_state& state, const field& curr, field& next) +static void +compute_curls(solver_state& state, const field& curr, field& next) { for (const auto& ed : state.eds) { @@ -316,7 +318,7 @@ compute_fluxes_planar(solver_state& state) } } -void +static void compute_fluxes(solver_state& state, const field& in, field& out) { compute_field_jumps(state, in); @@ -333,7 +335,7 @@ compute_fluxes(solver_state& state, const field& in, field& out) } } -void +static void compute_euler_update(solver_state& state, const field& y, const field& k, double dt, field& out) { for (size_t i = 0; i < out.num_dofs; i++) @@ -354,7 +356,7 @@ compute_euler_update(solver_state& state, const field& y, const field& k, double } } -void +static void compute_rk4_weighted_sum(solver_state& state, const field& in, double dt, field& out) { for (size_t i = 0; i < out.num_dofs; i++) @@ -375,7 +377,7 @@ compute_rk4_weighted_sum(solver_state& state, const field& in, double dt, field& } } -void +static void apply_operator(solver_state& state, const field& curr, field& next) { compute_curls(state, curr, next); diff --git a/src/maxwell_interface.cpp b/src/maxwell_interface.cpp index 764174f11e7d5559d86d06af025eb9b17622a9a7..8734f17bbf5c41be01b4bde5951df09f64b429f3 100644 --- a/src/maxwell_interface.cpp +++ b/src/maxwell_interface.cpp @@ -14,6 +14,7 @@ field::resize(size_t p_num_dofs) num_dofs = p_num_dofs; } +#ifdef ENABLE_GPU_SOLVER void field_gpu::zero() { @@ -24,7 +25,6 @@ field_gpu::zero() Hy.zero(); Hz.zero(); } - void field_gpu::resize(size_t p_num_dofs) { @@ -149,5 +149,6 @@ material_params_gpu::copyin(const material_params& mp) bc_coeffs.copyin(mp.bc_coeffs.data(), mp.bc_coeffs.size()); } +#endif /* ENABLE_GPU_SOLVER */ } // namespace maxwell