CVE-2022-50362 (GCVE-0-2022-50362)

Vulnerability from cvelistv5 – Published: 2025-09-17 14:56 – Updated: 2025-09-17 14:56
VLAI?
Summary
In the Linux kernel, the following vulnerability has been resolved: dmaengine: hisilicon: Add multi-thread support for a DMA channel When we get a DMA channel and try to use it in multiple threads it will cause oops and hanging the system. % echo 100 > /sys/module/dmatest/parameters/threads_per_chan % echo 100 > /sys/module/dmatest/parameters/iterations % echo 1 > /sys/module/dmatest/parameters/run [383493.327077] Unable to handle kernel paging request at virtual address dead000000000108 [383493.335103] Mem abort info: [383493.335103] ESR = 0x96000044 [383493.335105] EC = 0x25: DABT (current EL), IL = 32 bits [383493.335107] SET = 0, FnV = 0 [383493.335108] EA = 0, S1PTW = 0 [383493.335109] FSC = 0x04: level 0 translation fault [383493.335110] Data abort info: [383493.335111] ISV = 0, ISS = 0x00000044 [383493.364739] CM = 0, WnR = 1 [383493.367793] [dead000000000108] address between user and kernel address ranges [383493.375021] Internal error: Oops: 96000044 [#1] PREEMPT SMP [383493.437574] CPU: 63 PID: 27895 Comm: dma0chan0-copy2 Kdump: loaded Tainted: GO 5.17.0-rc4+ #2 [383493.457851] pstate: 204000c9 (nzCv daIF +PAN -UAO -TCO -DIT -SSBS BTYPE=--) [383493.465331] pc : vchan_tx_submit+0x64/0xa0 [383493.469957] lr : vchan_tx_submit+0x34/0xa0 This occurs because the transmission timed out, and that's due to data race. Each thread rewrite channels's descriptor as soon as device_issue_pending is called. It leads to the situation that the driver thinks that it uses the right descriptor in interrupt handler while channels's descriptor has been changed by other thread. The descriptor which in fact reported interrupt will not be handled any more, as well as its tx->callback. That's why timeout reports. With current fixes channels' descriptor changes it's value only when it has been used. A new descriptor is acquired from vc->desc_issued queue that is already filled with descriptors that are ready to be sent. Threads have no direct access to DMA channel descriptor. In case of channel's descriptor is busy, try to submit to HW again when a descriptor is completed. In this case, vc->desc_issued may be empty when hisi_dma_start_transfer is called, so delete error reporting on this. Now it is just possible to queue a descriptor for further processing.
Severity ?
No CVSS data available.
Assigner
Impacted products
Vendor Product Version
Linux Linux Affected: e9f08b65250d73ab70e79e194813f52b8d306784 , < af12e209a9d559394d35875ba0e6c80407605888 (git)
Affected: e9f08b65250d73ab70e79e194813f52b8d306784 , < 7cb9b20941e1fb20d22d0a2f460a3d4fa417274c (git)
Affected: e9f08b65250d73ab70e79e194813f52b8d306784 , < d4a8ec5cc7ff5d442bd49a44f26d74b2021ba4c8 (git)
Affected: e9f08b65250d73ab70e79e194813f52b8d306784 , < f4cee0b385cd0348e071d4d80c4c13cfe547c70d (git)
Affected: e9f08b65250d73ab70e79e194813f52b8d306784 , < 2cbb95883c990d0002a77e13d3278913ab26ad79 (git)
Create a notification for this product.
    Linux Linux Affected: 5.6
Unaffected: 0 , < 5.6 (semver)
Unaffected: 5.10.150 , ≤ 5.10.* (semver)
Unaffected: 5.15.75 , ≤ 5.15.* (semver)
Unaffected: 5.19.17 , ≤ 5.19.* (semver)
Unaffected: 6.0.3 , ≤ 6.0.* (semver)
Unaffected: 6.1 , ≤ * (original_commit_for_fix)
Create a notification for this product.
Show details on NVD website

{
  "containers": {
    "cna": {
      "affected": [
        {
          "defaultStatus": "unaffected",
          "product": "Linux",
          "programFiles": [
            "drivers/dma/hisi_dma.c"
          ],
          "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
          "vendor": "Linux",
          "versions": [
            {
              "lessThan": "af12e209a9d559394d35875ba0e6c80407605888",
              "status": "affected",
              "version": "e9f08b65250d73ab70e79e194813f52b8d306784",
              "versionType": "git"
            },
            {
              "lessThan": "7cb9b20941e1fb20d22d0a2f460a3d4fa417274c",
              "status": "affected",
              "version": "e9f08b65250d73ab70e79e194813f52b8d306784",
              "versionType": "git"
            },
            {
              "lessThan": "d4a8ec5cc7ff5d442bd49a44f26d74b2021ba4c8",
              "status": "affected",
              "version": "e9f08b65250d73ab70e79e194813f52b8d306784",
              "versionType": "git"
            },
            {
              "lessThan": "f4cee0b385cd0348e071d4d80c4c13cfe547c70d",
              "status": "affected",
              "version": "e9f08b65250d73ab70e79e194813f52b8d306784",
              "versionType": "git"
            },
            {
              "lessThan": "2cbb95883c990d0002a77e13d3278913ab26ad79",
              "status": "affected",
              "version": "e9f08b65250d73ab70e79e194813f52b8d306784",
              "versionType": "git"
            }
          ]
        },
        {
          "defaultStatus": "affected",
          "product": "Linux",
          "programFiles": [
            "drivers/dma/hisi_dma.c"
          ],
          "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
          "vendor": "Linux",
          "versions": [
            {
              "status": "affected",
              "version": "5.6"
            },
            {
              "lessThan": "5.6",
              "status": "unaffected",
              "version": "0",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "5.10.*",
              "status": "unaffected",
              "version": "5.10.150",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "5.15.*",
              "status": "unaffected",
              "version": "5.15.75",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "5.19.*",
              "status": "unaffected",
              "version": "5.19.17",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "6.0.*",
              "status": "unaffected",
              "version": "6.0.3",
              "versionType": "semver"
            },
            {
              "lessThanOrEqual": "*",
              "status": "unaffected",
              "version": "6.1",
              "versionType": "original_commit_for_fix"
            }
          ]
        }
      ],
      "cpeApplicability": [
        {
          "nodes": [
            {
              "cpeMatch": [
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "5.10.150",
                  "versionStartIncluding": "5.6",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "5.15.75",
                  "versionStartIncluding": "5.6",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "5.19.17",
                  "versionStartIncluding": "5.6",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "6.0.3",
                  "versionStartIncluding": "5.6",
                  "vulnerable": true
                },
                {
                  "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*",
                  "versionEndExcluding": "6.1",
                  "versionStartIncluding": "5.6",
                  "vulnerable": true
                }
              ],
              "negate": false,
              "operator": "OR"
            }
          ]
        }
      ],
      "descriptions": [
        {
          "lang": "en",
          "value": "In the Linux kernel, the following vulnerability has been resolved:\n\ndmaengine: hisilicon: Add multi-thread support for a DMA channel\n\nWhen we get a DMA channel and try to use it in multiple threads it\nwill cause oops and hanging the system.\n\n% echo 100 \u003e /sys/module/dmatest/parameters/threads_per_chan\n% echo 100 \u003e /sys/module/dmatest/parameters/iterations\n% echo 1 \u003e /sys/module/dmatest/parameters/run\n[383493.327077] Unable to handle kernel paging request at virtual\n\t\taddress dead000000000108\n[383493.335103] Mem abort info:\n[383493.335103]   ESR = 0x96000044\n[383493.335105]   EC = 0x25: DABT (current EL), IL = 32 bits\n[383493.335107]   SET = 0, FnV = 0\n[383493.335108]   EA = 0, S1PTW = 0\n[383493.335109]   FSC = 0x04: level 0 translation fault\n[383493.335110] Data abort info:\n[383493.335111]   ISV = 0, ISS = 0x00000044\n[383493.364739]   CM = 0, WnR = 1\n[383493.367793] [dead000000000108] address between user and kernel\n\t\taddress ranges\n[383493.375021] Internal error: Oops: 96000044 [#1] PREEMPT SMP\n[383493.437574] CPU: 63 PID: 27895 Comm: dma0chan0-copy2 Kdump:\n\t\tloaded Tainted: GO 5.17.0-rc4+ #2\n[383493.457851] pstate: 204000c9 (nzCv daIF +PAN -UAO -TCO -DIT\n\t\t-SSBS BTYPE=--)\n[383493.465331] pc : vchan_tx_submit+0x64/0xa0\n[383493.469957] lr : vchan_tx_submit+0x34/0xa0\n\nThis occurs because the transmission timed out, and that\u0027s due\nto data race. Each thread rewrite channels\u0027s descriptor as soon as\ndevice_issue_pending is called. It leads to the situation that\nthe driver thinks that it uses the right descriptor in interrupt\nhandler while channels\u0027s descriptor has been changed by other\nthread. The descriptor which in fact reported interrupt will not\nbe handled any more, as well as its tx-\u003ecallback.\nThat\u0027s why timeout reports.\n\nWith current fixes channels\u0027 descriptor changes it\u0027s value only\nwhen it has been used. A new descriptor is acquired from\nvc-\u003edesc_issued queue that is already filled with descriptors\nthat are ready to be sent. Threads have no direct access to DMA\nchannel descriptor. In case of channel\u0027s descriptor is busy, try\nto submit to HW again when a descriptor is completed. In this case,\nvc-\u003edesc_issued may be empty when hisi_dma_start_transfer is called,\nso delete error reporting on this. Now it is just possible to queue\na descriptor for further processing."
        }
      ],
      "providerMetadata": {
        "dateUpdated": "2025-09-17T14:56:14.189Z",
        "orgId": "416baaa9-dc9f-4396-8d5f-8c081fb06d67",
        "shortName": "Linux"
      },
      "references": [
        {
          "url": "https://git.kernel.org/stable/c/af12e209a9d559394d35875ba0e6c80407605888"
        },
        {
          "url": "https://git.kernel.org/stable/c/7cb9b20941e1fb20d22d0a2f460a3d4fa417274c"
        },
        {
          "url": "https://git.kernel.org/stable/c/d4a8ec5cc7ff5d442bd49a44f26d74b2021ba4c8"
        },
        {
          "url": "https://git.kernel.org/stable/c/f4cee0b385cd0348e071d4d80c4c13cfe547c70d"
        },
        {
          "url": "https://git.kernel.org/stable/c/2cbb95883c990d0002a77e13d3278913ab26ad79"
        }
      ],
      "title": "dmaengine: hisilicon: Add multi-thread support for a DMA channel",
      "x_generator": {
        "engine": "bippy-1.2.0"
      }
    }
  },
  "cveMetadata": {
    "assignerOrgId": "416baaa9-dc9f-4396-8d5f-8c081fb06d67",
    "assignerShortName": "Linux",
    "cveId": "CVE-2022-50362",
    "datePublished": "2025-09-17T14:56:14.189Z",
    "dateReserved": "2025-09-17T14:53:06.994Z",
    "dateUpdated": "2025-09-17T14:56:14.189Z",
    "state": "PUBLISHED"
  },
  "dataType": "CVE_RECORD",
  "dataVersion": "5.1",
  "vulnerability-lookup:meta": {
    "nvd": "{\"cve\":{\"id\":\"CVE-2022-50362\",\"sourceIdentifier\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\",\"published\":\"2025-09-17T15:15:34.980\",\"lastModified\":\"2025-09-18T13:43:34.310\",\"vulnStatus\":\"Awaiting Analysis\",\"cveTags\":[],\"descriptions\":[{\"lang\":\"en\",\"value\":\"In the Linux kernel, the following vulnerability has been resolved:\\n\\ndmaengine: hisilicon: Add multi-thread support for a DMA channel\\n\\nWhen we get a DMA channel and try to use it in multiple threads it\\nwill cause oops and hanging the system.\\n\\n% echo 100 \u003e /sys/module/dmatest/parameters/threads_per_chan\\n% echo 100 \u003e /sys/module/dmatest/parameters/iterations\\n% echo 1 \u003e /sys/module/dmatest/parameters/run\\n[383493.327077] Unable to handle kernel paging request at virtual\\n\\t\\taddress dead000000000108\\n[383493.335103] Mem abort info:\\n[383493.335103]   ESR = 0x96000044\\n[383493.335105]   EC = 0x25: DABT (current EL), IL = 32 bits\\n[383493.335107]   SET = 0, FnV = 0\\n[383493.335108]   EA = 0, S1PTW = 0\\n[383493.335109]   FSC = 0x04: level 0 translation fault\\n[383493.335110] Data abort info:\\n[383493.335111]   ISV = 0, ISS = 0x00000044\\n[383493.364739]   CM = 0, WnR = 1\\n[383493.367793] [dead000000000108] address between user and kernel\\n\\t\\taddress ranges\\n[383493.375021] Internal error: Oops: 96000044 [#1] PREEMPT SMP\\n[383493.437574] CPU: 63 PID: 27895 Comm: dma0chan0-copy2 Kdump:\\n\\t\\tloaded Tainted: GO 5.17.0-rc4+ #2\\n[383493.457851] pstate: 204000c9 (nzCv daIF +PAN -UAO -TCO -DIT\\n\\t\\t-SSBS BTYPE=--)\\n[383493.465331] pc : vchan_tx_submit+0x64/0xa0\\n[383493.469957] lr : vchan_tx_submit+0x34/0xa0\\n\\nThis occurs because the transmission timed out, and that\u0027s due\\nto data race. Each thread rewrite channels\u0027s descriptor as soon as\\ndevice_issue_pending is called. It leads to the situation that\\nthe driver thinks that it uses the right descriptor in interrupt\\nhandler while channels\u0027s descriptor has been changed by other\\nthread. The descriptor which in fact reported interrupt will not\\nbe handled any more, as well as its tx-\u003ecallback.\\nThat\u0027s why timeout reports.\\n\\nWith current fixes channels\u0027 descriptor changes it\u0027s value only\\nwhen it has been used. A new descriptor is acquired from\\nvc-\u003edesc_issued queue that is already filled with descriptors\\nthat are ready to be sent. Threads have no direct access to DMA\\nchannel descriptor. In case of channel\u0027s descriptor is busy, try\\nto submit to HW again when a descriptor is completed. In this case,\\nvc-\u003edesc_issued may be empty when hisi_dma_start_transfer is called,\\nso delete error reporting on this. Now it is just possible to queue\\na descriptor for further processing.\"}],\"metrics\":{},\"references\":[{\"url\":\"https://git.kernel.org/stable/c/2cbb95883c990d0002a77e13d3278913ab26ad79\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/7cb9b20941e1fb20d22d0a2f460a3d4fa417274c\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/af12e209a9d559394d35875ba0e6c80407605888\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/d4a8ec5cc7ff5d442bd49a44f26d74b2021ba4c8\",\"source\":\"416baaa9-dc9f-4396-8d5f-8c081fb06d67\"},{\"url\":\"https://git.kernel.org/stable/c/f4cee0b385cd0348e071d4d80c4c13cfe547c70d\",\"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 observed by the user.
  • Confirmed: The vulnerability has been validated from an analyst's perspective.
  • Published Proof of Concept: A public proof of concept is available for this vulnerability.
  • Exploited: The vulnerability was observed as exploited by the user who reported the sighting.
  • Patched: The vulnerability was observed as successfully patched by the user who reported the sighting.
  • Not exploited: The vulnerability was not observed as exploited by the user who reported the sighting.
  • Not confirmed: The user expressed doubt about the validity of the vulnerability.
  • Not patched: The vulnerability was not observed as successfully patched by the user who reported the sighting.


Loading…

Detection rules are retrieved from Rulezet.

Loading…

Loading…