Linux驱动设计:Hello World

步骤一、编写hello.c。
代码如下:
#include <linux/init.h>
#include <linux/module.h>
MODULE_LICENSE("Dual BSD/GPL");
static int hello_init(void)
{
  printk(KERN_INFO " Hello World enter\n");
  return 0;
}

static void hello_exit(void)
{
  printk(KERN_INFO " Hello World exit\n ");
}

module_init(hello_init);
module_exit(hello_exit);

步骤二、编写makefile。
内容如下:
ifneq ($(KERNELRELEASE),)
obj-m := hello.o
# Otherwise we were called directly from the command
# line; invoke the kernel build system.
else
KERNELDIR ?= /lib/modules/$(shell uname -r)/build
PWD := $(shell pwd)
default:
$(MAKE) -C $(KERNELDIR) M=$(PWD) modules
endif

步骤三、测试驱动的安装、卸载。
执行过程:  
[root@ hello]# make  
输出:
make -C /lib/modules/2.6.27.5-117.fc10.i686/build M=/mnt/hgfs/pub/code/kernel/hello modules
make[1]: Entering directory `/usr/src/kernels/2.6.27.5-117.fc10.i686'  
  CC [M] /mnt/hgfs/pub/code/kernel/hello/hello.o  
  Building modules, stage 2.  
  MODPOST 1 modules  
  CC /mnt/hgfs/pub/code/kernel/hello/hello.mod.o  
  LD [M] /mnt/hgfs/pub/code/kernel/hello/hello.ko  
make[1]: Leaving directory `/usr/src/kernels/2.6.27.5-117.fc10.i686'  

执行: insmod ./hello.ko 和 rmmod,没有输出任何内容!
[root@ hello]# insmod ./hello.ko
[root@ hello]# rmmod hello
为什么呢。
原来,如果不在字符模式下需要到 /var/log/messages中去看输出结果的。
执行 tail /var/log/messages,看见输出结果了!

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wwxjjj.html