SLE BCI GNU Compiler Collection

GNU Compiler Collection container based on the SLE Base Container Image.

Get Image
Digest:
sha256:0838eb84f3af381a1df9ca467825a63c431d9e9b5244733e2e38155170c5e0d8
0838eb84f
Repository:
registry.suse.com/bci/gcc:latest

Description

SLE BCI GNU Compiler Collection container image (GCC)

RedistributableSLSA Provenance: Available

Description

The GNU Compiler Collection (GCC) is an optimizing compiler for various architectures and operating systems. It is the default compiler in the GNU project and most Linux distributions, including SUSE Linux Enterprise and openSUSE.

Usage

Compile an application with a Dockerfile

Normally, you'd want to compile an application and distribute it as part of a custom container image. To do this, create a Dockerfile similar to the one below. The Dockerfile uses this image to build a custom container image, copies the sources to a working directory, and compiles the application:

FROM registry.suse.com/bci/gcc:14
WORKDIR /src/
COPY . /src/
RUN gcc main.c src1.c src2.c
CMD ["./a.out"]

It is also possible to compile a static binary with gcc as part of a multistage build:

FROM registry.suse.com/bci/gcc:14 as builder
WORKDIR /src/
COPY . /src/
RUN gcc -o app main.c src1.c src2.c

FROM registry.suse.com/bci/bci-micro:latest
WORKDIR /build/
COPY --from=builder /src/app /build/
CMD ["/build/app"]

Note that you must build a static binary to deploy it into bci-micro; otherwise shared libraries might be missing. You cannot deploy such an app into a scratch image, as it is not possible to statically link glibc.

Available build systems

The container image comes with make by default. Other build systems and related utilities are available in the repository, and they can be installed using zypper. This includes the following:

  • meson
  • cmake
  • ninja
  • autoconf & automake

Available compiler frontends

The GNU Compiler Collections supports a wide range of frontends. The container image ships the C, C++ and fortran frontends available as gcc, g++ and gfortran respectively. The following additional frontends can be installed from the repository:

Using the container image interactively

You can use the image to create ephemeral containers that execute only gcc. This can be useful in situations, where building a full container image is not practical. One way to do this is to mount the working directory of an application into the launched container and compile the application there:

podman run --rm -it -v $(pwd):/src/:Z registry.suse.com/bci/gcc:14 \
    gcc -o /src/app.out /src/*.c

or by invoking make

podman run --rm -it -v $(pwd):/src/:Z --workdir /src/ \
    registry.suse.com/bci/gcc:14 \
    make

Note that the binary built using this approach are unlikely to work on a local machine. They only work on operating systems that are binary-compatible to SLE.

Licensing

SPDX-License-Identifier: GPL-3.0-or-later

This documentation and the build recipe are licensed as GPL-3.0-or-later. The container itself contains various software components under various open source licenses listed in the associated Software Bill of Materials (SBOM).

This image is based on SLE BCI, a stable and redistributable foundation for software innovation. SLE BCI is enterprise-ready, and it comes with an option for support.

See the SLE BCI EULA for further information.

  • Image Data

    Last Built: 11 Dec 13:55 UTC

    Compressed Size: 203.7 MB

    Uncompressed Size: 593.5 MB

    Support Level: L3

    Supported until: 31 Jul 2026


  • Health Index
    A

    No vulnerabilities found

    Last Scan:

    1 day ago