From ad06dc009b0e1aee8f1ce7530d5f285d5bf3310b Mon Sep 17 00:00:00 2001 From: Tim Deegan Date: Mon, 16 May 2011 13:34:25 +0100 Subject: Build target to wrap dist/install in a .deb archive. Adds "make deb", which does a "make dist" build and wraps the resulting dist/install files in dist/xen-.deb This is _not_ a "packaged" version of Xen for Debian users, nor is it intended to compete with anyone else's packaging efforts. In particular it doesn't do any of the boot-time or fstab fixups needed to actually start the xen tools. It's just a quick hack for developers to be able to quickly install and uninstall a Xen build on a test box. Signed-off-by: Tim Deegan --- Makefile | 5 +++++ tools/misc/mkdeb | 56 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ xen/Makefile | 4 ++++ 3 files changed, 65 insertions(+) create mode 100644 tools/misc/mkdeb diff --git a/Makefile b/Makefile index 662e31f549..9f1e3c4af1 100644 --- a/Makefile +++ b/Makefile @@ -118,6 +118,11 @@ world: $(MAKE) kdelete $(MAKE) dist +# Package a build in a .deb file +.PHONY: deb +deb: dist + fakeroot sh ./tools/misc/mkdeb $(XEN_ROOT) $$($(MAKE) -C xen xenversion | grep -v :) + # clean doesn't do a kclean .PHONY: clean clean:: diff --git a/tools/misc/mkdeb b/tools/misc/mkdeb new file mode 100644 index 0000000000..603cd6baa8 --- /dev/null +++ b/tools/misc/mkdeb @@ -0,0 +1,56 @@ +#!/bin/sh +# +# mkdeb: package the dist/install output of a Xen build in a .deb +# +# Takes 2 arguments, the path to the dist directory and the version + +set -e + +if test -z "$1" -o -z "$2" ; then + echo "usage: $0 path-to-XEN_ROOT xen-version" + exit 1 +fi + +cd $1 +version=$2 +if test "$XEN_TARGET_ARCH" = "x86_32"; then + arch=i386 +else + arch=amd64 +fi + +# Prepare the directory to package +cd dist +rm -rf deb +cp -a install deb + +# Debian doesn't use /usr/lib64 for 64-bit libraries +if test -d deb/usr/lib64 ; then + cp -a deb/usr/lib64/* deb/usr/lib/ + rm -rf deb/usr/lib64 +fi + +# Fill in the debian boilerplate +mkdir -p deb/DEBIAN +cat >deb/DEBIAN/control <