Linux设备驱动程序——简单字符设备驱动程序
一、重要知识点
1. 主次设备号
dev_t
dev_t是内核中用来表示设备编号的数据类型;
int MAJOR(dev_t dev)
int MINOR(dev_t dev)
这两个宏抽取主次设备号。
dev_t MKDEV(unsigned int major, unsignedint minor)
这个宏由主/次设备号构造一个dev_t结构。
2. 分配和释放设备号
int register_chardev_region(dev_t first,unsigned int count, char *name)
静态申请设备号。
Int alloc_chardev_region(dev_t *dev,unsigned int firstminor, unsigned int count, char *name)
动态申请设备号,注意第一个参数是传地址,而静态则是传值。
3. 几种重要的数据结构
struct file
file结构代表一个打开的文件,它由内核在open时创建,并传递给该文件上进行操作的所有函数,直到最后的close函数。
file结构private_data是跨系统调用时保存状态信息非常有用的资源。
file结构的f_ops 保存了文件的当前读写位置。
struct inode
内核用inode代表一个磁盘上的文件,它和file结构不同,后者表示打开的文件描述符。对于单个文件,可能会有许多个表示打开文件的文件描述符file结构,但他们都指单个inode结构。inode的dev_t i_rdev成员包含了真正的设备编号,struct cdev *i_cdev包含了指向struct cdev结构的指针。
struct file_operations
file_operations结构保存了字符设备驱动程序的方法。
4. 字符设备的注册和注销
struct cdev *cdev_alloc(void);
void cdev_init(struct cdev *dev, structfile_operations *fops);
int cdev_add(struct cdev *dev, dev_t num,unsigned int count);
void cdev_del(struct cdev *dev);
用来管理cdev结构的函数,内核中使用该结构表示字符设备。注意cdev_add函数的count参数为次设备的个数,要想拥有多个次设备,就必须将该参数设为次设备的个数。
5. 并发处理
信号量和自旋锁的区别,使用信号量时当调用进程试图获得一个锁定了的锁时会导致进程睡眠,而自旋锁则是一直循法的等待一直到该锁解锁了为止。
1)信号量
DECLARE_MUTEX(name);
DECLARE_MUTEX_LOCKED(name);
声明和初始化用在互斥模式中的信号量的两个宏
void init_MUTEX(struct semaphore *sem)
void init_MUTEX_LOCKER(struct semaphore*sem);
这两个函数可以在运行时初始化信号量
void down(struct semaphore *sem);
int down_interruptible(struct semaphore*sem);
int down_trylock(struct semahpore *sem);
void up(struct semaphore *sem);
锁定和解锁信号量。如果必要,down会将调用进程置于不可中断的休眠状态;相反,down_interruptible可被信号中断。down_trylock不会休眠,并且会在信号量不可用时立即返回。锁定信号量的代码最后必须使用up解锁该信号量。
2)自旋锁
spionlock_t lock = SPIN_LOCK_UNLOCKED;
spin_lock_init(spinlock_t *lock);
初始化自旋锁的两种方式。
voidspin_lock(spinlock_t *lock);
锁定自旋锁
voidspin_unlock(spinlock_t *lock);
解锁自旋锁
&
相关新闻>>
- 发表评论
-
- 最新评论 更多>>