Skip to content

Latest commit

 

History

History
357 lines (250 loc) · 9.88 KB

INSTALL.md

File metadata and controls

357 lines (250 loc) · 9.88 KB

Building and Installing Kmyth


Table of Contents


Requirements

  • TPM version 2.0.

  • TPM must be enabled.

  • TPM must be configured (see Notes)


Installation

Dependencies

Required for building Kmyth:

  • C Standard Library development libraries and headers
  • OpenSSL development libraries and headers
  • TPM 2.0 TSS development libraries and headers
  • TPM 2.0 Access Broker and Resource Manager development libraries and headers
  • C compiler
  • Make
  • Valgrind (can be utilized to detect memory management and threading bugs, and otherwise profile programs - kmyth uses valgrind API, so it is a dependency even if not intending to perform analysis with valgrind)
  • libkmip (used in getkey)

With the exception of libkmip these dependencies can likely be met using your package manager. libkmip must be installed from source.

CentOS 8 (Red Hat 8/9) Commands

yum install openssl openssl-devel glibc gcc libffi-devel valgrind valgrind-devel

yum install tpm2-abrmd tpm2-tss tpm2-tss-devel tpm2-abrmd-devel

Ubuntu 20.04 Commands

apt install make gcc openssl libssl-dev libffi-dev valgrind

apt install tss2 libtss2-dev libtss2-tcti-tabrmd-dev tpm2-abrmd

Required for running Kmyth unit tests:

  • CUnit framework library and headers
  • CUnit framework documentation (optional)

Some unit tests may also assume the use of a TPM 2.0 emulator.

CentOS 8 (Red Hat 8/9) Commands

yum install CUnit CUnit-devel

Ubuntu 20.04 Commands

apt install libcunit1 libcunit1-dev libcunit1-doc

Useful TPM 2.0 utilities (may be required for TPM configuration, etc):

  • tpm2-tools (command line tools for TPM 2.0 based on tpm2-tss)
CentOS 8 (Red Hat 8/9) Commands

yum install tpm2-tools

Ubuntu 20.04 Commands

apt install tpm2-tools

Building

Building Kmyth

Once the dependencies are installed:

  1. Download the code

  2. The documentation is built using make docs. The doxygen generated documentation is put in ./doc.

  3. In the base directory run make or make all to create:

  • ./lib/libkmyth-utils.so
  • ./lib/libkmyth-logger.so
  • ./lib/libkmyth-tpm.so
  • ./bin/kmyth-seal
  • ./bin/kmyth-unseal
  • ./bin/kmyth-getkey
  1. The existing build (executables, object files, and documentation) can be cleared away to support a fresh build by using make clean.

  2. To install the kmyth headers, library, and the executables run sudo make install. By default this installs:

  • /usr/local/include/kmyth/file_io.h
  • /usr/local/include/kmyth/formatting_tools.h
  • /usr/local/include/kmyth/memory_util.h
  • /usr/local/include/kmyth/kmyth_log.h
  • /usr/local/include/kmyth/kmyth.h
  • /usr/local/lib/libkmyth-utils.so
  • /usr/local/lib/libkmyth-logger.so
  • /usr/local/lib/libkmyth-tpm.so
  • /usr/local/bin/kmyth-seal
  • /usr/local/bin/kmyth-unseal

In addition to a normal (full) build/installation, a few partial approaches are also supported to support those applications needing more granular access to kmyth functionality:

  1. Kmyth provides a fairly generic logging capability that could be repurposed by other applications. In order to support potential re-use, kmyth logging functionality is built as a separate shared libary (kmyth-logger). To build only the 'kmyth-logger' library run make logger-lib. This might be useful if only the logging functionality is required. It creates:
  • ./lib/libkmyth-logger.so Running sudo make install after this will install:
  • /usr/local/lib/libkmyth-logger.so
  • /uae/local/include/kmyth/kmyth_log.h
  1. Because the kmyth enclave code is intended to built within other projects, we created libkmyth-utils.so to expose functionality that other projects might find useful. In this library we include our formatting tools (e.g., our base64 encode/decode functions), our memory utilities, and our file I/O utilities. This avoids potential reference conflicts when building Kmyth as a submodule, and it allows other programs to use existing calls, such as kmyth's secure_memset. This library does not contain any code specific to the TPM or SGX. To build only the 'kmyth-utils' library run make utils-lib. This might be useful if only the kmyth utility functionality is required. It creates:
  • ./lib/libkmyth-utils.so Running sudo make install after this will install:
  • /usr/local/lib/libkmyth-utils.so
  • /usr/local/include/kmyth/file_io.h
  • /usr/local/include/kmyth/formatting_tools.h
  • /usr/local/include/kmyth/memory_util.h
  1. To build all kmyth shared libraries, but not the kmyth applications, run make libs. This will create:
  • ./lib/libkmyth-utils.so
  • ./lib/libkmyth-logger.so
  • ./lib/libkmyth-tpm.so Running sudo make install after this will install:
  • /usr/local/include/kmyth/file_io.h
  • /usr/local/include/kmyth/formatting_tools.h
  • /usr/local/include/kmyth/memory_util.h
  • /usr/local/include/kmyth/kmyth_log.h
  • /usr/local/include/kmyth/kmyth.h
  • /usr/local/lib/libkmyth-logger.so
  • /usr/local/lib/libkmyth-tpm.so

Any installed files can be uninstalled by running sudo make uninstall.

Running Kmyth Unit Tests
  1. In the base directory run make and then make test to build and run the tests.

Building the Dependencies

First, install as many of the above listed dependencies as you can.

The following instructions will walk you through the build process for the various Kmyth dependencies, using the IBM TPM 2.0 Emulator in place of a hardware TPM. This guide builds upward from the bottom-level dependencies, starting with the tpm2-tss library, then the tpm2-tools utility library, and finally the tpm2-abrmd broker library. We wrap up by doing a simple build of the emulator. Note that build steps for later tools or libraries may require dependencies installed earlier in the sequence.

These build instructions were developed and tested on CentOS 8.

Building the tpm2-tss library
  1. Clone the tpm2-tss GitHub repository.
$ git clone https://github.com/tpm2-software/tpm2-tss.git
$ cd tpm2-tss
  1. Install dependencies from the PowerTools repository. Note that if PowerTools is already enabled, you can just run the install.
$ sudo dnf --enablerepo=PowerTools
$ sudo dnf install autoconf-archive json-c-devel
  1. Install the remaining dependencies by using the existing upstream tpm2-tss package.
$ sudo dnf builddep tpm2-tss
$ sudo yum -y install libcurl-devel
  1. Run the bootstrap and configure scripts. Note that you may need to change the udevrulesdir and udevrulesprefix configuration values for your system setup.
$ ./bootstrap
$ ./configure --with-udevrulesdir=/etc/udev/rules.d --with-udevrulesprefix=80-
  1. Build and install the tpm2-tss library.
$ make -j$(nproc)
$ sudo make install
  1. Update the system configuration.
$ sudo udevadm control --reload-rules && udevadm trigger
$ sudo ldconfig
Building the tpm2-tools library
  1. Clone the tpm2-tools GitHub repository.
$ git clone https://github.com/tpm2-software/tpm2-tools.git
$ cd tpm2-tools
  1. Install dependencies by using the existing upsream tpm2-tools package.
$ sudo dnf builddep tpm2-tools
  1. Install additional dependencies.
$ sudo yum -y install automake libtool autoconf autoconf-archive libstdc++-devel gcc pkg-config uriparser-devel libgcrypt-devel dbus-devel glib2-devel libcurl-devel libuuid-devel
  1. Run the bootstrg e m m m s s s map and configure scripts. You may need to change the PKG_CONFIG_PATH configuration value for your system.
$ ./bootstrap
$ PKG_CONFIG_PATh=/usr/local/lib/pkgconfig ./configure
  1. Build and install the tpm2-tools library.
$ make -j$(nproc)
$ sudo make install
  1. Update the system configuration.
$ sudo ldconfig
Building the tpm2-abrmd library
  1. Clone the tpm2-abrmd GitHub repository.
$ git clone https://github.com/tpm2-software/tpm2-abrmd.git
$ cd tpm2-abrmd
  1. Install dependencies.
$ sudo yum -y install glib2-devel
  1. Run the bootstrap and configure scripts. You may need to change the PKG_CONFIG_PATH configuration value for your system.
$ ./bootstrap
$ PKG_CONFIG_PATH=/usr/local/lib/pkgconfig ./configure
  1. Build and install the tpm2-abrmd library.
$ make
$ sudo make install
  1. Update the system configuration.
$ sudo ldconfig
Building the IBM TPM 2.0 Emulator
  1. Download the emulator package from SourceForge: https://sourceforge.net/projects/ibmswtpm2/

  2. Unpack the emulator package. Note the package name may vary slightly depending on when you download it.

$ mkdir ibm-tpm2-emulator
$ mv ~/Downloads/ibmtpm1628.tar.gz ibm-tmp2-emulator/.
$ cd ibm-tpm2-emulator
$ tar -xvf ibmtpm1628.tar.gz
  1. Build the emulator.
$ cd src
$ make
  1. The emulator executable can be found at: ./src/tpm_server

Running with TPM 2.0 Emulators

Kmyth should function using any TPM 2.0 emulators, however it does not provide any security benefit and should only be done for testing purposes.

IBM Emulator

  • IBM's TPM 2.0 emulator can be used with Kmyth for testing purposes. If you want to use this emulator there are 2 steps after it is built.
    1. Run the simulator executible.
    2. As the tss user execute tpm2-abrmd --tcti=mssim

Microsoft Simulator

We have not tried this simulator, so if you have please let us know!