Lucene search

K
ubuntucveUbuntu.comUB:CVE-2023-52910
HistoryAug 21, 2024 - 12:00 a.m.

CVE-2023-52910

2024-08-2100:00:00
ubuntu.com
ubuntu.com
1
linux kernel
cve-2023-52910
iommu/iova
alloc iova
overflow issue
retry logic
low_pfn
allocation_successful
specific situations

AI Score

7.4

Confidence

Low

EPSS

0

Percentile

5.1%

In the Linux kernel, the following vulnerability has been resolved:
iommu/iova: Fix alloc iova overflows issue
In __alloc_and_insert_iova_range, there is an issue that retry_pfn
overflows. The value of iovad->anchor.pfn_hi is ~0UL, then when
iovad->cached_node is iovad->anchor, curr_iova->pfn_hi + 1 will
overflow. As a result, if the retry logic is executed, low_pfn is
updated to 0, and then new_pfn < low_pfn returns false to make the
allocation successful.
This issue occurs in the following two situations:

  1. The first iova size exceeds the domain size. When initializing
    iova domain, iovad->cached_node is assigned as iovad->anchor. For
    example, the iova domain size is 10M, start_pfn is 0x1_F000_0000,
    and the iova size allocated for the first time is 11M. The
    following is the log information, new->pfn_lo is smaller than
    iovad->cached_node.
    Example log as follows:
    [ 223.798112][T1705487] sh: [name:iova&]__alloc_and_insert_iova_range
    start_pfn:0x1f0000,retry_pfn:0x0,size:0xb00,limit_pfn:0x1f0a00
    [ 223.799590][T1705487] sh: [name:iova&]__alloc_and_insert_iova_range
    success start_pfn:0x1f0000,new->pfn_lo:0x1efe00,new->pfn_hi:0x1f08ff
  2. The node with the largest iova->pfn_lo value in the iova domain
    is deleted, iovad->cached_node will be updated to iovad->anchor,
    and then the alloc iova size exceeds the maximum iova size that can
    be allocated in the domain.
    After judging that retry_pfn is less than limit_pfn, call retry_pfn+1
    to fix the overflow issue.
OSVersionArchitecturePackageVersionFilename
ubuntu22.04noarchlinux< 5.15.0-70.77UNKNOWN
ubuntu22.04noarchlinux-aws< 5.15.0-1034.38UNKNOWN
ubuntu20.04noarchlinux-aws-5.15< 5.15.0-1034.38~20.04.1UNKNOWN
ubuntu22.04noarchlinux-azure< 5.15.0-1036.43UNKNOWN
ubuntu20.04noarchlinux-azure-5.15< 5.15.0-1036.43~20.04.1UNKNOWN
ubuntu22.04noarchlinux-azure-fde< 5.15.0-1036.43.1UNKNOWN
ubuntu20.04noarchlinux-azure-fde-5.15< 5.15.0-1036.43~20.04.1.1UNKNOWN
ubuntu22.04noarchlinux-gcp< 5.15.0-1032.40UNKNOWN
ubuntu20.04noarchlinux-gcp-5.15< 5.15.0-1032.40~20.04.1UNKNOWN
ubuntu22.04noarchlinux-gke< 5.15.0-1031.36UNKNOWN
Rows per page:
1-10 of 241

AI Score

7.4

Confidence

Low

EPSS

0

Percentile

5.1%