How to build Yocto with a custom kernel - TechNexion/u-boot-tn-imx GitHub Wiki
-
Follow the steps to build yocto (as described in this page: tn-imx-yocto-manifest) all the way up to configuring yocto build, before “bitbake” command to start building yocto (The line containing DISTRO=XXX MACHINE=YYY source edm-setup-release.sh …. ). This will setup the build environment and configure the Yocto build system.
-
Execute the following command to preserve the current working directory:
pushd $(pwd)
-
Issue the following command:
bitbake -c unpack virtual/kernel
mkdir ../local_repo/
cp -r tmp/work-shared/<MACHINE>/kernel-source ../local_repo/
-> where is the parameter “MACHINE” used when configuring the build parameters. -
Type in the following command:
cd ../local_repo/kernel-source
and now you may start modifying the kernel source code.
-
When the modification of the kernel is done, be sure to commit it (but you don’t have to push the commit to the remote git branch). Get the hash/id of the commit.
-
Now go to /sources/meta-tn-imx-bsp/recipes-kernel/linux/ and then modify following lines in the linux-tn-src_4.14.98.inc as following:
KERNEL_SRC = “git://${BSPDIR}/local_repo/kernel-source;protocol=file”
SRCREV = “Commit ID”
where the 'Commit ID' is the id for your previous commit. If you created your own branch to work on, then you will need to modify the SRCBRANCH parameter as well to point to the new branch.
-
Execute the command “popd” to return to the building/working directory of Yocto.
-
Issue the relevant bitbake command (In this case, it will be “bitbake fsl-image-qt5-validation-imx”) to commence the build process.