diff options
| -rw-r--r-- | drivers/bluetooth/ath3k.c | 4 | ||||
| -rw-r--r-- | drivers/bluetooth/btusb.c | 2 | ||||
| -rw-r--r-- | drivers/net/wireless/mwifiex/join.c | 7 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/Kconfig | 4 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2800pci.c | 14 | ||||
| -rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8192cu/hw.c | 89 | ||||
| -rw-r--r-- | net/nfc/llcp/llcp.c | 62 | ||||
| -rw-r--r-- | net/nfc/llcp/sock.c | 2 |
8 files changed, 108 insertions, 76 deletions
diff --git a/drivers/bluetooth/ath3k.c b/drivers/bluetooth/ath3k.c index a8a41e07a221..b282af181b44 100644 --- a/drivers/bluetooth/ath3k.c +++ b/drivers/bluetooth/ath3k.c | |||
| @@ -74,8 +74,10 @@ static struct usb_device_id ath3k_table[] = { | |||
| 74 | 74 | ||
| 75 | /* Atheros AR3012 with sflash firmware*/ | 75 | /* Atheros AR3012 with sflash firmware*/ |
| 76 | { USB_DEVICE(0x0CF3, 0x3004) }, | 76 | { USB_DEVICE(0x0CF3, 0x3004) }, |
| 77 | { USB_DEVICE(0x0CF3, 0x3008) }, | ||
| 77 | { USB_DEVICE(0x0CF3, 0x311D) }, | 78 | { USB_DEVICE(0x0CF3, 0x311D) }, |
| 78 | { USB_DEVICE(0x13d3, 0x3375) }, | 79 | { USB_DEVICE(0x13d3, 0x3375) }, |
| 80 | { USB_DEVICE(0x04CA, 0x3004) }, | ||
| 79 | { USB_DEVICE(0x04CA, 0x3005) }, | 81 | { USB_DEVICE(0x04CA, 0x3005) }, |
| 80 | { USB_DEVICE(0x04CA, 0x3006) }, | 82 | { USB_DEVICE(0x04CA, 0x3006) }, |
| 81 | { USB_DEVICE(0x04CA, 0x3008) }, | 83 | { USB_DEVICE(0x04CA, 0x3008) }, |
| @@ -106,8 +108,10 @@ static struct usb_device_id ath3k_blist_tbl[] = { | |||
| 106 | 108 | ||
| 107 | /* Atheros AR3012 with sflash firmware*/ | 109 | /* Atheros AR3012 with sflash firmware*/ |
| 108 | { USB_DEVICE(0x0cf3, 0x3004), .driver_info = BTUSB_ATH3012 }, | 110 | { USB_DEVICE(0x0cf3, 0x3004), .driver_info = BTUSB_ATH3012 }, |
| 111 | { USB_DEVICE(0x0cf3, 0x3008), .driver_info = BTUSB_ATH3012 }, | ||
| 109 | { USB_DEVICE(0x0cf3, 0x311D), .driver_info = BTUSB_ATH3012 }, | 112 | { USB_DEVICE(0x0cf3, 0x311D), .driver_info = BTUSB_ATH3012 }, |
| 110 | { USB_DEVICE(0x13d3, 0x3375), .driver_info = BTUSB_ATH3012 }, | 113 | { USB_DEVICE(0x13d3, 0x3375), .driver_info = BTUSB_ATH3012 }, |
| 114 | { USB_DEVICE(0x04ca, 0x3004), .driver_info = BTUSB_ATH3012 }, | ||
| 111 | { USB_DEVICE(0x04ca, 0x3005), .driver_info = BTUSB_ATH3012 }, | 115 | { USB_DEVICE(0x04ca, 0x3005), .driver_info = BTUSB_ATH3012 }, |
| 112 | { USB_DEVICE(0x04ca, 0x3006), .driver_info = BTUSB_ATH3012 }, | 116 | { USB_DEVICE(0x04ca, 0x3006), .driver_info = BTUSB_ATH3012 }, |
| 113 | { USB_DEVICE(0x04ca, 0x3008), .driver_info = BTUSB_ATH3012 }, | 117 | { USB_DEVICE(0x04ca, 0x3008), .driver_info = BTUSB_ATH3012 }, |
diff --git a/drivers/bluetooth/btusb.c b/drivers/bluetooth/btusb.c index 7e351e345476..e547851870e7 100644 --- a/drivers/bluetooth/btusb.c +++ b/drivers/bluetooth/btusb.c | |||
| @@ -132,8 +132,10 @@ static struct usb_device_id blacklist_table[] = { | |||
| 132 | 132 | ||
| 133 | /* Atheros 3012 with sflash firmware */ | 133 | /* Atheros 3012 with sflash firmware */ |
| 134 | { USB_DEVICE(0x0cf3, 0x3004), .driver_info = BTUSB_ATH3012 }, | 134 | { USB_DEVICE(0x0cf3, 0x3004), .driver_info = BTUSB_ATH3012 }, |
| 135 | { USB_DEVICE(0x0cf3, 0x3008), .driver_info = BTUSB_ATH3012 }, | ||
| 135 | { USB_DEVICE(0x0cf3, 0x311d), .driver_info = BTUSB_ATH3012 }, | 136 | { USB_DEVICE(0x0cf3, 0x311d), .driver_info = BTUSB_ATH3012 }, |
| 136 | { USB_DEVICE(0x13d3, 0x3375), .driver_info = BTUSB_ATH3012 }, | 137 | { USB_DEVICE(0x13d3, 0x3375), .driver_info = BTUSB_ATH3012 }, |
| 138 | { USB_DEVICE(0x04ca, 0x3004), .driver_info = BTUSB_ATH3012 }, | ||
| 137 | { USB_DEVICE(0x04ca, 0x3005), .driver_info = BTUSB_ATH3012 }, | 139 | { USB_DEVICE(0x04ca, 0x3005), .driver_info = BTUSB_ATH3012 }, |
| 138 | { USB_DEVICE(0x04ca, 0x3006), .driver_info = BTUSB_ATH3012 }, | 140 | { USB_DEVICE(0x04ca, 0x3006), .driver_info = BTUSB_ATH3012 }, |
| 139 | { USB_DEVICE(0x04ca, 0x3008), .driver_info = BTUSB_ATH3012 }, | 141 | { USB_DEVICE(0x04ca, 0x3008), .driver_info = BTUSB_ATH3012 }, |
diff --git a/drivers/net/wireless/mwifiex/join.c b/drivers/net/wireless/mwifiex/join.c index 246aa62a4817..2fe0ceba4400 100644 --- a/drivers/net/wireless/mwifiex/join.c +++ b/drivers/net/wireless/mwifiex/join.c | |||
| @@ -1117,10 +1117,9 @@ mwifiex_cmd_802_11_ad_hoc_join(struct mwifiex_private *priv, | |||
| 1117 | adhoc_join->bss_descriptor.bssid, | 1117 | adhoc_join->bss_descriptor.bssid, |
| 1118 | adhoc_join->bss_descriptor.ssid); | 1118 | adhoc_join->bss_descriptor.ssid); |
| 1119 | 1119 | ||
| 1120 | for (i = 0; bss_desc->supported_rates[i] && | 1120 | for (i = 0; i < MWIFIEX_SUPPORTED_RATES && |
| 1121 | i < MWIFIEX_SUPPORTED_RATES; | 1121 | bss_desc->supported_rates[i]; i++) |
| 1122 | i++) | 1122 | ; |
| 1123 | ; | ||
| 1124 | rates_size = i; | 1123 | rates_size = i; |
| 1125 | 1124 | ||
| 1126 | /* Copy Data Rates from the Rates recorded in scan response */ | 1125 | /* Copy Data Rates from the Rates recorded in scan response */ |
diff --git a/drivers/net/wireless/rt2x00/Kconfig b/drivers/net/wireless/rt2x00/Kconfig index 44d6ead43341..2bf4efa33186 100644 --- a/drivers/net/wireless/rt2x00/Kconfig +++ b/drivers/net/wireless/rt2x00/Kconfig | |||
| @@ -55,10 +55,10 @@ config RT61PCI | |||
| 55 | 55 | ||
| 56 | config RT2800PCI | 56 | config RT2800PCI |
| 57 | tristate "Ralink rt27xx/rt28xx/rt30xx (PCI/PCIe/PCMCIA) support" | 57 | tristate "Ralink rt27xx/rt28xx/rt30xx (PCI/PCIe/PCMCIA) support" |
| 58 | depends on PCI || RALINK_RT288X || RALINK_RT305X | 58 | depends on PCI || SOC_RT288X || SOC_RT305X |
| 59 | select RT2800_LIB | 59 | select RT2800_LIB |
| 60 | select RT2X00_LIB_PCI if PCI | 60 | select RT2X00_LIB_PCI if PCI |
| 61 | select RT2X00_LIB_SOC if RALINK_RT288X || RALINK_RT305X | 61 | select RT2X00_LIB_SOC if SOC_RT288X || SOC_RT305X |
| 62 | select RT2X00_LIB_FIRMWARE | 62 | select RT2X00_LIB_FIRMWARE |
| 63 | select RT2X00_LIB_CRYPTO | 63 | select RT2X00_LIB_CRYPTO |
| 64 | select CRC_CCITT | 64 | select CRC_CCITT |
diff --git a/drivers/net/wireless/rt2x00/rt2800pci.c b/drivers/net/wireless/rt2x00/rt2800pci.c index 48a01aa21f1c..ded73da4de0b 100644 --- a/drivers/net/wireless/rt2x00/rt2800pci.c +++ b/drivers/net/wireless/rt2x00/rt2800pci.c | |||
| @@ -89,7 +89,7 @@ static void rt2800pci_mcu_status(struct rt2x00_dev *rt2x00dev, const u8 token) | |||
| 89 | rt2x00pci_register_write(rt2x00dev, H2M_MAILBOX_CID, ~0); | 89 | rt2x00pci_register_write(rt2x00dev, H2M_MAILBOX_CID, ~0); |
| 90 | } | 90 | } |
| 91 | 91 | ||
| 92 | #if defined(CONFIG_RALINK_RT288X) || defined(CONFIG_RALINK_RT305X) | 92 | #if defined(CONFIG_SOC_RT288X) || defined(CONFIG_SOC_RT305X) |
| 93 | static int rt2800pci_read_eeprom_soc(struct rt2x00_dev *rt2x00dev) | 93 | static int rt2800pci_read_eeprom_soc(struct rt2x00_dev *rt2x00dev) |
| 94 | { | 94 | { |
| 95 | void __iomem *base_addr = ioremap(0x1F040000, EEPROM_SIZE); | 95 | void __iomem *base_addr = ioremap(0x1F040000, EEPROM_SIZE); |
| @@ -107,7 +107,7 @@ static inline int rt2800pci_read_eeprom_soc(struct rt2x00_dev *rt2x00dev) | |||
| 107 | { | 107 | { |
| 108 | return -ENOMEM; | 108 | return -ENOMEM; |
| 109 | } | 109 | } |
| 110 | #endif /* CONFIG_RALINK_RT288X || CONFIG_RALINK_RT305X */ | 110 | #endif /* CONFIG_SOC_RT288X || CONFIG_SOC_RT305X */ |
| 111 | 111 | ||
| 112 | #ifdef CONFIG_PCI | 112 | #ifdef CONFIG_PCI |
| 113 | static void rt2800pci_eepromregister_read(struct eeprom_93cx6 *eeprom) | 113 | static void rt2800pci_eepromregister_read(struct eeprom_93cx6 *eeprom) |
| @@ -1177,7 +1177,7 @@ MODULE_DEVICE_TABLE(pci, rt2800pci_device_table); | |||
| 1177 | #endif /* CONFIG_PCI */ | 1177 | #endif /* CONFIG_PCI */ |
| 1178 | MODULE_LICENSE("GPL"); | 1178 | MODULE_LICENSE("GPL"); |
| 1179 | 1179 | ||
| 1180 | #if defined(CONFIG_RALINK_RT288X) || defined(CONFIG_RALINK_RT305X) | 1180 | #if defined(CONFIG_SOC_RT288X) || defined(CONFIG_SOC_RT305X) |
| 1181 | static int rt2800soc_probe(struct platform_device *pdev) | 1181 | static int rt2800soc_probe(struct platform_device *pdev) |
| 1182 | { | 1182 | { |
| 1183 | return rt2x00soc_probe(pdev, &rt2800pci_ops); | 1183 | return rt2x00soc_probe(pdev, &rt2800pci_ops); |
| @@ -1194,7 +1194,7 @@ static struct platform_driver rt2800soc_driver = { | |||
| 1194 | .suspend = rt2x00soc_suspend, | 1194 | .suspend = rt2x00soc_suspend, |
| 1195 | .resume = rt2x00soc_resume, | 1195 | .resume = rt2x00soc_resume, |
| 1196 | }; | 1196 | }; |
| 1197 | #endif /* CONFIG_RALINK_RT288X || CONFIG_RALINK_RT305X */ | 1197 | #endif /* CONFIG_SOC_RT288X || CONFIG_SOC_RT305X */ |
| 1198 | 1198 | ||
| 1199 | #ifdef CONFIG_PCI | 1199 | #ifdef CONFIG_PCI |
| 1200 | static int rt2800pci_probe(struct pci_dev *pci_dev, | 1200 | static int rt2800pci_probe(struct pci_dev *pci_dev, |
| @@ -1217,7 +1217,7 @@ static int __init rt2800pci_init(void) | |||
| 1217 | { | 1217 | { |
| 1218 | int ret = 0; | 1218 | int ret = 0; |
| 1219 | 1219 | ||
| 1220 | #if defined(CONFIG_RALINK_RT288X) || defined(CONFIG_RALINK_RT305X) | 1220 | #if defined(CONFIG_SOC_RT288X) || defined(CONFIG_SOC_RT305X) |
| 1221 | ret = platform_driver_register(&rt2800soc_driver); | 1221 | ret = platform_driver_register(&rt2800soc_driver); |
| 1222 | if (ret) | 1222 | if (ret) |
| 1223 | return ret; | 1223 | return ret; |
| @@ -1225,7 +1225,7 @@ static int __init rt2800pci_init(void) | |||
| 1225 | #ifdef CONFIG_PCI | 1225 | #ifdef CONFIG_PCI |
| 1226 | ret = pci_register_driver(&rt2800pci_driver); | 1226 | ret = pci_register_driver(&rt2800pci_driver); |
| 1227 | if (ret) { | 1227 | if (ret) { |
| 1228 | #if defined(CONFIG_RALINK_RT288X) || defined(CONFIG_RALINK_RT305X) | 1228 | #if defined(CONFIG_SOC_RT288X) || defined(CONFIG_SOC_RT305X) |
| 1229 | platform_driver_unregister(&rt2800soc_driver); | 1229 | platform_driver_unregister(&rt2800soc_driver); |
| 1230 | #endif | 1230 | #endif |
| 1231 | return ret; | 1231 | return ret; |
| @@ -1240,7 +1240,7 @@ static void __exit rt2800pci_exit(void) | |||
| 1240 | #ifdef CONFIG_PCI | 1240 | #ifdef CONFIG_PCI |
| 1241 | pci_unregister_driver(&rt2800pci_driver); | 1241 | pci_unregister_driver(&rt2800pci_driver); |
| 1242 | #endif | 1242 | #endif |
| 1243 | #if defined(CONFIG_RALINK_RT288X) || defined(CONFIG_RALINK_RT305X) | 1243 | #if defined(CONFIG_SOC_RT288X) || defined(CONFIG_SOC_RT305X) |
| 1244 | platform_driver_unregister(&rt2800soc_driver); | 1244 | platform_driver_unregister(&rt2800soc_driver); |
| 1245 | #endif | 1245 | #endif |
| 1246 | } | 1246 | } |
diff --git a/drivers/net/wireless/rtlwifi/rtl8192cu/hw.c b/drivers/net/wireless/rtlwifi/rtl8192cu/hw.c index b1ccff474c79..c08d0f4c5f3d 100644 --- a/drivers/net/wireless/rtlwifi/rtl8192cu/hw.c +++ b/drivers/net/wireless/rtlwifi/rtl8192cu/hw.c | |||
| @@ -1377,74 +1377,57 @@ void rtl92cu_card_disable(struct ieee80211_hw *hw) | |||
| 1377 | 1377 | ||
| 1378 | void rtl92cu_set_check_bssid(struct ieee80211_hw *hw, bool check_bssid) | 1378 | void rtl92cu_set_check_bssid(struct ieee80211_hw *hw, bool check_bssid) |
| 1379 | { | 1379 | { |
| 1380 | /* dummy routine needed for callback from rtl_op_configure_filter() */ | ||
| 1381 | } | ||
| 1382 | |||
| 1383 | /*========================================================================== */ | ||
| 1384 | |||
| 1385 | static void _rtl92cu_set_check_bssid(struct ieee80211_hw *hw, | ||
| 1386 | enum nl80211_iftype type) | ||
| 1387 | { | ||
| 1388 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 1380 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
| 1389 | u32 reg_rcr = rtl_read_dword(rtlpriv, REG_RCR); | ||
| 1390 | struct rtl_hal *rtlhal = rtl_hal(rtlpriv); | 1381 | struct rtl_hal *rtlhal = rtl_hal(rtlpriv); |
| 1391 | struct rtl_phy *rtlphy = &(rtlpriv->phy); | 1382 | u32 reg_rcr = rtl_read_dword(rtlpriv, REG_RCR); |
| 1392 | u8 filterout_non_associated_bssid = false; | ||
| 1393 | 1383 | ||
| 1394 | switch (type) { | 1384 | if (rtlpriv->psc.rfpwr_state != ERFON) |
| 1395 | case NL80211_IFTYPE_ADHOC: | 1385 | return; |
| 1396 | case NL80211_IFTYPE_STATION: | 1386 | |
| 1397 | filterout_non_associated_bssid = true; | 1387 | if (check_bssid) { |
| 1398 | break; | 1388 | u8 tmp; |
| 1399 | case NL80211_IFTYPE_UNSPECIFIED: | ||
| 1400 | case NL80211_IFTYPE_AP: | ||
| 1401 | default: | ||
| 1402 | break; | ||
| 1403 | } | ||
| 1404 | if (filterout_non_associated_bssid) { | ||
| 1405 | if (IS_NORMAL_CHIP(rtlhal->version)) { | 1389 | if (IS_NORMAL_CHIP(rtlhal->version)) { |
| 1406 | switch (rtlphy->current_io_type) { | 1390 | reg_rcr |= (RCR_CBSSID_DATA | RCR_CBSSID_BCN); |
| 1407 | case IO_CMD_RESUME_DM_BY_SCAN: | 1391 | tmp = BIT(4); |
| 1408 | reg_rcr |= (RCR_CBSSID_DATA | RCR_CBSSID_BCN); | ||
| 1409 | rtlpriv->cfg->ops->set_hw_reg(hw, | ||
| 1410 | HW_VAR_RCR, (u8 *)(®_rcr)); | ||
| 1411 | /* enable update TSF */ | ||
| 1412 | _rtl92cu_set_bcn_ctrl_reg(hw, 0, BIT(4)); | ||
| 1413 | break; | ||
| 1414 | case IO_CMD_PAUSE_DM_BY_SCAN: | ||
| 1415 | reg_rcr &= ~(RCR_CBSSID_DATA | RCR_CBSSID_BCN); | ||
| 1416 | rtlpriv->cfg->ops->set_hw_reg(hw, | ||
| 1417 | HW_VAR_RCR, (u8 *)(®_rcr)); | ||
| 1418 | /* disable update TSF */ | ||
| 1419 | _rtl92cu_set_bcn_ctrl_reg(hw, BIT(4), 0); | ||
| 1420 | break; | ||
| 1421 | } | ||
| 1422 | } else { | 1392 | } else { |
| 1423 | reg_rcr |= (RCR_CBSSID); | 1393 | reg_rcr |= RCR_CBSSID; |
| 1424 | rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_RCR, | 1394 | tmp = BIT(4) | BIT(5); |
| 1425 | (u8 *)(®_rcr)); | ||
| 1426 | _rtl92cu_set_bcn_ctrl_reg(hw, 0, (BIT(4)|BIT(5))); | ||
| 1427 | } | 1395 | } |
| 1428 | } else if (filterout_non_associated_bssid == false) { | 1396 | rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_RCR, |
| 1397 | (u8 *) (®_rcr)); | ||
| 1398 | _rtl92cu_set_bcn_ctrl_reg(hw, 0, tmp); | ||
| 1399 | } else { | ||
| 1400 | u8 tmp; | ||
| 1429 | if (IS_NORMAL_CHIP(rtlhal->version)) { | 1401 | if (IS_NORMAL_CHIP(rtlhal->version)) { |
| 1430 | reg_rcr &= (~(RCR_CBSSID_DATA | RCR_CBSSID_BCN)); | 1402 | reg_rcr &= ~(RCR_CBSSID_DATA | RCR_CBSSID_BCN); |
| 1431 | rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_RCR, | 1403 | tmp = BIT(4); |
| 1432 | (u8 *)(®_rcr)); | ||
| 1433 | _rtl92cu_set_bcn_ctrl_reg(hw, BIT(4), 0); | ||
| 1434 | } else { | 1404 | } else { |
| 1435 | reg_rcr &= (~RCR_CBSSID); | 1405 | reg_rcr &= ~RCR_CBSSID; |
| 1436 | rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_RCR, | 1406 | tmp = BIT(4) | BIT(5); |
| 1437 | (u8 *)(®_rcr)); | ||
| 1438 | _rtl92cu_set_bcn_ctrl_reg(hw, (BIT(4)|BIT(5)), 0); | ||
| 1439 | } | 1407 | } |
| 1408 | reg_rcr &= (~(RCR_CBSSID_DATA | RCR_CBSSID_BCN)); | ||
| 1409 | rtlpriv->cfg->ops->set_hw_reg(hw, | ||
| 1410 | HW_VAR_RCR, (u8 *) (®_rcr)); | ||
| 1411 | _rtl92cu_set_bcn_ctrl_reg(hw, tmp, 0); | ||
| 1440 | } | 1412 | } |
| 1441 | } | 1413 | } |
| 1442 | 1414 | ||
| 1415 | /*========================================================================== */ | ||
| 1416 | |||
| 1443 | int rtl92cu_set_network_type(struct ieee80211_hw *hw, enum nl80211_iftype type) | 1417 | int rtl92cu_set_network_type(struct ieee80211_hw *hw, enum nl80211_iftype type) |
| 1444 | { | 1418 | { |
| 1419 | struct rtl_priv *rtlpriv = rtl_priv(hw); | ||
| 1420 | |||
| 1445 | if (_rtl92cu_set_media_status(hw, type)) | 1421 | if (_rtl92cu_set_media_status(hw, type)) |
| 1446 | return -EOPNOTSUPP; | 1422 | return -EOPNOTSUPP; |
| 1447 | _rtl92cu_set_check_bssid(hw, type); | 1423 | |
| 1424 | if (rtlpriv->mac80211.link_state == MAC80211_LINKED) { | ||
| 1425 | if (type != NL80211_IFTYPE_AP) | ||
| 1426 | rtl92cu_set_check_bssid(hw, true); | ||
| 1427 | } else { | ||
| 1428 | rtl92cu_set_check_bssid(hw, false); | ||
| 1429 | } | ||
| 1430 | |||
| 1448 | return 0; | 1431 | return 0; |
| 1449 | } | 1432 | } |
| 1450 | 1433 | ||
| @@ -2058,8 +2041,6 @@ void rtl92cu_update_hal_rate_table(struct ieee80211_hw *hw, | |||
| 2058 | (shortgi_rate << 4) | (shortgi_rate); | 2041 | (shortgi_rate << 4) | (shortgi_rate); |
| 2059 | } | 2042 | } |
| 2060 | rtl_write_dword(rtlpriv, REG_ARFR0 + ratr_index * 4, ratr_value); | 2043 | rtl_write_dword(rtlpriv, REG_ARFR0 + ratr_index * 4, ratr_value); |
| 2061 | RT_TRACE(rtlpriv, COMP_RATR, DBG_DMESG, "%x\n", | ||
| 2062 | rtl_read_dword(rtlpriv, REG_ARFR0)); | ||
| 2063 | } | 2044 | } |
| 2064 | 2045 | ||
| 2065 | void rtl92cu_update_hal_rate_mask(struct ieee80211_hw *hw, u8 rssi_level) | 2046 | void rtl92cu_update_hal_rate_mask(struct ieee80211_hw *hw, u8 rssi_level) |
diff --git a/net/nfc/llcp/llcp.c b/net/nfc/llcp/llcp.c index 7f8266dd14cb..b530afadd76c 100644 --- a/net/nfc/llcp/llcp.c +++ b/net/nfc/llcp/llcp.c | |||
| @@ -68,7 +68,8 @@ static void nfc_llcp_socket_purge(struct nfc_llcp_sock *sock) | |||
| 68 | } | 68 | } |
| 69 | } | 69 | } |
| 70 | 70 | ||
| 71 | static void nfc_llcp_socket_release(struct nfc_llcp_local *local, bool listen) | 71 | static void nfc_llcp_socket_release(struct nfc_llcp_local *local, bool listen, |
| 72 | int err) | ||
| 72 | { | 73 | { |
| 73 | struct sock *sk; | 74 | struct sock *sk; |
| 74 | struct hlist_node *tmp; | 75 | struct hlist_node *tmp; |
| @@ -100,7 +101,10 @@ static void nfc_llcp_socket_release(struct nfc_llcp_local *local, bool listen) | |||
| 100 | 101 | ||
| 101 | nfc_llcp_accept_unlink(accept_sk); | 102 | nfc_llcp_accept_unlink(accept_sk); |
| 102 | 103 | ||
| 104 | if (err) | ||
| 105 | accept_sk->sk_err = err; | ||
| 103 | accept_sk->sk_state = LLCP_CLOSED; | 106 | accept_sk->sk_state = LLCP_CLOSED; |
| 107 | accept_sk->sk_state_change(sk); | ||
| 104 | 108 | ||
| 105 | bh_unlock_sock(accept_sk); | 109 | bh_unlock_sock(accept_sk); |
| 106 | 110 | ||
| @@ -123,7 +127,10 @@ static void nfc_llcp_socket_release(struct nfc_llcp_local *local, bool listen) | |||
| 123 | continue; | 127 | continue; |
| 124 | } | 128 | } |
| 125 | 129 | ||
| 130 | if (err) | ||
| 131 | sk->sk_err = err; | ||
| 126 | sk->sk_state = LLCP_CLOSED; | 132 | sk->sk_state = LLCP_CLOSED; |
| 133 | sk->sk_state_change(sk); | ||
| 127 | 134 | ||
| 128 | bh_unlock_sock(sk); | 135 | bh_unlock_sock(sk); |
| 129 | 136 | ||
| @@ -133,6 +140,36 @@ static void nfc_llcp_socket_release(struct nfc_llcp_local *local, bool listen) | |||
| 133 | } | 140 | } |
| 134 | 141 | ||
| 135 | write_unlock(&local->sockets.lock); | 142 | write_unlock(&local->sockets.lock); |
| 143 | |||
| 144 | /* | ||
| 145 | * If we want to keep the listening sockets alive, | ||
| 146 | * we don't touch the RAW ones. | ||
| 147 | */ | ||
| 148 | if (listen == true) | ||
| 149 | return; | ||
| 150 | |||
| 151 | write_lock(&local->raw_sockets.lock); | ||
| 152 | |||
| 153 | sk_for_each_safe(sk, tmp, &local->raw_sockets.head) { | ||
| 154 | llcp_sock = nfc_llcp_sock(sk); | ||
| 155 | |||
| 156 | bh_lock_sock(sk); | ||
| 157 | |||
| 158 | nfc_llcp_socket_purge(llcp_sock); | ||
| 159 | |||
| 160 | if (err) | ||
| 161 | sk->sk_err = err; | ||
| 162 | sk->sk_state = LLCP_CLOSED; | ||
| 163 | sk->sk_state_change(sk); | ||
| 164 | |||
| 165 | bh_unlock_sock(sk); | ||
| 166 | |||
| 167 | sock_orphan(sk); | ||
| 168 | |||
| 169 | sk_del_node_init(sk); | ||
| 170 | } | ||
| 171 | |||
| 172 | write_unlock(&local->raw_sockets.lock); | ||
| 136 | } | 173 | } |
| 137 | 174 | ||
| 138 | struct nfc_llcp_local *nfc_llcp_local_get(struct nfc_llcp_local *local) | 175 | struct nfc_llcp_local *nfc_llcp_local_get(struct nfc_llcp_local *local) |
| @@ -142,20 +179,25 @@ struct nfc_llcp_local *nfc_llcp_local_get(struct nfc_llcp_local *local) | |||
| 142 | return local; | 179 | return local; |
| 143 | } | 180 | } |
| 144 | 181 | ||
| 145 | static void local_release(struct kref *ref) | 182 | static void local_cleanup(struct nfc_llcp_local *local, bool listen) |
| 146 | { | 183 | { |
| 147 | struct nfc_llcp_local *local; | 184 | nfc_llcp_socket_release(local, listen, ENXIO); |
| 148 | |||
| 149 | local = container_of(ref, struct nfc_llcp_local, ref); | ||
| 150 | |||
| 151 | list_del(&local->list); | ||
| 152 | nfc_llcp_socket_release(local, false); | ||
| 153 | del_timer_sync(&local->link_timer); | 185 | del_timer_sync(&local->link_timer); |
| 154 | skb_queue_purge(&local->tx_queue); | 186 | skb_queue_purge(&local->tx_queue); |
| 155 | cancel_work_sync(&local->tx_work); | 187 | cancel_work_sync(&local->tx_work); |
| 156 | cancel_work_sync(&local->rx_work); | 188 | cancel_work_sync(&local->rx_work); |
| 157 | cancel_work_sync(&local->timeout_work); | 189 | cancel_work_sync(&local->timeout_work); |
| 158 | kfree_skb(local->rx_pending); | 190 | kfree_skb(local->rx_pending); |
| 191 | } | ||
| 192 | |||
| 193 | static void local_release(struct kref *ref) | ||
| 194 | { | ||
| 195 | struct nfc_llcp_local *local; | ||
| 196 | |||
| 197 | local = container_of(ref, struct nfc_llcp_local, ref); | ||
| 198 | |||
| 199 | list_del(&local->list); | ||
| 200 | local_cleanup(local, false); | ||
| 159 | kfree(local); | 201 | kfree(local); |
| 160 | } | 202 | } |
| 161 | 203 | ||
| @@ -1348,7 +1390,7 @@ void nfc_llcp_mac_is_down(struct nfc_dev *dev) | |||
| 1348 | return; | 1390 | return; |
| 1349 | 1391 | ||
| 1350 | /* Close and purge all existing sockets */ | 1392 | /* Close and purge all existing sockets */ |
| 1351 | nfc_llcp_socket_release(local, true); | 1393 | nfc_llcp_socket_release(local, true, 0); |
| 1352 | } | 1394 | } |
| 1353 | 1395 | ||
| 1354 | void nfc_llcp_mac_is_up(struct nfc_dev *dev, u32 target_idx, | 1396 | void nfc_llcp_mac_is_up(struct nfc_dev *dev, u32 target_idx, |
| @@ -1427,6 +1469,8 @@ void nfc_llcp_unregister_device(struct nfc_dev *dev) | |||
| 1427 | return; | 1469 | return; |
| 1428 | } | 1470 | } |
| 1429 | 1471 | ||
| 1472 | local_cleanup(local, false); | ||
| 1473 | |||
| 1430 | nfc_llcp_local_put(local); | 1474 | nfc_llcp_local_put(local); |
| 1431 | } | 1475 | } |
| 1432 | 1476 | ||
diff --git a/net/nfc/llcp/sock.c b/net/nfc/llcp/sock.c index 5332751943a9..5c7cdf3f2a83 100644 --- a/net/nfc/llcp/sock.c +++ b/net/nfc/llcp/sock.c | |||
| @@ -278,6 +278,8 @@ struct sock *nfc_llcp_accept_dequeue(struct sock *parent, | |||
| 278 | 278 | ||
| 279 | pr_debug("Returning sk state %d\n", sk->sk_state); | 279 | pr_debug("Returning sk state %d\n", sk->sk_state); |
| 280 | 280 | ||
| 281 | sk_acceptq_removed(parent); | ||
| 282 | |||
| 281 | return sk; | 283 | return sk; |
| 282 | } | 284 | } |
| 283 | 285 | ||
