--- a/src/wl/sys/wl_cfg80211_hybrid.c 2014-06-26 10:42:08.000000000 +0000 +++ b/src/wl/sys/wl_cfg80211_hybrid.c 2014-07-17 22:49:58.707134487 +0000 @@ -2071,7 +2071,22 @@ wl_get_assoc_ies(wl); memcpy(&wl->bssid, &e->addr, ETHER_ADDR_LEN); wl_update_bss_info(wl); - cfg80211_ibss_joined(ndev, (u8 *)&wl->bssid, GFP_KERNEL); + { + struct wl_bss_info *bi; + u16 bss_info_channel; + struct ieee80211_channel *channel; + u32 freq; + + bi = (struct wl_bss_info *)(wl->extra_buf + 4); + bss_info_channel = bi->ctl_ch ? bi->ctl_ch : CHSPEC_CHANNEL(bi->chanspec); + + freq = ieee80211_channel_to_frequency(bss_info_channel, + (bss_info_channel <= CH_MAX_2G_CHANNEL) ? + IEEE80211_BAND_2GHZ : IEEE80211_BAND_5GHZ); + + channel = ieee80211_get_channel(wl_to_wiphy(wl), freq); + cfg80211_ibss_joined(ndev, (u8 *)&wl->bssid, channel, GFP_KERNEL); + } set_bit(WL_STATUS_CONNECTED, &wl->status); wl->profile->active = true; } --- a/src/wl/sys/wl_linux.c 2014-06-26 10:42:08.000000000 +0000 +++ b/src/wl/sys/wl_linux.c 2014-07-17 22:51:14.738622782 +0000 @@ -878,7 +878,7 @@ static SIMPLE_DEV_PM_OPS(wl_pm_ops, wl_suspend, wl_resume); #endif -static struct pci_driver wl_pci_driver = { +static struct pci_driver wl_pci_driver __refdata = { .name = "wl", .probe = wl_pci_probe, .remove = __devexit_p(wl_remove),