标签:
本文描述了如何编写并且加载一个 Linux 内核模块,以及实验过程中遇到的问题和解决方法。本实验在模块加载时在系统日志文件中输出信息“Hello world!",在模块被删除时在系统文件中输出信息”Goodbye World!"。包括以下内容:
1 // ---- HelloMod.c ---- // 2 #include <linux/module.h> 3 #include <linux/kernel.h> 4 #include <linux/init.h> 5 6 MODULE_LICENSE( "GPL" ); //get rid of taint message 7 MODULE_AUTHOR( "kunzhang" ); 8 MODULE_DESCRIPTION( "Hello World module" ); 9 10 static int __init lkp_init( void ) 11 { 12 printk( KERN_NOTICE"Hello, World! from the kernel message space ...\n" ); 13 return 0; 14 } 15 16 static void __exit lkp_cleanup( void ) 17 { 18 printk( KERN_NOTICE"<1>Goodbye, World! Leaving kernel space ...\n" ); 19 } 20 21 module_init( lkp_init ); 22 module_exit( lkp_cleanup );
1 ifneq ($(KERNELRELEASE),) 2 obj-m := hello.o 3 else 4 KDIR := /lib/modules/4.2.0-16-generic/build 5 6 all: 7 make -C $(KDIR) M=$(PWD) modules 8 clean: 9 rm -f *.ko *.o *.mod.o *mod.c *.symvers *.order 10 endif
Feb 8 17:37:20 SeventhCorner kernel: [ 3850.565815] Hello, World! from the kernel message space ... Feb 8 17:37:25 SeventhCorner kernel: [ 3856.246795] Goodbye, World! Leaving kernel space ...
标签:
原文地址:http://www.cnblogs.com/dim7/p/5185091.html