]> git.ipfire.org Git - thirdparty/linux.git/commit
interconnect: mediatek: Aggregate bandwidth with saturating add
authorNicolas Frattaroli <nicolas.frattaroli@collabora.com>
Mon, 24 Nov 2025 11:07:02 +0000 (12:07 +0100)
committerGeorgi Djakov <djakov@kernel.org>
Sun, 21 Dec 2025 11:59:54 +0000 (13:59 +0200)
commit6ffd02b82243d9907b5f5d2c7a2fc6a62669eece
treed2cc9a565b28a656c916fb3dee4cfcc48d184f5f
parent510f8214440c553e81774c5822437ccf154e9e38
interconnect: mediatek: Aggregate bandwidth with saturating add

By using a regular non-overflow-checking add, the MediaTek icc-emi
driver will happy wrap at U32_MAX + 1 to 0. As it's common for the
interconnect core to fill in INT_MAX values, this is not a hypothetical
situation, but something that actually happens in regular use. This
would be pretty disasterous if anything used this driver.

Replace the addition with an overflow-checked addition from overflow.h,
and saturate to U32_MAX if an overflow is detected.

Fixes: b45293799f75 ("interconnect: mediatek: Add MediaTek MT8183/8195 EMI Interconnect driver")
Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
Signed-off-by: Nicolas Frattaroli <nicolas.frattaroli@collabora.com>
Link: https://lore.kernel.org/r/20251124-mt8196-dvfsrc-v2-13-d9c1334db9f3@collabora.com
Signed-off-by: Georgi Djakov <djakov@kernel.org>
drivers/interconnect/mediatek/icc-emi.c