In the Linux kernel, the following vulnerability has been resolved:
rtnetlink: fix error logic of IFLA_BRIDGE_FLAGS writing back
In the commit d73ef2d69c0d (“rtnetlink: let rtnl_bridge_setlink checks
IFLA_BRIDGE_MODE length”), an adjustment was made to the old loop logic
in the function rtnl_bridge_setlink
to enable the loop to also check
the length of the IFLA_BRIDGE_MODE attribute. However, this adjustment
removed the break
statement and led to an error logic of the flags
writing back at the end of this function.
if (have_flags)
memcpy(nla_data(attr), &flags, sizeof(flags));
// attr should point to IFLA_BRIDGE_FLAGS NLA !!!
Before the mentioned commit, the attr
is granted to be IFLA_BRIDGE_FLAGS.
However, this is not necessarily true fow now as the updated loop will let
the attr point to the last NLA, even an invalid NLA which could cause
overflow writes.
This patch introduces a new variable br_flag
to save the NLA pointer
that points to IFLA_BRIDGE_FLAGS and uses it to resolve the mentioned
error logic.
[
{
"repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
"vendor": "Linux",
"product": "Linux",
"versions": [
{
"status": "affected",
"version": "ad46d4861ed3",
"lessThan": "b9fbc44159df",
"versionType": "git"
},
{
"status": "affected",
"version": "abb0172fa8dc",
"lessThan": "882a51a10ecf",
"versionType": "git"
},
{
"status": "affected",
"version": "047508edd602",
"lessThan": "a1227b27fccc",
"versionType": "git"
},
{
"status": "affected",
"version": "8dfac8071d58",
"lessThan": "f2261eb994aa",
"versionType": "git"
},
{
"status": "affected",
"version": "d73ef2d69c0d",
"lessThan": "167d8642daa6",
"versionType": "git"
},
{
"status": "affected",
"version": "d73ef2d69c0d",
"lessThan": "831bc2728fb4",
"versionType": "git"
},
{
"status": "affected",
"version": "d73ef2d69c0d",
"lessThan": "743ad091fb46",
"versionType": "git"
}
],
"programFiles": [
"net/core/rtnetlink.c"
],
"defaultStatus": "unaffected"
},
{
"repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
"vendor": "Linux",
"product": "Linux",
"versions": [
{
"status": "affected",
"version": "6.5"
},
{
"status": "unaffected",
"version": "0",
"lessThan": "6.5",
"versionType": "custom"
},
{
"status": "unaffected",
"version": "5.4.271",
"versionType": "custom",
"lessThanOrEqual": "5.4.*"
},
{
"status": "unaffected",
"version": "5.10.212",
"versionType": "custom",
"lessThanOrEqual": "5.10.*"
},
{
"status": "unaffected",
"version": "5.15.151",
"versionType": "custom",
"lessThanOrEqual": "5.15.*"
},
{
"status": "unaffected",
"version": "6.1.81",
"versionType": "custom",
"lessThanOrEqual": "6.1.*"
},
{
"status": "unaffected",
"version": "6.6.21",
"versionType": "custom",
"lessThanOrEqual": "6.6.*"
},
{
"status": "unaffected",
"version": "6.7.9",
"versionType": "custom",
"lessThanOrEqual": "6.7.*"
},
{
"status": "unaffected",
"version": "6.8",
"versionType": "original_commit_for_fix",
"lessThanOrEqual": "*"
}
],
"programFiles": [
"net/core/rtnetlink.c"
],
"defaultStatus": "affected"
}
]
git.kernel.org/stable/c/167d8642daa6a44b51de17f8ff0f584e1e762db7
git.kernel.org/stable/c/743ad091fb46e622f1b690385bb15e3cd3daf874
git.kernel.org/stable/c/831bc2728fb48a8957a824cba8c264b30dca1425
git.kernel.org/stable/c/882a51a10ecf24ce135d573afa0872aef02c5125
git.kernel.org/stable/c/a1227b27fcccc99dc44f912b479e01a17e2d7d31
git.kernel.org/stable/c/b9fbc44159dfc3e9a7073032752d9e03f5194a6f
git.kernel.org/stable/c/f2261eb994aa5757c1da046b78e3229a3ece0ad9
lists.debian.org/debian-lts-announce/2024/06/msg00017.html