Lucene search

K
cvelistLinuxCVELIST:CVE-2021-47005
HistoryFeb 28, 2024 - 8:13 a.m.

CVE-2021-47005 PCI: endpoint: Fix NULL pointer dereference for ->get_features()

2024-02-2808:13:25
Linux
www.cve.org
7
linux kernel
pci endpoint
null pointer dereference
vulnerability
get_features ops
pci_epc_ops
pci_epf_test_alloc_space
platform driver
epc features
patch
call trace

AI Score

7.5

Confidence

High

EPSS

0

Percentile

15.5%

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

PCI: endpoint: Fix NULL pointer dereference for ->get_features()

get_features ops of pci_epc_ops may return NULL, causing NULL pointer
dereference in pci_epf_test_alloc_space function. Let us add a check for
pci_epc_feature pointer in pci_epf_test_bind before we access it to avoid
any such NULL pointer dereference and return -ENOTSUPP in case
pci_epc_feature is not found.

When the patch is not applied and EPC features is not implemented in the
platform driver, we see the following dump due to kernel NULL pointer
dereference.

Call trace:
pci_epf_test_bind+0xf4/0x388
pci_epf_bind+0x3c/0x80
pci_epc_epf_link+0xa8/0xcc
configfs_symlink+0x1a4/0x48c
vfs_symlink+0x104/0x184
do_symlinkat+0x80/0xd4
__arm64_sys_symlinkat+0x1c/0x24
el0_svc_common.constprop.3+0xb8/0x170
el0_svc_handler+0x70/0x88
el0_svc+0x8/0x640
Code: d2800581 b9403ab9 f9404ebb 8b394f60 (f9400400)
—[ end trace a438e3c5a24f9df0 ]—

CNA Affected

[
  {
    "product": "Linux",
    "vendor": "Linux",
    "defaultStatus": "unaffected",
    "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git",
    "programFiles": [
      "drivers/pci/endpoint/functions/pci-epf-test.c"
    ],
    "versions": [
      {
        "version": "2c04c5b8eef7",
        "lessThan": "bbed83d7060e",
        "status": "affected",
        "versionType": "git"
      },
      {
        "version": "2c04c5b8eef7",
        "lessThan": "679ebad058b8",
        "status": "affected",
        "versionType": "git"
      },
      {
        "version": "2c04c5b8eef7",
        "lessThan": "0169d4f0bee4",
        "status": "affected",
        "versionType": "git"
      },
      {
        "version": "2c04c5b8eef7",
        "lessThan": "6613bc2301ba",
        "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/pci/endpoint/functions/pci-epf-test.c"
    ],
    "versions": [
      {
        "version": "5.1",
        "status": "affected"
      },
      {
        "version": "0",
        "lessThan": "5.1",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "5.10.38",
        "lessThanOrEqual": "5.10.*",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "5.11.22",
        "lessThanOrEqual": "5.11.*",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "5.12.5",
        "lessThanOrEqual": "5.12.*",
        "status": "unaffected",
        "versionType": "custom"
      },
      {
        "version": "5.13",
        "lessThanOrEqual": "*",
        "status": "unaffected",
        "versionType": "original_commit_for_fix"
      }
    ]
  }
]

AI Score

7.5

Confidence

High

EPSS

0

Percentile

15.5%