]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commit - net/ax25/ax25_dev.c
ax25: add refcount in ax25_dev to avoid UAF bugs
authorDuoming Zhou <duoming@zju.edu.cn>
Fri, 15 Apr 2022 16:14:15 +0000 (19:14 +0300)
committerStefan Bader <stefan.bader@canonical.com>
Fri, 20 May 2022 12:42:40 +0000 (14:42 +0200)
commit6f59a3483ec0e935e4551609245077465f3185b9
tree544a821e685be3a0b542c6046adcdda661f42b4a
parent4b4c5c11a45b4cf6a54e74ddb26f87c2903d655e
ax25: add refcount in ax25_dev to avoid UAF bugs

BugLink: https://bugs.launchpad.net/bugs/1969857
commit d01ffb9eee4af165d83b08dd73ebdf9fe94a519b upstream.

If we dereference ax25_dev after we call kfree(ax25_dev) in
ax25_dev_device_down(), it will lead to concurrency UAF bugs.
There are eight syscall functions suffer from UAF bugs, include
ax25_bind(), ax25_release(), ax25_connect(), ax25_ioctl(),
ax25_getname(), ax25_sendmsg(), ax25_getsockopt() and
ax25_info_show().

One of the concurrency UAF can be shown as below:

  (USE)                       |    (FREE)
                              |  ax25_device_event
                              |    ax25_dev_device_down
ax25_bind                     |    ...
  ...                         |      kfree(ax25_dev)
  ax25_fillin_cb()            |    ...
    ax25_fillin_cb_from_dev() |
  ...                         |

The root cause of UAF bugs is that kfree(ax25_dev) in
ax25_dev_device_down() is not protected by any locks.
When ax25_dev, which there are still pointers point to,
is released, the concurrency UAF bug will happen.

This patch introduces refcount into ax25_dev in order to
guarantee that there are no pointers point to it when ax25_dev
is released.

Signed-off-by: Duoming Zhou <duoming@zju.edu.cn>
Signed-off-by: David S. Miller <davem@davemloft.net>
[OP: backport to 5.15: adjusted context]
Signed-off-by: Ovidiu Panait <ovidiu.panait@windriver.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Stefan Bader <stefan.bader@canonical.com>
include/net/ax25.h
net/ax25/af_ax25.c
net/ax25/ax25_dev.c
net/ax25/ax25_route.c