Skip to content
Snippets Groups Projects
Commit 8bc3f7d7 authored by Christoph Junghans's avatar Christoph Junghans Committed by scheibelp
Browse files

Add ccache support (#3761)

If the user sets "ccache: true" in spack's config.yaml, Spack will use an available
ccache executable when compiling c/c++ code. This feature is disabled by default
(i.e. "ccache: false") and the documentation is updated with how to enable
ccache support
parent 8770957b
No related branches found
No related tags found
No related merge requests found
...@@ -90,3 +90,7 @@ config: ...@@ -90,3 +90,7 @@ config:
# If set to 4, for example, `spack install` will run `make -j4`. # If set to 4, for example, `spack install` will run `make -j4`.
# If not set, all available cores are used by default. # If not set, all available cores are used by default.
# build_jobs: 4 # build_jobs: 4
# If set to true, spack will use ccache to cache c compiles.
ccache: false
...@@ -191,3 +191,22 @@ to 4, for example, commands like ``spack install`` will run ``make -j4`` ...@@ -191,3 +191,22 @@ to 4, for example, commands like ``spack install`` will run ``make -j4``
instead of hogging every core. instead of hogging every core.
To build all software in serial, set ``build_jobs`` to 1. To build all software in serial, set ``build_jobs`` to 1.
--------------------
``ccache``
--------------------
When set to ``true`` Spack will use ccache to cache compiles. This is
useful specifically un two cases: (1) Use with ``spack setup``, (2)
Build the same package with many different variants. The default is
``false``.
When enabled Spack will look inside your ``PATH`` for a ``ccache``
executable and stop if it is not found. Some systems come with
``ccache``, but it can also be installed using ``spack install
ccache``. ``ccache`` comes with reasonable defaults for cache size
and location. (See the *Configuration settings* secion of ``man
ccache`` to learn more about the default settings and how change
them.) Please note that we currently disable ccache's ``hash_dir``
feature to avoid an issue with the stage directory (see
https://github.com/LLNL/spack/pull/3761#issuecomment-294352232 ).
...@@ -342,7 +342,15 @@ case "$mode" in ...@@ -342,7 +342,15 @@ case "$mode" in
args=("${args[@]}" ${SPACK_LDLIBS[@]}) ;; args=("${args[@]}" ${SPACK_LDLIBS[@]}) ;;
esac esac
full_command=("$command" "${args[@]}") #ccache only supports C languages, so filtering out Fortran
if [[ ( ${lang_flags} = "C" || ${lang_flags} = "CXX" ) && ${SPACK_CCACHE_BINARY} ]]; then
full_command=("${SPACK_CCACHE_BINARY}" "$command" "${args[@]}")
# #3761#issuecomment-294352232
# workaround for stage being a temp folder
export CCACHE_NOHASHDIR=yes
else
full_command=("$command" "${args[@]}")
fi
# In test command mode, write out full command for Spack tests. # In test command mode, write out full command for Spack tests.
if [[ $SPACK_TEST_COMMAND == dump-args ]]; then if [[ $SPACK_TEST_COMMAND == dump-args ]]; then
......
...@@ -98,6 +98,7 @@ ...@@ -98,6 +98,7 @@
SPACK_SHORT_SPEC = 'SPACK_SHORT_SPEC' SPACK_SHORT_SPEC = 'SPACK_SHORT_SPEC'
SPACK_DEBUG_LOG_ID = 'SPACK_DEBUG_LOG_ID' SPACK_DEBUG_LOG_ID = 'SPACK_DEBUG_LOG_ID'
SPACK_DEBUG_LOG_DIR = 'SPACK_DEBUG_LOG_DIR' SPACK_DEBUG_LOG_DIR = 'SPACK_DEBUG_LOG_DIR'
SPACK_CCACHE_BINARY = 'SPACK_CCACHE_BINARY'
# Platform-specific library suffix. # Platform-specific library suffix.
...@@ -335,6 +336,13 @@ def set_build_environment_variables(pkg, env, dirty): ...@@ -335,6 +336,13 @@ def set_build_environment_variables(pkg, env, dirty):
env.set(SPACK_DEBUG_LOG_ID, pkg.spec.format('${PACKAGE}-${HASH:7}')) env.set(SPACK_DEBUG_LOG_ID, pkg.spec.format('${PACKAGE}-${HASH:7}'))
env.set(SPACK_DEBUG_LOG_DIR, spack.main.spack_working_dir) env.set(SPACK_DEBUG_LOG_DIR, spack.main.spack_working_dir)
# Find ccache binary and hand it to build environment
if spack.config.get('config:ccache'):
ccache = Executable('ccache')
if not ccache:
raise RuntimeError("No ccache binary found in PATH")
env.set(SPACK_CCACHE_BINARY, ccache)
# Add any pkgconfig directories to PKG_CONFIG_PATH # Add any pkgconfig directories to PKG_CONFIG_PATH
for prefix in build_link_prefixes: for prefix in build_link_prefixes:
for directory in ('lib', 'lib64', 'share'): for directory in ('lib', 'lib64', 'share'):
......
...@@ -69,6 +69,7 @@ ...@@ -69,6 +69,7 @@
'locks': {'type': 'boolean'}, 'locks': {'type': 'boolean'},
'dirty': {'type': 'boolean'}, 'dirty': {'type': 'boolean'},
'build_jobs': {'type': 'integer', 'minimum': 1}, 'build_jobs': {'type': 'integer', 'minimum': 1},
'ccache': {'type': 'boolean'},
} }
}, },
}, },
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment