Skip to content

Latest commit

 

History

History
59 lines (45 loc) · 2.25 KB

Caching.md

File metadata and controls

59 lines (45 loc) · 2.25 KB

How caching works

To know if the storage contains the artifact we need, we are computing some hashes to make sure the input is the same.

Because the configuration and environment matter, the hash computation takes a few parameters into account.

How hash keys are computed.

Rust

We generate a blake3 digest for each file compiled. In parallel, we also take into account in the hash:

  • Path to the rustc executable
  • Host triple for this rustc
  • Path to the rustc sysroot
  • digests of all the shared libraries in rustc's $sysroot/lib
  • A shared, caching reader for rlib dependencies (for dist-client)
  • Parsed arguments from the rustc invocation

See

pub struct ParsedArguments {
for the full list

C/C++ compiler

For C/C++, the hash is generated with a blake3 digest of the preprocessed file (-E with gcc/clang). For compilations that specify multiple -arch flags, these flags are rewritten to their corresponding preprocessor defines to allow pre-processing the file (e.g -arch x86_64 is rewritten to -D__X86_64__=1), this can be enabled by setting the environment variable SCCACHE_CACHE_MULTIARCH but is disabled by default as it may not work in all cases.

We also take into account in the hash:

  • Hash of the compiler binary
  • Programming language
  • Flag required to compile for the given language
  • File in which to generate dependencies.
  • Commandline arguments for dependency generation
  • Commandline arguments for the preprocessor
  • Commandline arguments specifying the architecture to compile for
  • Extra files that need to have their contents hashed
  • Whether the compilation is generating profiling or coverage data
  • Color mode
  • Environment variables

See

pub struct ParsedArguments {

C/C++ preprocessor

In "preprocessor cache mode", explained in the local doc, an extra key is computed to cache the preprocessor output itself. It is very close to the C/C++ compiler one, but with additional elements:

  • The path of the input file
  • The hash of the input file

Note that some compiler options can disable preprocessor cache mode. As of this writing, only -Xpreprocessor and -Wp,* do.