summaryrefslogtreecommitdiff
path: root/util/docker
diff options
context:
space:
mode:
authorMartin Roth <martinroth@google.com>2016-08-31 21:26:17 -0600
committerMartin Roth <martinroth@google.com>2016-12-12 17:52:57 +0100
commitcbaab7ee3cf1080a98fe376564e5aadfe169c1d6 (patch)
tree7c95e362d6a6a1705e7b86e5df8c9d97b2ae8ed5 /util/docker
parenta0f6f9bdbc609e60b64a9d1551006c4cffedc977 (diff)
downloadcoreboot-cbaab7ee3cf1080a98fe376564e5aadfe169c1d6.tar.xz
util/docker: Add a makefile for common docker tasks
Commands for working with docker images: build-coreboot-sdk - Build coreboot-sdk container upload-coreboot-sdk - Upload coreboot-sdk to hub.docker.com build-coreboot-jenkins-node - Build coreboot-jenkins-node container upload-coreboot-jenkins-node - Upload coreboot-jenkins-node to hub.docker.com clean_coreboot_containers - remove all docker coreboot containers clean_coreboot_images - remove all docker coreboot images Commands for using docker images docker_build_coreboot <BUILD_CMD=target> - Build coreboot under coreboot-sdk docker_abuild <ABUILD_ARGS='-a -B'> - Run abuild under coreboot-sdk Change-Id: I3a75b0615747d32f593948f53eab076f303271bf Signed-off-by: Martin Roth <martinroth@google.com> Reviewed-on: https://review.coreboot.org/16388 Tested-by: build bot (Jenkins) Reviewed-by: Philipp Deppenwiese <zaolin.daisuki@googlemail.com> Reviewed-by: Patrick Georgi <pgeorgi@google.com>
Diffstat (limited to 'util/docker')
-rw-r--r--util/docker/Makefile87
1 files changed, 87 insertions, 0 deletions
diff --git a/util/docker/Makefile b/util/docker/Makefile
new file mode 100644
index 0000000000..45e23b0091
--- /dev/null
+++ b/util/docker/Makefile
@@ -0,0 +1,87 @@
+##
+## This file is part of the coreboot project.
+##
+## Copyright (C) 2016 Google, Inc.
+##
+## This program is free software; you can redistribute it and/or modify
+## it under the terms of the GNU General Public License as published by
+## the Free Software Foundation; version 2 of the License.
+##
+## This program is distributed in the hope that it will be useful,
+## but WITHOUT ANY WARRANTY; without even the implied warranty of
+## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+## GNU General Public License for more details.
+##
+export top=$(abspath $(CURDIR)/../..)
+export crossgcc_version=$(shell $(top)/util/crossgcc/buildgcc --version | grep 'cross toolchain' | sed 's/^.*\sv//' | sed 's/\s.*$$//')
+export DOCKER:=$(shell env sh -c "command -v docker")
+
+test_docker:
+ $(if $(DOCKER),,\
+ $(warning Docker command not found. Please install docker) \
+ $(warning https://docs.docker.com/engine/installation ) \
+ $(error halting))
+
+test_docker_login: test_docker
+ $(if $(shell if [ ! -f ~/.docker/config.json ]; then \
+ echo "docker authentication file not found"; fi), \
+ $(error Docker authentication file not found. Run 'docker login'))
+
+coreboot-sdk: test_docker
+ $(DOCKER) build -t coreboot/coreboot-sdk:$(crossgcc_version) coreboot-sdk
+
+upload-coreboot-sdk: test_docker_login
+ $(DOCKER) push coreboot/coreboot-sdk:$(crossgcc_version)
+
+coreboot-jenkins-node: test_docker
+ $(DOCKER) build -t coreboot/coreboot-jenkins-node:$(crossgcc_version) coreboot-jenkins-node
+
+upload-coreboot-jenkins-node: test_docker_login
+ $(DOCKER) push coreboot/coreboot-jenkins-node:$(crossgcc_version)
+
+clean_coreboot_containers: test_docker
+ $(DOCKER) rm $(docker ps -a | grep 'coreboot' | sed 's|\s.*$||')
+
+clean_coreboot_images: test_docker
+ $(DOCKER) rmi $(docker images | grep coreboot | sed 's|^\S\+\s\+\S\+\s\+||' | sed 's|\s.*$||')
+
+docker_build_coreboot: test_docker
+
+ $(DOCKER) run -u root -it -v $(top):/home/coreboot/coreboot \
+ --rm coreboot/coreboot-sdk:$(crossgcc_version) \
+ /bin/bash -c "cd /home/coreboot/coreboot && \
+ make clean && \
+ make $(BUILD_CMD)"
+ @echo "Enter root password to chown files to $$(whoami):$$(id -gn $$(whoami))"
+ @echo "Exiting now will leave built files owned by root"
+ sudo chown -R $$(whoami):$$(id -gn $$(whoami)) $(top)
+
+docker_abuild: test_docker
+ $(DOCKER) run -u root -it -v $(top):/home/coreboot/coreboot \
+ --rm coreboot/coreboot-sdk:$(crossgcc_version) \
+ /bin/bash -c "cd /home/coreboot/coreboot && \
+ make clean && \
+ util/abuild/abuild $(ABUILD_ARGS)"
+ @echo "Enter root password to chown files to $$(whoami):$$(id -gn $$(whoami))"
+ @echo "Exiting now will leave built files owned by root"
+ sudo chown -R $$(whoami):$$(id -gn $$(whoami)) $(top)
+
+help:
+ @echo "Commands for working with docker images:"
+ @echo " build-coreboot-sdk - Build coreboot-sdk container"
+ @echo " upload-coreboot-sdk - Upload coreboot-sdk to hub.docker.com"
+ @echo " build-coreboot-jenkins-node - Build coreboot-jenkins-node container"
+ @echo " upload-coreboot-jenkins-node - Upload coreboot-jenkins-node to hub.docker.com"
+ @echo " clean_coreboot_containers - remove all docker coreboot containers"
+ @echo " clean_coreboot_images - remove all docker coreboot images"
+ @echo
+ @echo "Commands for using docker images"
+ @echo " docker_build_coreboot <BUILD_CMD=target> - Build coreboot under coreboot-sdk"
+ @echo " docker_abuild <ABUILD_ARGS='-a -B'> - Run abuild under coreboot-sdk"
+
+.PHONY: test_docker test_docker_login help
+.PHONY: build-coreboot-jenkins-node upload-coreboot-jenkins-node
+.PHONY: build-coreboot-sdk upload-coreboot-sdk
+.PHONY: clean_coreboot_containers clean_coreboot_images
+.PHONY: docker_build_coreboot docker_abuild
+.PHONY: help \ No newline at end of file