Transcript: Using the Yocto BSP tools to manage kernel patches and config items
Here's a cut-and-paste shell session showing how to use the Yocto BSP 'yocto-kernel' tool to manage kernel patches and config items for a BSP that was created using 'yocto-bsp'. This particular session uses the qemu ARM BSP that was created in the Transcript: Using the Yocto BSP tools to create a qemu BSP.
The 'yocto-kernel' tool allows you to list, add, and remove kernel patches and individual kernel config items to/from a BSP's kernel recipe.
Like the other Yocto BSP tools, you can get help by simply invoking the command or sub-command with no parameters (first we need to source the environment, again this is using the BSP we created in the session linked to by the above link):
trz@elmorro:/usr/local/dev/Yocto$ source oe-init-build-env ### Shell environment set up for builds. ### You can now run 'bitbake <target>' Common targets are: core-image-minimal core-image-sato meta-toolchain meta-toolchain-sdk adt-installer meta-ide-support You can also run generated qemu images with a command like 'runqemu qemux86' trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel Usage: Modify and list Yocto BSP kernel config items and patches. usage: yocto-kernel [--version] [--help] COMMAND [ARGS] The most commonly used 'yocto-kernel' commands are: config list List the modifiable set of bare kernel config options for a BSP config add Add or modify bare kernel config options for a BSP config rm Remove bare kernel config options from a BSP patch list List the patches associated with a BSP patch add Patch the Yocto kernel for a BSP patch rm Remove patches from a BSP See 'yocto-kernel help COMMAND' for more information on a specific command. Options: --version show program's version number and exit -h, --help show this help message and exit -D, --debug output debug information
Let's start by adding a patch. Here's the patch we'll add: [yocto-testmod.patch: https://wiki.yoctoproject.org/wiki/images/c/c9/Yocto-testmod.patch] NOTE: You should use the patch in the link - scraping the screen from below will result in a patch with whitespace differences that won't apply:
diff --git a/drivers/misc/Kconfig b/drivers/misc/Kconfig index 6a1a092..b6165b6 100644 --- a/drivers/misc/Kconfig +++ b/drivers/misc/Kconfig @@ -392,6 +392,11 @@ config HMC6352 This driver provides support for the Honeywell HMC6352 compass, providing configuration and heading data via sysfs. +config YOCTO_TESTMOD + tristate "Yocto Test Driver" + help + This driver provides a silly message for testing Yocto. + config EP93XX_PWM tristate "EP93xx PWM support" depends on ARCH_EP93XX diff --git a/drivers/misc/Makefile b/drivers/misc/Makefile index 3e1d801..11384d8 100644 --- a/drivers/misc/Makefile +++ b/drivers/misc/Makefile @@ -36,6 +36,7 @@ obj-$(CONFIG_TI_DAC7512) += ti_dac7512.o obj-$(CONFIG_C2PORT) += c2port/ obj-$(CONFIG_IWMC3200TOP) += iwmc3200top/ obj-$(CONFIG_HMC6352) += hmc6352.o +obj-$(CONFIG_YOCTO_TESTMOD) += yocto-testmod.o obj-y += eeprom/ obj-y += cb710/ obj-$(CONFIG_SPEAR13XX_PCIE_GADGET) += spear13xx_pcie_gadget.o diff --git a/drivers/misc/yocto-testmod.c b/drivers/misc/yocto-testmod.c new file mode 100644 index 0000000..81de912 --- /dev/null +++ b/drivers/misc/yocto-testmod.c @@ -0,0 +1,36 @@ +/* + * Copyright 2012 Intel Corporation + * Authored-by: Tom Zanussi <tom.zanussi@intel.com> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + */ + +#include <linux/module.h> + +static int __init yocto_testmod_init(void) +{ + printk("Kilroy was here! __m_(OuO)_m__"); +} + +static void __exit yocto_testmod_exit(void) +{ + printk("Kilroy was not here!"); +} + +module_init(yocto_testmod_init); +module_exit(yocto_testmod_exit); + +MODULE_AUTHOR("Tom Zanussi <tom.zanussi@intel.com"); +MODULE_DESCRIPTION("Yocto Test Driver"); +MODULE_LICENSE("GPL");
First, let's list the current set of patches associated with the BSP. Again, we'll use the built-in help to remind ourselves of the syntax for that:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel patch list Usage: List the patches associated with the kernel for a BSP usage: yocto-kernel patch list <bsp-name> This command lists the patches associated with a BSP. NOTE: this only applies to patches listed in the kernel recipe's user-patches.scc file (and currently repeated in its SRC_URI). Options: -h, --help show this help message and exit
The name of our BSP is qemuarm, so we can list the current set of patches like this:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel patch list myqemuarm The current set of machine-specific patches for myqemuarm is:
As we can see, there are no patches listed, as we'd expect.
Let's see the syntax for adding a patch:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel patch add Usage: Patch the Yocto kernel for a specific BSP usage: yocto-kernel patch add <bsp-name> [<PATCH> ...] This command adds one or more patches to a BSP's machine branch. The patch will be added to the BSP's linux-yocto kernel user-patches.scc file (and currently repeated in its SRC_URI) and will be guaranteed to be applied in the order specified. Options: -h, --help show this help message and exit
So using the add subcommand as follows, we can add our patch:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel patch add myqemuarm /home/trz/newpatches/yocto-testmod.patch Added patches: yocto-testmod.patch
Let's verify that the patch was added:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel patch list myqemuarm The current set of machine-specific patches for myqemuarm is: 1) yocto-testmod.patch
So apparently it was. If you look at the patch, you can see that it adds new code as a module under 'misc devices'. In order to get it built in to the kernel, we need to enable a couple options, one to enable misc devices, and another to enable our particular module.
We can do that using analagous 'yocto-kernel config' subcommands. First, let's see if we already have any BSP-specific config options enabled for our BSP:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel config list myqemuarm The current set of machine-specific kernel config items for myqemuarm is: 1) CONFIG_FTRACE_SYSCALLS=y 2) CONFIG_SCHED_TRACER=y 3) CONFIG_IRQSOFF_TRACER=y 4) CONFIG_PREEMPT_TRACER=y
We do - these are a small set of BSP-specific options that were added by the BSP template that generated the BSP.
Let's add to these our two options:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel config add myqemuarm CONFIG_MISC_DEVICES=y Added items: CONFIG_MISC_DEVICES=y
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel config add myqemuarm CONFIG_YOCTO_TESTMOD=y Added items: CONFIG_YOCTO_TESTMOD=y
Now let's verify that they were added:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel config list myqemuarm The current set of machine-specific kernel config items for myqemuarm is: 1) CONFIG_FTRACE_SYSCALLS=y 2) CONFIG_SCHED_TRACER=y 3) CONFIG_IRQSOFF_TRACER=y 4) CONFIG_PREEMPT_TRACER=y 5) CONFIG_MISC_DEVICES=y 6) CONFIG_YOCTO_TESTMOD=y
Now that we've successfully added the patch and associated config items, we can rebuild with the new code and settings, reboot, and we should find our string 'Kilroy was here! __m_(OuO)_m__' in the dmesg log (simply open up a terminal window and type 'dmesg | egrep Kilroy' and you should see the string if everything went as expected).
trz@elmorro:/usr/local/dev/Yocto/build$ bitbake core-image-sato trz@elmorro:/usr/local/dev/Yocto/build$ runqemu qemuarm tmp/deploy/images/zImage-myqemuarm.bin tmp/deploy/images/core-image-sato-myqemuarm.ext3
We can also use 'yocto-kernel' to remove kernel patches and config items. Let's use it to remove the patch and config items we just added.
Let's first remove the patch:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel patch rm myqemuarm Specify the patches to remove: 1) yocto-testmod.patch 1 Removed patches: yocto-testmod.patch
And let's verify that it was removed:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel patch list myqemuarm The current set of machine-specific patches for myqemuarm is:
Let's do the same for the config items:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel config rm myqemuarmSpecify the kernel config items to remove: 1) CONFIG_FTRACE_SYSCALLS=y 2) CONFIG_SCHED_TRACER=y 3) CONFIG_IRQSOFF_TRACER=y 4) CONFIG_PREEMPT_TRACER=y 5) CONFIG_MISC_DEVICES=y 6) CONFIG_YOCTO_TESTMOD=y 5 Removed items: CONFIG_MISC_DEVICES=y trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel config rm myqemuarm Specify the kernel config items to remove: 1) CONFIG_FTRACE_SYSCALLS=y 2) CONFIG_SCHED_TRACER=y 3) CONFIG_IRQSOFF_TRACER=y 4) CONFIG_PREEMPT_TRACER=y 5) CONFIG_YOCTO_TESTMOD=y 5 Removed items: CONFIG_YOCTO_TESTMOD=y
And let's also verify that those are now gone:
trz@elmorro:/usr/local/dev/Yocto/build$ yocto-kernel config list myqemuarm The current set of machine-specific kernel config items for myqemuarm is: 1) CONFIG_FTRACE_SYSCALLS=y 2) CONFIG_SCHED_TRACER=y 3) CONFIG_IRQSOFF_TRACER=y 4) CONFIG_PREEMPT_TRACER=y
The appear to be. Rebuilding and booting should show that Kilroy has left (i.e. open a terminal window and typing 'dmesg | egrep Kilroy' should now show nothing again).