Lucene search

K
cvelistLinuxCVELIST:CVE-2023-52791
HistoryMay 21, 2024 - 3:31 p.m.

CVE-2023-52791 i2c: core: Run atomic i2c xfer when !preemptible

2024-05-2115:31:06
Linux
www.cve.org
4
i2c vulnerability
linux kernel
atomic transfer
preemptible
panic call

AI Score

6.5

Confidence

Low

EPSS

0

Percentile

10.3%

In the Linux kernel, the following vulnerability has been resolved:

i2c: core: Run atomic i2c xfer when !preemptible

Since bae1d3a05a8b, i2c transfers are non-atomic if preemption is
disabled. However, non-atomic i2c transfers require preemption (e.g. in
wait_for_completion() while waiting for the DMA).

panic() calls preempt_disable_notrace() before calling
emergency_restart(). Therefore, if an i2c device is used for the
restart, the xfer should be atomic. This avoids warnings like:

[ 12.667612] WARNING: CPU: 1 PID: 1 at kernel/rcu/tree_plugin.h:318 rcu_note_context_switch+0x33c/0x6b0
[ 12.676926] Voluntary context switch within RCU read-side critical section!

[ 12.742376] schedule_timeout from wait_for_completion_timeout+0x90/0x114
[ 12.749179] wait_for_completion_timeout from tegra_i2c_wait_completion+0x40/0x70

[ 12.994527] atomic_notifier_call_chain from machine_restart+0x34/0x58
[ 13.001050] machine_restart from panic+0x2a8/0x32c

Use !preemptible() instead, which is basically the same check as
pre-v5.2.

CNA Affected

[
  {
    "product": "Linux",
    "vendor": "Linux",
    "defaultStatus": "unaffected",
    "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
    "programFiles": [
      "drivers/i2c/i2c-core.h"
    ],
    "versions": [
      {
        "version": "bae1d3a05a8b",
        "lessThan": "25eb381a736e",
        "status": "affected",
        "versionType": "git"
      },
      {
        "version": "bae1d3a05a8b",
        "lessThan": "25284c46b657",
        "status": "affected",
        "versionType": "git"
      },
      {
        "version": "bae1d3a05a8b",
        "lessThan": "f6237afabc34",
        "status": "affected",
        "versionType": "git"
      },
      {
        "version": "bae1d3a05a8b",
        "lessThan": "185f3617adc8",
        "status": "affected",
        "versionType": "git"
      },
      {
        "version": "bae1d3a05a8b",
        "lessThan": "8c3fa52a46ff",
        "status": "affected",
        "versionType": "git"
      },
      {
        "version": "bae1d3a05a8b",
        "lessThan": "3473cf43b906",
        "status": "affected",
        "versionType": "git"
      },
      {
        "version": "bae1d3a05a8b",
        "lessThan": "aa49c90894d0",
        "status": "affected",
        "versionType": "git"
      }
    ]
  },
  {
    "product": "Linux",
    "vendor": "Linux",
    "defaultStatus": "affected",
    "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
    "programFiles": [
      "drivers/i2c/i2c-core.h"
    ],
    "versions": [
      {
        "version": "5.2",
        "status": "affected"
      },
      {
        "version": "0",
        "lessThan": "5.2",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "5.4.262",
        "lessThanOrEqual": "5.4.*",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "5.10.202",
        "lessThanOrEqual": "5.10.*",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "5.15.140",
        "lessThanOrEqual": "5.15.*",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "6.1.64",
        "lessThanOrEqual": "6.1.*",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "6.5.13",
        "lessThanOrEqual": "6.5.*",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "6.6.3",
        "lessThanOrEqual": "6.6.*",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "6.7",
        "lessThanOrEqual": "*",
        "status": "unaffected",
        "versionType": "original_commit_for_fix"
      }
    ]
  }
]

AI Score

6.5

Confidence

Low

EPSS

0

Percentile

10.3%