Subarch support added. README file is not updated
to reflect these changes yet. svn path=/branches/kernel-image-2.6.11/; revision=3146
This commit is contained in:
parent
d6e3ff9014
commit
f4e4f9aa53
|
@ -1,3 +0,0 @@
|
||||||
|
|
||||||
The current svn revisions are currently broken, while trying to implement
|
|
||||||
the subarch support. To do any testing please use revision 3136.
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
Major TODO items remaining:
|
||||||
|
|
||||||
|
* Patching mechanism: where are the debian and subarch-specific patches
|
||||||
|
going to be available and how they are going to be applied.
|
||||||
|
|
||||||
|
* Naming of the subarch-specific header packages. For that some magic
|
||||||
|
should be done in post-install.
|
||||||
|
|
||||||
|
* Looks like it would be optimal to have a common kernel-headers package
|
||||||
|
which would contain common headers for all arches without unmerged patches.
|
||||||
|
|
||||||
|
* Various remaining kludges (stripping and sparc32/sparc64 stuff on sparc,
|
||||||
|
for example).
|
|
@ -2,5 +2,5 @@
|
||||||
# Variables
|
# Variables
|
||||||
#
|
#
|
||||||
include_common_config := no
|
include_common_config := no
|
||||||
headers_extra := arch/i386/kernel/ams-offsets.s
|
headers_extra := arch/i386/kernel/asm-offsets.s
|
||||||
initrd_modules := kernel/drivers/video/vesafb.ko kernel/security/capability.ko
|
initrd_modules := kernel/drivers/video/vesafb.ko kernel/security/capability.ko
|
||||||
|
|
|
@ -4,213 +4,64 @@
|
||||||
#
|
#
|
||||||
version := 2.6.11
|
version := 2.6.11
|
||||||
abiname := 1
|
abiname := 1
|
||||||
ktver := 5
|
ktver := 4
|
||||||
kbuildver := 2.6-3
|
|
||||||
#
|
#
|
||||||
# Generally nothing needs to be modified below this line
|
# Generally nothing needs to be modified below this line
|
||||||
#
|
#
|
||||||
SHELL := sh -e
|
SHELL := sh -e
|
||||||
debver := $(version)-$(abiname)
|
kbpkg := kernel-kbuild-$(version)-$(abiname)
|
||||||
uver := $(subst .,_,$(version))
|
controls := $(wildcard arch/*/control.in arch/*/*/control.in)
|
||||||
debnum := -$(abiname)
|
karch := $(shell dpkg-architecture -qDEB_HOST_ARCH)
|
||||||
bpkg := kernel-build-$(debver)
|
|
||||||
kdir := kernel-source-$(version)
|
|
||||||
kbpkg := kernel-kbuild-$(kbuildver)
|
|
||||||
kpatch := /usr/src/kernel-patches/all/$(version)/apply/debian
|
|
||||||
DEBIAN_SRCTOP := $(CURDIR)/$(kdir)
|
|
||||||
DEBIAN_UPSTREAM_VERSION := $(version)
|
|
||||||
ifeq (,$(DEB_HOST_ARCH))
|
|
||||||
DEB_HOST_ARCH := $(shell dpkg-architecture -qDEB_HOST_ARCH)
|
|
||||||
DEB_BUILD_ARCH := $(shell dpkg-architecture -qDEB_BUILD_ARCH)
|
|
||||||
endif
|
|
||||||
export version debnum DEBIAN_SRCTOP DEBIAN_UPSTREAM_VERSION
|
|
||||||
#
|
#
|
||||||
# The CROSS variable is only used on sparc to call
|
# If we are not passed a subarchs variable, we obtain the complete
|
||||||
# the correct 'strip' binary on the kernel-image.
|
# subarch list as a list of subdirectories in arch/$(karch). We
|
||||||
# Not sure whether we really need it.
|
# also export the flavours variables, which allows to control which
|
||||||
#
|
# flavours are built.
|
||||||
ifneq ($(DEB_BUILD_ARCH),$(DEB_HOST_ARCH))
|
|
||||||
CROSS := $(DEB_HOST_ARCH)-linux-
|
|
||||||
endif
|
|
||||||
karch := $(DEB_HOST_ARCH)
|
|
||||||
controls := $(wildcard arch/*/control.in arch/*/*/control.in)
|
|
||||||
default := arch/$(karch)/config.default
|
|
||||||
configs := $(notdir $(wildcard arch/$(karch)/config.*))
|
|
||||||
configs := $(filter-out config.common config.default, $(configs))
|
|
||||||
#
|
|
||||||
# We can have different subarchs within the arch and different flavours
|
|
||||||
# within each subarch. We allow to override the choice of what to build
|
|
||||||
# via subarchs and flavours variables, so if they are defined, we leave
|
|
||||||
# them alone. Otherwise we get a list of subarchs as a list of subdirs
|
|
||||||
# in the arch/$(karch) directory.
|
|
||||||
#
|
#
|
||||||
ifndef subarchs
|
ifndef subarchs
|
||||||
subarchs := $(shell find arch/$(karch) \
|
subarchs := $(shell find arch/$(karch) \
|
||||||
-type d -mindepth 1 -maxdepth 1 \
|
-type d -mindepth 1 -maxdepth 1 \
|
||||||
! -name '.svn' -printf '%f\n')
|
! -name '.svn' -printf '%f\n')
|
||||||
endif
|
endif
|
||||||
ifeq ($(subarchs),)
|
ifeq (,$(subarchs))
|
||||||
subarchs := none
|
subarchs := none
|
||||||
endif
|
endif
|
||||||
ifndef flavours
|
|
||||||
flavours := $(patsubst config.%,%,$(configs))
|
|
||||||
endif
|
|
||||||
#
|
|
||||||
# Build the lists of the kernel and build dirs which need to be
|
|
||||||
# created based on the selected subarch and flavour values.
|
|
||||||
#
|
|
||||||
kdirs := $(addprefix $(kdir)-, $(subarchs))
|
|
||||||
bdirs := foreach(sub, $(subarchs), $(addprefix build-$(sub)-, $(flavours)))
|
|
||||||
|
|
||||||
-include arch/$(karch)/Makefile.inc
|
|
||||||
#
|
|
||||||
# Here we construct the command lines for different make-kpkg
|
|
||||||
# calls (build, kernel-image, kernel-headers) based on the values
|
|
||||||
# of variables defined so far and provided by the architecture
|
|
||||||
# in Makefile.inc. Note that $$i in these expressions is going to
|
|
||||||
# become a reference to the shell variable $i, which is expected
|
|
||||||
# to have the current flavour. This is slightly evil, but saves
|
|
||||||
# a lot of grief.
|
|
||||||
#
|
|
||||||
kpkg_headers_cmd := HEADER_CLEAN_HOOK='$(CURDIR)/header-install' make-kpkg
|
|
||||||
kpkg_headers_cmd += --append-to-version $(debnum)
|
|
||||||
kpkg_build_cmd := make-kpkg --append-to-version $(debnum)-$$i
|
|
||||||
ifdef added_patches
|
|
||||||
kpkg_headers_cmd += --added_patches $(subst @uver@,$(uver),$(added_patches))
|
|
||||||
kpkg_build_cmd += --added_patches $(subst @uver@,$(uver),$(added_patches))
|
|
||||||
endif
|
|
||||||
ifdef build_subarch
|
|
||||||
kpkg_build_cmd += --subarch $$i
|
|
||||||
endif
|
|
||||||
ifdef headers_subarch
|
|
||||||
kpkg_headers_cmd += --subarch $(headers_subarch)
|
|
||||||
endif
|
|
||||||
ifdef build_makeflags
|
|
||||||
kpkg_build_cmd := MAKEFLAGS=$(build_makeflags) $(kpkg_build_cmd)
|
|
||||||
endif
|
|
||||||
kpkg_image_cmd := $(kpkg_build_cmd) --initrd kernel_image
|
|
||||||
kpkg_build_cmd += build
|
|
||||||
kpkg_headers_cmd += kernel-headers
|
|
||||||
ifndef headers_dirs
|
|
||||||
headers_dirs = $(karch)
|
|
||||||
endif
|
|
||||||
|
|
||||||
all:
|
export version abiname ktver kbuildver flavours
|
||||||
echo "$(kdirs)"
|
|
||||||
#
|
|
||||||
# TODO:
|
|
||||||
# * Check that make oldconfig does not actually
|
|
||||||
# change the config file. If it does, something
|
|
||||||
# is wrong (missing/extra options, etc).
|
|
||||||
#
|
|
||||||
unpack: unpack-stamp
|
unpack: unpack-stamp
|
||||||
unpack-stamp: $(kdirs) $(configs) header-install
|
unpack-stamp:
|
||||||
for i in $(flavours); do \
|
dh_testdir
|
||||||
cp -al $(kdir) build-$$i; \
|
for i in $(subarchs); do \
|
||||||
cp config.$$i build-$$i/.config; \
|
$(MAKE) -f debian/rules.subarch subarch=$${i} unpack; \
|
||||||
make -C build-$$i ARCH=$(karch) oldconfig; \
|
|
||||||
done
|
done
|
||||||
ln -s $$(command -v touch) bin/touch.orig
|
ln -s $$(command -v touch) bin/touch.orig
|
||||||
touch unpack-stamp
|
touch unpack-stamp
|
||||||
#
|
|
||||||
# Problems:
|
|
||||||
# * m68k,mips have no-op build targets
|
|
||||||
# * sparc strips parts of the kernel after building
|
|
||||||
# otherwise it is too big for silo to boot.
|
|
||||||
# TODO:
|
|
||||||
# * Implement optional stripping of the kernel
|
|
||||||
# (for sparc).
|
|
||||||
# * Check that it is really ok to call --subarch
|
|
||||||
# with the name of the flavour. For mips which
|
|
||||||
# is another --subarch user it should be fine.
|
|
||||||
#
|
|
||||||
build: build-stamp
|
build: build-stamp
|
||||||
build-stamp: unpack-stamp
|
build-stamp: unpack-stamp
|
||||||
dh_testdir
|
dh_testdir
|
||||||
PATH=$$PWD/bin:$$PATH; \
|
for i in $(subarchs); do \
|
||||||
for i in $(flavours); do \
|
$(MAKE) -f debian/rules.subarch subarch=$${i} build; \
|
||||||
cd build-$$i; \
|
|
||||||
$(kpkg_build_cmd); \
|
|
||||||
cd ..; \
|
|
||||||
done
|
done
|
||||||
touch build-stamp
|
touch build-stamp
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
dh_testdir
|
dh_testdir
|
||||||
rm -f *-stamp header-install post-install config.*
|
rm -f *-stamp-* *-stamp config.*
|
||||||
rm -rf $(kdir) build-* install-* bin/touch.orig
|
rm -f header-install-* post-install bin/touch.orig
|
||||||
|
rm -rf kernel-source-* build-* install-*
|
||||||
dh_clean
|
dh_clean
|
||||||
#
|
|
||||||
# Problems:
|
|
||||||
# * Due to some reason i386 build runs some debhelper
|
|
||||||
# commands on the kernel-headers package, as if
|
|
||||||
# building it manually. I thought make-kpkg was supposed
|
|
||||||
# to take care of it.
|
|
||||||
#
|
|
||||||
binary-indep: build
|
binary-indep: build
|
||||||
#
|
|
||||||
# Problems:
|
|
||||||
# * sparc prepends the 'kernel-image' make-kpkg call
|
|
||||||
# by 'sparc32' and 'sparc64', depending on the flavour.
|
|
||||||
# Need to figure out the role of these binaries.
|
|
||||||
#
|
|
||||||
binary-arch: build
|
binary-arch: build
|
||||||
dh_testdir
|
dh_testdir
|
||||||
dh_clean -k
|
for i in $(subarchs); do \
|
||||||
dh_installdirs
|
$(MAKE) -f debian/rules.subarch subarch=$${i} binary; \
|
||||||
|
|
||||||
cd $(kdir); $(kpkg_headers_cmd)
|
|
||||||
|
|
||||||
mv $(kdir)/debian/files debian
|
|
||||||
|
|
||||||
for i in $(flavours); do \
|
|
||||||
cp -al build-$$i install-$$i; \
|
|
||||||
cd install-$$i; \
|
|
||||||
$(kpkg_image_cmd); \
|
|
||||||
cd ..; \
|
|
||||||
cat install-$$i/debian/files >> debian/files; \
|
|
||||||
rm -rf install-$$i ; \
|
|
||||||
done
|
done
|
||||||
mv *.deb ..
|
|
||||||
|
|
||||||
binary: binary-indep binary-arch
|
binary: binary-indep binary-arch
|
||||||
|
|
||||||
header-install: header-install.in
|
|
||||||
sed -e 's,@kbpkg@,$(kbpkg),g' \
|
|
||||||
-e 's,@headers_dirs@,$(headers_dirs),g' \
|
|
||||||
-e 's,@headers_extra@,$(headers_extra),g' \
|
|
||||||
header-install.in > header-install
|
|
||||||
chmod u+x header-install
|
|
||||||
|
|
||||||
post-install: post-install.in
|
|
||||||
sed -e 's,@initrd_modules@,$(initrd_modules),' \
|
|
||||||
post-install.in > post-install
|
|
||||||
#
|
|
||||||
# Generates the kernel config file for a subarch by merging
|
|
||||||
# the arch-independent config file (arch/config.common),
|
|
||||||
# arch-specific config file (arch/$(karch)/config.common),
|
|
||||||
# and subarch specific one (arch/$(karch)/config.subarch).
|
|
||||||
# It is possible to avoid the inclusion of the arch-indep
|
|
||||||
# config file by setting include_common_config = no in the
|
|
||||||
# arch/$(karch)/Makefile.inc. Absense of any of the above
|
|
||||||
# files is ignored.
|
|
||||||
#
|
|
||||||
config.%:
|
|
||||||
@echo -n "Generating configuration file $@ ..."
|
|
||||||
@arch='arch/$(karch)/config.common'; \
|
|
||||||
subarch='arch/$(karch)/$@'; \
|
|
||||||
include=''; \
|
|
||||||
if [ '$(include_common_config)' != 'no' ]; then \
|
|
||||||
include='arch/config.common'; \
|
|
||||||
fi; \
|
|
||||||
if [ -f "$${arch}" ]; then \
|
|
||||||
include="$${include} $${arch}"; \
|
|
||||||
fi; \
|
|
||||||
if [ -f "$${subarch}" ]; then \
|
|
||||||
include="$${include} $${subarch}"; \
|
|
||||||
fi; \
|
|
||||||
cat $${include} > $@
|
|
||||||
@echo " done."
|
|
||||||
#
|
#
|
||||||
# Prepares debian/control by cat'ing together all the
|
# Prepares debian/control by cat'ing together all the
|
||||||
# control files, substituting variables, removing all
|
# control files, substituting variables, removing all
|
||||||
|
@ -226,36 +77,5 @@ debian/control:
|
||||||
-e 's,@kbpkg@,$(kbpkg),g' | \
|
-e 's,@kbpkg@,$(kbpkg),g' | \
|
||||||
sed '/^[[:space:]]*$$/d' | \
|
sed '/^[[:space:]]*$$/d' | \
|
||||||
sed 's/^Package:/\n&/g' > debian/control
|
sed 's/^Package:/\n&/g' > debian/control
|
||||||
#
|
|
||||||
# This is a general target to create the ready-to-build directory
|
|
||||||
# for the correct subarch and flavour. For the arches with subarchs
|
|
||||||
# the directory will have the name build-$(subarch)-$(flavour). For
|
|
||||||
# the ones with subarch, it will be just build-$(flavour).
|
|
||||||
#
|
|
||||||
build-%:
|
|
||||||
set $(subst -, ,$@); shift; \
|
|
||||||
subarch="$${1}"; \
|
|
||||||
flavour="$${2}"; \
|
|
||||||
if [ -z "$${flavour}" ]; then \
|
|
||||||
cp -al $(kdir) build-$${subarch}; \
|
|
||||||
else \
|
|
||||||
cp -al $(kdir)-$${subarch} build-$${subarch}-$${flavour}; \
|
|
||||||
fi
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
$(kdir)-%: post-install
|
|
||||||
dh_testdir
|
|
||||||
tar jxf /usr/src/$(kdir).tar.bz2
|
|
||||||
mkdir -p $(kdir)/debian
|
|
||||||
cp debian/changelog $(kdir)/debian
|
|
||||||
cp debian/control $(kdir)/debian
|
|
||||||
cp debian/copyright $(kdir)/debian
|
|
||||||
# File below must be the proper subarch file
|
|
||||||
cp $(default) $(kdir)/.config
|
|
||||||
touch $(kdir)/debian/official
|
|
||||||
install post-install $(kdir)/debian
|
|
||||||
# Here we need to do the subarch-specific patching
|
|
||||||
mv $(kdir) $@
|
|
||||||
|
|
||||||
.PHONY: clean build unpack binary-indep binary-arch binary
|
.PHONY: clean build unpack binary-indep binary-arch binary
|
||||||
|
|
|
@ -0,0 +1,187 @@
|
||||||
|
#
|
||||||
|
# This Makefile executes the unpack/build/binary targets for a single
|
||||||
|
# subarch, which is passed in the subarch variable. Empty subarch
|
||||||
|
# variable means that we are building for an arch without the subarch.
|
||||||
|
# Additionally, variables version, abiname and ktver are
|
||||||
|
# expected to be available (need to be exported from the parent process).
|
||||||
|
# It is possible to override the flavours by setting the flavours
|
||||||
|
# variable.
|
||||||
|
#
|
||||||
|
SHELL := sh -e
|
||||||
|
debver := $(version)-$(abiname)
|
||||||
|
uver := $(subst .,_,$(version))
|
||||||
|
debnum := -$(abiname)
|
||||||
|
bpkg := kernel-build-$(debver)
|
||||||
|
kbpkg := kernel-kbuild-$(version)-$(abiname)
|
||||||
|
kpatch := /usr/src/kernel-patches/all/$(version)/apply/debian $(version)-$(ktver)
|
||||||
|
DEBIAN_UPSTREAM_VERSION := $(version)
|
||||||
|
ifeq (,$(DEB_HOST_ARCH))
|
||||||
|
DEB_HOST_ARCH := $(shell dpkg-architecture -qDEB_HOST_ARCH)
|
||||||
|
DEB_BUILD_ARCH := $(shell dpkg-architecture -qDEB_BUILD_ARCH)
|
||||||
|
endif
|
||||||
|
export version debnum DEBIAN_UPSTREAM_VERSION
|
||||||
|
|
||||||
|
karch := $(DEB_HOST_ARCH)
|
||||||
|
ifeq ($(subarch),none)
|
||||||
|
basedir := arch/$(karch)
|
||||||
|
else
|
||||||
|
basedir := arch/$(karch)/$(subarch)
|
||||||
|
endif
|
||||||
|
default := $(basedir)/config.default
|
||||||
|
configs := $(notdir $(wildcard $(basedir)/config.*))
|
||||||
|
configs := $(filter-out config.common config.default, $(configs))
|
||||||
|
tkdir := kernel-source-$(version)
|
||||||
|
kdir := kernel-source-$(version)-$(subarch)
|
||||||
|
ifndef flavours
|
||||||
|
flavours := $(patsubst config.%,%,$(configs))
|
||||||
|
endif
|
||||||
|
build_prefix := build-$(subarch)-
|
||||||
|
|
||||||
|
-include $(basedir)/Makefile.inc
|
||||||
|
#
|
||||||
|
# Here we construct the command lines for different make-kpkg
|
||||||
|
# calls (build, kernel-image, kernel-headers) based on the values
|
||||||
|
# of variables defined so far and provided by the arch/subarch
|
||||||
|
# in Makefile.inc. Note that $$i in these expressions is going to
|
||||||
|
# become a reference to the shell variable $i, which is expected
|
||||||
|
# to have the current flavour. This is slightly evil, but saves
|
||||||
|
# a lot of grief.
|
||||||
|
#
|
||||||
|
kpkg_headers_cmd := HEADER_CLEAN_HOOK='$(CURDIR)/header-install-$(subarch)'
|
||||||
|
kpkg_headers_cmd += make-kpkg --append-to-version $(debnum)
|
||||||
|
kpkg_build_cmd := make-kpkg --append-to-version $(debnum)-$$i
|
||||||
|
ifdef added_patches
|
||||||
|
kpkg_headers_cmd += --added_patches $(subst @uver@,$(uver),$(added_patches))
|
||||||
|
kpkg_build_cmd += --added_patches $(subst @uver@,$(uver),$(added_patches))
|
||||||
|
endif
|
||||||
|
ifdef build_subarch
|
||||||
|
kpkg_build_cmd += --subarch $$i
|
||||||
|
endif
|
||||||
|
ifdef headers_subarch
|
||||||
|
kpkg_headers_cmd += --subarch $(headers_subarch)
|
||||||
|
endif
|
||||||
|
ifdef build_makeflags
|
||||||
|
kpkg_build_cmd := MAKEFLAGS=$(build_makeflags) $(kpkg_build_cmd)
|
||||||
|
endif
|
||||||
|
kpkg_image_cmd := $(kpkg_build_cmd) --initrd kernel_image
|
||||||
|
kpkg_build_cmd += build
|
||||||
|
kpkg_headers_cmd += kernel-headers
|
||||||
|
ifndef headers_dirs
|
||||||
|
headers_dirs = $(karch)
|
||||||
|
endif
|
||||||
|
|
||||||
|
#
|
||||||
|
# TODO:
|
||||||
|
# * Check that make oldconfig does not actually
|
||||||
|
# change the config file. If it does, something
|
||||||
|
# is wrong (missing/extra options, etc).
|
||||||
|
#
|
||||||
|
unpack: unpack-stamp-$(subarch)
|
||||||
|
unpack-stamp-$(subarch): $(kdir) $(configs) header-install-$(subarch)
|
||||||
|
for i in $(flavours); do \
|
||||||
|
cp -al $(kdir) build-$(subarch)-$$i; \
|
||||||
|
cp config.$$i build-$(subarch)-$$i/.config; \
|
||||||
|
done
|
||||||
|
# Need to clean out configs so that there is no filename
|
||||||
|
# clash with other subarches.
|
||||||
|
rm -f $(configs)
|
||||||
|
touch unpack-stamp-$(subarch)
|
||||||
|
#
|
||||||
|
# TODO:
|
||||||
|
# * Implement optional stripping of the kernel
|
||||||
|
# (for sparc).
|
||||||
|
# * Check that it is really ok to call --subarch
|
||||||
|
# with the name of the flavour. For mips which
|
||||||
|
# is another --subarch user it should be fine.
|
||||||
|
#
|
||||||
|
build: build-stamp-$(subarch)
|
||||||
|
build-stamp-$(subarch): unpack-stamp-$(subarch)
|
||||||
|
dh_testdir
|
||||||
|
PATH=$$PWD/bin:$$PATH; \
|
||||||
|
for i in $(flavours); do \
|
||||||
|
cd build-$(subarch)-$$i; \
|
||||||
|
$(kpkg_build_cmd); \
|
||||||
|
cd ..; \
|
||||||
|
done
|
||||||
|
touch build-stamp-$(subarch)
|
||||||
|
|
||||||
|
binary-indep: build
|
||||||
|
binary-arch: build
|
||||||
|
dh_testdir
|
||||||
|
dh_clean -k
|
||||||
|
dh_installdirs
|
||||||
|
|
||||||
|
cd $(kdir); $(kpkg_headers_cmd)
|
||||||
|
#
|
||||||
|
# Hmm, is it right to just cat all the debian/files
|
||||||
|
# together? Need to check it out...
|
||||||
|
#
|
||||||
|
cat $(kdir)/debian/files >> debian/files
|
||||||
|
|
||||||
|
for i in $(flavours); do \
|
||||||
|
cp -al build-$(subarch)-$$i install-$$i; \
|
||||||
|
cd install-$$i; \
|
||||||
|
$(kpkg_image_cmd); \
|
||||||
|
cd ..; \
|
||||||
|
cat install-$$i/debian/files >> debian/files; \
|
||||||
|
rm -rf install-$$i ; \
|
||||||
|
done
|
||||||
|
mv *.deb ..
|
||||||
|
|
||||||
|
binary: binary-indep binary-arch
|
||||||
|
|
||||||
|
header-install-$(subarch): header-install.in
|
||||||
|
sed -e 's,@kbpkg@,$(kbpkg),g' \
|
||||||
|
-e 's,@ksource_dir@,$(CURDIR)/$(kdir),g' \
|
||||||
|
-e 's,@headers_dirs@,$(headers_dirs),g' \
|
||||||
|
-e 's,@headers_extra@,$(headers_extra),g' \
|
||||||
|
header-install.in > header-install-$(subarch)
|
||||||
|
chmod u+x header-install-$(subarch)
|
||||||
|
|
||||||
|
post-install: post-install.in
|
||||||
|
sed -e 's,@initrd_modules@,$(initrd_modules),' \
|
||||||
|
post-install.in > post-install
|
||||||
|
#
|
||||||
|
# Generates the kernel config file for a subarch by merging
|
||||||
|
# the arch-independent config file (arch/config.common),
|
||||||
|
# arch-specific config file (arch/$(karch)/config.common),
|
||||||
|
# and subarch specific one (arch/$(karch)/config.subarch).
|
||||||
|
# It is possible to avoid the inclusion of the arch-indep
|
||||||
|
# config file by setting include_common_config = no in the
|
||||||
|
# arch/$(karch)/Makefile.inc. Absense of any of the above
|
||||||
|
# files is ignored.
|
||||||
|
#
|
||||||
|
config.%:
|
||||||
|
@echo -n "Generating configuration file $@ ..."
|
||||||
|
arch='$(basedir)/config.common'; \
|
||||||
|
subarch='$(basedir)/$@'; \
|
||||||
|
include=''; \
|
||||||
|
if [ '$(include_common_config)' != 'no' ]; then \
|
||||||
|
include='arch/config.common'; \
|
||||||
|
fi; \
|
||||||
|
if [ -f "$${arch}" ]; then \
|
||||||
|
include="$${include} $${arch}"; \
|
||||||
|
fi; \
|
||||||
|
if [ -f "$${subarch}" ]; then \
|
||||||
|
include="$${include} $${subarch}"; \
|
||||||
|
fi; \
|
||||||
|
cat $${include} > $@
|
||||||
|
@echo " done."
|
||||||
|
#
|
||||||
|
# TODO: subarch specific patches
|
||||||
|
#
|
||||||
|
$(kdir): post-install
|
||||||
|
dh_testdir
|
||||||
|
tar jxf /usr/src/$(tkdir).tar.bz2
|
||||||
|
mkdir -p $(tkdir)/debian
|
||||||
|
cp debian/changelog $(tkdir)/debian
|
||||||
|
cp debian/control $(tkdir)/debian
|
||||||
|
cp debian/copyright $(tkdir)/debian
|
||||||
|
cp $(default) $(tkdir)/.config
|
||||||
|
touch $(tkdir)/debian/official
|
||||||
|
install post-install $(tkdir)/debian
|
||||||
|
cd $(tkdir) && $(kpatch)
|
||||||
|
# Here we need to do the subarch-specific patching
|
||||||
|
mv $(tkdir) $@
|
||||||
|
|
||||||
|
.PHONY: build unpack binary-indep binary-arch binary
|
|
@ -10,7 +10,7 @@ set -e
|
||||||
|
|
||||||
kbpkg=@kbpkg@
|
kbpkg=@kbpkg@
|
||||||
|
|
||||||
cd $DEBIAN_SRCTOP
|
cd @ksource_dir@
|
||||||
{
|
{
|
||||||
find . -path './scripts/*' -prune -o \
|
find . -path './scripts/*' -prune -o \
|
||||||
-path './Documentation/*' -prune -o \
|
-path './Documentation/*' -prune -o \
|
||||||
|
|
Loading…
Reference in New Issue