summaryrefslogtreecommitdiff
path: root/scripts/package
diff options
context:
space:
mode:
authorTheodore Ts'o <tytso@mit.edu>2010-12-24 09:42:10 -0500
committerMichal Marek <mmarek@suse.cz>2010-12-29 13:54:49 +0100
commitcd8d60a20a4516016c117ac0f1ac7b06ff606f7e (patch)
treeb9a898f3044d33b0b70d945970e153e00c80c054 /scripts/package
parent55f88eccf9c288eed2f93f9ca7d7fe4dd2da762e (diff)
downloadkernel-common-cd8d60a20a4516016c117ac0f1ac7b06ff606f7e.tar.gz
kernel-common-cd8d60a20a4516016c117ac0f1ac7b06ff606f7e.tar.bz2
kernel-common-cd8d60a20a4516016c117ac0f1ac7b06ff606f7e.zip
kbuild: create linux-headers package in deb-pkg
Create a linux-headers-$KVER.deb package which can be used to build external modules without having the source tree around. Signed-off-by: "Theodore Ts'o" <tytso@mit.edu> Signed-off-by: Michal Marek <mmarek@suse.cz>
Diffstat (limited to 'scripts/package')
-rw-r--r--scripts/package/builddeb28
1 files changed, 27 insertions, 1 deletions
diff --git a/scripts/package/builddeb b/scripts/package/builddeb
index ffe24194b763..5fc1e6f71838 100644
--- a/scripts/package/builddeb
+++ b/scripts/package/builddeb
@@ -76,15 +76,17 @@ else
fi
tmpdir="$objtree/debian/tmp"
fwdir="$objtree/debian/fwtmp"
+hdrdir="$objtree/debian/hdrtmp"
packagename=linux-image-$version
fwpackagename=linux-firmware-image
+hdrpackagename=linux-headers-$version
if [ "$ARCH" = "um" ] ; then
packagename=user-mode-linux-$version
fi
# Setup the directory structure
-rm -rf "$tmpdir" "$fwdir"
+rm -rf "$tmpdir" "$fwdir" "$hdrdir"
mkdir -m 755 -p "$tmpdir/DEBIAN"
mkdir -p "$tmpdir/lib" "$tmpdir/boot" "$tmpdir/usr/share/doc/$packagename"
mkdir -m 755 -p "$fwdir/DEBIAN"
@@ -226,6 +228,30 @@ EOF
fi
+# Build header package
+find . -name Makefile -o -name Kconfig\* -o -name \*.pl > /tmp/files$$
+find arch/x86/include include scripts -type f >> /tmp/files$$
+(cd $objtree; find .config Module.symvers include scripts -type f >> /tmp/objfiles$$)
+destdir=$hdrdir/usr/src/linux-headers-$version
+mkdir -p "$destdir" "$hdrdir/DEBIAN" "$hdrdir/usr/share/doc/$hdrpackagename"
+tar -c -f - -T /tmp/files$$ | (cd $destdir; tar -xf -)
+(cd $objtree; tar -c -f - -T /tmp/objfiles$$) | (cd $destdir; tar -xf -)
+rm -f /tmp/files$$ /tmp/objfiles$$
+arch=$(dpkg --print-architecture)
+
+cat <<EOF >> debian/control
+
+Package: $hdrpackagename
+Provides: linux-headers, linux-headers-2.6
+Architecture: $arch
+Description: Linux kernel headers for $KERNELRELEASE on $arch
+ This package provides kernel header files for $KERNELRELEASE on $arch
+ .
+ This is useful for people who need to build external modules
+EOF
+
+create_package "$hdrpackagename" "$hdrdir"
+
# Do we have firmware? Move it out of the way and build it into a package.
if [ -e "$tmpdir/lib/firmware" ]; then
mv "$tmpdir/lib/firmware" "$fwdir/lib/"