wok-current diff broadcom-wl64/stuff/3.14.0.patch @ rev 24196

updated perl-datetime-locale (0.45 -> 1.33)
author Hans-G?nter Theisgen
date Fri Dec 31 15:04:43 2021 +0100 (2021-12-31)
parents
children
line diff
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/broadcom-wl64/stuff/3.14.0.patch	Fri Dec 31 15:04:43 2021 +0100
     1.3 @@ -0,0 +1,103 @@
     1.4 +--- a/amd64/src/wl/sys/wl_linux.c
     1.5 ++++ a/amd64/src/wl/sys/wl_linux.c
     1.6 +@@ -1192,7 +1192,11 @@
     1.7 + #else
     1.8 + #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
     1.9 + 
    1.10 ++#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 17, 0))
    1.11 + 	dev = alloc_netdev(sizeof(wl_if_t), name, ether_setup);
    1.12 ++#else
    1.13 ++	dev = alloc_netdev(sizeof(wl_if_t), name, NET_NAME_UNKNOWN, ether_setup);
    1.14 ++#endif
    1.15 + 	wlif = netdev_priv(dev);
    1.16 + 	if (!dev) {
    1.17 + #else
    1.18 +@@ -3180,6 +3184,7 @@
    1.19 + {
    1.20 + 	char tmp[32];
    1.21 + 	sprintf(tmp, "%s%d", HYBRID_PROC, wl->pub->unit);
    1.22 ++#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0)
    1.23 + 	if ((wl->proc_entry = create_proc_entry(tmp, 0644, NULL)) == NULL) {
    1.24 + 		WL_ERROR(("%s: create_proc_entry %s failed\n", __FUNCTION__, tmp));
    1.25 + 		ASSERT(0);
    1.26 +@@ -3188,5 +3193,17 @@
    1.27 + 	wl->proc_entry->read_proc = wl_proc_read;
    1.28 + 	wl->proc_entry->write_proc = wl_proc_write;
    1.29 + 	wl->proc_entry->data = wl;
    1.30 ++#else
    1.31 ++	static const struct file_operations wl_proc_fops = {
    1.32 ++		.owner = THIS_MODULE,
    1.33 ++		.read = wl_proc_read,
    1.34 ++		.write = wl_proc_write,
    1.35 ++	};
    1.36 ++	if ((wl->proc_entry = proc_create(tmp, 0644, NULL,&wl_proc_fops)) == NULL) {
    1.37 ++		WL_ERROR(("%s: create_proc_entry %s failed\n", __FUNCTION__, tmp));
    1.38 ++		ASSERT(0);
    1.39 ++		return -1;
    1.40 ++	}
    1.41 ++#endif
    1.42 + 	return 0;
    1.43 + }
    1.44 +--- a/amd64/src/wl/sys/wl_cfg80211.c
    1.45 ++++ a/amd64/src/wl/sys/wl_cfg80211.c
    1.46 +@@ -1838,8 +1838,13 @@
    1.47 + 		mgmt->u.beacon.capab_info, &bi->BSSID));
    1.48 + 
    1.49 + 	signal = notif_bss_info->rssi * 100;
    1.50 ++#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 18, 0)
    1.51 + 	if (!cfg80211_inform_bss_frame(wiphy, channel, mgmt,
    1.52 + 	    le16_to_cpu(notif_bss_info->frame_len), signal, GFP_KERNEL)) {
    1.53 ++#else
    1.54 ++	if (!cfg80211_inform_bss_frame(wiphy, channel, CFG80211_BSS_FTYPE_UNKNOWN, mgmt,
    1.55 ++	    le16_to_cpu(notif_bss_info->frame_len), signal, GFP_KERNEL)) {
    1.56 ++#endif
    1.57 + 		WL_ERR(("cfg80211_inform_bss_frame error\n"));
    1.58 + 		kfree(notif_bss_info);
    1.59 + 		return -EINVAL;
    1.60 +@@ -1857,6 +1862,12 @@
    1.61 + 	u32 event = EVENT_TYPE(e);
    1.62 + 	u16 flags = EVENT_FLAGS(e);
    1.63 + 	u32 status = EVENT_STATUS(e);
    1.64 ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0)
    1.65 ++	struct ieee80211_channel *channel = NULL;
    1.66 ++	struct wiphy *wiphy;
    1.67 ++	u32 chanspec, chan;
    1.68 ++	u32 freq, band;
    1.69 ++#endif
    1.70 + 
    1.71 + 	WL_DBG(("\n"));
    1.72 + 
    1.73 +@@ -1868,7 +1879,11 @@
    1.74 + 		}
    1.75 + 		else if ((event == WLC_E_LINK && ~(flags & WLC_EVENT_MSG_LINK)) ||
    1.76 + 			event == WLC_E_DEAUTH_IND || event == WLC_E_DISASSOC_IND) {
    1.77 ++#if LINUX_VERSION_CODE < KERNEL_VERSION(4,2,0)
    1.78 + 			cfg80211_disconnected(ndev, 0, NULL, 0, GFP_KERNEL);
    1.79 ++#else
    1.80 ++			cfg80211_disconnected(ndev, 0, NULL, 0, false, GFP_KERNEL);
    1.81 ++#endif
    1.82 + 			clear_bit(WL_STATUS_CONNECTED, &wl->status);
    1.83 + 			wl_link_down(wl);
    1.84 + 			wl_init_prof(wl->profile);
    1.85 +@@ -1892,7 +1907,21 @@
    1.86 + 			wl_get_assoc_ies(wl);
    1.87 + 			memcpy(&wl->bssid, &e->addr, ETHER_ADDR_LEN);
    1.88 + 			wl_update_bss_info(wl);
    1.89 ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0)
    1.90 ++			wiphy = wl_to_wiphy(wl);
    1.91 ++			err = wl_dev_intvar_get(ndev, "chanspec", &chanspec);
    1.92 ++			if (err) {
    1.93 ++				WL_ERR(("Could not get chanspec, err %d\n", err));
    1.94 ++				return err;
    1.95 ++			}
    1.96 ++			chan = wf_chspec_ctlchan(chanspec);
    1.97 ++			band = (chan <= CH_MAX_2G_CHANNEL) ? IEEE80211_BAND_2GHZ : IEEE80211_BAND_5GHZ;
    1.98 ++			freq = ieee80211_channel_to_frequency(chan, band);
    1.99 ++			channel = ieee80211_get_channel(wiphy, freq);
   1.100 ++			cfg80211_ibss_joined(ndev, (u8 *)&wl->bssid, channel, GFP_KERNEL);
   1.101 ++#else
   1.102 + 			cfg80211_ibss_joined(ndev, (u8 *)&wl->bssid, GFP_KERNEL);
   1.103 ++#endif
   1.104 + 			set_bit(WL_STATUS_CONNECTED, &wl->status);
   1.105 + 			wl->profile->active = true;
   1.106 + 		}