首页 > 其他 > 详细

第一个内核模块

时间:2015-12-05 22:39:24      阅读:272      评论:0      收藏:0      [点我收藏+]

hello.c

#include<linux/module.h>
#include<linux/init.h>
#include<linux/kernel.h>
   
int init_module(){
     printk("<1>hello world!\n");
     return 0;
  }
void cleanup_module(){
  printk("<1>godbye");
 }
  
MODULE_LICENSE("GPL");

  Makefile

   linux_kernel=$(shell uname -r)
   linux_kernel_path=/usr/src/linux-headers-$(linux_kernel)
   curr_path=$(shell pwd)
   obj-m += hello.o
   all:
       make -C $(linux_kernel_path)    M=$(curr_path) modules
  clean:
      make -C $(linux_kernel_path)    M=$(curr_path) clean                       

 

root下执行make后

make -C /usr/src/linux-headers-3.13.0-67-generic    M=/home/hugh/myfs/ws modules
make[1]: Entering directory `/usr/src/linux-headers-3.13.0-67-generic  Building modules, stage 2.
  MODPOST 1 modules
make[1]: Leaving directory `/usr/src/linux-headers-3.13.0-67-generic

插入模块

insmod hello.ko

卸载模块

rmmod hello

dmesg查看日志

……
[113392.319719] hello: module verification failed: signature and/or  required key missing - tainting kernel
[113392.321763] hello world!
[113561.149510] <1>hello world!
[113487.425871] godbye
[113571.386171] <1>godbye

 

yep,it‘s done!

 

第一个内核模块

原文:http://www.cnblogs.com/HughParker/p/5022407.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!