驱动开发入门级

一,驱动开发笔记

1, 开发驱动常用的几个命令
  1. lsmod :list moduel 把我们机器上所有的驱动打印出来,

  2. insmod:安装驱动

  3. rmmod:删除驱动

  4. modinfo:打印驱动信息

  5. dmesg: 打印驱动log信息

2, makefile模板
#ubuntu的内核源码树,如果要编译在ubuntu中安装的模块就打开这2个
#KERN_VER = $(shell uname -r)
#KERN_DIR = /lib/modules/$(KERN_VER)/build


# 开发板的linux内核的源码树目录
KERN_DIR = /root/driver/kernel

obj-m    += module_test.o

all:
make -C $(KERN_DIR) M=`pwd` modules

cp:
cp *.ko /root/chensong/test/driver_test

.PHONY: clean    
clean:
make -C $(KERN_DIR) M=`pwd` modules clean

3, 开发模块的信息
module_init(chensongdev_init);
module_exit(chensongdev_exit);

// MODULE_xxx 添加模块信息
MODULE_LICENSE("GPL"); // 许可证
MODULE_AUTHOR("chensong"); //模块作者
MODULE_DESCRIPTION("led test"); //模块介绍信息
MODULE_ALIAS("alias chenli"); //模块别名信息

4, 简单helloworld

hello.c

#include <linux/init.h>
#include <linux/module.h>
MODULE_LICENSE("Dual BSD/GPL");   //内核2.6以上版本建议我们加上这个license
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);
// MODULE_xxx 添加模块信息
MODULE_LICENSE("GPL"); // 许可证
MODULE_AUTHOR("chensong"); //模块作者
MODULE_DESCRIPTION("hello wrold test"); //模块介绍信息
MODULE_ALIAS("alias chenli"); //模块别名信息

Makefile

KERN_VER = $(shell uname -r)  ## linux 
KERN_DIR = /lib/modules/$(KERN_VER)/build


# 开发板的linux内核的源码树目录
#KERN_DIR = /root/driver/kernel

obj-m    += hello.o

all:
        make -C $(KERN_DIR) M=`pwd` modules

cp:
        cp *.ko /root/porting_x210/rootfs/rootfs/driver_test

.PHONY: clean    
clean:
        make -C $(KERN_DIR) M=`pwd` modules clean

驱动helloworld

二, 下载linux内核代码分析

驱动的接口

实例

个人博客地址:https://chensongpoixs.github.io

0.基础的基础 |-学习WIN64驱动开发的硬件准备 |-配置驱动开发环境 ------------------------------ 1.驱动HelloWorld |-配置驱动测试环境 |-编译和加载内核HelloWorld ------------------------------ 2.内核编程基础 |-WIN64内核编程的基本规则 |-驱动程序与应用程序通信 |-内核里使用内存 |-内核里操作字符串 |-内核里操作文件 |-内核里操作注册表 |-内核里操作进线程 |-驱动里的其它常用代码 ------------------------------ 3.内核HOOK与UNHOOK |-系统调用、WOW64与兼容模式 |-编程实现突破WIN7的PatchGuard |-系统服务描述表结构详解 |-SSDT HOOK和UNHOOK |-SHADOW SSDT HOOK和UNHOOK |-INLINE HOOK和UNHOOK ------------------------------ 4.无HOOK监控技术 |-无HOOK监控进线程启动和退出 |-无HOOK监控模块加载 |-无HOOK监控注册表操作 |-无HOOK监控文件操作 |-无HOOK监控进线程句柄操作 |-使用对象回调监视文件访问 |-无HOOK监控网络访问 |-无HOOK监视修改时间 ------------------------------ 5.零散内容 |-驱动里实现内嵌汇编 |-DKOM隐藏进程+保护进程 |-枚举和隐藏内核模块 |-强制结束进程 |-强制读写进程内存 |-枚举消息钩子 |-强制解锁文件 |-初步探索PE32+格式文件 ------------------------------ 6.用户态HOOK与UNHOOK |-RING3注射DLL到系统进程 |-RING3的INLINE HOOK和UNHOOK |-RING3的EAT HOOK和IAT HOOK ------------------------------ 7.反回调 |-枚举与删除创建进线程回调 |-枚举与删除加载映像回调 |-枚举与删除注册表回调 |-枚举与对抗MiniFilter |-枚举与删除对象回调
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值