关于驱动程序模块编译

derest12 2010-08-31 11:24:20
为什么我的驱动程序模块编译时候通过了,并生产了.ko文件,当我加载到系统上时不能出现我想要的结果,我是初学者,
#include <linux/init.h>
#include <linux/module.h>

MODULE_LICENSE("Dual BSD/GPL");

static int hello_init(void)
{
printk(KERN_ALERT "hello, world\n");
return 0;
}

static void hello_exit(void)
{
printk(KERN_ALERT "Goodbye, cruel world\n");
}

module_init(hello_init);
module_exit(hello_exit);
应该出现的结果是在加载的时候出现hello,wrold,在卸载模块的时候出现Goodbye,cruel wrold,但是我加载后卸载了什么都没出现。请问各位高手这个可能是哪点出错了?
...全文
343 22 打赏 收藏 转发到动态 举报
写回复
用AI写文章
22 条回复
切换为时间正序
请发表友善的回复…
发表回复
derest12 2010-09-04
  • 打赏
  • 举报
回复
呵呵,我知道那点出错了,是我的Kcongfig和Mskefile文件的里面的标题有一个字母写反了,悲剧,太不仔细了,
九个太阳2023 2010-09-01
  • 打赏
  • 举报
回复
要想在内核配置选项中出现这个模块,必须要修改Kconfig这个文件,
derest12 2010-09-01
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 hao507 的回复:]
我上周也弄的这个问题
http://blog.csdn.net/hao507/archive/2010/08/27/5843351.aspx
看我这篇文章~~希望对你有所帮助~
[/Quote]
为什么我照着你这个 到内核里面的编译模块,但内核模块下,调用
make ARCH=arm CROSS_COMPILE=arm-none-linux-gnueabi- xconfig出现的是一个内核模块配置选项,但是我在里面并没有找到相应的新加的驱动程序选项,请问一下你是怎么做的?
九个太阳2023 2010-09-01
  • 打赏
  • 举报
回复
[Quote=引用 16 楼 derest12 的回复:]
没事 反正是对了的,不过我编译模块是调用的一个Makefile文件,没有专门在内核里面去修改Kconfig和Makefile文件,我试过那样了,但是没有生产我要的.ko文件,我也不知道怎么回事
看来还要继续探索
[/Quote]
呵呵,是的哈,靠自己调出来的时候,心情很爽~~
祝你好运~
derest12 2010-09-01
  • 打赏
  • 举报
回复
没事 反正是对了的,不过我编译模块是调用的一个Makefile文件,没有专门在内核里面去修改Kconfig和Makefile文件,我试过那样了,但是没有生产我要的.ko文件,我也不知道怎么回事
看来还要继续探索
九个太阳2023 2010-09-01
  • 打赏
  • 举报
回复
[Quote=引用 14 楼 derest12 的回复:]
10楼的,呵呵 不好意思哈,我的交叉编译器弄错了,改过来了就好了,呵呵,
我还有一个疑问,为什么我在卸载我的模块时,控制台会多出一句提示rmmod: module 'hello' not found,我在网上看了别人的帖子,但是在我的lib/modules/2.6.28.6/删除了那个modules.dep.bb文件还是一样的 不行,我在那个看见,而且这个文件是在卸载指令调用的时候 才会生成,删……
[/Quote]
你说说你动态加载具体的做法是怎样的
九个太阳2023 2010-09-01
  • 打赏
  • 举报
回复
[Quote=引用 20 楼 derest12 的回复:]
我已经修改了同目录下的Kconfig和Makefile,并在内核模块看到了相应的选项了,我标记为M,再调用模块编译,但是在相应的目录下并未看见生成的.ko文件,你们知道一般这样的情况 ,可能是什么地方出错吗?
[/Quote]
你重新编译了么?
最好把你的Kconfig和Makefile的代码贴出来,这样方便大家交流~~~
derest12 2010-09-01
  • 打赏
  • 举报
回复
我已经修改了同目录下的Kconfig和Makefile,并在内核模块看到了相应的选项了,我标记为M,再调用模块编译,但是在相应的目录下并未看见生成的.ko文件,你们知道一般这样的情况 ,可能是什么地方出错吗?
lkncjy 2010-08-31
  • 打赏
  • 举报
回复
莫非是init()和exit()函数前面分别还要有个关键字修饰的问题,LZ试一下啵,我也不确定。
wwwunix 2010-08-31
  • 打赏
  • 举报
回复
1、用dmesg看看有没有输出。
2、用lsmod看看你的模块是否加载成功。
deep_pro 2010-08-31
  • 打赏
  • 举报
回复
dmesg 了没
九个太阳2023 2010-08-31
  • 打赏
  • 举报
回复
我上周也弄的这个问题
http://blog.csdn.net/hao507/archive/2010/08/27/5843351.aspx
看我这篇文章~~希望对你有所帮助~
derest12 2010-08-31
  • 打赏
  • 举报
回复
10楼的,呵呵 不好意思哈,我的交叉编译器弄错了,改过来了就好了,呵呵,
我还有一个疑问,为什么我在卸载我的模块时,控制台会多出一句提示rmmod: module 'hello' not found,我在网上看了别人的帖子,但是在我的lib/modules/2.6.28.6/删除了那个modules.dep.bb文件还是一样的 不行,我在那个看见,而且这个文件是在卸载指令调用的时候 才会生成,删除了也没有用的
derest12 2010-08-31
  • 打赏
  • 举报
回复
我看了,那个打印的提示语在/var/log/messages文件中的,为什么会这样呢,那个高手能告诉我
hurricane880 2010-08-31
  • 打赏
  • 举报
回复
$cat /var/log/message | grep hello
九个太阳2023 2010-08-31
  • 打赏
  • 举报
回复
我的那篇文章在我的平台上是测试过的~~呵呵,
九个太阳2023 2010-08-31
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 derest12 的回复:]
二楼的,我照着你那个步骤编译,但是我在内核的主目录下调用
make ARCH=arm CROSS_COMPILE=arm-none-linux-gnueabi-xconfig指令,会一直报错误信息,编译不来,提示如下:
make: arm-none-linux-gnueabi-xconfiggcc:命令未找到
CHK include/linux/version.h
make[1]: “……
[/Quote]
你的交叉编译器用的是什么??
wwwunix 2010-08-31
  • 打赏
  • 举报
回复
你的交叉编译器用的是什么?
如果是
arm-linux-gcc
那么这样用:
make ARCH=arm CROSS_COMPILE=arm-linux-
derest12 2010-08-31
  • 打赏
  • 举报
回复
二楼的,我照着你那个步骤编译,但是我在内核的主目录下调用
make ARCH=arm CROSS_COMPILE=arm-none-linux-gnueabi-xconfig指令,会一直报错误信息,编译不来,提示如下:
make: arm-none-linux-gnueabi-xconfiggcc:命令未找到
CHK include/linux/version.h
make[1]: “include/asm-arm/mach-types.h”是最新的。
CHK include/linux/utsrelease.h
SYMLINK include/asm -> include/asm-arm
CC kernel/bounds.s
/bin/sh: arm-none-linux-gnueabi-xconfiggcc: command not found
make[1]: *** [kernel/bounds.s] 错误 127
make: *** [prepare0] 错误 2
请问一下 各位怎么解决
derest12 2010-08-31
  • 打赏
  • 举报
回复
lsmod 模块是成功加载了的,我是用的虚拟机,在终端上没有输出,
dmesg是什么意思?
加载更多回复(2)
《Android系统源代码情景分析》随书光盘内容(源代码) 目录如下: 第1篇 初识Android系统 第1章 准备知识 1.1 Linux内核参考书籍 1.2 Android应用程序参考书籍 1.3 下载、编译和运行Android源代码 1.3.1 下载Android源代码 1.3.2 编译Android源代码 1.3.3 运行Android模拟器 1.4 下载、编译和运行Android内核源代码 1.4.1 下载Android内核源代码 1.4.2 编译Android内核源代码 1.4.3 运行Android模拟器 1.5 开发第一个Android应用程序 1.6 单独编译和打包Android应用程序模块 1.6.1 导入单独编译模块的mmm命令 1.6.2 单独编译Android应用程序模块 1.6.3 重新打包Android系统镜像文件 第2章 硬件抽象层 2.1 开发Android硬件驱动程序 2.1.1 实现内核驱动程序模块 2.1.2 修改内核Kconfig文件 2.1.3 修改内核Makefile文件 2.1.4 编译内核驱动程序模块 2.1.5 验证内核驱动程序模块 2.2 开发C可执行程序验证Android硬件驱动程序 2.3 开发Android硬件抽象层模块 2.3.1 硬件抽象层模块编写规范 2.3.2 编写硬件抽象层模块接口 2.3.3 硬件抽象层模块的加载过程 2.3.4 处理硬件设备访问权限问题 2.4 开发Android硬件访问服务 2.4.1 定义硬件访问服务接口 2.4.2 实现硬件访问服务 2.4.3 实现硬件访问服务的JNI方法 2.4.4 启动硬件访问服务 2.5 开发Android应用程序来使用硬件访问服务 第3章 智能指针 3.1 轻量级指针 3.1.1 实现原理分析 3.1.2 应用实例分析 3.2 强指针和弱指针 3.2.1 强指针的实现原理分析 3.2.2 弱指针的实现原理分析 3.2.3 应用实例分析 第2篇 Android专用驱动系统 第4章 Logger日志系统 4.1 Logger日志格式 4.2 Logger日志驱动程序 4.2.1 基础数据结构 4.2.2 日志设备的初始化过程 4.2.3 日志设备文件的打开过程 4.2.4 日志记录的读取过程 4.2.5 日志记录的写入过程 4.3 运行时库层日志库 4.4 C/C++日志写入接口 4.5 Java日志写入接口 4.6 Logcat工具分析 4.6.1 相关数据结构 4.6.2 初始化过程 4.6.3 日志记录的读取过程 4.6.4 日志记录的输出过程 第5章 Binder进程间通信系统 5.1 Binder驱动程序 5.1.1 基础数据结构 5.1.2 Binder设备的初始化过程 5.1.3 Binder设备文件的打开过程 5.1.4 Binder设备文件的内存映射过程 5.1.5 内核缓冲区管理 5.2 Binder进程间通信库 5.3 Binder进程间通信应用实例 5.4 Binder对象引用计数技术 5.4.1 Binder本地对象的生命周期 5.4.2 Binder实体对象的生命周期 5.4.3 Binder引用对象的生命周期 5.4.4 Binder代理对象的生命周期 5.5 Binder对象死亡通知机制 5.5.1 注册死亡接收通知 5.5.2 发送死亡接收通知 5.5.3 注销死亡接收通知 5.6 Service Manager的启动过程 5.6.1 打开和映射Binder设备文件 5.6.2 注册为Binder上下文管理者 5.6.3 循环等待Client进程请求 5.7 Service Manager代理对象的获取过程 5.8 Service组件的启动过程 5.8.1 注册Service组件 5.8.2 启动Binder线程池 5.9 Service代理对象的获取过程 5.10 Binder进程间通信机制的Java接口 5.10.1 Service Manager的Java代理对象的获取过程 5.10.2 Java服务接口的定义和解析 5.10.3 Java服务的启动过程 5.10.4 Java服务代理对象的获取过程 5.10.5 Java服务的调用过程 第6章 Ashmem匿名共享内存系统 6.1 Ashmem驱动程序 6.1.1 基础数据结构 6.1.2 匿名共享内存设备的初始化过程 6.1.3 匿名共享内存设备文件的打开过程 6.1.4 匿名共享内存设备文件的内存映射过程 6.1.5 匿名共享内存块的锁定和解锁过程 6.1.6 匿名共享内存块的回收过程 6.2 运行时库cutils的匿名共享内存访问接口 6.3 匿名共享内存的C++访问接口 6.3.1 MemoryHeapBase 6.3.2 MemoryBase 6.3.3 应用实例 6.4 匿名共享内存的Java访问接口 6.4.1 MemoryFile 6.4.2 应用实例 6.5 匿名共享内存的共享原理 第3篇 Android应用程序框架 第7章 Activity组件的启动过程 7.1 Activity组件应用实例 7.2 根Activity组件的启动过程 7.3 子Activity组件在进程内的启动过程 7.4 子Activity组件在新进程中的启动过程 第8章 Service组件的启动过程 8.1 Service组件应用实例 8.2 Service组件在新进程中的启动过程 8.3 Service组件在进程内的绑定过程 第9章 Android系统广播机制 9.1 广播机制应用实例 9.2 广播接收者的注册过程 9.3 广播的发送过程 第10章 Content Provider组件的实现原理 10.1 Content Provider组件应用实例 10.1.1 ArticlesProvider 10.1.2 Article 10.2 Content Provider组件的启动过程 10.3 Content Provider组件的数据共享原理 10.3.1 数据共享模型 10.3.2 数据传输过程 10.4 Content Provider组件的数据更新通知机制 10.4.1 注册内容观察者 10.4.2 发送数据更新通知 第11章 Zygote和System进程的启动过程 11.1 Zygote进程的启动脚本 11.2 Zygote进程的启动过程 11.3 System进程的启动过程 第12章 Android应用程序进程的启动过程 12.1 应用程序进程的创建过程 12.2 Binder线程池的启动过程 12.3 消息循环的创建过程 第13章 Android应用程序的消息处理机制 13.1 创建线程消息队列 13.2 线程消息循环过程 13.3 线程消息发送过程 13.4 线程消息处理过程 第14章 Android应用程序的键盘消息处理机制 14.1 键盘消息处理模型 14.2 InputManager的启动过程 14.2.1 创建InputManager 14.2.2 启动InputManager 14.2.3 启动InputDispatcher 14.2.4 启动InputReader 14.3 InputChannel的注册过程 14.3.1 创建InputChannel 14.3.2 注册Server端InputChannel 14.3.3 注册系统当前激活的应用程序窗口 14.3.4 注册Client端InputChannel 14.4 键盘消息的分发过程 14.4.1 InputReader获得键盘事件 14.4.2 InputDispatcher分发键盘事件 14.4.3 系统当前激活的应用程序窗口获得键盘消息 14.4.4 InputDispatcher获得键盘事件处理完成通知 14.5 InputChannel的注销过程 14.5.1 销毁应用程序窗口 14.5.2 注销Client端InputChannel 14.5.3 注销Server端InputChannel 第15章 Android应用程序线程的消息循环模型 15.1 应用程序主线程消息循环模型 15.2 与界面无关的应用程序子线程消息循环模型 15.3 与界面相关的应用程序子线程消息循环模型 第16章 Android应用程序的安装和显示过程 16.1 应用程序的安装过程 16.2 应用程序的显示过程

4,441

社区成员

发帖
与我相关
我的任务
社区描述
Linux/Unix社区 内核源代码研究区
社区管理员
  • 内核源代码研究区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧