kernel: Fix depmod for multilib
Using populate_sysroot for this data was a nice idea but flawed as it doesn't work in multilib builds. Instead we can use PKGDATA_DIR since this is consistent over multilib builds. It also turns out to be slightly neater code too. Hopefully this resolves the problem once and for all. (From OE-Core rev: 6cccae3ca54c1177a1d91d23c3e151d74e735ee9) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
parent
36bd248463
commit
3f15d8a807
|
@ -231,16 +231,20 @@ kernel_do_install() {
|
||||||
[ -e Module.symvers ] && install -m 0644 Module.symvers ${D}/boot/Module.symvers-${KERNEL_VERSION}
|
[ -e Module.symvers ] && install -m 0644 Module.symvers ${D}/boot/Module.symvers-${KERNEL_VERSION}
|
||||||
install -d ${D}${sysconfdir}/modules-load.d
|
install -d ${D}${sysconfdir}/modules-load.d
|
||||||
install -d ${D}${sysconfdir}/modprobe.d
|
install -d ${D}${sysconfdir}/modprobe.d
|
||||||
|
|
||||||
# Stash data for depmod
|
|
||||||
install -d ${D}${datadir}/kernel-depmod/
|
|
||||||
echo "${KERNEL_VERSION}" > ${D}${datadir}/kernel-depmod/kernel-abiversion
|
|
||||||
cp System.map ${D}${datadir}/kernel-depmod/System.map-${KERNEL_VERSION}
|
|
||||||
}
|
}
|
||||||
do_install[prefuncs] += "package_get_auto_pr"
|
do_install[prefuncs] += "package_get_auto_pr"
|
||||||
|
|
||||||
addtask shared_workdir after do_compile before do_install
|
addtask shared_workdir after do_compile before do_install
|
||||||
|
|
||||||
|
emit_depmod_pkgdata() {
|
||||||
|
# Stash data for depmod
|
||||||
|
install -d ${PKGDESTWORK}/kernel-depmod/
|
||||||
|
echo "${KERNEL_VERSION}" > ${PKGDESTWORK}/kernel-depmod/kernel-abiversion
|
||||||
|
cp System.map ${PKGDESTWORK}/kernel-depmod/System.map-${KERNEL_VERSION}
|
||||||
|
}
|
||||||
|
|
||||||
|
PACKAGEFUNCS += "emit_depmod_pkgdata"
|
||||||
|
|
||||||
do_shared_workdir () {
|
do_shared_workdir () {
|
||||||
cd ${B}
|
cd ${B}
|
||||||
|
|
||||||
|
@ -285,21 +289,13 @@ do_shared_workdir () {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Only stage the files we need for depmod, not the modules/firmware
|
# We don't need to stage anything, not the modules/firmware since those would clash with linux-firmware
|
||||||
sysroot_stage_all () {
|
sysroot_stage_all () {
|
||||||
sysroot_stage_dir ${D}${datadir}/kernel-depmod ${SYSROOT_DESTDIR}${datadir}/kernel-depmod
|
:
|
||||||
}
|
}
|
||||||
|
|
||||||
KERNEL_CONFIG_COMMAND ?= "oe_runmake_call -C ${S} O=${B} oldnoconfig || yes '' | oe_runmake -C ${S} O=${B} oldconfig"
|
KERNEL_CONFIG_COMMAND ?= "oe_runmake_call -C ${S} O=${B} oldnoconfig || yes '' | oe_runmake -C ${S} O=${B} oldconfig"
|
||||||
|
|
||||||
PACKAGE_PREPROCESS_FUNCS += "kernel_package_preprocess"
|
|
||||||
|
|
||||||
kernel_package_preprocess () {
|
|
||||||
rm -rf ${PKGD}${datadir}/kernel-depmod
|
|
||||||
rmdir ${PKGD}${datadir}
|
|
||||||
rmdir ${PKGD}${exec_prefix}
|
|
||||||
}
|
|
||||||
|
|
||||||
kernel_do_configure() {
|
kernel_do_configure() {
|
||||||
# fixes extra + in /lib/modules/2.6.37+
|
# fixes extra + in /lib/modules/2.6.37+
|
||||||
# $ scripts/setlocalversion . => +
|
# $ scripts/setlocalversion . => +
|
||||||
|
|
|
@ -209,7 +209,7 @@ class Rootfs(object):
|
||||||
'new', '-v'])
|
'new', '-v'])
|
||||||
|
|
||||||
def _generate_kernel_module_deps(self):
|
def _generate_kernel_module_deps(self):
|
||||||
kernel_abi_ver_file = oe.path.join(self.d.getVar('STAGING_DIR_TARGET', True), self.d.getVar('datadir', True), "kernel-depmod",
|
kernel_abi_ver_file = oe.path.join(self.d.getVar('PKGDATA_DIR', True), "kernel-depmod",
|
||||||
'kernel-abiversion')
|
'kernel-abiversion')
|
||||||
if not os.path.exists(kernel_abi_ver_file):
|
if not os.path.exists(kernel_abi_ver_file):
|
||||||
bb.fatal("No kernel-abiversion file found (%s), cannot run depmod, aborting" % kernel_abi_ver_file)
|
bb.fatal("No kernel-abiversion file found (%s), cannot run depmod, aborting" % kernel_abi_ver_file)
|
||||||
|
|
|
@ -19,21 +19,21 @@ if [ "\$1" != "-a" -o "\$2" != "-b" ]; then
|
||||||
echo "Usage: depmodwrapper -a -b rootfs KERNEL_VERSION" >&2
|
echo "Usage: depmodwrapper -a -b rootfs KERNEL_VERSION" >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
if [ ! -r ${STAGING_DIR_TARGET}${datadir}/kernel-depmod/kernel-abiversion ]; then
|
if [ ! -r ${PKGDATA_DIR}/kernel-depmod/kernel-abiversion ]; then
|
||||||
echo "Unable to read: ${STAGING_DIR_TARGET}${datadir}/kernel-depmod/kernel-abiversion" >&2
|
echo "Unable to read: ${PKGDATA_DIR}/kernel-depmod/kernel-abiversion" >&2
|
||||||
else
|
else
|
||||||
kernelabi=\$(cat ${STAGING_DIR_TARGET}${datadir}/kernel-depmod/kernel-abiversion)
|
kernelabi=\$(cat ${PKGDATA_DIR}/kernel-depmod/kernel-abiversion)
|
||||||
if [ "\$kernelabi" != "\$4" ]; then
|
if [ "\$kernelabi" != "\$4" ]; then
|
||||||
echo "Error: Kernel version \$4 does not match kernel-abiversion (\$kernelabi)" >&2
|
echo "Error: Kernel version \$4 does not match kernel-abiversion (\$kernelabi)" >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -r ${STAGING_DIR_TARHET}${datadir}/kernel-depmod/System.map-\$4 ]; then
|
if [ ! -r ${PKGDATA_DIR}/kernel-depmod/System.map-\$4 ]; then
|
||||||
echo "Unable to read: ${STAGING_DIR_TARGET}${datadir}/kernel-depmod/System.map-\$4" >&2
|
echo "Unable to read: ${PKGDATA_DIR}/kernel-depmod/System.map-\$4" >&2
|
||||||
exec env depmod "\$1" "\$2" "\$3" "\$4"
|
exec env depmod "\$1" "\$2" "\$3" "\$4"
|
||||||
else
|
else
|
||||||
exec env depmod "\$1" "\$2" "\$3" -F "${STAGING_DIR_TARGET}${datadir}/kernel-depmod/System.map-\$4" "\$4"
|
exec env depmod "\$1" "\$2" "\$3" -F "${PKGDATA_DIR}/kernel-depmod/System.map-\$4" "\$4"
|
||||||
fi
|
fi
|
||||||
EOF
|
EOF
|
||||||
chmod +x ${D}${bindir_crossscripts}/depmodwrapper
|
chmod +x ${D}${bindir_crossscripts}/depmodwrapper
|
||||||
|
|
Loading…
Reference in New Issue