Description
In the Linux kernel, the following vulnerability has been resolved: dpaa2-switch: validate num_ifs to prevent out-of-bounds write The driver obtains sw_attr.num_ifs from firmware via dpsw_get_attributes() but never validates it against DPSW_MAX_IF (64). This value controls iteration in dpaa2_switch_fdb_get_flood_cfg(), which writes port indices into the fixed-size cfg->if_id[DPSW_MAX_IF] array. When firmware reports num_ifs >= 64, the loop can write past the array bounds. Add a bound check for num_ifs in dpaa2_switch_init(). dpaa2_switch_fdb_get_flood_cfg() appends the control interface (port num_ifs) after all matched ports. When num_ifs == DPSW_MAX_IF and all ports match the flood filter, the loop fills all 64 slots and the control interface write overflows by one entry. The check uses >= because num_ifs == DPSW_MAX_IF is also functionally broken. build_if_id_bitmap() silently drops any ID >= 64: if (id[i] < DPSW_MAX_IF) bmap[id[i] / 64] |= ...
Product status
539dda3c5d190c5088b5e57944b1b482fcb464de (git) before a26dda3bae469c8e4e1b1993ad33dafa32d0fc28
539dda3c5d190c5088b5e57944b1b482fcb464de (git) before a3034a8d56174dd6464c46823438f25797910a8d
539dda3c5d190c5088b5e57944b1b482fcb464de (git) before b690635d4719214892855b79ce018d4b1672ac96
539dda3c5d190c5088b5e57944b1b482fcb464de (git) before 8b841fd529db9faf8bc678d429d4bf4e98b10900
539dda3c5d190c5088b5e57944b1b482fcb464de (git) before 89764cf44544e943230f5e03b8c40a90da26537c
539dda3c5d190c5088b5e57944b1b482fcb464de (git) before c18493f750208eb4ff1198fc5a02786b8b2d70a6
539dda3c5d190c5088b5e57944b1b482fcb464de (git) before 8a5752c6dcc085a3bfc78589925182e4e98468c5
5.13
Any version before 5.13
5.15.202 (semver)
6.1.165 (semver)
6.6.128 (semver)
6.12.75 (semver)
6.18.16 (semver)
6.19.6 (semver)
7.0 (original_commit_for_fix)
References
git.kernel.org/...c/a26dda3bae469c8e4e1b1993ad33dafa32d0fc28
git.kernel.org/...c/a3034a8d56174dd6464c46823438f25797910a8d
git.kernel.org/...c/b690635d4719214892855b79ce018d4b1672ac96
git.kernel.org/...c/8b841fd529db9faf8bc678d429d4bf4e98b10900
git.kernel.org/...c/89764cf44544e943230f5e03b8c40a90da26537c
git.kernel.org/...c/c18493f750208eb4ff1198fc5a02786b8b2d70a6
git.kernel.org/...c/8a5752c6dcc085a3bfc78589925182e4e98468c5