Linux2.6内核驱动移植参考

作者:晏渭川
随着linux2.6的发布,由于2.6内核做了教的改动,各个设备的驱动程序在不同程度上要
进行改写。为了方便各位linux爱好者我把自己整理的这分文档share出来。该文当列举
了2.6内核同以前版本的绝大多数变化,可惜的是由于时间和精力有限没有详细列出各个
函数的用法。
特别声明:该文档中的内容来自http:/lwn.net,该网也上也有各个函数的较为详细的
说明可供各位参考。如果需要该文档的word版的朋友, 请mail到weiriver@sohu.com索
取。
1、 使用新的入口
必须包含
module_init(your_init_func);
module_exit(your_exit_func);
老版本:int init_module(void);
void cleanup_module(voi);
2.4中两种都可以用,对如后面的入口函数不必要显示包含任何头文件。
2、 gpl
module_license(dual bsd/gpl);
老版本:module_license(gpl);
3、 模块参数
必须显式包含
module_param(name, type, perm);
module_param_named(name, value, type, perm);
参数定义
module_param_string(name, string, len, perm);
module_param_array(name, type, num, perm);
老版本:module_parm(variable,type);
module_parm_desc(variable,type);
4、 模块别名
module_alias(alias-name);
这是新增的,在老版本中需在/etc/modules.conf配置,现在在代码中就可以实现。
5、 模块计数
int try_module_get(&module);
module_put();
老版本:mod_inc_use_count 和 mod_dec_use_count
6、 符号导出
只有显示的导出符号才能被其他模块使用,默认不导出所有的符号,不必使用export_no
_symbols
老板本:默认导出所有的符号,除非使用export_no_symbols
7、 内核版本检查
需要在多个文件中包含时,不必定义__no_version__
老版本:在多个文件中包含时,除在主文件外的其他文件中必须定义_
_no_version__,防止版本重复定义。
8、 设备号
kdev_t被废除不可用,新的dev_t拓展到了32位,12位主设备号,20位次设备号。
unsigned int iminor(struct inode *inode);
unsigned int imajor(struct inode *inode);
老版本:8位主设备号,8位次设备号
int major(kdev_t dev);
int minor(kdev_t dev);
9、 内存分配头文件变更
所有的内存分配函数包含在头文件,而原来的不存在
老版本:内存分配函数包含在头文件
10、 结构体的初试化
gcc开始采用ansi c的struct结构体的初始化形式:
static struct some_structure = {
.field1 = value,
.field2 = value,
..
};
老版本:非标准的初试化形式
static struct some_structure = {
field1: value,
field2: value,
..
};
11、 用户模式帮助器
int call_usermodehelper(char *path, char **argv, char **envp,
int wait);
新增wait参数
12、 request_module()
request_module(foo-device-%d, number);
老版本:
char module_name[32];
printf(module_name, foo-device-%d, number);
request_module(module_name);
13、 dev_t引发的字符设备的变化
1、取主次设备号为
unsigned iminor(struct inode *inode);
unsigned imajor(struct inode *inode);
2、老的register_chrdev()用法没变,保持向后兼容,但不能访问设备号大于256的设备

3、新的接口为
a)注册字符设备范围
int register_chrdev_region(dev_t from, unsigned count, char *name);
b)动态申请主设备号
int alloc_chrdev_region(dev_t *dev, unsigned baseminor, unsigned count, char
*name);
看了这两个函数郁闷吧^_^!怎么和file_operations结构联系起来啊?别急!
c)包含 ,利用struct cdev和file_operations连接
struct cdev *cdev_alloc(void);
void cdev_init(struct cdev *cdev, struct file_operations *fops);
int cdev_add(struct cdev *cdev, dev_t dev, unsigned count);
(分别为,申请cdev结构,和fops连接,将设备加入到系统中!好复杂啊!)
d)void cdev_del(struct cdev *cdev);
只有在cdev_add执行成功才可运行。
e)辅助函数
kobject_put(&cdev->kobj);
struct kobject *cdev_get(struct cdev *cdev);
void cdev_put(struct cdev *cdev);
这一部分变化和新增的/sys/dev有一定的关联。
14、 新增对/proc的访问操作
以前的/proc中只能得到string, seq_file操作能得到如long等多种数据。
相关函数:
static struct seq_operations 必须实现这个类似file_operations得数据中得各个成
员函数。
seq_printf();
int seq_putc(struct seq_file *m, char c);
int seq_puts(struct seq_file *m, const char *s);
int seq_escape(struct seq_file *m, const char *s, const char *esc);
int seq_path(struct seq_file *m, struct vfsmount *mnt,
struct dentry *dentry, char *esc);
seq_open(file, &ct_seq_ops);
等等
15、 底层内存分配
1、头文件改为

基于FPGA的系统易测试性的研究
苹果计划在2024年iPhone 16上使用第一代3纳米芯片
联通扭转颓势,联通显示出后继乏力
远大新风肺保FE6拆解评测 方面表现都达到很高的水准
安森美半导体推出BelaSigna R261高性能语音捕获SoC
Linux2.6内核驱动移植参考
PWM是如何工作的
功率放大器在无线电能传输系统中的应用
来了!微信7.0.20 for Android正式版已经发布
NVIDIA 邀您参加 —— AI 软硬件协同开发技术交流与人才发展分享会
【解读】磁铁的磁性究竟来源于哪里
Zigbee 3.0网络优化的一些方法和建议
人工智能技术:如何突破机器学习的先验假设
骨传导耳机危害有哪些?骨传导耳机对听力有害吗?
全球十大电视制造商计划在2021年购买2亿块液晶电视面板
索尼4KHDR液晶电视X9500G芯片强大 让画面品质更进一步
HTC Vive推出VR开发者比赛 将面向全球的VR开发者
未来“电机驱动与控制”的四大特性!
大尺寸电视背光源订单增多,LED厂商业绩看涨
【模拟电路设计】输入失调电压