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 dockerfiles #771

Merged
merged 41 commits into from
Feb 21, 2021
Merged
Show file tree
Hide file tree
Changes from 22 commits
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
53386ef
added gettext dependency for qemu build
eddygta17 Jun 13, 2020
8e19b46
Update Gemmini.rst
amsharifian Oct 7, 2020
4253382
switched dockerfile base to ubuntu and fixed bugs. created entrypoint…
schwarz-em Nov 30, 2020
8141c71
entrypoint.sh sets environment variables correctly. Dockerfile has al…
schwarz-em Dec 1, 2020
77459a3
working version of dockerfile and entrypoint.sh
schwarz-em Dec 3, 2020
cfca224
removed log files for real this time?
schwarz-em Dec 3, 2020
fe1f7fe
changed permissions of entrypoint.sh
schwarz-em Dec 6, 2020
7439191
removed some redundancies from dockerfile
schwarz-em Dec 8, 2020
3957282
Cleaned up dockerfile
Dec 21, 2020
ef84927
Removed environment variables from dockerfile
Dec 23, 2020
db7fafb
switched dockerfile base to ubuntu and fixed bugs. created entrypoint…
schwarz-em Nov 30, 2020
f5ae2e0
entrypoint.sh sets environment variables correctly. Dockerfile has al…
schwarz-em Dec 1, 2020
f25aa8d
working version of dockerfile and entrypoint.sh
schwarz-em Dec 3, 2020
3ba19bb
changed permissions of entrypoint.sh
schwarz-em Dec 6, 2020
8300d9c
removed log files
Jan 12, 2021
b528058
part 2 of removing log files
Jan 12, 2021
9b84682
Fixed comments and simplified entrypoint
Jan 14, 2021
49a76a6
Updated ci dockerfile. Moved dockerfiles to outer directory. Updated …
Jan 21, 2021
a46c4e6
moved Dockerfiles
Jan 21, 2021
fa2da01
Changed config.yml to use new docker image
Jan 21, 2021
925bace
fixed merge conflict
Jan 21, 2021
58665ea
Added hardcoded environment variables to CI-Dockerfile and updated co…
Jan 22, 2021
500d2b8
Build both CI and main images in one dockerfile. Updated README.md
Jan 28, 2021
e13266b
Install python
Jan 28, 2021
5e90372
Updated image for to 1.0.2 for config.yml. Fixed formatting in Docker…
Jan 28, 2021
e95e033
Updated dockerfile comments and updated dockerfile readme. Removed ci…
Feb 4, 2021
d2b3dca
Readme updated for main dockerfile
Feb 4, 2021
7eb8f39
Uses latest chipyard ci image
Feb 5, 2021
34e56d5
Moved CMD command
Feb 6, 2021
1f8b597
Uses latest version of ci-image
Feb 6, 2021
84cfc73
Removed default argument
Feb 8, 2021
75bc39a
Uses latest ci image
Feb 8, 2021
323394f
Increased timeout limit
Feb 8, 2021
d7be658
Added information about docker image
Feb 14, 2021
788b22a
Added more details on docker image
Feb 15, 2021
0f3a703
Increased timeout to 20m
Feb 15, 2021
f06afa2
Increased timeout to 20m for chipyard-hetero tests
Feb 15, 2021
18aa600
Fix Chipyard spelling in docs [ci skip]
abejgonzalez Feb 15, 2021
d647534
Added more details on which tools are initialized in the docker image
Feb 19, 2021
9c650de
Removed apt-get upgrade and edited for image size
Feb 19, 2021
b12fa04
Updated docker image
Feb 19, 2021
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
3 changes: 1 addition & 2 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ parameters:
executors:
main-env:
docker:
- image: ucbbar/chipyard-image:1.0.1
- image: schwarzem/chipyard-test:1.0.1
environment:
JVM_OPTS: -Xmx3200m # Customize the JVM maximum heap limit

Expand Down Expand Up @@ -520,4 +520,3 @@ workflows:
- prepare-chipyard-fpga:
requires:
- install-riscv-toolchain

216 changes: 0 additions & 216 deletions .circleci/images/Dockerfile

This file was deleted.

43 changes: 43 additions & 0 deletions Dockerfiles/CI-Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
### Note: This DockerFile is adapted from https://github.com/ucb-bar/chipyard/blob/master/.circleci/images/Dockerfile which was adapted from: https://github.com/CircleCI-Public/example-images/openjdk
abejgonzalez marked this conversation as resolved.
Show resolved Hide resolved
# This is a chipyard setup for CI, no toolchains are initialized
abejgonzalez marked this conversation as resolved.
Show resolved Hide resolved

FROM ubuntu:18.04
ARG CHIPYARD_HASH

MAINTAINER https://groups.google.com/forum/#!forum/chipyard

# Install dependencies for ubuntu-req.sh
RUN apt-get update && \
apt-get upgrade -y && \
apt-get install -y \
curl \
git \
sudo

# Stopping docker keyboard-config from disrupting ubuntu-req.sh
RUN sudo DEBIAN_FRONTEND=noninteractive apt-get install -y keyboard-configuration && \
sudo DEBIAN_FRONTEND=noninteractive apt-get install -y console-setup

# Adds a new user called riscvuser
RUN groupadd --gid 3434 riscvuser \
&& useradd --uid 3434 --gid riscvuser --shell /bin/bash --create-home riscvuser \
&& echo 'riscvuser ALL=NOPASSWD: ALL' >> /etc/sudoers.d/50-riscvuser \
&& echo 'Defaults env_keep += "DEBIAN_FRONTEND"' >> /etc/sudoers.d/env_keep

WORKDIR /home/riscvuser
USER riscvuser

# Update PATH for RISCV toolchain (note: hardcoded for CircleCI)
ENV RISCV="/home/riscvuser/riscv-tools-install"
ENV LD_LIBRARY_PATH="$RISCV/lib"
ENV PATH="$RISCV/bin:$PATH"

# Install Chipyard
RUN git clone https://github.com/ucb-bar/chipyard.git && \
cd chipyard && \
git checkout $CHIPYARD_HASH && \
./scripts/ubuntu-req.sh 1>/dev/null

# END IMAGE CUSTOMIZATIONS

CMD ["/bin/sh"]
55 changes: 55 additions & 0 deletions Dockerfiles/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
### Note: This DockerFile is adapted from https://github.com/ucb-bar/chipyard/blob/master/.circleci/images/Dockerfile which was adapted from: https://github.com/CircleCI-Public/example-images/openjdk
# This is a full chipyard setup

FROM ubuntu:18.04
ARG CHIPYARD_HASH
abejgonzalez marked this conversation as resolved.
Show resolved Hide resolved

MAINTAINER https://groups.google.com/forum/#!forum/chipyard

# Install dependencies for ubuntu-req.sh
RUN apt-get update && \
apt-get upgrade -y && \
apt-get install -y \
curl \
git \
sudo

# Stopping docker keyboard-config from disrupting ubuntu-req.sh
RUN sudo DEBIAN_FRONTEND=noninteractive apt-get install -y keyboard-configuration && \
sudo DEBIAN_FRONTEND=noninteractive apt-get install -y console-setup

# Adds a new user called riscvuser
RUN groupadd --gid 3434 riscvuser \
&& useradd --uid 3434 --gid riscvuser --shell /bin/bash --create-home riscvuser \
&& echo 'riscvuser ALL=NOPASSWD: ALL' >> /etc/sudoers.d/50-riscvuser \
&& echo 'Defaults env_keep += "DEBIAN_FRONTEND"' >> /etc/sudoers.d/env_keep

WORKDIR /home/riscvuser
USER riscvuser

# Install Chipyard
RUN git clone https://github.com/ucb-bar/chipyard.git && \
cd chipyard && \
git checkout $CHIPYARD_HASH && \
./scripts/ubuntu-req.sh 1>/dev/null

# Run ubuntu-req.sh to install necessary dependencies
RUN cd chipyard && \
export MAKEFLAGS=-"j $(nproc)" && \
./scripts/init-submodules-no-riscv-tools.sh 1>/dev/null

# Install riscv-tools
RUN cd chipyard && \
export MAKEFLAGS=-"j $(nproc)" && \
./scripts/build-toolchains.sh riscv-tools 1>/dev/null

# Install esp-tools
RUN cd chipyard && \
export MAKEFLAGS=-"j $(nproc)" && \
./scripts/build-toolchains.sh esp-tools 1>/dev/null

ENTRYPOINT ["chipyard/scripts/entrypoint.sh"]

# END IMAGE CUSTOMIZATIONS

CMD ["/bin/sh"]
8 changes: 8 additions & 0 deletions scripts/entrypoint.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
#!/bin/bash

# used with the dockerfile to set up enviroment variables by running env.sh
# adapted from https://stackoverflow.com/questions/55921914/how-to-source-a-script-with-environment-variables-in-a-docker-build-process

. /home/riscvuser/chipyard/env.sh

exec "$@"