Since this book talks about device drivers, let's start by adding our code under the drivers directory of the Linux sources, and specifically in drivers/misc, where miscellaneous drivers lie. We should place a file named dummy-code.c in drivers/misc with the following contents:
Our new file, drivers/misc/dummy-code.c, will have no effect if we don't properly insert it into the kernel configuration and building system. In order to do so, we have to modify the drivers/misc/Kconfig and drivers/misc/Makefilefiles as follows. The former file must be changed, as follows:
--- a/drivers/misc/Kconfig +++ b/drivers/misc/Kconfig @@ -527,4 +527,10 @@ source "drivers/misc/echo/Kconfig" source "drivers/misc/cxl/Kconfig" source "drivers/misc/ocxl/Kconfig" source "drivers/misc/cardreader/Kconfig" + +config DUMMY_CODE + tristate "Dummy code" + default n + ---help--- + This module is just for demonstration purposes. endmenu
Note that you can easily add the preceding code and whatever is needed to compile it by just using the patchcommand, as follows, in your main directory of Linux sources: $ patch -p1 < add_custom_code.patch
Well, if we now use the make menuconfigcommand and we navigate through Device Drivers to the bottom of the Misc devices menu entries, we should get something as shown in the following screenshot:
In the preceding screenshot, I've already selected the Dummy code entry so that we can see what the final settings should look like.
Note that the Dummy code entry must be selected as built-in ( the * character) and not as module (the M character).
Note also that, if we do not execute the make menuconfig command and we execute directly the make Image command to compile the kernel, then the building system will ask us what to do with the DUMMY_CODE setting, as shown in the following. Obviously, we have to answer yes by using the y character: $ make Image scripts/kconfig/conf --syncconfig Kconfig * * Restart config... * * * Misc devices * Analog Devices Digital Potentiometers (AD525X_DPOT) [N/m/y/?] n ... Dummy code (DUMMY_CODE) [N/m/y/?] (NEW) y
If everything is correctly in place, then we execute the make Imagecommand to recompile the kernel. We should see that our new file is compiled and then added to the kernel Image file, as follows:
$ make Image scripts/kconfig/conf --syncconfig Kconfig ... CC drivers/misc/dummy-code.o AR drivers/misc/built-in.a AR drivers/built-in.a ... LD vmlinux SORTEX vmlinux SYSMAP System.map OBJCOPY arch/arm64/boot/Image
OK, now what we have to do is just replace the Imagefile on the microSD with the one that has just been rebuilt and then restart the system (see the How to add the kernelrecipe in Chapter 1, Installing the Development System).