2。4里是通过2个全局变量来设置每个设备信息
int blk_size[][];
该数组通过主设备号和次设备号索引。它描述了每个设备的大小,以千字节为单位。如果 blk_size[major] 为 NULL,则不会检查该设备的大小(也就是说,内核可以访问超过设备尾部的数据)。
int blksize_size[][];
该 数组包含了每个设备所使用的块大小,以字节为单位。和前述数组一样,该二维数组也通过主设备号和次设备号索引。如果 blksize_size[major] 为空指针,则假定块的尺寸为 BLOCK_SIZE(当前定义为 1 KB)。设备的块大小必须是 2 的幂,这是因为内核使用位移操作将偏移量转换成块编号。
int set_blocksize(kdev_t dev, int size)
内核函数改blksize, 其实就是修改上述指针指向的内容, fs/fat ext 等等都用到。 但是都是在内部使用,没有EXPORT出来
2。6就是用内核的函数来设置
blk_queue_hardsect_size(md->queue.queue, 1 << md->block_bits);
set_capacity(md->disk, card->csd.capacity);
udelay(超过1000) 竟然不好用了, 必须mdelay 呵呵
int blk_size[][];
该数组通过主设备号和次设备号索引。它描述了每个设备的大小,以千字节为单位。如果 blk_size[major] 为 NULL,则不会检查该设备的大小(也就是说,内核可以访问超过设备尾部的数据)。
int blksize_size[][];
该 数组包含了每个设备所使用的块大小,以字节为单位。和前述数组一样,该二维数组也通过主设备号和次设备号索引。如果 blksize_size[major] 为空指针,则假定块的尺寸为 BLOCK_SIZE(当前定义为 1 KB)。设备的块大小必须是 2 的幂,这是因为内核使用位移操作将偏移量转换成块编号。
int set_blocksize(kdev_t dev, int size)
内核函数改blksize, 其实就是修改上述指针指向的内容, fs/fat ext 等等都用到。 但是都是在内部使用,没有EXPORT出来
2。6就是用内核的函数来设置
blk_queue_hardsect_size(md->queue.queue, 1 << md->block_bits);
set_capacity(md->disk, card->csd.capacity);
udelay(超过1000) 竟然不好用了, 必须mdelay 呵呵