acrn-hypervisor/.travis-dockerfiles
Geoffroy Van Cutsem c7da3976b7 Dockerfile: update Ubuntu 16.04 Dockerfile to include all deps
Update the Ubuntu 16.04 Dockerfile to add some missing dependencies and
updates, specifically:
* Need binutils 2.27 (or higher)
* Need pkg-config
* Need GPIO header file [1]

[1] Note that the current instructions for adding the GPIO header file
(linux/gpio.h) are still incomplete and compilation will fail.

Tracked-On: #2737
Signed-off-by: Geoffroy Van Cutsem <geoffroy.vancutsem@intel.com>
2019-05-10 15:41:43 +08:00
..
Dockerfile.centos7 Dockerfiles: add Python3 and kconfiglib build dependency 2018-06-25 17:30:30 +08:00
Dockerfile.clearlinux Dockerfile: remove security by-pass in Clear Linux Dockerfile 2018-07-11 21:35:31 +08:00
Dockerfile.debian8 Dockerfiles: add Python3 and kconfiglib build dependency 2018-06-25 17:30:30 +08:00
Dockerfile.fedora26 Dockerfiles: add Python3 and kconfiglib build dependency 2018-06-25 17:30:30 +08:00
Dockerfile.fedora27 Dockerfiles: add Python3 and kconfiglib build dependency 2018-06-25 17:30:30 +08:00
Dockerfile.fedora28 Dockerfiles: add Python3 and kconfiglib build dependency 2018-06-25 17:30:30 +08:00
Dockerfile.ubuntu14.04 Dockerfiles: add Python3 and kconfiglib build dependency 2018-06-25 17:30:30 +08:00
Dockerfile.ubuntu16.04 Dockerfile: update Ubuntu 16.04 Dockerfile to include all deps 2019-05-10 15:41:43 +08:00
Dockerfile.ubuntu18.04 Dockerfiles: add Python3 and kconfiglib build dependency 2018-06-25 17:30:30 +08:00
README.md Dockerfiles: add Python3 and kconfiglib build dependency 2018-06-25 17:30:30 +08:00

README.md

Build containers for Project ACRN

Introduction

This folder contains a number of Dockerfile that include all the build tools and dependencies to build the ACRN Project components, i.e. the hypervisor, devicemodel and tools

The workflow is pretty simple and can be summarized in these few steps:

  1. Build the build containers based on your preferred OS
  2. Clone the Project ACRN repository
  3. Start the build container and give it the repository
  4. Build the Project ACRN components

The pre-requisite is that you have Docker installed on your machine. Explaining how to install it on your system is beyond the scope of this document, please visit https://www.docker.com for detailed instructions.

Build the build containers

Each Dockerfile in this repo has an extension that tells what Linux distribution it is based on. To build a container using any of those, use this command:

$ sudo docker build -t <container-name> -f Dockerfile.<baseos> .

As an example, to build a container based on CentOS 7, do:

$ sudo docker build -t centos7 -f Dockerfile.centos7 .

Clone Project ACRN

Follow these simple steps to clone the Project ACRN repositories

$ mkdir ~/acrn
$ cd ~/acrn
$ git clone https://github.com/projectacrn/acrn-hypervisor

Start the build container

Use this ~/acrn/acrn-hypervisor folder and pass it on to your build container:

$ cd ~/acrn/acrn-hypervisor
$ sudo docker run -ti -v $PWD:/root/acrn <container-name>

Using CentOS 7 again as an example, that gives us:

$ cd ~/acrn/acrn-hypervisor
$ sudo docker run -ti -v $PWD:/root/acrn centos7

Note: if you encounter permission issues within the container (as it happens on a Fedora 27 host), try adding the :z parameter to the mount option. This will unlock the permission restriction (that comes from SElinux). Your command-line would then be:

$ cd ~/acrn/acrn-hypervisor
$ sudo docker run -ti -v $PWD:/root/acrn:z centos7

Build the ACRN components

The steps above place you inside the container and give you access to the Project ACRN repository you cloned earlier. You can now build any of the components. Here are a few examples:

# make hypervisor PLATFORM=uefi
# make devicemodel
# make tools

If you want to build it all, simply do:

# make PLATFORM=uefi

You can do this for all build combinations. All the build dependencies and tools are pre-installed in the container as well as a couple of useful tools (git and vim) so you can directly edit files to experiment from within the container.

The tools to build the ACRN documentation is (still) missing from these containers.