Description
In the Linux kernel, the following vulnerability has been resolved: nfc: s3fwrn5: allocate rx skb before consuming bytes s3fwrn82_uart_read() reports the number of accepted bytes to the serdev core. The current code consumes bytes into recv_skb and may already deliver a complete frame before allocating a fresh receive buffer. If that alloc_skb() fails, the callback returns 0 even though it has already consumed bytes, and it leaves recv_skb as NULL for the next receive callback. That breaks the receive_buf() accounting contract and can also lead to a NULL dereference on the next skb_put_u8(). Allocate the receive skb lazily before consuming the next byte instead. If allocation fails, return the number of bytes already accepted.
Product status
3f52c2cb7e3ada37513dabb69a22cf917dba754f (git) before d8c2aa3c4a1ec530a485e46a1c4f1a118bb00156
3f52c2cb7e3ada37513dabb69a22cf917dba754f (git) before 7c31f7a599cf00fad3c204092a91a924126c67e4
3f52c2cb7e3ada37513dabb69a22cf917dba754f (git) before 6d931680a9851481c3243689488eafed08eeff71
3f52c2cb7e3ada37513dabb69a22cf917dba754f (git) before 09822d3d6f68a0cdc4626e0c507324a4927f55a9
3f52c2cb7e3ada37513dabb69a22cf917dba754f (git) before 5c14a19d5b1645cce1cb1252833d70b23635b632
5.11
Any version before 5.11
6.6.136 (semver)
6.12.83 (semver)
6.18.24 (semver)
6.19.14 (semver)
7.0 (original_commit_for_fix)
References
git.kernel.org/...c/d8c2aa3c4a1ec530a485e46a1c4f1a118bb00156
git.kernel.org/...c/7c31f7a599cf00fad3c204092a91a924126c67e4
git.kernel.org/...c/6d931680a9851481c3243689488eafed08eeff71
git.kernel.org/...c/09822d3d6f68a0cdc4626e0c507324a4927f55a9
git.kernel.org/...c/5c14a19d5b1645cce1cb1252833d70b23635b632