Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 1 | FROM ubuntu:18.04 |
| 2 | RUN apt-get update |
| 3 | RUN apt-get install -y \ |
| 4 | autoconf \ |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 5 | autoconf-archive \ |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 6 | automake \ |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 7 | build-essential \ |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 8 | g++ \ |
| 9 | gcc \ |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 10 | git \ |
| 11 | libssl-dev \ |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 12 | libtool \ |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 13 | m4 \ |
| 14 | net-tools \ |
Tony Y | 8431ed9 | 2018-06-07 16:38:50 -0700 | [diff] [blame^] | 15 | pkg-config |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 16 | |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 17 | # OpenSSL |
| 18 | ARG openssl_name=openssl-1.1.0h |
| 19 | WORKDIR /tmp |
| 20 | ADD https://www.openssl.org/source/$openssl_name.tar.gz . |
| 21 | RUN tar xvf $openssl_name.tar.gz |
| 22 | WORKDIR $openssl_name |
| 23 | RUN ./config --prefix=/usr/local/openssl --openssldir=/usr/local/openssl |
| 24 | RUN make -j$(nproc) |
| 25 | RUN make install |
| 26 | RUN openssl version |
John Andersen | 6c601f0 | 2017-06-29 15:23:27 -0700 | [diff] [blame] | 27 | |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 28 | # IBM's Software TPM 2.0 |
| 29 | ARG ibmtpm_name=ibmtpm1119 |
| 30 | WORKDIR /tmp |
Tony Y | 8431ed9 | 2018-06-07 16:38:50 -0700 | [diff] [blame^] | 31 | ADD "https://downloads.sourceforge.net/project/ibmswtpm2/$ibmtpm_name.tar.gz" . |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 32 | RUN sha256sum $ibmtpm_name.tar.gz | grep ^b9eef79904e276aeaed2a6b9e4021442ef4d7dfae4adde2473bef1a6a4cd10fb |
| 33 | RUN mkdir -p $ibmtpm_name |
| 34 | RUN tar xvf $ibmtpm_name.tar.gz -C $ibmtpm_name |
| 35 | WORKDIR $ibmtpm_name/src |
| 36 | RUN CFLAGS="-I/usr/local/openssl/include" make -j$(nproc) |
| 37 | RUN cp tpm_server /usr/local/bin |
John Andersen | 80efcb4 | 2017-07-18 15:01:51 -0700 | [diff] [blame] | 38 | |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 39 | RUN apt-get install -y \ |
| 40 | libcmocka0 \ |
| 41 | libcmocka-dev \ |
| 42 | libgcrypt20-dev \ |
| 43 | libtool \ |
| 44 | liburiparser-dev \ |
| 45 | uthash-dev |
John Andersen | e459189 | 2017-07-19 10:13:30 -0700 | [diff] [blame] | 46 | |
Tony Y | 14a2400 | 2018-06-05 14:00:41 -0700 | [diff] [blame] | 47 | # TPM2-TSS |
| 48 | COPY . /tmp/tpm2-tss/ |
| 49 | WORKDIR /tmp/tpm2-tss |
| 50 | RUN ./bootstrap |
| 51 | RUN ./configure --enable-unit |
| 52 | RUN make -j$(nproc) check |
| 53 | RUN make install |
| 54 | RUN ldconfig |
| 55 | ENV LD_LIBRARY_PATH /usr/local/lib |
| 56 | RUN cat test-suite.log |
| 57 | |