cve-2024-27414
Vulnerability from cvelistv5
Published
2024-05-17 11:50
Modified
2024-08-02 00:34
Severity
Summary
rtnetlink: fix error logic of IFLA_BRIDGE_FLAGS writing back
Impacted products
VendorProduct
LinuxLinux
LinuxLinux
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": "b9fbc44159df",
              "status": "affected",
              "version": "ad46d4861ed3",
              "versionType": "git"
            },
            {
              "lessThan": "882a51a10ecf",
              "status": "affected",
              "version": "abb0172fa8dc",
              "versionType": "git"
            },
            {
              "lessThan": "a1227b27fccc",
              "status": "affected",
              "version": "047508edd602",
              "versionType": "git"
            },
            {
              "lessThan": "f2261eb994aa",
              "status": "affected",
              "version": "8dfac8071d58",
              "versionType": "git"
            },
            {
              "lessThan": "167d8642daa6",
              "status": "affected",
              "version": "d73ef2d69c0d",
              "versionType": "git"
            },
            {
              "lessThan": "831bc2728fb4",
              "status": "affected",
              "version": "d73ef2d69c0d",
              "versionType": "git"
            },
            {
              "lessThan": "743ad091fb46",
              "status": "affected",
              "version": "d73ef2d69c0d",
              "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": "custom"
            },
            {
              "lessThanOrEqual": "5.4.*",
              "status": "unaffected",
              "version": "5.4.271",
              "versionType": "custom"
            },
            {
              "lessThanOrEqual": "5.10.*",
              "status": "unaffected",
              "version": "5.10.212",
              "versionType": "custom"
            },
            {
              "lessThanOrEqual": "5.15.*",
              "status": "unaffected",
              "version": "5.15.151",
              "versionType": "custom"
            },
            {
              "lessThanOrEqual": "6.1.*",
              "status": "unaffected",
              "version": "6.1.81",
              "versionType": "custom"
            },
            {
              "lessThanOrEqual": "6.6.*",
              "status": "unaffected",
              "version": "6.6.21",
              "versionType": "custom"
            },
            {
              "lessThanOrEqual": "6.7.*",
              "status": "unaffected",
              "version": "6.7.9",
              "versionType": "custom"
            },
            {
              "lessThanOrEqual": "*",
              "status": "unaffected",
              "version": "6.8",
              "versionType": "original_commit_for_fix"
            }
          ]
        }
      ],
      "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": "2024-05-29T05:28:41.292Z",
        "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"
        },
        {
          "url": "https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html"
        }
      ],
      "title": "rtnetlink: fix error logic of IFLA_BRIDGE_FLAGS writing back",
      "x_generator": {
        "engine": "bippy-a5840b7849dd"
      }
    }
  },
  "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": "2024-08-02T00:34:52.359Z",
    "state": "PUBLISHED"
  },
  "dataType": "CVE_RECORD",
  "dataVersion": "5.1",
  "meta": {
    "nvd": "{\"cve\":{\"id\":\"CVE-2024-27414\",\"sourceIdentifier\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\",\"published\":\"2024-05-17T12:15:12.673\",\"lastModified\":\"2024-06-25T22:15:29.803\",\"vulnStatus\":\"Awaiting Analysis\",\"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.\"},{\"lang\":\"es\",\"value\":\"En el kernel de Linux, se ha resuelto la siguiente vulnerabilidad: rtnetlink: corrige la l\u00f3gica de error de la reescritura de IFLA_BRIDGE_FLAGS En el commit d73ef2d69c0d (\\\"rtnetlink: let rtnl_bridge_setlink comprueba la longitud de IFLA_BRIDGE_MODE\\\"), se realiz\u00f3 un ajuste a la l\u00f3gica de bucle anterior en la funci\u00f3n ` rtnl_bridge_setlink` para permitir que el bucle tambi\u00e9n verifique la longitud del atributo IFLA_BRIDGE_MODE. Sin embargo, este ajuste elimin\u00f3 la declaraci\u00f3n \\\"break\\\" y gener\u00f3 una l\u00f3gica de error en la escritura de los indicadores al final de esta funci\u00f3n. if (have_flags) memcpy(nla_data(attr), \u0026amp;flags, sizeof(flags)); // attr deber\u00eda apuntar a IFLA_BRIDGE_FLAGS NLA !!! Antes de la confirmaci\u00f3n mencionada, se concede que el `attr` sea IFLA_BRIDGE_FLAGS. Sin embargo, esto no es necesariamente cierto ahora, ya que el bucle actualizado permitir\u00e1 que el atributo apunte al \u00faltimo NLA, incluso un NLA no v\u00e1lido que podr\u00eda causar escrituras desbordadas. Este parche introduce una nueva variable `br_flag` para guardar el puntero NLA que apunta a IFLA_BRIDGE_FLAGS y lo usa para resolver la l\u00f3gica de error mencionada.\"}],\"metrics\":{},\"references\":[{\"url\":\"https://git.kernel.org/stable/c/167d8642daa6a44b51de17f8ff0f584e1e762db7\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/743ad091fb46e622f1b690385bb15e3cd3daf874\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/831bc2728fb48a8957a824cba8c264b30dca1425\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/882a51a10ecf24ce135d573afa0872aef02c5125\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/a1227b27fcccc99dc44f912b479e01a17e2d7d31\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/b9fbc44159dfc3e9a7073032752d9e03f5194a6f\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/f2261eb994aa5757c1da046b78e3229a3ece0ad9\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"}]}}"
  }
}


Log in or create an account to share your comment.




Tags
Taxonomy of the tags.


Loading...

Loading...