static struct kmem_cache *buf_pool_cache;
 static struct dentry *aoe_debugfs_dir;
 
-/* GPFS needs a larger value than the default. */
-static int aoe_maxsectors;
+/* random default picked from the historic block max_sectors cap */
+static int aoe_maxsectors = 2560;
 module_param(aoe_maxsectors, int, 0644);
 MODULE_PARM_DESC(aoe_maxsectors,
        "When nonzero, set the maximum number of sectors per I/O request");
        mempool_t *mp;
        struct blk_mq_tag_set *set;
        sector_t ssize;
+       struct queue_limits lim = {
+               .max_hw_sectors         = aoe_maxsectors,
+               .io_opt                 = SZ_2M,
+       };
        ulong flags;
        int late = 0;
        int err;
                goto err_mempool;
        }
 
-       gd = blk_mq_alloc_disk(set, NULL, d);
+       gd = blk_mq_alloc_disk(set, &lim, d);
        if (IS_ERR(gd)) {
                pr_err("aoe: cannot allocate block queue for %ld.%d\n",
                        d->aoemajor, d->aoeminor);
        WARN_ON(d->flags & DEVFL_TKILL);
        WARN_ON(d->gd);
        WARN_ON(d->flags & DEVFL_UP);
-       /* random number picked from the history block max_sectors cap */
-       blk_queue_max_hw_sectors(gd->queue, 2560u);
-       blk_queue_io_opt(gd->queue, SZ_2M);
        d->bufpool = mp;
        d->blkq = gd->queue;
        d->gd = gd;
-       if (aoe_maxsectors)
-               blk_queue_max_hw_sectors(gd->queue, aoe_maxsectors);
        gd->major = AOE_MAJOR;
        gd->first_minor = d->sysminor;
        gd->minors = AOE_PARTITIONS;