Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update intel and gcc containers - fix builds and move to ubuntu 24.04 #1432

Merged
merged 19 commits into from
Dec 23, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
61 changes: 28 additions & 33 deletions configs/containers/docker-ubuntu-gcc-openmpi.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,14 @@ spack:

compilers:
- compiler:
spec: gcc@12.3.0
spec: gcc@13.3.0
paths:
cc: /usr/bin/gcc-12
cxx: /usr/bin/g++-12
f77: /usr/bin/gfortran-12
fc: /usr/bin/gfortran-12
cc: /usr/bin/gcc-13
cxx: /usr/bin/g++-13
f77: /usr/bin/gfortran-13
fc: /usr/bin/gfortran-13
flags: {}
operating_system: ubuntu22.04
operating_system: ubuntu24.04
modules: []
environment: {}
extra_rpaths: []
Expand All @@ -29,16 +29,16 @@ spack:
target: [x86_64]
providers:
mpi: [[email protected]]
compiler: [gcc@12.3.0]
compiler: [gcc@13.3.0]
gcc:
buildable: false
externals:
- spec: gcc@12.3.0
- spec: gcc@13.3.0
prefix: /usr
gcc-runtime:
buildable: false
externals:
- spec: gcc-runtime@12.3.0
- spec: gcc-runtime@13.3.0
prefix: /usr
diffutils:
buildable: false
Expand All @@ -55,15 +55,15 @@ spack:
externals:
- spec: [email protected]
prefix: /usr
grep:
llvm:
buildable: false
externals:
- spec: [email protected]
- spec: [email protected]
prefix: /usr
mysql:
buildable: false
externals:
- spec: [email protected].39
- spec: [email protected].40
prefix: /usr
qt:
buildable: false
Expand All @@ -76,7 +76,6 @@ spack:
externals:
- spec: [email protected]
prefix: /usr
version: [1.21.2]

specs: []

Expand All @@ -98,7 +97,7 @@ spack:
# Sets the base images for the stages where Spack builds the
# software or where the software gets installed after being built..
images:
os: ubuntu:22.04
os: ubuntu:24.04
spack:
url: https://github.com/jcsda/spack
ref: spack-stack-dev
Expand All @@ -111,12 +110,13 @@ spack:
os_packages:
build:
- bc
- cpp-12
- g++-12
- gcc-12
- gfortran-12
- cpp-13
- g++-13
- gcc-13
- gfortran-13
- git
- git-lfs
- llvm-14
- make
- mysql-server
- qtbase5-dev
Expand All @@ -127,12 +127,13 @@ spack:

final:
- bc
- cpp-12
- g++-12
- gcc-12
- gfortran-12
- cpp-13
- g++-13
- gcc-13
- gfortran-13
- git
- git-lfs
- llvm-14
- make
- mysql-server
- qtbase5-dev
Expand All @@ -157,12 +158,9 @@ spack:
# Copy the spack-stack extension repo into the spack code
COPY spack-ext-SPACK_STACK_HASH/repos/spack-stack $SPACK_ROOT/var/spack/repos/spack-stack
# Register spack-stack extension repo
RUN spack repo add $SPACK_ROOT/var/spack/repos/spack-stack --scope defaults
# Set the GNU 12.x toolchain as the default compilers.
RUN ln -svf /usr/bin/gfortran-12 /usr/bin/gfortran && \
ln -svf /usr/bin/cpp-12 /usr/bin/cpp && \
ln -svf /usr/bin/gcc-12 /usr/bin/gcc && \
ln -svf /usr/bin/g++-12 /usr/bin/g++
RUN spack repo add $SPACK_ROOT/var/spack/repos/spack-stack --scope defaults && \
# Needed by py-llvmlite
update-alternatives --install /usr/bin/llvm-config llvm-config /usr/bin/llvm-config-14 100
pre_final: |
# Set environment variables for installing tzdata
ENV DEBIAN_FRONTEND=noninteractive
Expand All @@ -178,18 +176,15 @@ spack:
final: |
# Copy spack find output from builder
COPY --from=builder /root/spack_find.out /root/spack_find.out
# Set the GNU 12.x toolchain as the default compilers.
RUN ln -svf /usr/bin/gfortran-12 /usr/bin/gfortran && \
ln -svf /usr/bin/cpp-12 /usr/bin/cpp && \
ln -svf /usr/bin/gcc-12 /usr/bin/gcc && \
ln -svf /usr/bin/g++-12 /usr/bin/g++
# Make a non-root user:nonroot / group:nonroot for running MPI
RUN useradd -U -k /etc/skel -s /bin/bash -d /home/nonroot -m nonroot --uid 43891 && \
echo "ulimit -s unlimited" >> /home/nonroot/.bashrc && \
echo "ulimit -v unlimited" >> /home/nonroot/.bashrc && \
echo "export CC=gcc" >> /home/nonroot/.bashrc && \
echo "export CXX=g++" >> /home/nonroot/.bashrc && \
echo "export FC=gfortran" >> /home/nonroot/.bashrc && \
# Needed by py-llvmlite
update-alternatives --install /usr/bin/llvm-config llvm-config /usr/bin/llvm-config-14 100 && \
printf "[credential]\n helper = cache --timeout=7200\n" >> /home/nonroot/.gitconfig && \
mkdir /home/nonroot/.pmix && \
echo "rmaps_default_mapping_policy=:oversubscribe" >> /home/nonroot/.pmix/mca-params.conf && \
Expand Down
Loading
Loading