We use these services and cookies to improve your user experience. You may opt out if you wish, however, this may limit some features on this site.

Please see our statement on Data Privacy.

Crisp.chat (Helpdesk and Chat)

Ok

THREATINT
PUBLISHED

CVE-2024-26996

usb: gadget: f_ncm: Fix UAF ncm object at re-bind after usb ep transport error



Description

In the Linux kernel, the following vulnerability has been resolved: usb: gadget: f_ncm: Fix UAF ncm object at re-bind after usb ep transport error When ncm function is working and then stop usb0 interface for link down, eth_stop() is called. At this piont, accidentally if usb transport error should happen in usb_ep_enable(), 'in_ep' and/or 'out_ep' may not be enabled. After that, ncm_disable() is called to disable for ncm unbind but gether_disconnect() is never called since 'in_ep' is not enabled. As the result, ncm object is released in ncm unbind but 'dev->port_usb' associated to 'ncm->port' is not NULL. And when ncm bind again to recover netdev, ncm object is reallocated but usb0 interface is already associated to previous released ncm object. Therefore, once usb0 interface is up and eth_start_xmit() is called, released ncm object is dereferrenced and it might cause use-after-free memory. [function unlink via configfs] usb0: eth_stop dev->port_usb=ffffff9b179c3200 --> error happens in usb_ep_enable(). NCM: ncm_disable: ncm=ffffff9b179c3200 --> no gether_disconnect() since ncm->port.in_ep->enabled is false. NCM: ncm_unbind: ncm unbind ncm=ffffff9b179c3200 NCM: ncm_free: ncm free ncm=ffffff9b179c3200 <-- released ncm [function link via configfs] NCM: ncm_alloc: ncm alloc ncm=ffffff9ac4f8a000 NCM: ncm_bind: ncm bind ncm=ffffff9ac4f8a000 NCM: ncm_set_alt: ncm=ffffff9ac4f8a000 alt=0 usb0: eth_open dev->port_usb=ffffff9b179c3200 <-- previous released ncm usb0: eth_start dev->port_usb=ffffff9b179c3200 <-- eth_start_xmit() --> dev->wrap() Unable to handle kernel paging request at virtual address dead00000000014f This patch addresses the issue by checking if 'ncm->netdev' is not NULL at ncm_disable() to call gether_disconnect() to deassociate 'dev->port_usb'. It's more reasonable to check 'ncm->netdev' to call gether_connect/disconnect rather than check 'ncm->port.in_ep->enabled' since it might not be enabled but the gether connection might be established.

Reserved 2024-02-19 | Published 2024-05-01 | Updated 2024-12-19 | Assigner Linux

Product status

Default status
unaffected

1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 before 7f67c2020cb08499c400abf0fc32c65e4d9a09ca
affected

1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 before 0588bbbd718a8130b98c54518f1e0b569ce60a93
affected

1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 before f356fd0cbd9c9cbd0854657a80d1608d0d732db3
affected

1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 before 7250326cbb1f4f90391ac511a126b936cefb5bb7
affected

1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 before 6334b8e4553cc69f51e383c9de545082213d785e
affected

Default status
affected

5.15.157
unaffected

6.1.88
unaffected

6.6.29
unaffected

6.8.8
unaffected

6.9
unaffected

References

git.kernel.org/...c/7f67c2020cb08499c400abf0fc32c65e4d9a09ca

git.kernel.org/...c/0588bbbd718a8130b98c54518f1e0b569ce60a93

git.kernel.org/...c/f356fd0cbd9c9cbd0854657a80d1608d0d732db3

git.kernel.org/...c/7250326cbb1f4f90391ac511a126b936cefb5bb7

git.kernel.org/...c/6334b8e4553cc69f51e383c9de545082213d785e

cve.org (CVE-2024-26996)

nvd.nist.gov (CVE-2024-26996)

Download JSON

Share this page
https://cve.threatint.com/CVE/CVE-2024-26996

Support options

Helpdesk Chat, Email, Knowledgebase