Open Source


System Integration


Building a “Hello, world” kernel module

Building a Linux kernel module on Red Hat-derived distributions requires the kernel-devel package.

Place the following in hello.c:

#include <linux/module.h>
#include <linux/kernel.h>

int init_module(void)
        /* NOTE: See kern_levels.h for level constants. */
        printk(KERN_INFO "Hello, world!\n");

        return 0;

void cleanup_module(void)
        printk(KERN_INFO "Goodbye, world!\n");


Place the following in Makefile:

obj-m += hello.o

        make -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules

        make -C /lib/modules/$(shell uname -r)/build M=$(PWD) clean

Build the module using make. Load the module using insmod hello.ko, and remove it using rmmod hello; upon completing either, you should see a message recorded by the computer's logging system.

Receiving parameters at module load time

The module_param and MODULE_PARM_DESC macros aid in declaring and documenting kernel-module parameters, respectively. The module_param macro takes as arguments a parameter name, parameter type, and a series of permission bits which, if non-zero, apply to a sysfs entry that the module might later create. Each use of module_param should correspond with a global variable which shares the name of the parameter.

static char *option = "default value";

module_param(option, charp, 0000);
MODULE_PARM_DESC(option, "An example character string option");

The sample option above could be set using the command insmod hello.ko option=foo.

Reproducing the kernel source used to build the kernel for a Red Hat-derived distribution

  1. yumdownloader --source kernel
  2. rpm -Uvh kernel...
  3. rpmbuild -bs rpmbuild/SPECS/kernel.spec
This will result in a copy of the kernel source tree at rpmbuild/BUILD/kernel.... One way to build the kernel is to modify this source tree, produce a patch, place the patch in rpmbuild/SOURCES, modify rpmbuild/SPECS/kernel.spec to make use of the patch, and rebuild the kernel using rpmbuild -ba rpmbuild/SPECS/kernel.spec.
Email: www@flyn.org — ✉ 6110 Campfire Court; Columbia, Maryland 21045; USA