CVE-2023-53106 (GCVE-0-2023-53106)
Vulnerability from cvelistv5
Published
2025-05-02 15:55
Modified
2025-05-04 07:49
Severity ?
Summary
In the Linux kernel, the following vulnerability has been resolved: nfc: st-nci: Fix use after free bug in ndlc_remove due to race condition This bug influences both st_nci_i2c_remove and st_nci_spi_remove. Take st_nci_i2c_remove as an example. In st_nci_i2c_probe, it called ndlc_probe and bound &ndlc->sm_work with llt_ndlc_sm_work. When it calls ndlc_recv or timeout handler, it will finally call schedule_work to start the work. When we call st_nci_i2c_remove to remove the driver, there may be a sequence as follows: Fix it by finishing the work before cleanup in ndlc_remove CPU0 CPU1 |llt_ndlc_sm_work st_nci_i2c_remove | ndlc_remove | st_nci_remove | nci_free_device| kfree(ndev) | //free ndlc->ndev | |llt_ndlc_rcv_queue |nci_recv_frame |//use ndlc->ndev
Impacted products
Vendor Product Version
Linux Linux Version: 35630df68d6030daf12dde12ed07bbe26324e6ac
Version: 35630df68d6030daf12dde12ed07bbe26324e6ac
Version: 35630df68d6030daf12dde12ed07bbe26324e6ac
Version: 35630df68d6030daf12dde12ed07bbe26324e6ac
Version: 35630df68d6030daf12dde12ed07bbe26324e6ac
Version: 35630df68d6030daf12dde12ed07bbe26324e6ac
Version: 35630df68d6030daf12dde12ed07bbe26324e6ac
Version: 35630df68d6030daf12dde12ed07bbe26324e6ac
Create a notification for this product.
   Linux Linux Version: 3.17
Create a notification for this product.
Show details on NVD website


{
  "containers": {
    "cna": {
      "affected": [
        {
          "defaultStatus": "unaffected",
          "product": "Linux",
          "programFiles": [
            "drivers/nfc/st-nci/ndlc.c"
          ],
          "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
          "vendor": "Linux",
          "versions": [
            {
              "lessThan": "2156490c4b7cacda9a18ec99929940b8376dc0e3",
              "status": "affected",
              "version": "35630df68d6030daf12dde12ed07bbe26324e6ac",
              "versionType": "git"
            },
            {
              "lessThan": "3405eb641dafcc8b28d174784b203c1622c121bf",
              "status": "affected",
              "version": "35630df68d6030daf12dde12ed07bbe26324e6ac",
              "versionType": "git"
            },
            {
              "lessThan": "b0c202a8dc63008205a5d546559736507a9aae66",
              "status": "affected",
              "version": "35630df68d6030daf12dde12ed07bbe26324e6ac",
              "versionType": "git"
            },
            {
              "lessThan": "43aa468df246175207a7d5d7d6d31b231f15b49c",
              "status": "affected",
              "version": "35630df68d6030daf12dde12ed07bbe26324e6ac",
              "versionType": "git"
            },
            {
              "lessThan": "84dd9cc34014e3a3dcce0eb6d54b8a067e97676b",
              "status": "affected",
              "version": "35630df68d6030daf12dde12ed07bbe26324e6ac",
              "versionType": "git"
            },
            {
              "lessThan": "5e331022b448fbc5e76f24349cd0246844dcad25",
              "status": "affected",
              "version": "35630df68d6030daf12dde12ed07bbe26324e6ac",
              "versionType": "git"
            },
            {
              "lessThan": "f589e5b56c562d99ea74e05b1c3f0eab78aa17a3",
              "status": "affected",
              "version": "35630df68d6030daf12dde12ed07bbe26324e6ac",
              "versionType": "git"
            },
            {
              "lessThan": "5000fe6c27827a61d8250a7e4a1d26c3298ef4f6",
              "status": "affected",
              "version": "35630df68d6030daf12dde12ed07bbe26324e6ac",
              "versionType": "git"
            }
          ]
        },
        {
          "defaultStatus": "affected",
          "product": "Linux",
          "programFiles": [
            "drivers/nfc/st-nci/ndlc.c"
          ],
          "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
          "vendor": "Linux",
          "versions": [
            {
              "status": "affected",
              "version": "3.17"
            },
            {
              "lessThan": "3.17",
              "status": "unaffected",
              "version": "0",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "4.14.*",
              "status": "unaffected",
              "version": "4.14.311",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "4.19.*",
              "status": "unaffected",
              "version": "4.19.279",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "5.4.*",
              "status": "unaffected",
              "version": "5.4.238",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "5.10.*",
              "status": "unaffected",
              "version": "5.10.176",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "5.15.*",
              "status": "unaffected",
              "version": "5.15.104",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "6.1.*",
              "status": "unaffected",
              "version": "6.1.21",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "6.2.*",
              "status": "unaffected",
              "version": "6.2.8",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "*",
              "status": "unaffected",
              "version": "6.3",
              "versionType": "original_commit_for_fix"
            }
          ]
        }
      ],
      "cpeApplicability": [
        {
          "nodes": [
            {
              "cpeMatch": [
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "4.14.311",
                  "versionStartIncluding": "3.17",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "4.19.279",
                  "versionStartIncluding": "3.17",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "5.4.238",
                  "versionStartIncluding": "3.17",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "5.10.176",
                  "versionStartIncluding": "3.17",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "5.15.104",
                  "versionStartIncluding": "3.17",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "6.1.21",
                  "versionStartIncluding": "3.17",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "6.2.8",
                  "versionStartIncluding": "3.17",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "6.3",
                  "versionStartIncluding": "3.17",
                  "vulnerable": true
                }
              ],
              "negate": false,
              "operator": "OR"
            }
          ]
        }
      ],
      "descriptions": [
        {
          "lang": "en",
          "value": "In the Linux kernel, the following vulnerability has been resolved:\n\nnfc: st-nci: Fix use after free bug in ndlc_remove due to race condition\n\nThis bug influences both st_nci_i2c_remove and st_nci_spi_remove.\nTake st_nci_i2c_remove as an example.\n\nIn st_nci_i2c_probe, it called ndlc_probe and bound \u0026ndlc-\u003esm_work\nwith llt_ndlc_sm_work.\n\nWhen it calls ndlc_recv or timeout handler, it will finally call\nschedule_work to start the work.\n\nWhen we call st_nci_i2c_remove to remove the driver, there\nmay be a sequence as follows:\n\nFix it by finishing the work before cleanup in ndlc_remove\n\nCPU0                  CPU1\n\n                    |llt_ndlc_sm_work\nst_nci_i2c_remove   |\n  ndlc_remove       |\n     st_nci_remove  |\n     nci_free_device|\n     kfree(ndev)    |\n//free ndlc-\u003endev   |\n                    |llt_ndlc_rcv_queue\n                    |nci_recv_frame\n                    |//use ndlc-\u003endev"
        }
      ],
      "providerMetadata": {
        "dateUpdated": "2025-05-04T07:49:58.487Z",
        "orgId": "416baaa9-dc9f-4396-8d5f-8c081fb06d67",
        "shortName": "Linux"
      },
      "references": [
        {
          "url": "https://git.kernel.org/stable/c/2156490c4b7cacda9a18ec99929940b8376dc0e3"
        },
        {
          "url": "https://git.kernel.org/stable/c/3405eb641dafcc8b28d174784b203c1622c121bf"
        },
        {
          "url": "https://git.kernel.org/stable/c/b0c202a8dc63008205a5d546559736507a9aae66"
        },
        {
          "url": "https://git.kernel.org/stable/c/43aa468df246175207a7d5d7d6d31b231f15b49c"
        },
        {
          "url": "https://git.kernel.org/stable/c/84dd9cc34014e3a3dcce0eb6d54b8a067e97676b"
        },
        {
          "url": "https://git.kernel.org/stable/c/5e331022b448fbc5e76f24349cd0246844dcad25"
        },
        {
          "url": "https://git.kernel.org/stable/c/f589e5b56c562d99ea74e05b1c3f0eab78aa17a3"
        },
        {
          "url": "https://git.kernel.org/stable/c/5000fe6c27827a61d8250a7e4a1d26c3298ef4f6"
        }
      ],
      "title": "nfc: st-nci: Fix use after free bug in ndlc_remove due to race condition",
      "x_generator": {
        "engine": "bippy-1.2.0"
      }
    }
  },
  "cveMetadata": {
    "assignerOrgId": "416baaa9-dc9f-4396-8d5f-8c081fb06d67",
    "assignerShortName": "Linux",
    "cveId": "CVE-2023-53106",
    "datePublished": "2025-05-02T15:55:47.501Z",
    "dateReserved": "2025-05-02T15:51:43.553Z",
    "dateUpdated": "2025-05-04T07:49:58.487Z",
    "state": "PUBLISHED"
  },
  "dataType": "CVE_RECORD",
  "dataVersion": "5.1",
  "vulnerability-lookup:meta": {
    "nvd": "{\"cve\":{\"id\":\"CVE-2023-53106\",\"sourceIdentifier\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\",\"published\":\"2025-05-02T16:15:29.520\",\"lastModified\":\"2025-05-05T20:54:45.973\",\"vulnStatus\":\"Awaiting Analysis\",\"cveTags\":[],\"descriptions\":[{\"lang\":\"en\",\"value\":\"In the Linux kernel, the following vulnerability has been resolved:\\n\\nnfc: st-nci: Fix use after free bug in ndlc_remove due to race condition\\n\\nThis bug influences both st_nci_i2c_remove and st_nci_spi_remove.\\nTake st_nci_i2c_remove as an example.\\n\\nIn st_nci_i2c_probe, it called ndlc_probe and bound \u0026ndlc-\u003esm_work\\nwith llt_ndlc_sm_work.\\n\\nWhen it calls ndlc_recv or timeout handler, it will finally call\\nschedule_work to start the work.\\n\\nWhen we call st_nci_i2c_remove to remove the driver, there\\nmay be a sequence as follows:\\n\\nFix it by finishing the work before cleanup in ndlc_remove\\n\\nCPU0                  CPU1\\n\\n                    |llt_ndlc_sm_work\\nst_nci_i2c_remove   |\\n  ndlc_remove       |\\n     st_nci_remove  |\\n     nci_free_device|\\n     kfree(ndev)    |\\n//free ndlc-\u003endev   |\\n                    |llt_ndlc_rcv_queue\\n                    |nci_recv_frame\\n                    |//use ndlc-\u003endev\"},{\"lang\":\"es\",\"value\":\"En el kernel de Linux, se ha resuelto la siguiente vulnerabilidad: nfc: st-nci: Fix use after free bug en ndlc_remove debido a una condici\u00f3n de ejecuci\u00f3n Este error afecta tanto a st_nci_i2c_remove como a st_nci_spi_remove. Tomemos st_nci_i2c_remove como ejemplo. En st_nci_i2c_probe, llam\u00f3 a ndlc_probe y vincul\u00f3 \u0026amp;ndlc-\u0026gt;sm_work con llt_ndlc_sm_work. Cuando llama a ndlc_recv o al controlador de tiempo de espera, finalmente llamar\u00e1 a schedule_work para iniciar el trabajo. Cuando llamamos a st_nci_i2c_remove para eliminar el controlador, puede haber una secuencia como la siguiente: Arr\u00e9glelo finalizando el trabajo antes de la limpieza en ndlc_remove CPU0 CPU1 |llt_ndlc_sm_work st_nci_i2c_remove | ndlc_remove | st_nci_remove | nci_free_device| kfree(ndev) | //liberar ndlc-\u0026gt;ndev | |llt_ndlc_rcv_queue |nci_recv_frame |//usar ndlc-\u0026gt;ndev\"}],\"metrics\":{},\"references\":[{\"url\":\"https://git.kernel.org/stable/c/2156490c4b7cacda9a18ec99929940b8376dc0e3\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/3405eb641dafcc8b28d174784b203c1622c121bf\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/43aa468df246175207a7d5d7d6d31b231f15b49c\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/5000fe6c27827a61d8250a7e4a1d26c3298ef4f6\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/5e331022b448fbc5e76f24349cd0246844dcad25\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/84dd9cc34014e3a3dcce0eb6d54b8a067e97676b\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/b0c202a8dc63008205a5d546559736507a9aae66\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/f589e5b56c562d99ea74e05b1c3f0eab78aa17a3\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"}]}}"
  }
}


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.
  • 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…