免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2110 | 回复: 1
打印 上一主题 下一主题

求救..一个块设备的问题... [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-05-11 22:45 |只看该作者 |倒序浏览
很悲催, 我自己根据sbull简化的块设备出问题了...搞了几天都没解决.!
在mkfs.ext3 /dev/my_block 的时候...卡在Writing superblocks and filesystem accounting information:  /*这里*/

-,- 实在想不通哪出问题了.!.. 以下是代码,  哪个好心的帮我解决一下....
还有就是- - 有没有关于驱动的群... .我自己QQ上加的群都没几个人说话- - 一问问题群就冷清了.!

#include <linux/module.h>
#include <linux/slab.h>
#include <linux/moduleparam.h>
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/fs.h>
#include <linux/errno.h>
#include <linux/kdev_t.h>
#include <linux/blkdev.h>
#include <linux/genhd.h>
#include <linux/vmalloc.h>
#include <linux/types.h>
#include <linux/buffer_head.h>
#include <linux/fcntl.h>
#include <linux/sched.h>

MODULE_LICENSE("GPL");
#define MY_BLOCK_SIZE (16*1024*1024)

static int block_major = 0;
module_param(block_major, int , 0);

struct block_dev{
        int size;      
        u8 *data;
        spinlock_t lock;      
        struct request_queue *queue;
        struct gendisk *gd;
};

struct block_dev *Devices = NULL;

static void  block_transfer(struct block_dev *dev, unsigned long  sector,
                                 unsigned long  nsect, char *buffer, int write)
{
        unsigned long offset = sector << 9;
        unsigned long nbytes = nsect << 9;

        if ((offset + nbytes) > dev->size)
        {
                printk(KERN_NOTICE "Beyond-end write (%lu %lu)\n", offset, nbytes);
                return;
        }

        if (write == WRITE)
        memcpy(dev->data + offset, buffer , nbytes);

        else
        memcpy(buffer, dev->data + offset, nbytes);
}

static void block_request(struct request_queue *q)
{
        struct request *req;

        while((req = blk_fetch_request(q)) != NULL)
        {
                struct block_dev *dev = req->rq_disk->private_data;

                if (!blk_fs_request(req))
                {
                        printk(KERN_ALERT "Blk_fs_request error");
                        __blk_end_request_all(req, -1);
                        continue;
                }


                block_transfer(dev, blk_rq_pos(req), blk_rq_cur_sectors(req),
                                                req->buffer, rq_data_dir(req));
                        __blk_end_request_cur(req, 0);
        }
}

static struct block_device_operations block_fops ={
        .owner                = THIS_MODULE,
};

static int __init block_init(void)
{
        block_major = register_blkdev(block_major, "My_block");
        if (block_major <= 0){
                printk(KERN_ALERT "Register blkdev error:%d", block_major);
                return 0;
        }

        Devices = kmalloc(sizeof(struct block_dev), GFP_KERNEL);
        if (Devices == NULL){
                printk(KERN_ALERT "Kmalloc error");      
                unregister_blkdev(block_major, "My_block");
                return -ENOMEM;
        }

        memset(Devices, 0, sizeof(struct block_dev));
        Devices -> size = MY_BLOCK_SIZE;
        Devices -> data = vmalloc(Devices->size);
        if (Devices->data == NULL){
                printk(KERN_ALERT"Vmalloc error");
                return ENOMEM;;
        }
        spin_lock_init(&Devices->lock);

        Devices->queue = blk_init_queue(block_request, &Devices->lock);
        if (Devices->queue == NULL)
        {
                if (Devices->data)
                        vfree(Devices->data);
                return -ENOMEM;
        }
        Devices->queue->queuedata = Devices;
        blk_queue_logical_block_size(Devices->queue, 512);
               

        Devices->gd = alloc_disk(1);
        if (! Devices->gd)
        {
                if (Devices->data)
                        vfree(Devices->data);
                return -ENOMEM;
        }

        strcpy(Devices->gd->disk_name, "My_block");
        Devices->gd->major = block_major;
        Devices->gd->first_minor = 0;
        Devices->gd->fops = &block_fops;
        Devices->gd->queue = Devices->queue;
        Devices->gd->private_data  = Devices;
        set_capacity(Devices->gd, MY_BLOCK_SIZE>>9);
        add_disk(Devices->gd);

        return 0;

}

static void __exit block_exit(void)
{
        if (Devices->gd)
                del_gendisk(Devices->gd);

        if (Devices->queue)
                blk_cleanup_queue(Devices->queue);

        if (Devices -> data)
                vfree(Devices->data);

        unregister_blkdev(block_major, "My_block");
        kfree(Devices);
}

module_init(block_init);
module_exit(block_exit);

论坛徽章:
0
2 [报告]
发表于 2013-08-22 16:35 |只看该作者
我可以给你说怎么解决,但是为什么这样解决我也不清楚。。可以探讨  qq:1193533825
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP