咔叽游戏

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 719|回复: 0

[Linux] Linux内核设备驱动之Linux内核基础笔记整理

[复制链接]
  • TA的每日心情
    无聊
    2019-6-2 14:11
  • 签到天数: 4 天

    [LV.2]圆转纯熟

    发表于 2019-4-22 16:25:14 | 显示全部楼层 |阅读模式
    今天小编就为大家分享一篇关于Linux内核设备驱动之Linux内核基础笔记整理,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    1. Linux内核驱动模块机制
    静态加载, 把驱动模块编进内核, 在内核启动时加载
    动态加载, 把驱动模块编为ko, 在内核启动后,需要用时加载
    2. 编写内核驱动
    1. #include <linux/module.h>
    2. #include <linux/init.h>
    3. static int __init test_init(void)
    4. {
    5. return 0; //返回0表示成功, 返加负数退出加载模块
    6. }
    7. //__init 当内核把驱动初始化完后, 释放此函数的代码指令空间
    8. static void __exit test_exit(void)
    9. {
    10. ....
    11. }
    12. //__exit 指定此函数只在驱动卸载时使用, 用完后释放
    13. module_init(test_init); //指定test_init为模块初始化函数
    14. module_exit(test_exit); //指定test_exit为模块退出时卸载函数
    15. MODULE_LICENSE("GPL"); //指定所支持的协议
    16. MODULE_AUTHOR("作者");
    17. MODULE_DESCRIPTION("描述");
    18. MODULE_VERSION("版本");
    19. #define __init __section(.init.text)
    20. #define __initdata __section(.init.data)
    21. char __initdata buf[] = "hello world";
    22. #define __exitdata __section(.exit.data)
    23. #define __exit __section(.exit.text)
    24. /////////////
    复制代码
    modinfo test.ko 查看模块的信息
    cat /proc/modules 查看当前系统的动态加载模块  相当于lsmod

    test 1768 0 - Live 0xbf03c000
    模块名, 使用的内存大小, 调用次数,  有效 , 模块所在的内存地址

    ls /sys/module 查看所有模块
    3. 驱动模块的Makefile
      obj-m  += test.o   //源码文件为test.cmodules:make -C 内核源码目录 M=驱动代码所在目录 modulesmodules install:make -C 内核源码目录 M=驱动代码所在目录 modules_install      INSTALL_MOD_PATH=/文件系统路径clean:make -C 内核源码目录 M=驱动代码所在目录 modules clean
    4. 查看驱动输出的消息
    1. cat /var/log/messages
    2. tail /var/log/messages
    复制代码
    5. printk的级别控制

    /usr/src/kernels/2.6.18-194.el5-i686/include/linux/kernel.h
    1. <linux/kernel.h>
    2. #define KERN_EMERG "<0>" /* system is unusable */
    3. #define KERN_ALERT "<1>" /* action must be taken immediately */
    4. #define KERN_CRIT "<2>" /* critical conditions */
    5. #define KERN_ERR "<3>" /* error conditions */
    6. #define KERN_WARNING "<4>" /* warning conditions */
    7. #define KERN_NOTICE "<5>" /* normal but significant condition */
    8. #define KERN_INFO "<6>" /* informational */
    9. #define KERN_DEBUG "<7>" /* debug-level messages */
    复制代码
    默认的级别为 KERN_WARNING "<4>"
    使用 : printk(KERN_INFO"内容");
    查看当前内核的输出级别 cat /proc/sys/kernel/printk
    7       4       1       7
      7:console_loglevel
    4:default_message_loglevel
    1:minimum_console_loglevel
    7:default_console_loglevel
    当printk函数使用的级别小于当前console_loglevel级别时, 则可以输出, 否则不输出
    修改级别输出  echo 8 > /proc/sys/kernel/printk
    总结
    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对咔叽网单www.2nzz.com的支持。如果你想了解更多相关内容请查看下面相关链接

    QQ|免责声明|小黑屋|手机版|Archiver|咔叽游戏

    GMT+8, 2024-3-29 08:48

    Powered by Discuz! X3.4

    © 2001-2023 Discuz! Team.

    快速回复 返回顶部 返回列表