Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a38db5b6 authored by Stefano Brivio's avatar Stefano Brivio Committed by John W. Linville
Browse files

b43: fix use-after-free rfkill bug



Fix rfkill code which caused a use-after-free bug.

Signed-off-by: default avatarStefano Brivio <stefano.brivio@polimi.it>
Acked-by: default avatarMichael Buesch <mb@bu3sch.de>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 8ff9d21e
Loading
Loading
Loading
Loading
+6 −5
Original line number Diff line number Diff line
@@ -138,8 +138,11 @@ void b43_rfkill_init(struct b43_wldev *dev)
	rfk->rfkill->user_claim_unsupported = 1;

	rfk->poll_dev = input_allocate_polled_device();
	if (!rfk->poll_dev)
		goto err_free_rfk;
	if (!rfk->poll_dev) {
		rfkill_free(rfk->rfkill);
		goto err_freed_rfk;
	}

	rfk->poll_dev->private = dev;
	rfk->poll_dev->poll = b43_rfkill_poll;
	rfk->poll_dev->poll_interval = 1000; /* msecs */
@@ -175,8 +178,7 @@ void b43_rfkill_init(struct b43_wldev *dev)
err_free_polldev:
	input_free_polled_device(rfk->poll_dev);
	rfk->poll_dev = NULL;
err_free_rfk:
	rfkill_free(rfk->rfkill);
err_freed_rfk:
	rfk->rfkill = NULL;
out_error:
	rfk->registered = 0;
@@ -195,6 +197,5 @@ void b43_rfkill_exit(struct b43_wldev *dev)
	rfkill_unregister(rfk->rfkill);
	input_free_polled_device(rfk->poll_dev);
	rfk->poll_dev = NULL;
	rfkill_free(rfk->rfkill);
	rfk->rfkill = NULL;
}