块设备驱动的框架:
调用过程自上而下为:应用程序读写文件—>虚拟文件系统(ext3, yaffs2, jffs2)—>由ll_rw_block函数转换成扇区的读写—>块设备驱动程序—>读写硬件
块设备驱动程序提供一个队列,将读操作和写操作放入队列内,并且在队列中优化读写顺序使得读写占用时间减小(这就是为什么有时候读的数据可能并不是真正从磁盘上读来的而是cache中),设备驱动另外必要的功能就是要注册设备。原理上字符设备也同样可以对字盘读写,只是少了块设备驱动那样的电梯调度算法。
块设备驱动中重要的数据结构:
struct gendisk:可使用函数alloc_disk分配;
一个简单的块设备驱动需要给以下结构体内的值进行赋值:
struct gendisk {
/* major, first_minor and minors are input parameters only,
* don't use directly. Use disk_devt() and disk_max_parts().
*/
…………
struct request_queue *queue;//使用blk_init_queue函数设置队列,队列中包括读写的操作
int major; /* major number of driver *///使用register_blkdev注册到一个主设备号
int first_minor;
int minors; /* maximum number of minors, =1 for
* disks that can't be partitioned. */
char disk_name[DISK_NAME_LEN];/* name of major driver */
struct block_device_operations *fops;
struct hd_struct part0;//使用set_capacity函数设置有多少个扇区
…………
};
最后注册gendisk,使用函数:add_disk函数。
对以上相关的结构体进行反注册的函数有:unregister_blkdev(major, "blockdisk");del_gendisk(block_disk);put_disk(block_disk);blk_cleanup_queue(block_queue);
关于调试块设备的相关命令:
mkdosfs&