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

Commit 78c1c7e1 authored by Johannes Berg's avatar Johannes Berg Committed by John W. Linville
Browse files

cfg80211: free_priv for BSS info



When cfg80211 users have their own allocated data in the per-BSS
private data, they will need to free this when the BSS struct is
destroyed. Add a free_priv method and fix one place where the BSS
was kfree'd rather than released properly.

Signed-off-by: default avatarJohannes Berg <johannes@sipsolutions.net>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 99cf5f5f
Loading
Loading
Loading
Loading
+2 −0
Original line number Diff line number Diff line
@@ -567,6 +567,7 @@ enum cfg80211_signal_type {
 * @len_information_elements: total length of the information elements
 * @signal: signal strength value
 * @signal_type: signal type
 * @free_priv: function pointer to free private data
 * @priv: private area for driver use, has at least wiphy->bss_priv_size bytes
 */
struct cfg80211_bss {
@@ -582,6 +583,7 @@ struct cfg80211_bss {
	s32 signal;
	enum cfg80211_signal_type signal_type;

	void (*free_priv)(struct cfg80211_bss *bss);
	u8 priv[0] __attribute__((__aligned__(sizeof(void *))));
};

+1 −1
Original line number Diff line number Diff line
@@ -376,7 +376,7 @@ void cfg80211_dev_free(struct cfg80211_registered_device *drv)
	mutex_destroy(&drv->mtx);
	mutex_destroy(&drv->devlist_mtx);
	list_for_each_entry_safe(scan, tmp, &drv->bss_list, list)
		kfree(scan);
		cfg80211_put_bss(&scan->pub);
	kfree(drv);
}

+2 −0
Original line number Diff line number Diff line
@@ -56,6 +56,8 @@ static void bss_release(struct kref *ref)
	struct cfg80211_internal_bss *bss;

	bss = container_of(ref, struct cfg80211_internal_bss, ref);
	if (bss->pub.free_priv)
		bss->pub.free_priv(&bss->pub);
	kfree(bss);
}