Hoa Nguyen has uploaded this change for review. ( https://gem5-review.googlesource.com/c/public/gem5/+/52564 )

Change subject: tests: Add a weekly test for SST integration.
......................................................................

tests: Add a weekly test for SST integration.

This test includes,
- A dockerfile creating a Docker image containing SST-Core
and SST-Elements installed. The image also contains the
bbl-busybox-boot-exit binary from gem5-resources.
- A week test involving compiling gem5 as a library, and
booting a linux kernel without a disk image using SST where
gem5 TimingSimpleCPU is the CPU core.

Change-Id: I2bf90b4121ed0d38300451648f2e358a7c3fffe2
Signed-off-by: Hoa Nguyen <hoangu...@ucdavis.edu>
---
M tests/weekly.sh
A util/dockerfiles/sst-11.1.0/Dockerfile
2 files changed, 108 insertions(+), 0 deletions(-)



diff --git a/tests/weekly.sh b/tests/weekly.sh
index 393c66f..882da7b 100755
--- a/tests/weekly.sh
+++ b/tests/weekly.sh
@@ -39,7 +39,26 @@
     threads=$1
 fi

+build_and_run_SST () {
+    isa=$1
+    variant=$2
+
+    docker run -u $UID:$GID --volume "${gem5_root}":"${gem5_root}" -w \
+        "${gem5_root}" --rm TODO? \
+            bash -c "\
+scons build/${isa}/libgem5_${variant}.so -j${threads} --without-tcmalloc; \
+cd ext/sst; \
+make clean; make -j ${threads}; \
+ln -s /resources/bbl-busybox-boot-exit; \
+sst --add-lib-path=./ sst/example.py; \
+"
+}
+
 # Run the gem5 very-long tests.
 docker run -u $UID:$GID --volume "${gem5_root}":"${gem5_root}" -w \
"${gem5_root}"/tests --rm gcr.io/gem5-test/ubuntu-20.04_all-dependencies \
         ./main.py run --length very-long -j${threads} -t${threads}
+
+# Run an SST test.
+build_and_run_SST RISCV opt
+
diff --git a/util/dockerfiles/sst-11.1.0/Dockerfile b/util/dockerfiles/sst-11.1.0/Dockerfile
new file mode 100644
index 0000000..e30cdea
--- /dev/null
+++ b/util/dockerfiles/sst-11.1.0/Dockerfile
@@ -0,0 +1,71 @@
+# Copyright (c) 2021 The Regents of the University of California
+# All Rights Reserved.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions are
+# met: redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer;
+# redistributions in binary form must reproduce the above copyright
+# notice, this list of conditions and the following disclaimer in the
+# documentation and/or other materials provided with the distribution;
+# neither the name of the copyright holders nor the names of its
+# contributors may be used to endorse or promote products derived from
+# this software without specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+FROM ubuntu:20.04
+
+ENV DEBIAN_FRONTEND=noninteractive
+RUN apt -y update
+RUN apt -y upgrade
+RUN apt -y install build-essential git m4 scons zlib1g zlib1g-dev \
+ libprotobuf-dev protobuf-compiler libprotoc-dev libgoogle-perftools-dev \
+    python3-dev python3-six python-is-python3 doxygen libboost-all-dev \
+    libhdf5-serial-dev python3-pydot libpng-dev libelf-dev pkg-config pip \
+    python3-venv wget
+
+ENV SST_CORE_HOME="/sst/"
+
+# SST Stuff
+RUN mkdir /sst
+
+# Download and build SST-Core without MPI support
+WORKDIR /sst/
+RUN wget https://github.com/sstsimulator/sst-core/releases/download/v11.1.0_Final/sstcore-11.1.0.tar.gz; \
+    tar xf sstcore-11.1.0.tar.gz;
+WORKDIR /sst/sstcore-11.1.0/
+RUN ./configure --prefix=$SST_CORE_HOME --with-python=/usr/bin/python3-config \
+                                        --disable-mpi; \
+    make all -j $(nproc); \
+    make install;
+
+# Download and build SST-Elements
+WORKDIR /sst
+RUN wget https://github.com/sstsimulator/sst-elements/releases/download/v11.1.0_Final/sstelements-11.1.0.tar.gz; \
+    tar xf sstelements-11.1.0.tar.gz;
+WORKDIR /sst/sst-elements-library-11.1.0/
+RUN ./configure --prefix=$SST_CORE_HOME --with-python=/usr/bin/python3-config \
+                                        --with-sst-core=$SST_CORE_HOME; \
+    make all -j $(nproc); \
+    make install;
+
+# Download the disk image
+RUN mkdir /resources/
+WORKDIR /resources/
+RUN wget http://dist.gem5.org/dist/develop/misc/riscv/bbl-busybox-boot-exit;
+
+# Setting the environmental variables
+ENV PATH=$PATH:$SST_CORE_HOME/bin
+ENV PKG_CONFIG_PATH=$PKG_CONFIG_PATH:$SST_CORE_HOME/lib/pkgconfig/
+

--
To view, visit https://gem5-review.googlesource.com/c/public/gem5/+/52564
To unsubscribe, or for help writing mail filters, visit https://gem5-review.googlesource.com/settings

Gerrit-Project: public/gem5
Gerrit-Branch: develop
Gerrit-Change-Id: I2bf90b4121ed0d38300451648f2e358a7c3fffe2
Gerrit-Change-Number: 52564
Gerrit-PatchSet: 1
Gerrit-Owner: Hoa Nguyen <hoangu...@ucdavis.edu>
Gerrit-MessageType: newchange
_______________________________________________
gem5-dev mailing list -- gem5-dev@gem5.org
To unsubscribe send an email to gem5-dev-le...@gem5.org
%(web_page_url)slistinfo%(cgiext)s/%(_internal_name)s

Reply via email to