1

我为块设备(Linux,Ubuntu 16)开发了一个“过滤器”,在初始化过滤器驱动程序期间,我尝试了后端(现有设备)的队列指针, bdev_get_queue宏的主体显示很酷的评论“这永远不会NULL",但我为struct block_device的bd_disk字段设置了NULL 。

我还需要检查什么?

static int __init dua_init(void)
{
    int status;
    struct request_queue *backend_queue = NULL;
    struct super_block *sb = NULL;

    printk(KERN_NOTICE __MODULE__ ": Initialize the driver ...\n");

    if ( IS_ERR(backend_bdev = lookup_bdev(dudrv_bckend, FMODE_READ)) )
        {
        status = PTR_ERR(backend_bdev);
        printk(KERN_ERR __MODULE__ ": lookup_bdev(%s) -> %d\n", dudrv_bckend, status);
        return  status;
        }

    $DELAY(1);

    if ( sb = freeze_bdev(backend_bdev) )
        $TRACE(": freeze I/O on block device %s ...", dudrv_bckend);

    $DELAY(1);

    $TRACE(" %p ", backend_bdev->bd_disk);

    $DELAY(1);

    backend_queue = bdev_get_queue(backend_bdev);

    $TRACE(" -- ");

    $DELAY(1);

    if ( backend_make_request_fn != backend_queue->make_request_fn )
        {
        backend_make_request_fn = backend_queue->make_request_fn;
        backend_queue->make_request_fn = dua_make_request_fn;

        $TRACE(": Change for %s request_fn = %p -> %p, ", dudrv_bckend, backend_make_request_fn, backend_queue->make_request_fn);
        }
    else    {
        printk(KERN_NOTICE __MODULE__ ": I/O request process has been set.\n");
        }

    $TRACE(" -- ");

    /* unlock filesystem */
    $DELAY(1);
    if ( sb )
        if (status = thaw_bdev(backend_bdev, sb))
            printk(KERN_NOTICE __MODULE__ ": thaw_bdev() -> %d\n", status);

    printk(KERN_NOTICE __MODULE__ ": End the driver initialization.\n");

    return 0;
}

更新1:队列的指针应该由bdev_get_queuestruct block_device返回有什么区别。bd_queue ?

4

1 回答 1

0

lookup_bdev() 不会创建完整的块 I/O 上下文。

于 2018-01-22T11:19:51.790 回答