Commit 94cd8329 authored by Pavel Begunkov's avatar Pavel Begunkov Committed by Jens Axboe
Browse files

io_uring: use size_add helpers for ring offsets



Use size_add / size_mul set of functions for rings_size() calculations.
It's more consistent with struct_size(), and errors are preserved across
a series of calculations, so intermediate result checks can be omitted.

Signed-off-by: default avatarPavel Begunkov <asml.silence@gmail.com>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent e279bb4b
Loading
Loading
Loading
Loading
+8 −10
Original line number Diff line number Diff line
@@ -2765,13 +2765,6 @@ unsigned long rings_size(unsigned int flags, unsigned int sq_entries,

	*sq_offset = SIZE_MAX;

	off = struct_size(rings, cqes, cq_entries);
	if (off == SIZE_MAX)
		return SIZE_MAX;
	if (flags & IORING_SETUP_CQE32) {
		if (check_shl_overflow(off, 1, &off))
			return SIZE_MAX;
	}
	if (flags & IORING_SETUP_CQE_MIXED) {
		if (cq_entries < 2)
			return SIZE_MAX;
@@ -2781,6 +2774,12 @@ unsigned long rings_size(unsigned int flags, unsigned int sq_entries,
			return SIZE_MAX;
	}

	off = struct_size(rings, cqes, cq_entries);
	if (flags & IORING_SETUP_CQE32)
		off = size_mul(off, 2);
	if (off == SIZE_MAX)
		return SIZE_MAX;

#ifdef CONFIG_SMP
	off = ALIGN(off, SMP_CACHE_BYTES);
	if (off == 0)
@@ -2793,9 +2792,8 @@ unsigned long rings_size(unsigned int flags, unsigned int sq_entries,
		*sq_offset = off;

		sq_array_size = array_size(sizeof(u32), sq_entries);
		if (sq_array_size == SIZE_MAX)
			return SIZE_MAX;
		if (check_add_overflow(off, sq_array_size, &off))
		off = size_add(off, sq_array_size);
		if (off == SIZE_MAX)
			return SIZE_MAX;
	}