FROM ubuntu:22.04 as builder RUN apt-get -qq update -y \ && DEBIAN_FRONTEND=noninteractive \ apt-get install -y --no-install-recommends \ bison \ build-essential \ ca-certificates \ clang \ cmake \ flex \ gawk \ git \ golang \ graphviz \ less \ libboost-dev \ libboost-filesystem-dev \ libboost-iostreams-dev \ libboost-program-options-dev \ libboost-thread-dev \ libeigen3-dev \ libffi-dev \ libftdi-dev \ libhidapi-dev \ libreadline-dev \ lld \ llvm \ mercurial \ nano \ pkg-config \ python3 \ python3-dev \ tcl-dev \ verilator \ vim \ xdot \ && rm -rf /var/lib/apt/lists/* RUN git clone --depth=1 https://github.com/YosysHQ/icestorm /src WORKDIR /src RUN make -j$(nproc --ignore=2) \ && make install RUN git show -s >/repo-commit-icestorm WORKDIR / RUN rm -rf /src # Custom iceprog for the RPi 2040-based programmer (will be upstreamed). RUN git clone -b interfaces --depth=1 https://github.com/tillitis/icestorm /src WORKDIR /src/iceprog RUN make -j$(nproc --ignore=2) \ && make PROGRAM_PREFIX=tillitis- install RUN git show -s >/repo-commit-tillitis--icestorm WORKDIR / RUN rm -rf /src RUN git clone https://github.com/YosysHQ/yosys /src WORKDIR /src # Avoiding current issue with yosys & icebram, filed in: # https://github.com/YosysHQ/yosys/issues/3478 RUN git checkout 06ef3f264afaa3eaeab45cc0404d8006c15f02b1 \ && make -j$(nproc --ignore=2) \ && make install RUN git show -s >/repo-commit-yosys WORKDIR / RUN rm -rf /src RUN git clone --depth=1 https://github.com/YosysHQ/nextpnr /src WORKDIR /src RUN cmake -DARCH=ice40 -DCMAKE_INSTALL_PREFIX=/usr/local . \ && make -j$(nproc --ignore=2) \ && make install RUN git show -s >/repo-commit-nextpnr WORKDIR / RUN rm -rf /src FROM ubuntu:22.04 COPY --from=builder /usr/local/ /usr/local RUN apt-get -qq update -y \ && DEBIAN_FRONTEND=noninteractive \ apt-get install -y --no-install-recommends \ bison \ build-essential \ ca-certificates \ clang \ cmake \ flex \ gawk \ git \ golang \ graphviz \ less \ libboost-dev \ libboost-filesystem-dev \ libboost-iostreams-dev \ libboost-program-options-dev \ libboost-thread-dev \ libeigen3-dev \ libftdi1 \ libhidapi-libusb0 \ lld \ llvm \ mercurial \ nano \ pkg-config \ python3 \ python3-dev \ tcl-dev \ verilator \ vim \ xdot \