一,环境搭建步骤
1)下载Linux源码
1> ~#apt-cache search linux-source
出现:linux-source - Linux kernel source with Ubuntu patches
linux-source-3.0.0 - Linux kernel source for version 3.0.0 with Ubuntu patches
2>~#apt-get install linux-source-3.0.0
下载完成后,在/usr/src/下会出现一个linux-source-3.0.0.tar.bz2。解压: tar jxvf linux-source-3.0.0.tar.bz2
3>然后在Linux内核源码目录/usr/src/linux-source-2.6.32目录下面用老的方法配置好Linux内核:
~#make oldconfig
4>编译内核:~#make //大概需要一个小时
5>编译模块:~#make modules
6>安装模块:~#make modules_install
以上步骤完成后,会在/lib/modules 目录下生成一个文件夹3.0.0-12-generic
二,hello.c
三,Makefile
四,~#make //生成文件如下
hello.c hello.ko hello.mod.o Makefile modules.order
hello.c~ hello.mod.c hello.o Makefile~ Module.symvers
1>装载目标模块:~#insmod ./hello.ko
~#lsmod //查看目前安装的驱动模块,有hello
2>模块装载触发hello.c的init()方法,输出hello world,如果没有的话,是因为其将输出放到/var/log/syslog中去了。打开便可以看见你的结果!
卸载目标模块命令是:~#rmmod ./hello.ko
总结:从此我们迈出了Linux驱动开发的第一步
代码深度解析:
1)查找文件位置:
find / -name module.h
我的文件位置在:/usr/src/linux-source-3.0.0/include/linux/module.h //其余的位置也有好多,但是这个文件位置才是正解
/usr/src/linux-source-3.0.0/include/linux/in.h
2)另外,如果你的模块需要用到参数传递,那么你可能就要声明moduleparam.h这个头文件了。
3)模块里常包含一些描述性声明,如:
MODULE_LICENSE("GPL"); // "GPL" 是指明了 这是GNU General Public License的任意版本
// “GPL v2” 是指明 这仅声明为GPL的第二版本
// "GPL and addtional"
// "Dual BSD/GPL"
// "Dual MPL/GPL"
// "Proprietary" 私有的
// 除非你的模块显式地声明一个开源版本,否则内核会默认你这是一个私有的模块(Proprietary)。
MODULE_AUTHOR // 声明作者
MODULE_DESCRIPTION // 对这个模块作一个简单的描述,这个描述是"human-readable"的
MODULE_VERSION // 这个模块的版本
MODULE_ALIAS // 这个模块的别名
MODULE_DEVICE_TABLE // 告诉用户空间这个模块支持什么样的设备
MODULE_声明可以写在模块的任何地方(但必须在函数外面),但是惯例是写在模块最后。
4)
Linux KERN_ALERT 什么意思
消息打印级别:
fmt----消息级别:
#define KERN_EMERG"<0>"
#defineKERN_ALERT"<1>"
#define KERN_CRIT"<2>"
#define KERN_ERR"<3>"
#define KERN_WARNING"<4>"
#define KERN_NOTICE"<5>"
#define KERN_INFO"<6>"
#define KERN_DEBUG"<7>"
|
不同级别使用不同字符串表示,数字越小,级别越高。
printk输出跟输出的日志级别有关系,当输出日志级别比控制台的级别高时,就会显示在控制台上,当比控制台低时,则会记录在/var/log/message中.但是当系统同时运行了klogd和syslogd时,都追加到/var/log/message.在/proc/sys/kernel/printk文件中,前两个整数为当前的日志级别和默认的日志级别(默认的日志级别即为printk的输出级别).
注意:
需要开启klogd和syslogd服务才能正常输出。通过klogd可以改变系统消息输出级别。
linux0.11为什么在内核态使用printk()函数,而在用户态使用printf()函数?
(1)答:printk()函数是直接使用了向终端写函数tty_write()。而printf()函数是调用write()系统调用函数向标准输出设备写。所以在用户态(如进程0)不能够直接使用printk()函数,而在内核态由于他已是特权级,所以无需系统调用来改变特权级,因而能够直接使用printk()函数。
printk是内核输出,在终端是看不见的。
你可以看一下系统日志。/var/log/message。
或者使用dmesg命令看一下
不管你可能怎么想,printk()并不是设计用来同用户交互的,虽然我们在hello-1就是出于这样的目的使用它!它实际上是为内核提供日志功能,记录内核信息或用来给出警告。因此,每个printk()声明都会带一个优先级,就像你看到的<1>和KERN_ALERT那样。内核总共定义了八个优先级的宏,所以你不必使用晦涩的数字代码,并且你可以从文件linux/kernel.h查看这些宏和它们的意义。如果你不指明优先级,默认的优先级DEFAULT_MESSAGE_LOGLEVEL将被采用。
阅读一下这些优先级的宏。头文件同时也描述了每个优先级的意义。在实际中,使用宏而不要使用数字,就像<4>。总是使用宏,就像KERN_WARNING。
当优先级低于int console_loglevel,信息将直接打印在你的终端上。如果同时syslogd和klogd都在运行,信息也同时添加在文件/var/log/messages,而不管是否显示在控制台上与否。我们使用像KERN_ALERT这样的高优先级,来确保printk()将信息输出到控制台而不是只是添加到日志文件中。当你编写真正的实用的模块时,你应该针对可能遇到的情况使用合适的优先级。
分享到:
相关推荐
stays mad 反PCL宣传库。Anti PCL pro
那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据
yolo系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值
clickhouse-jdbc驱动jar文件用于建立jdbc链接
那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据
泰尔指数、泰尔指数模型(含案例源码+数据+stata详细操作过程)-最新出炉.zip
中药实验管理系统的出现,是为了满足中医药领域对实验教学、实验管理和个人信息管理的需求。该系统集成了多个功能模块,旨在提高实验教学效率,简化实验管理流程,并为用户提供便捷的个人信息管理服务。 系统包含的功能丰富多样。其中,“首页”作为系统的入口,提供了系统的概览和导航功能。而“个人中心”则允许用户查看和管理自己的个人信息,包括修改密码等安全设置。 在个人信息管理方面,系统提供了“个人信息”、“学生管理”、“教师管理”和“实验员管理”等模块。这些模块帮助用户更好地管理个人资料和角色信息,确保信息的准确性和安全性。 实验室管理相关的功能也是该系统的重要组成部分。其中,“实验教学管理”支持教师发布实验教学计划和教学资源,方便学生进行在线学习。“实验信息管理”和“实验预约管理”则帮助学生了解实验详情并进行预约,提高实验教学的有序性和效率。同时,“实验指导管理”和“实验评分管理”为实验员和教师提供了实验指导和评分功能,确保实验教学的质量和效果。 此外,“器材信息管理”模块用于管理实验室的器材和设备信息,方便用户了解器材的使用情况和预约情况。而“自由讨论”模块则为用户提供了一个交流和讨论的平
比赛地址:中文NLP地址要素解析 https://tianchi.aliyun.com/notebook/467867?spm=a2c22.12281976.0.0.654b265fTnW3lu 长期赛: 分数:87.7271 排名:长期赛:56(本次)/6990(团体或个人) 方案:BERT-BiLSTM-CRF-NER 预训练模型:bert-base-chinese 训练结果: F1 : 0.9040681554670564 accuracy : 0.9313805261730405 precision : 0.901296612724897 recall : 0.9068567961165048 运行脚本: python run_bert_lstm_crf.py
基于pytorch卷积神经网络的中文手写汉字识别,使用HWDB数据库_hand-writing-recognition
SQLLLLLLLLLLL
那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据
面板回归模型选择包括配套数据和stata代码命令-最新出炉.zip
yolo系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值
挂售转卖竞拍商城系统源码/竞拍系统/转拍闪拍系统/后端PHP+前端uniapp源码 亲测可用 1、后台管理:系统管理员通过后台可以轻松添加商品进行挂单。这包括商品的详细信息,如名称、描述、价格、库存等。 商品展示:挂单后的商品会在商城前端进行展示,供用户浏览和竞拍。 2. 场次设置 时间规划:管理员可以规划并设置竞拍的场次以及每个场次的开始时间。场次可以是定期举行的,也可以是根据特殊活动或节假日进行设置的。场次公告:用户可以在商城前端查看当前和即将开始的竞拍场次信息。 3. 用户抢单 竞拍规则:用户可以在竞拍开始后参与竞拍,按照设定的加价幅度进行出价。 竞拍实时性:系统实时更新竞拍价格,确保所有用户都能看到新的竞拍情况。 通过这套竞拍商城系统,用户可以享受到丰富的竞拍体验,同时也可以根据自己的需求选择提货或转售商品,实现资产的增值。管理员则可以通过后台系统轻松管理商品和场次,确保竞拍的顺利进行。 安装教程: 测试环境 Nginx + PHP7.3 + MySQL5.6 内附详细安装说明。
Go 语言版的分词器基于字典树和最大匹配算法略微的加了点消歧
机器学习-线性回归数据示例
2023年国县域统计年鉴数据(含县市卷+乡镇卷)-最新出炉.zip
基于GO语言的采集器(采集头条)项目资源
那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据
WPS word 使用字体