CVE-2024-27414 (GCVE-0-2024-27414)
Vulnerability from cvelistv5
Published
2024-05-17 11:50
Modified
2025-05-04 12:55
Severity ?
Summary
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.
Impacted products
Vendor Product Version
Linux Linux Version: ad46d4861ed36315d3d9e838723ba3e367ecc042
Version: abb0172fa8dc4a4ec51aa992b7269ed65959f310
Version: 047508edd602921ee8bb0f2aa2100aa2e9bedc75
Version: 8dfac8071d58447e5cace4c4c6fe493ce2f615f6
Version: d73ef2d69c0dba5f5a1cb9600045c873bab1fb7f
Version: d73ef2d69c0dba5f5a1cb9600045c873bab1fb7f
Version: d73ef2d69c0dba5f5a1cb9600045c873bab1fb7f
Version: 00757f58e37b2d9a6f99e15be484712390cd2bab
Create a notification for this product.
Show details on NVD website


{
  "containers": {
    "adp": [
      {
        "metrics": [
          {
            "other": {
              "content": {
                "id": "CVE-2024-27414",
                "options": [
                  {
                    "Exploitation": "none"
                  },
                  {
                    "Automatable": "no"
                  },
                  {
                    "Technical Impact": "partial"
                  }
                ],
                "role": "CISA Coordinator",
                "timestamp": "2024-05-21T15:56:59.979228Z",
                "version": "2.0.3"
              },
              "type": "ssvc"
            }
          }
        ],
        "providerMetadata": {
          "dateUpdated": "2024-06-04T17:46:58.154Z",
          "orgId": "134c704f-9b21-4f2e-91b3-4a467353bcc0",
          "shortName": "CISA-ADP"
        },
        "title": "CISA ADP Vulnrichment"
      },
      {
        "providerMetadata": {
          "dateUpdated": "2024-08-02T00:34:52.359Z",
          "orgId": "af854a3a-2127-422b-91ae-364da2661108",
          "shortName": "CVE"
        },
        "references": [
          {
            "tags": [
              "x_transferred"
            ],
            "url": "https://git.kernel.org/stable/c/b9fbc44159dfc3e9a7073032752d9e03f5194a6f"
          },
          {
            "tags": [
              "x_transferred"
            ],
            "url": "https://git.kernel.org/stable/c/882a51a10ecf24ce135d573afa0872aef02c5125"
          },
          {
            "tags": [
              "x_transferred"
            ],
            "url": "https://git.kernel.org/stable/c/a1227b27fcccc99dc44f912b479e01a17e2d7d31"
          },
          {
            "tags": [
              "x_transferred"
            ],
            "url": "https://git.kernel.org/stable/c/f2261eb994aa5757c1da046b78e3229a3ece0ad9"
          },
          {
            "tags": [
              "x_transferred"
            ],
            "url": "https://git.kernel.org/stable/c/167d8642daa6a44b51de17f8ff0f584e1e762db7"
          },
          {
            "tags": [
              "x_transferred"
            ],
            "url": "https://git.kernel.org/stable/c/831bc2728fb48a8957a824cba8c264b30dca1425"
          },
          {
            "tags": [
              "x_transferred"
            ],
            "url": "https://git.kernel.org/stable/c/743ad091fb46e622f1b690385bb15e3cd3daf874"
          },
          {
            "tags": [
              "x_transferred"
            ],
            "url": "https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html"
          }
        ],
        "title": "CVE Program Container"
      }
    ],
    "cna": {
      "affected": [
        {
          "defaultStatus": "unaffected",
          "product": "Linux",
          "programFiles": [
            "net/core/rtnetlink.c"
          ],
          "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
          "vendor": "Linux",
          "versions": [
            {
              "lessThan": "b9fbc44159dfc3e9a7073032752d9e03f5194a6f",
              "status": "affected",
              "version": "ad46d4861ed36315d3d9e838723ba3e367ecc042",
              "versionType": "git"
            },
            {
              "lessThan": "882a51a10ecf24ce135d573afa0872aef02c5125",
              "status": "affected",
              "version": "abb0172fa8dc4a4ec51aa992b7269ed65959f310",
              "versionType": "git"
            },
            {
              "lessThan": "a1227b27fcccc99dc44f912b479e01a17e2d7d31",
              "status": "affected",
              "version": "047508edd602921ee8bb0f2aa2100aa2e9bedc75",
              "versionType": "git"
            },
            {
              "lessThan": "f2261eb994aa5757c1da046b78e3229a3ece0ad9",
              "status": "affected",
              "version": "8dfac8071d58447e5cace4c4c6fe493ce2f615f6",
              "versionType": "git"
            },
            {
              "lessThan": "167d8642daa6a44b51de17f8ff0f584e1e762db7",
              "status": "affected",
              "version": "d73ef2d69c0dba5f5a1cb9600045c873bab1fb7f",
              "versionType": "git"
            },
            {
              "lessThan": "831bc2728fb48a8957a824cba8c264b30dca1425",
              "status": "affected",
              "version": "d73ef2d69c0dba5f5a1cb9600045c873bab1fb7f",
              "versionType": "git"
            },
            {
              "lessThan": "743ad091fb46e622f1b690385bb15e3cd3daf874",
              "status": "affected",
              "version": "d73ef2d69c0dba5f5a1cb9600045c873bab1fb7f",
              "versionType": "git"
            },
            {
              "status": "affected",
              "version": "00757f58e37b2d9a6f99e15be484712390cd2bab",
              "versionType": "git"
            }
          ]
        },
        {
          "defaultStatus": "affected",
          "product": "Linux",
          "programFiles": [
            "net/core/rtnetlink.c"
          ],
          "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
          "vendor": "Linux",
          "versions": [
            {
              "status": "affected",
              "version": "6.5"
            },
            {
              "lessThan": "6.5",
              "status": "unaffected",
              "version": "0",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "5.4.*",
              "status": "unaffected",
              "version": "5.4.271",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "5.10.*",
              "status": "unaffected",
              "version": "5.10.212",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "5.15.*",
              "status": "unaffected",
              "version": "5.15.151",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "6.1.*",
              "status": "unaffected",
              "version": "6.1.81",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "6.6.*",
              "status": "unaffected",
              "version": "6.6.21",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "6.7.*",
              "status": "unaffected",
              "version": "6.7.9",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "*",
              "status": "unaffected",
              "version": "6.8",
              "versionType": "original_commit_for_fix"
            }
          ]
        }
      ],
      "cpeApplicability": [
        {
          "nodes": [
            {
              "cpeMatch": [
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "5.4.271",
                  "versionStartIncluding": "5.4.253",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "5.10.212",
                  "versionStartIncluding": "5.10.190",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "5.15.151",
                  "versionStartIncluding": "5.15.126",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "6.1.81",
                  "versionStartIncluding": "6.1.45",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "6.6.21",
                  "versionStartIncluding": "6.5",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "6.7.9",
                  "versionStartIncluding": "6.5",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "6.8",
                  "versionStartIncluding": "6.5",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionStartIncluding": "6.4.10",
                  "vulnerable": true
                }
              ],
              "negate": false,
              "operator": "OR"
            }
          ]
        }
      ],
      "descriptions": [
        {
          "lang": "en",
          "value": "In the Linux kernel, the following vulnerability has been resolved:\n\nrtnetlink: fix error logic of IFLA_BRIDGE_FLAGS writing back\n\nIn the commit d73ef2d69c0d (\"rtnetlink: let rtnl_bridge_setlink checks\nIFLA_BRIDGE_MODE length\"), an adjustment was made to the old loop logic\nin the function `rtnl_bridge_setlink` to enable the loop to also check\nthe length of the IFLA_BRIDGE_MODE attribute. However, this adjustment\nremoved the `break` statement and led to an error logic of the flags\nwriting back at the end of this function.\n\nif (have_flags)\n    memcpy(nla_data(attr), \u0026flags, sizeof(flags));\n    // attr should point to IFLA_BRIDGE_FLAGS NLA !!!\n\nBefore the mentioned commit, the `attr` is granted to be IFLA_BRIDGE_FLAGS.\nHowever, this is not necessarily true fow now as the updated loop will let\nthe attr point to the last NLA, even an invalid NLA which could cause\noverflow writes.\n\nThis patch introduces a new variable `br_flag` to save the NLA pointer\nthat points to IFLA_BRIDGE_FLAGS and uses it to resolve the mentioned\nerror logic."
        }
      ],
      "providerMetadata": {
        "dateUpdated": "2025-05-04T12:55:42.575Z",
        "orgId": "416baaa9-dc9f-4396-8d5f-8c081fb06d67",
        "shortName": "Linux"
      },
      "references": [
        {
          "url": "https://git.kernel.org/stable/c/b9fbc44159dfc3e9a7073032752d9e03f5194a6f"
        },
        {
          "url": "https://git.kernel.org/stable/c/882a51a10ecf24ce135d573afa0872aef02c5125"
        },
        {
          "url": "https://git.kernel.org/stable/c/a1227b27fcccc99dc44f912b479e01a17e2d7d31"
        },
        {
          "url": "https://git.kernel.org/stable/c/f2261eb994aa5757c1da046b78e3229a3ece0ad9"
        },
        {
          "url": "https://git.kernel.org/stable/c/167d8642daa6a44b51de17f8ff0f584e1e762db7"
        },
        {
          "url": "https://git.kernel.org/stable/c/831bc2728fb48a8957a824cba8c264b30dca1425"
        },
        {
          "url": "https://git.kernel.org/stable/c/743ad091fb46e622f1b690385bb15e3cd3daf874"
        }
      ],
      "title": "rtnetlink: fix error logic of IFLA_BRIDGE_FLAGS writing back",
      "x_generator": {
        "engine": "bippy-1.2.0"
      }
    }
  },
  "cveMetadata": {
    "assignerOrgId": "416baaa9-dc9f-4396-8d5f-8c081fb06d67",
    "assignerShortName": "Linux",
    "cveId": "CVE-2024-27414",
    "datePublished": "2024-05-17T11:50:57.207Z",
    "dateReserved": "2024-02-25T13:47:42.682Z",
    "dateUpdated": "2025-05-04T12:55:42.575Z",
    "state": "PUBLISHED"
  },
  "dataType": "CVE_RECORD",
  "dataVersion": "5.1",
  "vulnerability-lookup:meta": {
    "vulnrichment": {
      "containers": "{\"adp\": [{\"title\": \"CVE Program Container\", \"references\": [{\"url\": \"https://git.kernel.org/stable/c/b9fbc44159dfc3e9a7073032752d9e03f5194a6f\", \"tags\": [\"x_transferred\"]}, {\"url\": \"https://git.kernel.org/stable/c/882a51a10ecf24ce135d573afa0872aef02c5125\", \"tags\": [\"x_transferred\"]}, {\"url\": \"https://git.kernel.org/stable/c/a1227b27fcccc99dc44f912b479e01a17e2d7d31\", \"tags\": [\"x_transferred\"]}, {\"url\": \"https://git.kernel.org/stable/c/f2261eb994aa5757c1da046b78e3229a3ece0ad9\", \"tags\": [\"x_transferred\"]}, {\"url\": \"https://git.kernel.org/stable/c/167d8642daa6a44b51de17f8ff0f584e1e762db7\", \"tags\": [\"x_transferred\"]}, {\"url\": \"https://git.kernel.org/stable/c/831bc2728fb48a8957a824cba8c264b30dca1425\", \"tags\": [\"x_transferred\"]}, {\"url\": \"https://git.kernel.org/stable/c/743ad091fb46e622f1b690385bb15e3cd3daf874\", \"tags\": [\"x_transferred\"]}, {\"url\": \"https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html\", \"tags\": [\"x_transferred\"]}], \"providerMetadata\": {\"orgId\": \"af854a3a-2127-422b-91ae-364da2661108\", \"shortName\": \"CVE\", \"dateUpdated\": \"2024-08-02T00:34:52.359Z\"}}, {\"metrics\": [{\"other\": {\"type\": \"ssvc\", \"content\": {\"id\": \"CVE-2024-27414\", \"role\": \"CISA Coordinator\", \"options\": [{\"Exploitation\": \"none\"}, {\"Automatable\": \"no\"}, {\"Technical Impact\": \"partial\"}], \"version\": \"2.0.3\", \"timestamp\": \"2024-05-21T15:56:59.979228Z\"}}}], \"providerMetadata\": {\"orgId\": \"134c704f-9b21-4f2e-91b3-4a467353bcc0\", \"shortName\": \"CISA-ADP\", \"dateUpdated\": \"2024-05-23T19:01:25.220Z\"}, \"title\": \"CISA ADP Vulnrichment\"}], \"cna\": {\"title\": \"rtnetlink: fix error logic of IFLA_BRIDGE_FLAGS writing back\", \"affected\": [{\"repo\": \"https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git\", \"vendor\": \"Linux\", \"product\": \"Linux\", \"versions\": [{\"status\": \"affected\", \"version\": \"ad46d4861ed36315d3d9e838723ba3e367ecc042\", \"lessThan\": \"b9fbc44159dfc3e9a7073032752d9e03f5194a6f\", \"versionType\": \"git\"}, {\"status\": \"affected\", \"version\": \"abb0172fa8dc4a4ec51aa992b7269ed65959f310\", \"lessThan\": \"882a51a10ecf24ce135d573afa0872aef02c5125\", \"versionType\": \"git\"}, {\"status\": \"affected\", \"version\": \"047508edd602921ee8bb0f2aa2100aa2e9bedc75\", \"lessThan\": \"a1227b27fcccc99dc44f912b479e01a17e2d7d31\", \"versionType\": \"git\"}, {\"status\": \"affected\", \"version\": \"8dfac8071d58447e5cace4c4c6fe493ce2f615f6\", \"lessThan\": \"f2261eb994aa5757c1da046b78e3229a3ece0ad9\", \"versionType\": \"git\"}, {\"status\": \"affected\", \"version\": \"d73ef2d69c0dba5f5a1cb9600045c873bab1fb7f\", \"lessThan\": \"167d8642daa6a44b51de17f8ff0f584e1e762db7\", \"versionType\": \"git\"}, {\"status\": \"affected\", \"version\": \"d73ef2d69c0dba5f5a1cb9600045c873bab1fb7f\", \"lessThan\": \"831bc2728fb48a8957a824cba8c264b30dca1425\", \"versionType\": \"git\"}, {\"status\": \"affected\", \"version\": \"d73ef2d69c0dba5f5a1cb9600045c873bab1fb7f\", \"lessThan\": \"743ad091fb46e622f1b690385bb15e3cd3daf874\", \"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\": \"semver\"}, {\"status\": \"unaffected\", \"version\": \"5.4.271\", \"versionType\": \"semver\", \"lessThanOrEqual\": \"5.4.*\"}, {\"status\": \"unaffected\", \"version\": \"5.10.212\", \"versionType\": \"semver\", \"lessThanOrEqual\": \"5.10.*\"}, {\"status\": \"unaffected\", \"version\": \"5.15.151\", \"versionType\": \"semver\", \"lessThanOrEqual\": \"5.15.*\"}, {\"status\": \"unaffected\", \"version\": \"6.1.81\", \"versionType\": \"semver\", \"lessThanOrEqual\": \"6.1.*\"}, {\"status\": \"unaffected\", \"version\": \"6.6.21\", \"versionType\": \"semver\", \"lessThanOrEqual\": \"6.6.*\"}, {\"status\": \"unaffected\", \"version\": \"6.7.9\", \"versionType\": \"semver\", \"lessThanOrEqual\": \"6.7.*\"}, {\"status\": \"unaffected\", \"version\": \"6.8\", \"versionType\": \"original_commit_for_fix\", \"lessThanOrEqual\": \"*\"}], \"programFiles\": [\"net/core/rtnetlink.c\"], \"defaultStatus\": \"affected\"}], \"references\": [{\"url\": \"https://git.kernel.org/stable/c/b9fbc44159dfc3e9a7073032752d9e03f5194a6f\"}, {\"url\": \"https://git.kernel.org/stable/c/882a51a10ecf24ce135d573afa0872aef02c5125\"}, {\"url\": \"https://git.kernel.org/stable/c/a1227b27fcccc99dc44f912b479e01a17e2d7d31\"}, {\"url\": \"https://git.kernel.org/stable/c/f2261eb994aa5757c1da046b78e3229a3ece0ad9\"}, {\"url\": \"https://git.kernel.org/stable/c/167d8642daa6a44b51de17f8ff0f584e1e762db7\"}, {\"url\": \"https://git.kernel.org/stable/c/831bc2728fb48a8957a824cba8c264b30dca1425\"}, {\"url\": \"https://git.kernel.org/stable/c/743ad091fb46e622f1b690385bb15e3cd3daf874\"}], \"x_generator\": {\"engine\": \"bippy-5f407fcff5a0\"}, \"descriptions\": [{\"lang\": \"en\", \"value\": \"In the Linux kernel, the following vulnerability has been resolved:\\n\\nrtnetlink: fix error logic of IFLA_BRIDGE_FLAGS writing back\\n\\nIn the commit d73ef2d69c0d (\\\"rtnetlink: let rtnl_bridge_setlink checks\\nIFLA_BRIDGE_MODE length\\\"), an adjustment was made to the old loop logic\\nin the function `rtnl_bridge_setlink` to enable the loop to also check\\nthe length of the IFLA_BRIDGE_MODE attribute. However, this adjustment\\nremoved the `break` statement and led to an error logic of the flags\\nwriting back at the end of this function.\\n\\nif (have_flags)\\n    memcpy(nla_data(attr), \u0026flags, sizeof(flags));\\n    // attr should point to IFLA_BRIDGE_FLAGS NLA !!!\\n\\nBefore the mentioned commit, the `attr` is granted to be IFLA_BRIDGE_FLAGS.\\nHowever, this is not necessarily true fow now as the updated loop will let\\nthe attr point to the last NLA, even an invalid NLA which could cause\\noverflow writes.\\n\\nThis patch introduces a new variable `br_flag` to save the NLA pointer\\nthat points to IFLA_BRIDGE_FLAGS and uses it to resolve the mentioned\\nerror logic.\"}], \"providerMetadata\": {\"orgId\": \"416baaa9-dc9f-4396-8d5f-8c081fb06d67\", \"shortName\": \"Linux\", \"dateUpdated\": \"2024-12-19T08:54:40.197Z\"}}}",
      "cveMetadata": "{\"cveId\": \"CVE-2024-27414\", \"state\": \"PUBLISHED\", \"dateUpdated\": \"2024-12-19T08:54:40.197Z\", \"dateReserved\": \"2024-02-25T13:47:42.682Z\", \"assignerOrgId\": \"416baaa9-dc9f-4396-8d5f-8c081fb06d67\", \"datePublished\": \"2024-05-17T11:50:57.207Z\", \"assignerShortName\": \"Linux\"}",
      "dataType": "CVE_RECORD",
      "dataVersion": "5.1"
    }
  }
}


Log in or create an account to share your comment.




Tags
Taxonomy of the tags.


Loading…

Loading…

Loading…

Sightings

Author Source Type Date

Nomenclature

  • Seen: The vulnerability was mentioned, discussed, or seen somewhere by the user.
  • Confirmed: The vulnerability is confirmed from an analyst perspective.
  • Published Proof of Concept: A public proof of concept is available for this vulnerability.
  • Exploited: This vulnerability was exploited and seen by the user reporting the sighting.
  • Patched: This vulnerability was successfully patched by the user reporting the sighting.
  • Not exploited: This vulnerability was not exploited or seen by the user reporting the sighting.
  • Not confirmed: The user expresses doubt about the veracity of the vulnerability.
  • Not patched: This vulnerability was not successfully patched by the user reporting the sighting.


Loading…

Loading…