* debian/bin/install-image: Remove.
* debian/rules.real - Use bash. - Add logic to build flavour header package. - Fix generic headers package. svn path=/dists/trunk/linux-2.6/; revision=5824
This commit is contained in:
parent
e550ad4272
commit
d2e3e4638e
|
@ -1,154 +0,0 @@
|
||||||
#!/bin/bash
|
|
||||||
#
|
|
||||||
# This is the hook file executed by make-kpkg in the end of creation
|
|
||||||
# of the linux-image for a particular flavour. The major task it performs
|
|
||||||
# is the creation of the flavour-specific linux-headers package.
|
|
||||||
#
|
|
||||||
set -e
|
|
||||||
|
|
||||||
debhelper_pre() {
|
|
||||||
dh_clean -k --package="$1"
|
|
||||||
dh_installdirs --package="$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
debhelper_post() {
|
|
||||||
dh_installdocs --package="$1"
|
|
||||||
dh_installchangelogs --package="$1"
|
|
||||||
dh_compress --package="$1"
|
|
||||||
dh_fixperms --package="$1"
|
|
||||||
dh_strip --package="$1"
|
|
||||||
dh_installdeb --package="$1"
|
|
||||||
dh_gencontrol --package="$1"
|
|
||||||
dh_md5sums --package="$1"
|
|
||||||
dh_builddeb --package="$1"
|
|
||||||
}
|
|
||||||
# The version which ends up here is something like
|
|
||||||
# $(version)-$(abiname)-$(flavour) and debnum is just
|
|
||||||
# -$(abiname), so that the variables get the values:
|
|
||||||
# suffix=$(flavour)
|
|
||||||
# prefix=$(version)-$(abiname)
|
|
||||||
# prefix is then used to form a destination directory
|
|
||||||
# to link to. For cases with subarch we need to link
|
|
||||||
# to linux-headers-$(subarch)-$(version)-$(abiname),
|
|
||||||
# not just linux-headers-$(version)-$(abiname).
|
|
||||||
#
|
|
||||||
prefix="$DEBIAN_VERSION$DEBIAN_LOCALVERSION_HEADERS"
|
|
||||||
pkg="linux-headers-$DEBIAN_VERSION$DEBIAN_LOCALVERSION"
|
|
||||||
top="$PWD/debian/$pkg"
|
|
||||||
dir="$top/usr/src/$pkg"
|
|
||||||
#
|
|
||||||
# Here we need to find the kernel architecture which
|
|
||||||
# is appropriate for the current flavour. It is available
|
|
||||||
# in kernel-package as KERNEL_ARCH. Cleanest way is to get
|
|
||||||
# make-kpkg export it to this script.
|
|
||||||
#
|
|
||||||
# Currently we just use the fact that in the build directory
|
|
||||||
# the symlink include/asm must point to include/asm-${arch}
|
|
||||||
#
|
|
||||||
arch="$(readlink include/asm)"
|
|
||||||
arch="$(basename "${arch}")"
|
|
||||||
arch="${arch#asm-}"
|
|
||||||
|
|
||||||
debhelper_pre "$pkg"
|
|
||||||
|
|
||||||
#
|
|
||||||
# Stuff below is ugly as hell, but does the trick so I'm not
|
|
||||||
# touching it until we can invent something better.
|
|
||||||
#
|
|
||||||
mkdir -p "$dir/arch/$arch/kernel"
|
|
||||||
mkdir -p "$dir/include/linux"
|
|
||||||
cp -a .config "$dir"
|
|
||||||
echo "$DEBIAN_LOCALVERSION" > "$dir/localversion"
|
|
||||||
|
|
||||||
cp -a Module.symvers "$dir"
|
|
||||||
|
|
||||||
find . -mindepth 1 -maxdepth 1 \
|
|
||||||
! -name debian -a ! -name Documentation -a ! -name include -a \
|
|
||||||
! -name DEBIAN -a ! -name scripts -a ! -name arch -a ! -name '.*' -a \( \
|
|
||||||
-name Makefile -o -type d \) \
|
|
||||||
-printf "../linux-headers-$prefix/%f\n" |
|
|
||||||
xargs ln -s --target-directory="$dir"
|
|
||||||
|
|
||||||
find "arch/$arch" -mindepth 1 -maxdepth 1 \( \
|
|
||||||
-type d -a ! -name include -a ! -name kernel -o \
|
|
||||||
-type f -a \( -name 'Makefile*' -o -name 'Kconfig*' \) \) \
|
|
||||||
-printf "../../../linux-headers-$prefix/%p\n" |
|
|
||||||
xargs ln -s --target-directory="$dir/arch/$arch"
|
|
||||||
if [ -d arch/$arch/include ]; then
|
|
||||||
cp -a arch/$arch/include $dir/arch/$arch/include
|
|
||||||
fi
|
|
||||||
[ -f "arch/$arch/kernel/asm-offsets.s" ] && ln -f "arch/$arch/kernel/asm-offsets.s" "$dir/arch/$arch/kernel"
|
|
||||||
ln -s "../../../../linux-headers-$prefix/arch/$arch/kernel/Makefile" "$dir/arch/$arch/kernel"
|
|
||||||
find include -mindepth 1 -maxdepth 1 \
|
|
||||||
! -name config -a ! -name linux -a ! -name 'asm-*' \
|
|
||||||
-printf "../../linux-headers-$prefix/%p\n" |
|
|
||||||
xargs ln -s --target-directory="$dir/include"
|
|
||||||
cp -a include/config "$dir/include"
|
|
||||||
|
|
||||||
ln -sf "asm-${arch}" "$dir/include/asm"
|
|
||||||
for i in generic $KERNEL_HEADER_DIRS; do
|
|
||||||
mkdir "$dir/include/asm-$i"
|
|
||||||
find "include/asm-$i" -mindepth 1 -maxdepth 1 \
|
|
||||||
\( -type f -a ! -links 2 -o ! -type f \) \
|
|
||||||
-printf "../../../linux-headers-$prefix/%p\n" |
|
|
||||||
xargs --no-run-if-empty ln -s --target-directory="$dir/include/asm-$i"
|
|
||||||
find "include/asm-$i" -mindepth 1 -maxdepth 1 \
|
|
||||||
-type f -links 2 |
|
|
||||||
xargs --no-run-if-empty ln -f --target-directory="$dir/include/asm-$i"
|
|
||||||
done
|
|
||||||
|
|
||||||
find include/linux -mindepth 1 -maxdepth 1 \
|
|
||||||
! -name autoconf.h -a ! -name compile.h -a ! -name version.h \
|
|
||||||
-printf "../../../linux-headers-$prefix/%p\n" |
|
|
||||||
xargs ln -s --target-directory="$dir/include/linux"
|
|
||||||
cp -a include/linux/autoconf.h include/linux/compile.h \
|
|
||||||
include/linux/version.h "$dir/include/linux"
|
|
||||||
|
|
||||||
mkdir -p "$top/lib/modules/$version"
|
|
||||||
ln -s "/usr/src/linux-headers-$version" "$top/lib/modules/$version/build"
|
|
||||||
|
|
||||||
# Populate the scripts directory. The strategy here is to specify what
|
|
||||||
# *not* to copy, to make things a little bit more robust. We first create
|
|
||||||
# a file with exclude patterns, then copy everything minus excluded files.
|
|
||||||
#
|
|
||||||
cat > scripts-exclude <<EXCLUDES
|
|
||||||
*.c
|
|
||||||
*.c_shipped
|
|
||||||
*.h
|
|
||||||
*.y
|
|
||||||
*.l
|
|
||||||
*.gperf
|
|
||||||
*POTFILES.in
|
|
||||||
*.gitignore
|
|
||||||
*lxdialog*
|
|
||||||
*package*
|
|
||||||
EXCLUDES
|
|
||||||
tar cfh - -X scripts-exclude scripts | (cd "$dir"; umask 000; tar xsf -)
|
|
||||||
rm -f script-exclude
|
|
||||||
|
|
||||||
debhelper_post "$pkg"
|
|
||||||
|
|
||||||
#
|
|
||||||
# Check whether we should force any modules to be available
|
|
||||||
# on the initrd.
|
|
||||||
#
|
|
||||||
cd "${IMAGE_TOP}/lib/modules/${version}"
|
|
||||||
modules='@initrd_modules@'
|
|
||||||
if [ -n "${modules}" ]; then
|
|
||||||
mkdir initrd
|
|
||||||
for i in ${modules}; do
|
|
||||||
if [ -f "${i}" ]; then
|
|
||||||
ln "${i}" initrd
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
#
|
|
||||||
# Clean up the build and source symlinks
|
|
||||||
#
|
|
||||||
if [ -L build ]; then
|
|
||||||
rm -f build
|
|
||||||
fi
|
|
||||||
if [ -L source ]; then
|
|
||||||
rm -f source
|
|
||||||
fi
|
|
|
@ -5,12 +5,13 @@
|
||||||
# Additionally, variables version, abiname and ltver are
|
# Additionally, variables version, abiname and ltver are
|
||||||
# expected to be available (need to be exported from the parent process).
|
# expected to be available (need to be exported from the parent process).
|
||||||
#
|
#
|
||||||
SHELL := sh -e
|
SHELL := bash -e
|
||||||
DEB_HOST_ARCH := $(shell dpkg-architecture -a'$(ARCH)' -qDEB_HOST_ARCH)
|
DEB_HOST_ARCH := $(shell dpkg-architecture -a'$(ARCH)' -qDEB_HOST_ARCH)
|
||||||
DEB_HOST_GNU_TYPE := $(shell dpkg-architecture -a'$(ARCH)' -qDEB_HOST_GNU_TYPE)
|
DEB_HOST_GNU_TYPE := $(shell dpkg-architecture -a'$(ARCH)' -qDEB_HOST_GNU_TYPE)
|
||||||
DEB_BUILD_ARCH := $(shell dpkg-architecture -a'$(ARCH)' -qDEB_BUILD_ARCH)
|
DEB_BUILD_ARCH := $(shell dpkg-architecture -a'$(ARCH)' -qDEB_BUILD_ARCH)
|
||||||
|
|
||||||
export PYTHONPATH = $(CURDIR)/debian/lib/python
|
export PYTHONPATH = $(CURDIR)/debian/lib/python
|
||||||
|
export DH_OPTIONS
|
||||||
|
|
||||||
#
|
#
|
||||||
# Build the list of common config files to be included
|
# Build the list of common config files to be included
|
||||||
|
@ -56,7 +57,7 @@ setup_env += MAKEFLAGS='$(setup_makeflags)'
|
||||||
# Targets
|
# Targets
|
||||||
#
|
#
|
||||||
binary-arch-subarch: install-header-$(ARCH)-$(SUBARCH)
|
binary-arch-subarch: install-header-$(ARCH)-$(SUBARCH)
|
||||||
binary-arch-flavour: install-image-$(ARCH)-$(SUBARCH)-$(FLAVOUR)
|
binary-arch-flavour: install-image-$(ARCH)-$(SUBARCH)-$(FLAVOUR) install-header-$(ARCH)-$(SUBARCH)-$(FLAVOUR)
|
||||||
|
|
||||||
binary-indep: install-doc install-patch install-source install-tree
|
binary-indep: install-doc install-patch install-source install-tree
|
||||||
|
|
||||||
|
@ -181,10 +182,9 @@ install-dummy:
|
||||||
|
|
||||||
install-image-$(ARCH)-$(SUBARCH)-$(FLAVOUR): SOURCE_DIR=$(BUILD_DIR)/build-$(ARCH)-$(SUBARCH)-$(FLAVOUR)
|
install-image-$(ARCH)-$(SUBARCH)-$(FLAVOUR): SOURCE_DIR=$(BUILD_DIR)/build-$(ARCH)-$(SUBARCH)-$(FLAVOUR)
|
||||||
install-image-$(ARCH)-$(SUBARCH)-$(FLAVOUR): DIR=$(BUILD_DIR)/$@
|
install-image-$(ARCH)-$(SUBARCH)-$(FLAVOUR): DIR=$(BUILD_DIR)/$@
|
||||||
install-image-$(ARCH)-$(SUBARCH)-$(FLAVOUR): $(STAMPS_DIR)/build-$(ARCH)-$(SUBARCH)-$(FLAVOUR) debian/bin/install-image
|
install-image-$(ARCH)-$(SUBARCH)-$(FLAVOUR): $(STAMPS_DIR)/build-$(ARCH)-$(SUBARCH)-$(FLAVOUR)
|
||||||
rm -rf '$(DIR)'
|
rm -rf '$(DIR)'
|
||||||
cp -al '$(SOURCE_DIR)' '$(DIR)'
|
cp -al '$(SOURCE_DIR)' '$(DIR)'
|
||||||
install debian/bin/install-image '$(DIR)/debian/post-install'
|
|
||||||
cd '$(DIR)'; $(setup_env) $(kpkg_image) kernel-image
|
cd '$(DIR)'; $(setup_env) $(kpkg_image) kernel-image
|
||||||
cat '$(DIR)/debian/files' >> debian/files
|
cat '$(DIR)/debian/files' >> debian/files
|
||||||
ifdef IMAGE_POSTPROC
|
ifdef IMAGE_POSTPROC
|
||||||
|
@ -197,7 +197,7 @@ endif
|
||||||
rm -rf '$(DIR)'
|
rm -rf '$(DIR)'
|
||||||
|
|
||||||
install-header-$(ARCH)-$(SUBARCH): PACKAGE_NAME = linux-headers-$(VERSION)-$(ABINAME)$(LOCALVERSION_HEADERS)
|
install-header-$(ARCH)-$(SUBARCH): PACKAGE_NAME = linux-headers-$(VERSION)-$(ABINAME)$(LOCALVERSION_HEADERS)
|
||||||
install-header-$(ARCH)-$(SUBARCH): export DH_OPTIONS = -p$(PACKAGE_NAME)
|
install-header-$(ARCH)-$(SUBARCH): DH_OPTIONS = -p$(PACKAGE_NAME)
|
||||||
install-header-$(ARCH)-$(SUBARCH): BASE_DIR = /usr/src/$(PACKAGE_NAME)
|
install-header-$(ARCH)-$(SUBARCH): BASE_DIR = /usr/src/$(PACKAGE_NAME)
|
||||||
install-header-$(ARCH)-$(SUBARCH): SOURCE_DIR = $(BUILD_DIR)/source-$(ARCH)-$(SUBARCH)
|
install-header-$(ARCH)-$(SUBARCH): SOURCE_DIR = $(BUILD_DIR)/source-$(ARCH)-$(SUBARCH)
|
||||||
install-header-$(ARCH)-$(SUBARCH): DIR = $(CURDIR)/debian/$(PACKAGE_NAME)/$(BASE_DIR)
|
install-header-$(ARCH)-$(SUBARCH): DIR = $(CURDIR)/debian/$(PACKAGE_NAME)/$(BASE_DIR)
|
||||||
|
@ -212,8 +212,9 @@ install-header-$(ARCH)-$(SUBARCH): $(STAMPS_DIR)/source-$(ARCH)-$(SUBARCH)
|
||||||
-path './arch/*' -prune -o \
|
-path './arch/*' -prune -o \
|
||||||
-path './include/asm*' -prune -o \
|
-path './include/asm*' -prune -o \
|
||||||
-path './scripts/*' -prune -o \
|
-path './scripts/*' -prune -o \
|
||||||
-path './include/' -o \
|
-path './include/*' -print -o \
|
||||||
\( -name 'Makefile*' -o -name 'Kconfig*' -o -name 'Rules.make' \) -print; \
|
\( -name 'Makefile*' -o -name 'Kconfig*' -o -name 'Rules.make' \) -print; \
|
||||||
|
find include/asm-generic -print; \
|
||||||
for i in $(KERNEL_HEADER_DIRS); do \
|
for i in $(KERNEL_HEADER_DIRS); do \
|
||||||
find arch/$$i \
|
find arch/$$i \
|
||||||
\( -name 'Makefile*' -o -name 'Kconfig*' -o -name 'Rules.make' \) -print; \
|
\( -name 'Makefile*' -o -name 'Kconfig*' -o -name 'Rules.make' \) -print; \
|
||||||
|
@ -224,6 +225,79 @@ install-header-$(ARCH)-$(SUBARCH): $(STAMPS_DIR)/source-$(ARCH)-$(SUBARCH)
|
||||||
cpio -pd --preserve-modification-time $(DIR)
|
cpio -pd --preserve-modification-time $(DIR)
|
||||||
$(MAKE) -f debian/rules.real install-base
|
$(MAKE) -f debian/rules.real install-base
|
||||||
|
|
||||||
|
install-header-$(ARCH)-$(SUBARCH)-$(FLAVOUR): PACKAGE_NAME = linux-headers-$(VERSION)-$(ABINAME)$(LOCALVERSION)
|
||||||
|
install-header-$(ARCH)-$(SUBARCH)-$(FLAVOUR): PACKAGE_NAME_HEADERS = linux-headers-$(VERSION)-$(ABINAME)$(LOCALVERSION_HEADERS)
|
||||||
|
install-header-$(ARCH)-$(SUBARCH)-$(FLAVOUR): DH_OPTIONS = -p$(PACKAGE_NAME)
|
||||||
|
install-header-$(ARCH)-$(SUBARCH)-$(FLAVOUR): BASE_DIR = /usr/src/$(PACKAGE_NAME)
|
||||||
|
install-header-$(ARCH)-$(SUBARCH)-$(FLAVOUR): SOURCE_DIR = $(BUILD_DIR)/build-$(ARCH)-$(SUBARCH)-$(FLAVOUR)
|
||||||
|
install-header-$(ARCH)-$(SUBARCH)-$(FLAVOUR): REF_DIR = $(BUILD_DIR)/source-$(ARCH)-$(SUBARCH)
|
||||||
|
install-header-$(ARCH)-$(SUBARCH)-$(FLAVOUR): PACKAGE_DIR = $(CURDIR)/debian/$(PACKAGE_NAME)
|
||||||
|
install-header-$(ARCH)-$(SUBARCH)-$(FLAVOUR): DIR = $(PACKAGE_DIR)/$(BASE_DIR)
|
||||||
|
install-header-$(ARCH)-$(SUBARCH)-$(FLAVOUR): $(STAMPS_DIR)/build-$(ARCH)-$(SUBARCH)-$(FLAVOUR)
|
||||||
|
dh_testdir
|
||||||
|
dh_testroot
|
||||||
|
dh_clean -k -d
|
||||||
|
|
||||||
|
mkdir -p "${DIR}/arch/${KERNEL_ARCH}/kernel"
|
||||||
|
mkdir -p "${DIR}/include"
|
||||||
|
cp -a ${SOURCE_DIR}/{.config,Module.symvers} "${DIR}"
|
||||||
|
echo ${DEBIAN_LOCALVERSION} > "${DIR}/localversion"
|
||||||
|
|
||||||
|
cd ${SOURCE_DIR}; \
|
||||||
|
find . -mindepth 1 -maxdepth 1 \
|
||||||
|
! -name debian -a ! -name Documentation -a ! -name include -a \
|
||||||
|
! -name DEBIAN -a ! -name scripts -a ! -name arch -a ! -name '.*' -a \( \
|
||||||
|
-name Makefile -o -type d \) \
|
||||||
|
-printf "../${PACKAGE_NAME_HEADERS}/%f\n" | \
|
||||||
|
xargs ln -s --target-directory="${DIR}"
|
||||||
|
|
||||||
|
cd ${SOURCE_DIR}; \
|
||||||
|
find "arch/${KERNEL_ARCH}" -mindepth 1 -maxdepth 1 \( \
|
||||||
|
-type d -a ! -name include -a ! -name kernel -o \
|
||||||
|
-type f -a \( -name 'Makefile*' -o -name 'Kconfig*' \) \) \
|
||||||
|
-printf "../../../${PACKAGE_NAME_HEADERS}/%p\n" | \
|
||||||
|
xargs ln -s --target-directory="${DIR}/arch/${KERNEL_ARCH}"
|
||||||
|
|
||||||
|
[ -d "${SOURCE_DIR}/arch/${KERNEL_ARCH}/include" ] && \
|
||||||
|
cp -a "${SOURCE_DIR}/arch/${KERNEL_ARCH}/include" "${DIR}/arch/${KERNEL_ARCH}/include" || :
|
||||||
|
[ -f "${SOURCE_DIR}/arch/${KERNEL_ARCH}/kernel/asm-offsets.s" ] && \
|
||||||
|
ln -f "${SOURCE_DIR}/arch/${KERNEL_ARCH}/kernel/asm-offsets.s" "${DIR}/arch/${KERNEL_ARCH}/kernel" || :
|
||||||
|
ln -s "../../../../${PACKAGE_NAME_HEADERS}/arch/${KERNEL_ARCH}/kernel/Makefile" "${DIR}/arch/${KERNEL_ARCH}/kernel"
|
||||||
|
|
||||||
|
cd ${SOURCE_DIR}; \
|
||||||
|
find include -mindepth 1 -maxdepth 1 \
|
||||||
|
! -name config -a ! -name linux -a ! -name 'asm-*' \
|
||||||
|
-printf "../../${PACKAGE_NAME_HEADERS}/%p\n" | \
|
||||||
|
xargs ln -s --target-directory="${DIR}/include"
|
||||||
|
cp -a ${SOURCE_DIR}/include/config "${DIR}/include"
|
||||||
|
|
||||||
|
ln -sf "asm-${KERNEL_ARCH}" "${DIR}/include/asm"
|
||||||
|
|
||||||
|
cd ${SOURCE_DIR}; \
|
||||||
|
for dir in linux asm-generic $(foreach t, $(KERNEL_HEADER_DIRS), asm-$(t)); do \
|
||||||
|
mkdir "${DIR}/include/$$dir"; \
|
||||||
|
for file in $$(find "include/$$dir" -mindepth 1 -maxdepth 1); do \
|
||||||
|
if [ -e ${CURDIR}/${REF_DIR}/$$file ]; then \
|
||||||
|
ln -s --target-directory="${DIR}/include/$$dir" "../../../${PACKAGE_NAME_HEADERS}/${REF_DIR}/$$file"; \
|
||||||
|
elif [ -d ${CURDIR}/${SOURCE_DIR}/$$file ]; then \
|
||||||
|
cp -a "${CURDIR}/${SOURCE_DIR}/$$file" "${DIR}/include/$$dir"; \
|
||||||
|
else \
|
||||||
|
ln -f --target-directory="${DIR}/include/$$dir" "${CURDIR}/${SOURCE_DIR}/$$file"; \
|
||||||
|
fi \
|
||||||
|
done \
|
||||||
|
done
|
||||||
|
|
||||||
|
mkdir -p "${PACKAGE_DIR}/lib/modules/${UPSTREAM_VERSION}"
|
||||||
|
ln -s "/usr/src/${PACKAGE_NAME}" "${PACKAGE_DIR}/lib/modules/${UPSTREAM_VERSION}/build"
|
||||||
|
|
||||||
|
# Populate the scripts directory. The strategy here is to specify what
|
||||||
|
# *not* to copy, to make things a little bit more robust. We first create
|
||||||
|
# a file with exclude patterns, then copy everything minus excluded files.
|
||||||
|
#
|
||||||
|
tar $(foreach t, *.c *.h *.y *.l *.gperf *POTFILES.in .gitignore *lxdialog* *package* *.cc *.glade *_shipped, --exclude=$(t)) -chf - scripts | (cd "${DIR}"; umask 000; tar xsf -)
|
||||||
|
|
||||||
|
$(MAKE) -f debian/rules.real install-base
|
||||||
|
|
||||||
install-headers-all: DH_OPTIONS = -plinux-headers-$(VERSION)
|
install-headers-all: DH_OPTIONS = -plinux-headers-$(VERSION)
|
||||||
install-headers-all:
|
install-headers-all:
|
||||||
dh_testdir
|
dh_testdir
|
||||||
|
|
Loading…
Reference in New Issue