CVE-2023-52998

EUVD-2023-59722
In the Linux kernel, the following vulnerability has been resolved:

net: fec: Use page_pool_put_full_page when freeing rx buffers

The page_pool_release_page was used when freeing rx buffers, and this
function just unmaps the page (if mapped) and does not recycle the page.
So after hundreds of down/up the eth0, the system will out of memory.
For more details, please refer to the following reproduce steps and
bug logs. To solve this issue and refer to the doc of page pool, the
page_pool_put_full_page should be used to replace page_pool_release_page.
Because this API will try to recycle the page if the page refcnt equal to
1. After testing 20000 times, the issue can not be reproduced anymore
(about testing 391 times the issue will occur on i.MX8MN-EVK before).

Reproduce steps:
Create the test script and run the script. The script content is as
follows:
LOOPS=20000
i=1
while [ $i -le $LOOPS ]
do
    echo "TINFO:ENET $curface up and down test $i times"
    org_macaddr=$(cat /sys/class/net/eth0/address)
    ifconfig eth0 down
    ifconfig eth0  hw ether $org_macaddr up
    i=$(expr $i + 1)
done
sleep 5
if cat /sys/class/net/eth0/operstate | grep 'up';then
    echo "TEST PASS"
else
    echo "TEST FAIL"
fi

Bug detail logs:
TINFO:ENET  up and down test 391 times
[  850.471205] Qualcomm Atheros AR8031/AR8033 30be0000.ethernet-1:00: attached PHY driver (mii_bus:phy_addr=30be0000.ethernet-1:00, irq=POLL)
[  853.535318] IPv6: ADDRCONF(NETDEV_CHANGE): eth0: link becomes ready
[  853.541694] fec 30be0000.ethernet eth0: Link is Up - 1Gbps/Full - flow control rx/tx
[  870.590531] page_pool_release_retry() stalled pool shutdown 199 inflight 60 sec
[  931.006557] page_pool_release_retry() stalled pool shutdown 199 inflight 120 sec
TINFO:ENET  up and down test 392 times
[  991.426544] page_pool_release_retry() stalled pool shutdown 192 inflight 181 sec
[ 1051.838531] page_pool_release_retry() stalled pool shutdown 170 inflight 241 sec
[ 1093.751217] Qualcomm Atheros AR8031/AR8033 30be0000.ethernet-1:00: attached PHY driver (mii_bus:phy_addr=30be0000.ethernet-1:00, irq=POLL)
[ 1096.446520] page_pool_release_retry() stalled pool shutdown 308 inflight 60 sec
[ 1096.831245] fec 30be0000.ethernet eth0: Link is Up - 1Gbps/Full - flow control rx/tx
[ 1096.839092] IPv6: ADDRCONF(NETDEV_CHANGE): eth0: link becomes ready
[ 1112.254526] page_pool_release_retry() stalled pool shutdown 103 inflight 302 sec
[ 1156.862533] page_pool_release_retry() stalled pool shutdown 308 inflight 120 sec
[ 1172.674516] page_pool_release_retry() stalled pool shutdown 103 inflight 362 sec
[ 1217.278532] page_pool_release_retry() stalled pool shutdown 308 inflight 181 sec
TINFO:ENET  up and down test 393 times
[ 1233.086535] page_pool_release_retry() stalled pool shutdown 103 inflight 422 sec
[ 1277.698513] page_pool_release_retry() stalled pool shutdown 308 inflight 241 sec
[ 1293.502525] page_pool_release_retry() stalled pool shutdown 86 inflight 483 sec
[ 1338.110518] page_pool_release_retry() stalled pool shutdown 308 inflight 302 sec
[ 1353.918540] page_pool_release_retry() stalled pool shutdown 32 inflight 543 sec
[ 1361.179205] Qualcomm Atheros AR8031/AR8033 30be0000.ethernet-1:00: attached PHY driver (mii_bus:phy_addr=30be0000.ethernet-1:00, irq=POLL)
[ 1364.255298] fec 30be0000.ethernet eth0: Link is Up - 1Gbps/Full - flow control rx/tx
[ 1364.263189] IPv6: ADDRCONF(NETDEV_CHANGE): eth0: link becomes ready
[ 1371.998532] page_pool_release_retry() stalled pool shutdown 310 inflight 60 sec
[ 1398.530542] page_pool_release_retry() stalled pool shutdown 308 inflight 362 sec
[ 1414.334539] page_pool_release_retry() stalled pool shutdown 16 inflight 604 sec
[ 1432.414520] page_pool_release_retry() stalled pool shutdown 310 inflight 120 sec
[ 1458.942523] page_pool_release_retry() stalled pool shutdown 308 inflight 422 sec
[ 1474.750521] page_pool_release_retry() stalled pool shutdown 16 inflight 664 sec
TINFO:ENET  up and down test 394 times
[ 1492.8305
---truncated---
ProviderTypeBase ScoreAtk. VectorAtk. ComplexityPriv. RequiredVector
NISTPrimary
5.5 MEDIUM
LOCAL
LOW
LOW
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H
Base Score
CVSS 3.x
EPSS Score
Percentile: 22%
Affected Products (NVD)
VendorProductVersion
linuxlinux_kernel
6.1 ≤
𝑥
< 6.1.9
linuxlinux_kernel
6.2:rc1
linuxlinux_kernel
6.2:rc2
linuxlinux_kernel
6.2:rc3
linuxlinux_kernel
6.2:rc4
linuxlinux_kernel
6.2:rc5
𝑥
= Vulnerable software versions
Debian logo
Debian Releases
Debian Product
Codename
linux
bookworm
6.1.129-1
fixed
bookworm (security)
6.1.128-1
fixed
bullseye
5.10.223-1
not-affected
bullseye (security)
5.10.234-1
fixed
sid
6.12.20-1
fixed
trixie
6.12.19-1
fixed
Ubuntu logo
Ubuntu Releases
Ubuntu Product
Codename
linux
bionic
needs-triage
focal
needs-triage
jammy
needs-triage
noble
needs-triage
oracular
needs-triage
trusty
needs-triage
xenial
needs-triage
linux-allwinner-5.19
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-aws
bionic
needs-triage
focal
needs-triage
jammy
needs-triage
noble
needs-triage
oracular
needs-triage
trusty
needs-triage
xenial
needs-triage
linux-aws-5.0
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-aws-5.11
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-aws-5.13
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-aws-5.15
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-aws-5.19
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-aws-5.3
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-aws-5.4
bionic
needs-triage
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-aws-5.8
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-aws-6.2
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-aws-6.5
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-aws-6.8
focal
dne
jammy
needs-triage
noble
dne
oracular
dne
linux-aws-fips
bionic
needs-triage
focal
needs-triage
jammy
needs-triage
noble
dne
oracular
dne
linux-aws-hwe
focal
dne
jammy
dne
noble
dne
oracular
dne
xenial
needs-triage
linux-azure
bionic
ignored
focal
needs-triage
jammy
needs-triage
noble
needs-triage
oracular
needs-triage
trusty
needs-triage
xenial
needs-triage
linux-azure-4.15
bionic
needs-triage
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-azure-5.11
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-azure-5.13
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-azure-5.15
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-azure-5.19
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-azure-5.3
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-azure-5.4
bionic
needs-triage
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-azure-5.8
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-azure-6.2
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-azure-6.5
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-azure-6.8
focal
dne
jammy
needs-triage
noble
dne
oracular
dne
linux-azure-edge
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-azure-fde
focal
ignored
jammy
needs-triage
noble
dne
oracular
dne
linux-azure-fde-5.15
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-azure-fde-5.19
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-azure-fde-6.2
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-azure-fips
bionic
needs-triage
focal
needs-triage
jammy
needs-triage
noble
dne
oracular
dne
linux-bluefield
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-fips
bionic
needs-triage
focal
needs-triage
jammy
needs-triage
noble
dne
oracular
dne
xenial
needs-triage
linux-gcp
bionic
ignored
focal
needs-triage
jammy
needs-triage
noble
needs-triage
oracular
needs-triage
xenial
needs-triage
linux-gcp-4.15
bionic
needs-triage
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-gcp-5.11
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-gcp-5.13
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-gcp-5.15
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-gcp-5.19
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-gcp-5.3
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-gcp-5.4
bionic
needs-triage
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-gcp-5.8
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-gcp-6.2
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-gcp-6.5
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-gcp-6.8
focal
dne
jammy
needs-triage
noble
dne
oracular
dne
linux-gcp-fips
bionic
needs-triage
focal
needs-triage
jammy
needs-triage
noble
dne
oracular
dne
linux-gke
focal
ignored
jammy
needs-triage
noble
needs-triage
oracular
dne
linux-gke-4.15
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-gke-5.15
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-gke-5.4
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-gkeop
focal
ignored
jammy
needs-triage
noble
needs-triage
oracular
dne
linux-gkeop-5.15
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-gkeop-5.4
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-hwe
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
xenial
needs-triage
linux-hwe-5.11
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-hwe-5.13
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-hwe-5.15
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-hwe-5.19
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-hwe-5.4
bionic
needs-triage
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-hwe-5.8
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-hwe-6.11
focal
dne
jammy
dne
noble
needs-triage
oracular
dne
linux-hwe-6.2
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-hwe-6.5
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-hwe-6.8
focal
dne
jammy
needs-triage
noble
dne
oracular
dne
linux-hwe-edge
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
xenial
ignored
linux-ibm
focal
needs-triage
jammy
needs-triage
noble
needs-triage
oracular
dne
linux-ibm-5.15
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-ibm-5.4
bionic
needs-triage
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-intel-5.13
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-intel-iot-realtime
focal
dne
jammy
needs-triage
noble
dne
oracular
dne
linux-intel-iotg
focal
dne
jammy
needs-triage
noble
dne
oracular
dne
linux-intel-iotg-5.15
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-iot
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-kvm
bionic
needs-triage
focal
needs-triage
jammy
needs-triage
noble
dne
oracular
dne
xenial
needs-triage
linux-lowlatency
focal
dne
jammy
needs-triage
noble
needs-triage
oracular
needs-triage
linux-lowlatency-hwe-5.15
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-lowlatency-hwe-5.19
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-lowlatency-hwe-6.11
focal
dne
jammy
dne
noble
needs-triage
oracular
dne
linux-lowlatency-hwe-6.2
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-lowlatency-hwe-6.5
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-lowlatency-hwe-6.8
focal
dne
jammy
needs-triage
noble
dne
oracular
dne
linux-lts-xenial
focal
dne
jammy
dne
noble
dne
oracular
dne
trusty
needs-triage
linux-nvidia
focal
dne
jammy
needs-triage
noble
needs-triage
oracular
dne
linux-nvidia-6.2
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-nvidia-6.5
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-nvidia-6.8
focal
dne
jammy
needs-triage
noble
dne
oracular
dne
linux-nvidia-lowlatency
focal
dne
jammy
dne
noble
needs-triage
oracular
dne
linux-nvidia-tegra
focal
dne
jammy
needs-triage
noble
needs-triage
oracular
dne
linux-nvidia-tegra-igx
focal
dne
jammy
needs-triage
noble
dne
oracular
dne
linux-oem
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-oem-5.10
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-oem-5.13
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-oem-5.14
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-oem-5.17
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-oem-5.6
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-oem-6.0
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-oem-6.1
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-oem-6.11
focal
dne
jammy
dne
noble
needs-triage
oracular
dne
linux-oem-6.5
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-oem-6.8
focal
dne
jammy
dne
noble
needs-triage
oracular
dne
linux-oracle
bionic
needs-triage
focal
needs-triage
jammy
needs-triage
noble
needs-triage
oracular
needs-triage
xenial
needs-triage
linux-oracle-5.0
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-oracle-5.11
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-oracle-5.13
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-oracle-5.15
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-oracle-5.3
bionic
ignored
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-oracle-5.4
bionic
needs-triage
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-oracle-5.8
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-oracle-6.5
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-oracle-6.8
focal
dne
jammy
needs-triage
noble
dne
oracular
dne
linux-raspi
focal
needs-triage
jammy
needs-triage
noble
needs-triage
oracular
needs-triage
linux-raspi-5.4
bionic
needs-triage
focal
dne
jammy
dne
noble
dne
oracular
dne
linux-raspi-realtime
focal
dne
jammy
dne
noble
needs-triage
oracular
dne
linux-raspi2
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-realtime
focal
dne
jammy
needs-triage
noble
needs-triage
oracular
needs-triage
linux-riscv
focal
ignored
jammy
ignored
noble
needs-triage
oracular
needs-triage
linux-riscv-5.11
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-riscv-5.15
focal
needs-triage
jammy
dne
noble
dne
oracular
dne
linux-riscv-5.19
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-riscv-5.8
focal
ignored
jammy
dne
noble
dne
oracular
dne
linux-riscv-6.5
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-riscv-6.8
focal
dne
jammy
needs-triage
noble
dne
oracular
dne
linux-starfive-5.19
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-starfive-6.2
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-starfive-6.5
focal
dne
jammy
ignored
noble
dne
oracular
dne
linux-xilinx-zynqmp
focal
needs-triage
jammy
needs-triage
noble
dne
oracular
dne