提交 525ec495 编写于 作者: S Sagi Grimberg 提交者: Christoph Hellwig

nvmet-file: clamp-down file namespace lba_shift

When the backing file is a tempfile for example, the inode i_blkbits
can be 1M in size which causes problems for hosts to support as the
disk block size. Instead, expose the minimum between i_blkbits and
12 (4K sector size).
Signed-off-by: NSagi Grimberg <sagi@grimberg.me>
Reviewed-by: N- Chaitanya Kulkarni <chaitanya.kulkarni@wdc.com>
Signed-off-by: NChristoph Hellwig <hch@lst.de>
上级 a5dffbb6
...@@ -49,7 +49,12 @@ int nvmet_file_ns_enable(struct nvmet_ns *ns) ...@@ -49,7 +49,12 @@ int nvmet_file_ns_enable(struct nvmet_ns *ns)
goto err; goto err;
ns->size = stat.size; ns->size = stat.size;
ns->blksize_shift = file_inode(ns->file)->i_blkbits; /*
* i_blkbits can be greater than the universally accepted upper bound,
* so make sure we export a sane namespace lba_shift.
*/
ns->blksize_shift = min_t(u8,
file_inode(ns->file)->i_blkbits, 12);
ns->bvec_cache = kmem_cache_create("nvmet-bvec", ns->bvec_cache = kmem_cache_create("nvmet-bvec",
NVMET_MAX_MPOOL_BVEC * sizeof(struct bio_vec), NVMET_MAX_MPOOL_BVEC * sizeof(struct bio_vec),
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册