Description
In the Linux kernel, the following vulnerability has been resolved: net: qrtr: ns: Fix use-after-free in driver remove() In the remove callback, if a packet arrives after destroy_workqueue() is called, but before sock_release(), the qrtr_ns_data_ready() callback will try to queue the work, causing use-after-free issue. Fix this issue by saving the default 'sk_data_ready' callback during qrtr_ns_init() and use it to replace the qrtr_ns_data_ready() callback at the start of remove(). This ensures that even if a packet arrives after destroy_workqueue(), the work struct will not be dereferenced. Note that it is also required to ensure that the RX threads are completed before destroying the workqueue, because the threads could be using the qrtr_ns_data_ready() callback.
Product status
0c2204a4ad710d95d348ea006f14ba926e842ffd (git) before 65168712c216584ff482a7d1a67589f2079b2634
0c2204a4ad710d95d348ea006f14ba926e842ffd (git) before dff081c3602f2fd810f69ef47945a226980dd05d
0c2204a4ad710d95d348ea006f14ba926e842ffd (git) before 4ae0bd51bf7079e9c2a06b5de0ae04ba70d10167
0c2204a4ad710d95d348ea006f14ba926e842ffd (git) before 0f313eb6a8f6dffa491373cf3afab979fa1c02f4
0c2204a4ad710d95d348ea006f14ba926e842ffd (git) before db3c60ec772de30acae92d560dfcc5258e58dbe8
0c2204a4ad710d95d348ea006f14ba926e842ffd (git) before 2e127ceb1c415e246076d8e09e23e443a7a2038f
0c2204a4ad710d95d348ea006f14ba926e842ffd (git) before f96779e916576e81430ebb326baff6e433fef8ae
0c2204a4ad710d95d348ea006f14ba926e842ffd (git) before 7809fea20c9404bfcfa6112ec08d1fe1d3520beb
5.7
Any version before 5.7
5.10.258 (semver)
5.15.209 (semver)
6.1.175 (semver)
6.6.140 (semver)
6.12.86 (semver)
6.18.27 (semver)
7.0.4 (semver)
7.1-rc1 (original_commit_for_fix)
References
git.kernel.org/...c/65168712c216584ff482a7d1a67589f2079b2634
git.kernel.org/...c/dff081c3602f2fd810f69ef47945a226980dd05d
git.kernel.org/...c/4ae0bd51bf7079e9c2a06b5de0ae04ba70d10167
git.kernel.org/...c/0f313eb6a8f6dffa491373cf3afab979fa1c02f4
git.kernel.org/...c/db3c60ec772de30acae92d560dfcc5258e58dbe8
git.kernel.org/...c/2e127ceb1c415e246076d8e09e23e443a7a2038f
git.kernel.org/...c/f96779e916576e81430ebb326baff6e433fef8ae
git.kernel.org/...c/7809fea20c9404bfcfa6112ec08d1fe1d3520beb