mirror of
https://github.com/torvalds/linux.git
synced 2026-04-18 14:53:58 -04:00
ublk: widen ublk_shmem_buf_reg.len to __u64 for 4GB buffer support
The __u32 len field cannot represent a 4GB buffer (0x100000000 overflows to 0). Change it to __u64 so buffers up to 4GB can be registered. Add a reserved field for alignment and validate it is zero. The kernel enforces a default max of 4GB (UBLK_SHMEM_BUF_SIZE_MAX) which may be increased in future. Signed-off-by: Ming Lei <tom.leiming@gmail.com> Link: https://patch.msgid.link/20260409133020.3780098-2-tom.leiming@gmail.com Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
@@ -63,6 +63,9 @@
|
||||
#define UBLK_CMD_REG_BUF _IOC_NR(UBLK_U_CMD_REG_BUF)
|
||||
#define UBLK_CMD_UNREG_BUF _IOC_NR(UBLK_U_CMD_UNREG_BUF)
|
||||
|
||||
/* Default max shmem buffer size: 4GB (may be increased in future) */
|
||||
#define UBLK_SHMEM_BUF_SIZE_MAX (1ULL << 32)
|
||||
|
||||
#define UBLK_IO_REGISTER_IO_BUF _IOC_NR(UBLK_U_IO_REGISTER_IO_BUF)
|
||||
#define UBLK_IO_UNREGISTER_IO_BUF _IOC_NR(UBLK_U_IO_UNREGISTER_IO_BUF)
|
||||
|
||||
@@ -5351,11 +5354,15 @@ static int ublk_ctrl_reg_buf(struct ublk_device *ub,
|
||||
if (buf_reg.flags & ~UBLK_SHMEM_BUF_READ_ONLY)
|
||||
return -EINVAL;
|
||||
|
||||
if (buf_reg.reserved)
|
||||
return -EINVAL;
|
||||
|
||||
addr = buf_reg.addr;
|
||||
size = buf_reg.len;
|
||||
nr_pages = size >> PAGE_SHIFT;
|
||||
|
||||
if (!size || !PAGE_ALIGNED(size) || !PAGE_ALIGNED(addr))
|
||||
if (!size || size > UBLK_SHMEM_BUF_SIZE_MAX ||
|
||||
!PAGE_ALIGNED(size) || !PAGE_ALIGNED(addr))
|
||||
return -EINVAL;
|
||||
|
||||
disk = ublk_get_disk(ub);
|
||||
|
||||
Reference in New Issue
Block a user