Description
In the Linux kernel, the following vulnerability has been resolved: net: ti: icssg-prueth: fix use-after-free of CPPI descriptor in RX path cppi5_hdesc_get_psdata() returns a pointer into the CPPI descriptor. In both emac_rx_packet() and emac_rx_packet_zc(), the descriptor is freed via k3_cppi_desc_pool_free() before the psdata pointer is used by emac_rx_timestamp(), which dereferences psdata[0] and psdata[1]. This constitutes a use-after-free on every received packet that goes through the timestamp path. Defer the descriptor free until after all accesses through the psdata pointer are complete. For emac_rx_packet(), move the free into the requeue label so both early-exit and success paths free the descriptor after all accesses are done. For emac_rx_packet_zc(), move the free to the end of the loop body after emac_dispatch_skb_zc() (which calls emac_rx_timestamp()) has returned.
Product status
46eeb90f03e03d5e8f7f9f1f0eb0792104fc5f86 (git) before d5827316debcb677679bb014885d7be92c410e11
46eeb90f03e03d5e8f7f9f1f0eb0792104fc5f86 (git) before eb8c426c9803beb171f89d15fea17505eb517714
6.15
Any version before 6.15
6.19.11 (semver)
7.0 (original_commit_for_fix)
References
git.kernel.org/...c/d5827316debcb677679bb014885d7be92c410e11
git.kernel.org/...c/eb8c426c9803beb171f89d15fea17505eb517714