diff options
author | Martin Roth <martinroth@google.com> | 2016-08-31 21:26:17 -0600 |
---|---|---|
committer | Martin Roth <martinroth@google.com> | 2016-12-12 17:52:57 +0100 |
commit | cbaab7ee3cf1080a98fe376564e5aadfe169c1d6 (patch) | |
tree | 7c95e362d6a6a1705e7b86e5df8c9d97b2ae8ed5 | |
parent | a0f6f9bdbc609e60b64a9d1551006c4cffedc977 (diff) |
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>
-rw-r--r-- | util/docker/Makefile | 87 |
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 |