Skip to content

Commit

Permalink
Update docs on deploying spack
Browse files Browse the repository at this point in the history
  • Loading branch information
xylar committed Jan 17, 2024
1 parent 9309c4a commit cf29ebc
Showing 1 changed file with 22 additions and 6 deletions.
28 changes: 22 additions & 6 deletions docs/developers_guide/deploying_spack.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,10 @@ If system modules change in E3SM, we try to stay in sync:
- pnetcdf
- mkl (or other linear algebra libs)

When we update the `mache` version in Polaris, we also need to bump the
Polaris version (typically either the major or the minor version) and then
re-deploy shared spack environments on each supported machine.

### Spack

Spack is for libraries used by MPAS and tools that need system MPI:
Expand All @@ -25,13 +29,21 @@ Spack is for libraries used by MPAS and tools that need system MPI:
- PETSc
- Netlib LAPACK

When we update the versions of any of these libraries in Polaris, we also need
to bump the Polaris version (typically either the major or the minor version)
and then re-deploy shared spack environments on each supported machine.

### Conda

Conda (via conda-forge) is used for python packages and related dependencies
that don’t need system MPI. Conda environments aren’t shared between
developers because the polaris you’re developing is part of the conda
environment.

When we update the constraints on conda dependencies, we also need to bump the
Polaris alpha, beta or rc version. We do not need to re-deploy spack
environments on share machines because they remain unaffected.

## Mache

A brief tour of mache.
Expand Down Expand Up @@ -100,14 +112,18 @@ by polaris. Here, we will use `<fork>` as a stand-in for the fork of mache
to use (e.g. `E3SM-Project/mache`) and `<branch>` as the stand-in for a branch on
that fork (e.g. `main`).

We also need to make sure there is a spack branch for the version of mache.
This is a branch off of the develop branch on
We also need to make sure there is a spack branch for the version of Polaris.
The spack branch is a branch off of the develop branch on
[E3SM’s spack repo](https://github.com/E3SM-Project/spack) that has any
updates to packages required for this version of mache and polaris. The
spack branch will omit any alpha, beta or rc suffix on the mache version
because it is intended to be the spack branch we will use once the `mache`
release happens. In this example, we will work with the branch
uupdates to packages required for this version of mache. The remote branch
is named after the release version of mache (omitting any alpha, beta or rc
suffix because it is intended to be the spack branch we will use once the
``mache`` release happens). In this example, we will work with the branch
[spack_for_mache_1.12.0](https://github.com/E3SM-Project/spack/tree/spack_for_mache_1.12.0).
The local clone is instead named after the Polaris version (again any omitting
alpha, beta or rc) plus the compiler and MPI library because we have discovered
two users cannot make modifications to the same git clone. Giving each clone
of the spack branch a unique name ensures that they are independent.

Here's how to get a branch of polaris we're testing (`simplify_local_mache`
in this case) as a local worktree:
Expand Down

0 comments on commit cf29ebc

Please sign in to comment.