有关 Linux 下内核模块的开发方式的记录
2010-09-10 09:25
465 查看
1、本文全文为半香仙笛(Woody.c)原创
2、如果需要转载本文,请注明出处:http://blog.csdn.net/mcg890414/archive/2010/09/10/5874943.aspx
3、如果需要和笔者交流,请邮件至mcg890414@163.com
Thinking in Linux C...
前几天照着《Linux设备驱动开发详解》上的 代码翘入了计算机一段内核模块代码,但是完全没有编译成功,gcc告诉我,这个不认识,那个也不认识……
内核模块代码如下:
很郁闷。但是郁闷之余,还是需要找个途径来解决吧。
上网查了资料,网上牛人太多,写的东西虽然很给力,但是大多看不懂,所以决定还是问实验室同学。
同学告诉我,需要make,然后拷贝给我一个makefile的模板,很给力。
makefile(2.6内核)源码如下:
很给力。
make之后产生了我要的东西。
然后,insmod ./hello.ko
却告诉我:insmod: error inserting './hello.ko': -1 Operation not permitted
我郁闷了。。。这神马情况?
原来要加sudo,因为这是在往内核插入模块。
OK,成功了,再lsmod能看到hello的模块已经装载成功了
想看看printk的结果?dmesg,看到输出的结果了
嗯,该卸载了。。。
rmmod hello
呀。。。ERROR: Removing 'hello': Operation not permitted
又忘了sudo,这可不是好习惯。。
好了,dmesg看到了,成功卸载模块。
嗯,好啦~~
哈哈,原来很简单,其实失败离成功,只是一点点偏差而已。
你成功了么?
2、如果需要转载本文,请注明出处:http://blog.csdn.net/mcg890414/archive/2010/09/10/5874943.aspx
3、如果需要和笔者交流,请邮件至mcg890414@163.com
Thinking in Linux C...
前几天照着《Linux设备驱动开发详解》上的 代码翘入了计算机一段内核模块代码,但是完全没有编译成功,gcc告诉我,这个不认识,那个也不认识……
内核模块代码如下:
#include <linux/init.h> #include <linux/module.h> MODULE_LICENSE("Dual BSD/GPL"); static int hello_init(void) { printk(KERN_ALERT " Hello World ENTER/n"); return 0; } static void hello_exit(void) { printk(KERN_ALERT " Hello World EXIT/n"); return; } module_init(hello_init); module_exit(hello_exit); MODULE_AUTHOR("Woody.c"); MODULE_DESCRIPTION("A simple Hello world Module"); MODULE_ALIAS("a simplest module"); ~
很郁闷。但是郁闷之余,还是需要找个途径来解决吧。
上网查了资料,网上牛人太多,写的东西虽然很给力,但是大多看不懂,所以决定还是问实验室同学。
同学告诉我,需要make,然后拷贝给我一个makefile的模板,很给力。
makefile(2.6内核)源码如下:
# MakeFile 2.6: obj-m += hello.o # 产生对应的路径变量 CURRENT_PATH := $(shell pwd) # 内核源码当前版本 LINUX_KERNEL := $(shell uname -r) #内核源码绝对路径 LINUX_KERNEL_PATH := /usr/src/linux-headers-$(LINUX_KERNEL) #编译对象 all: make -C $(LINUX_KERNEL_PATH) M=$(CURRENT_PATH) modules #清理工作 clean: make -C $(LINUX_KERNEL_PATH) M=$(CURRENT_PATH) clean ~
很给力。
make之后产生了我要的东西。
然后,insmod ./hello.ko
却告诉我:insmod: error inserting './hello.ko': -1 Operation not permitted
我郁闷了。。。这神马情况?
原来要加sudo,因为这是在往内核插入模块。
OK,成功了,再lsmod能看到hello的模块已经装载成功了
想看看printk的结果?dmesg,看到输出的结果了
嗯,该卸载了。。。
rmmod hello
呀。。。ERROR: Removing 'hello': Operation not permitted
又忘了sudo,这可不是好习惯。。
好了,dmesg看到了,成功卸载模块。
嗯,好啦~~
哈哈,原来很简单,其实失败离成功,只是一点点偏差而已。
你成功了么?
相关文章推荐
- 有关 Linux 下内核模块的开发方式的记录 .
- Linux 下内核模块的开发方式的记录 及问题解决(入门的Helloworld)
- Linux 驱动开发-内核模块设计笔记 0
- linux内核及驱动开发中有关__init,__exit和__initdata的用法
- 在 Linux 下用户空间与内核空间数据交换的方式,第 1 部分: 内核启动参数、模块参数与s...
- linux驱动开发内核模块编译——Makefile入门
- Linux 驱动开发之内核模块开发(四)—— 符号表的导出
- linux 学习- 编程基础之内核模块开发
- Linux 驱动开发之内核模块开发 (三)—— 模块传参
- linux 内核模块开发注意事项
- linux 内核模块的编译(用于驱动开发)
- Linux 驱动开发之内核模块开发(四)—— 符号表的导出
- Linux学习之内核模块开发详解
- linux、内核源码、内核编译与配置、内核模块开发、内核启动流程
- Linux内核驱动开发之KGDB单步调试内核(kgdboc方式)
- linux、内核源码、内核编译与配置、内核模块开发、内核启动流程(转)
- linux、内核源码、内核编译与配置、内核模块开发、内核启动流程
- Linux 驱动开发之内核模块开发 (二)—— 内核模块编译 Makefile 入门
- Linux-内核模块开发
- linux驱动开发笔记--2.3内核模块相比于应用程序