OpenRAM/docker/Dockerfile

161 lines
5.4 KiB
Docker
Raw Normal View History

2021-11-02 19:10:59 +01:00
FROM ubuntu:20.04
ENV DEBIAN_FRONTEND noninteractive
RUN ln -s /usr/share/zoneinfo/America/Los_Angeles /etc/localtime
RUN echo "America/Los_Angeles" > /etc/timezone
RUN apt-get update
RUN apt-get --no-install-recommends -y upgrade
### Dependencies ###
# General tools for building etc.
RUN apt-get install --no-install-recommends -y build-essential git ssh vim gosu autoconf automake libtool bison flex
# Use bash instead of dash
RUN rm /bin/sh && ln -s /bin/bash /bin/sh
# Needed by OpenRAM
RUN apt-get install --no-install-recommends -y python3 python3-numpy python3-scipy python3-pip python3-matplotlib python3-venv python3-sklearn python3-subunit python3-coverage
# Needed by Netgen
RUN apt-get install --no-install-recommends -y m4 csh tk tk-dev tcl-dev
# Needed by ngspice
RUN apt-get install --no-install-recommends -y libxaw7-dev libreadline8 libreadline-dev
# X11
RUN apt-get install --no-install-recommends -y libx11-dev libcairo2-dev
# Klayout
RUN apt-get install --no-install-recommends -y qt5-default qtcreator ruby-full ruby-dev python3-dev qtmultimedia5-dev libqt5multimediawidgets5 libqt5multimedia5-plugins libqt5multimedia5 libqt5svg5-dev libqt5designer5 libqt5designercomponents5 libqt5xmlpatterns5-dev qttools5-dev
### Klayout ###
#ARG KLAYOUT_COMMIT=v0.27.8
ARG KLAYOUT_COMMIT=ea1bf40a1ee1c1c934e47a0020417503ab3d7e7e
2021-11-02 19:10:59 +01:00
WORKDIR /root
RUN git clone https://github.com/KLayout/klayout
WORKDIR /root/klayout
RUN git checkout ${KLAYOUT_COMMIT}
2022-03-10 20:48:53 +01:00
RUN ./build.sh -qt5 -debug -j 8 \
&& cp -r bin-debug /usr/local/klayout
2021-11-02 19:10:59 +01:00
RUN rm -rf /root/klayout
2022-02-06 18:04:38 +01:00
### Trilinos ###
ARG TRILINOS_COMMIT=trilinos-release-12-12-1
WORKDIR /root
RUN apt-get update
2022-02-06 18:04:38 +01:00
RUN apt-get install --no-install-recommends -y cmake libfftw3-dev mpich libblas-dev liblapack-dev libsuitesparse-dev libfl-dev openmpi-bin libopenmpi-dev gfortran
RUN git clone --depth 1 --branch ${TRILINOS_COMMIT} https://github.com/trilinos/Trilinos.git
RUN mkdir /root/Trilinos/build
WORKDIR /root/Trilinos/build
RUN cmake \
-G "Unix Makefiles" \
-DCMAKE_C_COMPILER=mpicc \
-DCMAKE_CXX_COMPILER=mpic++ \
-DCMAKE_Fortran_COMPILER=mpif77 \
-DCMAKE_CXX_FLAGS="-O3 -fPIC" \
-DCMAKE_C_FLAGS="-O3 -fPIC" \
-DCMAKE_Fortran_FLAGS="-O3 -fPIC" \
-DCMAKE_INSTALL_PREFIX=/usr/local/XyceLibs/Parallel \
-DCMAKE_MAKE_PROGRAM="make" \
-DTrilinos_ENABLE_NOX=ON \
-DNOX_ENABLE_LOCA=ON \
-DTrilinos_ENABLE_EpetraExt=ON \
-DEpetraExt_BUILD_BTF=ON \
-DEpetraExt_BUILD_EXPERIMENTAL=ON \
-DEpetraExt_BUILD_GRAPH_REORDERINGS=ON \
-DTrilinos_ENABLE_TrilinosCouplings=ON \
-DTrilinos_ENABLE_Ifpack=ON \
-DTrilinos_ENABLE_ShyLU=ON \
-DTrilinos_ENABLE_Isorropia=ON \
-DTrilinos_ENABLE_AztecOO=ON \
-DTrilinos_ENABLE_Belos=ON \
-DTrilinos_ENABLE_Teuchos=ON \
-DTeuchos_ENABLE_COMPLEX=ON \
-DTrilinos_ENABLE_Amesos=ON \
-DAmesos_ENABLE_KLU=ON \
-DTrilinos_ENABLE_Sacado=ON \
-DTrilinos_ENABLE_Kokkos=ON \
-DTrilinos_ENABLE_Zoltan=ON \
-DTrilinos_ENABLE_ALL_OPTIONAL_PACKAGES=OFF \
-DTrilinos_ENABLE_CXX11=ON \
-DTPL_ENABLE_AMD=ON \
-DAMD_LIBRARY_DIRS="/usr/lib" \
-DTPL_AMD_INCLUDE_DIRS="/usr/include/suitesparse" \
-DTPL_ENABLE_BLAS=ON \
-DTPL_ENABLE_LAPACK=ON \
-DTPL_ENABLE_MPI=ON \
/root/Trilinos
RUN make -j 4
RUN make install
ARG XYCE_COMMIT=b7bb12d81f11d8b50141262537299b09d64b5565
WORKDIR /root
RUN git clone https://github.com/Xyce/Xyce.git
WORKDIR /root/Xyce
RUN git checkout ${XYCE_COMMIT}
RUN ./bootstrap
RUN mkdir /root/Xyce/build
WORKDIR /root/Xyce/build
RUN ../configure CXXFLAGS="-O3 -std=c++11" \
ARCHDIR="/usr/local/XyceLibs/Parallel" \
CPPFLAGS="-I/usr/include/suitesparse" \
--enable-mpi CXX=mpicxx CC=mpicc F77=mpif77 \
--prefix=/usr/local/Xyce/Parallel --enable-shared --enable-xyce-shareable
RUN make -j 4 install
2021-11-02 19:10:59 +01:00
### Ngspice ###
ARG NGSPICE_COMIT=032b1c32c4dbad45ff132bcfac1dbecadbd8abb0
WORKDIR /root
RUN git clone git://git.code.sf.net/p/ngspice/ngspice
WORKDIR /root/ngspice
RUN git checkout ${NGSPICE_COMMIT}
RUN ./autogen.sh \
&& ./configure --enable-openmp --with-readline \
&& make \
&& make install
RUN rm -rf /root/ngspice
### Netgen ###
#ARG NETGEN_COMMIT=1.5.195
ARG NETGEN_COMMIT=1.5.221
WORKDIR /root
2022-02-28 18:11:09 +01:00
#RUN git clone https://github.com/RTimothyEdwards/netgen.git netgen
RUN git clone git://opencircuitdesign.com/netgen netgen
WORKDIR /root/netgen
RUN git checkout ${NETGEN_COMMIT}
RUN ./configure \
&& make -j$(nproc) \
&& make install
RUN rm -rf /root/netgen
### iVerilog ###
2022-02-08 01:30:25 +01:00
RUN apt-get install --no-install-recommends -y iverilog
2022-02-23 22:04:53 +01:00
### Magic ###
2022-02-28 18:11:09 +01:00
#ARG MAGIC_COMMIT=db4fa65bfc096e63954b37b188ea27b90ab31839
#ARG MAGIC_COMMIT=8.3.274
2022-06-08 23:23:28 +02:00
#ARG MAGIC_COMMIT=8.3.310
ARG MAGIC_COMMIT=d099562e85e16654ef4573f1eb26c89d1b3d1ee2
2022-02-23 22:04:53 +01:00
WORKDIR /root
2022-02-28 18:11:09 +01:00
#RUN git clone https://github.com/RTimothyEdwards/magic.git magic
RUN git clone git://opencircuitdesign.com/magic magic
2022-02-23 22:04:53 +01:00
WORKDIR /root/magic
RUN git checkout ${MAGIC_COMMIT}
RUN ./configure \
&& make \
&& make install
RUN rm -rf /root/magic
2021-11-02 19:10:59 +01:00
### CLEAN UP ###
# Remove development tools to save space
2022-02-06 18:04:38 +01:00
RUN apt-get remove -y build-essential autoconf automake libtool bison flex tcl-dev tk-dev cmake
2021-11-02 19:10:59 +01:00
# Cleanup to save some space
RUN apt-get clean
RUN rm -rf /var/lib/apt/lists/*
# ### SET UP A GENERIC USER ###
RUN useradd cad-user
2022-03-07 16:58:00 +01:00
RUN mkdir /home/cad-user
RUN chown -R cad-user /home/cad-user
RUN chgrp -R cad-user /home/cad-user
2022-02-01 22:20:02 +01:00
ADD set-paths.sh /home/cad-user/.bashrc
USER cad-user
WORKDIR /home/cad-user