当前位置:首页 > 教育培训 >

linux内核的使用(linux内核的主要功能)

来源:原点资讯(www.yd166.com)时间:2023-06-11 23:48:09作者:YD166手机阅读>>

概述

嵌入式设备驱动开发中将驱动程序以模块的形式发布,更是极大地提高了设备使用的灵活性——用户只需要拿到相关驱动模块,再插入到用户的内核中,即可灵活地使用你的设备。

概述

嵌入式设备驱动开发中将驱动程序以模块的形式发布,更是极大地提高了设备使用的灵活性——用户只需要拿到相关驱动模块,再插入到用户的内核中,即可灵活地使用你的设备。

使用Linux模块的优点
  • 1. 用户可以随时扩展Linux系统的功能。
  • 2. 当要修改当前Linux系统的驱动时,只需要卸载旧模块,编译目标驱动模块,重新安装插入即可。
  • 3. 系统中如果需要使用新模块,不必重新编译内核,只要插入相应的模块即可。
  • 4. 减小Linux内核的体积,节省flash。
linux模块命令详细介绍

1. 模块安装命令:insmod

insmod xxxx.ko

2. 查看当前已经安装模块:lsmod

lsmod 不需要参数

3. 模块卸载命令:rmmod

rmmod xxxxx.ko

4. 查看模块信息:modinfo

在X86上操作:

[root@zhifachen linux-3.5]# modinfo/root/work/rootfs/home/mod/tiny4412_hello_module.ko filename: /root/work/rootfs/home/mod/tiny4412_hello_module.ko license: GPL depends: intree: Y vermagic: 3.5.0-FriendlyARM SMP preempt mod_unload ARMv7 p2v8 [root@zhifachen linux-3.5]#Linux模块命令测试示例

注意:模块的编译是依赖具体一份源码,并且这份被编译过,并且没有使用mrproper,distclean清除的源码工程。

使用makemodules编译内核源码树中的模块

  • 1. 添加内核菜单
  • 2. make menuconfig 配置为 M
  • 3. 在顶层目录终端输入makemodules

直接make 也可生成模块文件(.ko),也会生成zImage,当你只想编译模块而不想编译zImage时候使用 make modules 命令会更加快速。

把内核源码树中的模块源文件编译到内核映像中

如果不需要配置菜单只想编译代码到内核zImage,Makefile可以这样写obj-y = xxxx.o

如果不需要配置菜单只想编译代码为外部模块,Makefile可以这样写 obj-m = xxxx.o

在内核源码中添加自定义的模块并且编译1.2.5外部独立Makefile编译模块

在驱动开发阶段,接触到新驱动机率非常高,如果都要去修改内核源码Makefile, 太过于繁杂,也不利于移植,实际开发中会使用另外一种方法来编译模块文件。

Linux内核模块代码文件模板

可以直接复制内核源码中自带的示例模板来测试:drivers/char/tiny4412_hello_module.c

Linux内核模块编译Makefile模板

编译模块Makefile文件:

obj-m = xyd_hello_module.o all: @make -C /root/work/linux-3.5/ M=$(PWD) modules @rm -rf *.o *.mod.c modules.order Module.symvers *~ *.bak clean: @rm -rf *.o *.mod.c modules.order Module.symvers *.ko *~ *.bak make -C $(KDIR)M=$(PWD) modules

M=选项让该Makefile在构造modules目标之前返回到模块源代码目录,然后modules目标指向obj-m变量中设定的模块;在上面的例子中,我们将该变量设置成了module.o。

上面的清除规则是自己写的,也可利用内核Makefile清除规则来清编译生成目标文件,改进后代码:

obj-m = xyd_hello_module.o # x86 编译时候使用: uname -r 得到当前内核的版本号 #KDIR := /lib/modules/`uname -r`/build #arm 编译时候使用 KDIR :=/root/work/linux-3.5 all: @make -C $(KDIR) M=$(PWD) modules clean: @make -C $(KDIR) M=$(PWD) modules clean @rm -f *.ko.unsigned *~Linux内核printk函数

内核中不能使用printf函数输出信息,要使用printk函数,这个函数有输出等级控制的。

内核通过 printk() 输出的信息具有日志级别,日志级别是通过在 printk() 输出的字符串前加一个带尖括号的整数来控制的,如 printk("<6>Hello, world!/n");。内核中共提供了八种不同的日志级别,在 linux/kernel.h 中有相应的宏对应。

#defineKERN_EMERG "<0>" /* system is unusable 系统不可用*/ #defineKERN_ALERT "<1>" /* action must be takenimmediately警报,必须立即采取行动*/ #define KERN_CRIT "<2>" /*critical conditions临界状态 */ #defineKERN_ERR "<3>" /* error conditions 错误状态*/ #defineKERN_WARNING "<4>" /* warningconditions警告状态*/ #defineKERN_NOTICE "<5>" /* normal but significant正常的,但引人注目*/ #define KERN_INFO "<6>" /*informational 信息*/ #defineKERN_DEBUG "<7>" /* debug-level messages调试等级信息 */ 可以通过查看/proc/sys/kernel/printk文件内容知道设置信息。 [root@ChenZhiFa/]# cat /proc/sys/kernel/printk

可以通过echo命令修改种个等级:

[root@ChenZhiFa/]# echo 4 4 1 7 > /proc/sys/kernel/printk

说明:直接使用printk( “kkkk”);这样没有指明等级,这种未明确指定。

只有等级比较当前终端等级高才会在终端上显示出来。

以下进行X86 系统上的测试(在纯字符界面下测试有效,在图形界面中是无效)

在图形界面系统中按Ctl Alt F2(F2~F6键其中一个,不同电脑可能不同),可以进入到纯字符界面,要返回按Ctl Alt F1(不同电脑可能不同)

printk --- 不支持浮点数,实际上驱动程序也不支持浮点运算。所有浮点运算应该放在用户空间。

使用Linux模块的优点
  • 1. 用户可以随时扩展Linux系统的功能。
  • 2. 当要修改当前Linux系统的驱动时,只需要卸载旧模块,编译目标驱动模块,重新安装插入即可。
  • 3. 系统中如果需要使用新模块,不必重新编译内核,只要插入相应的模块即可。
  • 4. 减小Linux内核的体积,节省flash。
Linux模块命令详细介绍

1. 模块安装命令:insmod

insmod xxxx.ko

2. 查看当前已经安装模块:lsmod

lsmod 不需要参数

3. 模块卸载命令:rmmod

rmmod xxxxx.ko

4. 查看模块信息:modinfo

在X86上操作:

[root@zhifachen linux-3.5]# modinfo/root/work/rootfs/home/mod/tiny4412_hello_module.ko filename: /root/work/rootfs/home/mod/tiny4412_hello_module.ko license: GPL depends: intree: Y vermagic: 3.5.0-FriendlyARM SMP preempt mod_unload ARMv7 p2v8 [root@zhifachen linux-3.5]#Linux模块命令测试示例

注意:模块的编译是依赖具体一份源码,并且这份被编译过,并且没有使用mrproper,distclean清除的源码工程。

使用makemodules编译内核源码树中的模块

  • 1. 添加内核菜单
  • 2. make menuconfig 配置为 M
  • 3. 在顶层目录终端输入makemodules

直接make 也可生成模块文件(.ko),也会生成zImage,当你只想编译模块而不想编译zImage时候使用 make modules 命令会更加快速。

把内核源码树中的模块源文件编译到内核映像中

如果不需要配置菜单只想编译代码到内核zImage,Makefile可以这样写obj-y = xxxx.o

如果不需要配置菜单只想编译代码为外部模块,Makefile可以这样写 obj-m = xxxx.o

在内核源码中添加自定义的模块并且编译1.2.5外部独立Makefile编译模块

在驱动开发阶段,接触到新驱动机率非常高,如果都要去修改内核源码Makefile, 太过于繁杂,也不利于移植,实际开发中会使用另外一种方法来编译模块文件。

Linux内核模块代码文件模板

可以直接复制内核源码中自带的示例模板来测试:drivers/char/tiny4412_hello_module.c

Linux内核模块编译Makefile模板

编译模块Makefile文件:

obj-m = xyd_hello_module.o all: @make -C /root/work/linux-3.5/ M=$(PWD) modules @rm -rf *.o *.mod.c modules.order Module.symvers *~ *.bak clean: @rm -rf *.o *.mod.c modules.order Module.symvers *.ko *~ *.bak make -C $(KDIR)M=$(PWD) modules

M=选项让该Makefile在构造modules目标之前返回到模块源代码目录,然后modules目标指向obj-m变量中设定的模块;在上面的例子中,我们将该变量设置成了module.o。

上面的清除规则是自己写的,也可利用内核Makefile清除规则来清编译生成目标文件,改进后代码:

obj-m = xyd_hello_module.o # x86 编译时候使用: uname -r 得到当前内核的版本号 #KDIR := /lib/modules/`uname -r`/build #arm 编译时候使用 KDIR :=/root/work/linux-3.5 all: @make -C $(KDIR) M=$(PWD) modules clean: @make -C $(KDIR) M=$(PWD) modules clean @rm -f *.ko.unsigned *~Linux内核printk函数

内核中不能使用printf函数输出信息,要使用printk函数,这个函数有输出等级控制的。

内核通过 printk() 输出的信息具有日志级别,日志级别是通过在 printk() 输出的字符串前加一个带尖括号的整数来控制的,如 printk("<6>Hello, world!/n");。内核中共提供了八种不同的日志级别,在 linux/kernel.h 中有相应的宏对应。

#defineKERN_EMERG "<0>" /* system is unusable 系统不可用*/ #defineKERN_ALERT "<1>" /* action must be takenimmediately警报,必须立即采取行动*/ #define KERN_CRIT "<2>" /*critical conditions临界状态 */ #defineKERN_ERR "<3>" /* error conditions 错误状态*/ #defineKERN_WARNING "<4>" /* warningconditions警告状态*/ #defineKERN_NOTICE "<5>" /* normal but significant正常的,但引人注目*/ #define KERN_INFO "<6>" /*informational 信息*/ #defineKERN_DEBUG "<7>" /* debug-level messages调试等级信息 */ 可以通过查看/proc/sys/kernel/printk文件内容知道设置信息。 [root@ChenZhiFa/]# cat /proc/sys/kernel/printk

可以通过echo命令修改种个等级:

[root@ChenZhiFa/]# echo 4 4 1 7 > /proc/sys/kernel/printk

说明:直接使用printk( “kkkk”);这样没有指明等级,这种未明确指定。

只有等级比较当前终端等级高才会在终端上显示出来。

以下进行X86 系统上的测试(在纯字符界面下测试有效,在图形界面中是无效)

在图形界面系统中按Ctl Alt F2(F2~F6键其中一个,不同电脑可能不同),可以进入到纯字符界面,要返回按Ctl Alt F1(不同电脑可能不同)

printk --- 不支持浮点数,实际上驱动程序也不支持浮点运算。所有浮点运算应该放在用户空间。

栏目热文

linux基本命令(linux常用命令图解)

linux基本命令(linux常用命令图解)

我们并不是每天都会谈论 Linux 的命令行。但正如一些读者指出的那样,你们也想学习一些命令行的技巧。因此,我整理了一份...

2023-06-12 00:31:29查看全文 >>

linux 内核分析(Linux 内核分析发送缓冲区)

linux 内核分析(Linux 内核分析发送缓冲区)

概述前段时间朋友让整理Linux内核这一块的内容,抽空整理了下linux内核方面,主要从linux体系结构和linux内...

2023-06-12 00:26:32查看全文 >>

linux内核参数大全(Linux升级内核)

linux内核参数大全(Linux升级内核)

作为一名优秀的Linux运维工程师,参数优化是一门十分重要的功课。你是不是一听到这个词就头痛?没关系,小编帮你快速掌握这...

2023-06-11 23:57:38查看全文 >>

图解linux内核(通俗易懂讲解linux内核)

图解linux内核(通俗易懂讲解linux内核)

前言:本文和其它的“Linux内核分析”文章都基于如下约定: 内核版本为Linux 3.10.29(该版本是一个long...

2023-06-12 00:17:24查看全文 >>

linux内核配置详解(linux内核的配置原则)

linux内核配置详解(linux内核的配置原则)

前言 Linux内核是操作系统的核心,也是操作系统最基本的部分。 Linux内核的体积结构是单内核的、但是他充分采用了微...

2023-06-12 00:07:24查看全文 >>

英雄联盟为什么调不了符文(韩国英雄联盟为什么那么强)

英雄联盟为什么调不了符文(韩国英雄联盟为什么那么强)

最近英雄联盟大更新后迎来不少吐糟,特别是对于那些步入社会的老玩家,本来就没啥时间玩,大更新后完全看不懂符文等,表示纷纷弃...

2023-06-12 00:12:19查看全文 >>

英雄联盟没有一键符文是怎么回事(英雄联盟一键符文不见了)

英雄联盟没有一键符文是怎么回事(英雄联盟一键符文不见了)

如果Wegame取消一键配置符文,这个做法是否正确?网友:普天同庆就在近期,大家有没有发现,在玩英雄联盟的时候,导入符文...

2023-06-12 00:12:59查看全文 >>

英雄联盟符文设置失败(英雄联盟设置符文页出错)

英雄联盟符文设置失败(英雄联盟设置符文页出错)

#520游我宠你#随着科技的进步,电子游戏也是越来越多样化,这让游戏爱好者有了更多的选择。可即使如此,每个赛季仍有大量玩...

2023-06-11 23:54:07查看全文 >>

英雄联盟符文不生效怎么回事

英雄联盟符文不生效怎么回事

S12赛事出乎了许多LOL玩家的预料,因为一些不可预知的因素,LPL选手的水平受到了一定程度的限制。但不论如何,八强才打...

2023-06-12 00:32:50查看全文 >>

英雄联盟老是无法应用符文

英雄联盟老是无法应用符文

这可能是英雄联盟历史上补丁更新后最灰暗的一天,在外服更新9.14版本之后,游戏中出现了大量让玩家感到非常郁闷的导致游戏无...

2023-06-11 23:57:17查看全文 >>

文档排行