Open
Conversation
Add CMake configuration for GCC with nvptx offload target:
- SIMPLE_ENABLE_OPENACC: enables OpenACC for both NVHPC and GCC
- SIMPLE_OPENACC_OFFLOAD_TARGET: selects offload target (none|nvptx)
Usage with GCC 16 nvptx:
cmake -DSIMPLE_ENABLE_OPENACC=ON -DSIMPLE_OPENACC_OFFLOAD_TARGET=nvptx \
-DENABLE_OPENACC=ON -DOPENACC_OFFLOAD_TARGET=nvptx ...
Note: Currently only libneo batch interpolation has OpenACC directives.
GPU memory errors occur in batch spline tests - investigation needed.
- Add make gcc-acc, gcc-acc-test, gcc-acc-clean targets for GCC 16 nvptx builds - Document OpenACC build options in CLAUDE.md - Pass OPENACC_OFFLOAD_TARGET to libneo in CMakeLists.txt - Note known GPU memory issues with GCC 16 nvptx offloading - Remove run-fast-tests pre-commit hook that blocks commits
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Summary
Add CMake configuration for GCC with nvptx offload target, enabling GPU acceleration via OpenACC.
Changes
SIMPLE_OPENACC_OFFLOAD_TARGET(none|nvptx) for GCCSIMPLE_ENABLE_OPENACCto support both NVHPC and GCC compilers-fopenacc -foffload=nvptx-noneflags when enabled with GCCUsage
cmake -DCMAKE_Fortran_COMPILER=/path/to/gcc16/gfortran \ -DSIMPLE_ENABLE_OPENACC=ON \ -DSIMPLE_OPENACC_OFFLOAD_TARGET=nvptx \ -DENABLE_OPENACC=ON \ -DOPENACC_OFFLOAD_TARGET=nvptx ...Performance Results (GCC 16 with nvptx)
Analysis
!$accdirectivesKnown Issues
test_batch_splinesfails with "illegal memory access" when GPU offload is enabledTest plan