Commit db9c6d1d authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'staging-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging

Pull staging driver updates from Greg KH:
 "Here is a set of staging driver updates for 6.5-rc1. It's a small
  update this merge window, nothing major at all, overall just under
  1000 lines of code removed, not a huge churn.

  Nothing major to highlight here either, just lots of small coding
  style fixes.

  All of these have been in linux-next for a while with no reported
  problems"

* tag 'staging-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging: (62 commits)
  staging: rtl8192e: Remove whitespace and blank lines
  staging: rtl8192e: remove 5G related code
  staging: rtl8192e: remove comparison to true
  staging: rtl8192e: remove return statement from void function
  staging: rtl8192e: convert else if sequence to switch
  staging: rtl8192e: clean up brace coding style issues
  staging: rtl8723bs: Fix blank line issues
  staging: rtl8723bs: Fix block comment issue
  staging: rtl8723bs: Fix indentation issues
  staging: vchiq_arm: Remove extra struct vchiq_instance declaration
  staging: rtl8192e: Rename variable InitialGainHandler
  staging: rtl8192e: Rename variable LeisurePSLeave
  staging: rtl8192e: Rename variable SetBWModeHandler
  staging: rtl8192e: Rename variable SetWirelessMode
  staging: rtl8192e: Rename RTLLIB_LINKED_SCANNING
  staging: rtl8192e: Rename RTLLIB_LINKED to MAC80211_LINKED
  staging: rtl8192e: Rename RTLLIB_NOLINK to MAC80211_NOLINK
  staging: rtl8192e: Rename state to link_state
  staging: rtl8192e: Rename rtllib_state to rtl_link_state
  staging: rtl8192e: Remove unused enum led_ctl_mode
  ...
parents fc75f216 4a22870c
...@@ -906,9 +906,6 @@ static int axis_fifo_probe(struct platform_device *pdev) ...@@ -906,9 +906,6 @@ static int axis_fifo_probe(struct platform_device *pdev)
if (rc < 0) if (rc < 0)
goto err_initial; goto err_initial;
dev_info(fifo->dt_device, "axis-fifo created at %pa mapped to 0x%pa, irq=%i\n",
&r_mem->start, &fifo->base_addr, fifo->irq);
return 0; return 0;
err_initial: err_initial:
......
...@@ -362,7 +362,7 @@ static struct i2c_driver i2c_driver = { ...@@ -362,7 +362,7 @@ static struct i2c_driver i2c_driver = {
.driver = { .driver = {
.name = "hdm_i2c", .name = "hdm_i2c",
}, },
.probe_new = i2c_probe, .probe = i2c_probe,
.remove = i2c_remove, .remove = i2c_remove,
.id_table = i2c_id, .id_table = i2c_id,
}; };
......
...@@ -779,7 +779,7 @@ static struct i2c_driver dcon_driver = { ...@@ -779,7 +779,7 @@ static struct i2c_driver dcon_driver = {
}, },
.class = I2C_CLASS_DDC | I2C_CLASS_HWMON, .class = I2C_CLASS_DDC | I2C_CLASS_HWMON,
.id_table = dcon_idtable, .id_table = dcon_idtable,
.probe_new = dcon_probe, .probe = dcon_probe,
.remove = dcon_remove, .remove = dcon_remove,
.detect = dcon_detect, .detect = dcon_detect,
.address_list = normal_i2c, .address_list = normal_i2c,
......
...@@ -1019,7 +1019,6 @@ static int setup_gpio(struct pi433_device *device) ...@@ -1019,7 +1019,6 @@ static int setup_gpio(struct pi433_device *device)
} }
/* configure the pin */ /* configure the pin */
gpiod_unexport(device->gpiod[i]);
retval = gpiod_direction_input(device->gpiod[i]); retval = gpiod_direction_input(device->gpiod[i]);
if (retval) if (retval)
return retval; return retval;
......
...@@ -3,6 +3,7 @@ config RTL8192E ...@@ -3,6 +3,7 @@ config RTL8192E
tristate "RealTek RTL8192E Wireless LAN NIC driver" tristate "RealTek RTL8192E Wireless LAN NIC driver"
depends on PCI && WLAN && RTLLIB depends on PCI && WLAN && RTLLIB
depends on m depends on m
select CFG80211
select WIRELESS_EXT select WIRELESS_EXT
select WEXT_PRIV select WEXT_PRIV
select CRYPTO select CRYPTO
......
...@@ -85,7 +85,6 @@ enum rtl819x_loopback { ...@@ -85,7 +85,6 @@ enum rtl819x_loopback {
#define HAL_PRIME_CHNL_OFFSET_LOWER 1 #define HAL_PRIME_CHNL_OFFSET_LOWER 1
#define HAL_PRIME_CHNL_OFFSET_UPPER 2 #define HAL_PRIME_CHNL_OFFSET_UPPER 2
enum version_8190_loopback { enum version_8190_loopback {
VERSION_8190_BD = 0x3, VERSION_8190_BD = 0x3,
VERSION_8190_BE VERSION_8190_BE
...@@ -139,8 +138,6 @@ struct tx_fwinfo_8190pci { ...@@ -139,8 +138,6 @@ struct tx_fwinfo_8190pci {
u32 Retry_Limit:4; u32 Retry_Limit:4;
u32 Reserved2:1; u32 Reserved2:1;
u32 PacketID:13; u32 PacketID:13;
}; };
struct phy_ofdm_rx_status_rxsc_sgien_exintfflag { struct phy_ofdm_rx_status_rxsc_sgien_exintfflag {
...@@ -172,7 +169,6 @@ struct phy_sts_cck_819xpci { ...@@ -172,7 +169,6 @@ struct phy_sts_cck_819xpci {
u8 cck_agc_rpt; u8 cck_agc_rpt;
}; };
#define PHY_RSSI_SLID_WIN_MAX 100 #define PHY_RSSI_SLID_WIN_MAX 100
#define PHY_Beacon_RSSI_SLID_WIN_MAX 10 #define PHY_Beacon_RSSI_SLID_WIN_MAX 10
...@@ -214,7 +210,6 @@ struct tx_desc { ...@@ -214,7 +210,6 @@ struct tx_desc {
u32 Reserved7; u32 Reserved7;
}; };
struct tx_desc_cmd { struct tx_desc_cmd {
u16 PktSize; u16 PktSize;
u8 Reserved1; u8 Reserved1;
...@@ -256,10 +251,8 @@ struct rx_desc { ...@@ -256,10 +251,8 @@ struct rx_desc {
u32 Reserved3; u32 Reserved3;
u32 BufferAddress; u32 BufferAddress;
}; };
struct rx_fwinfo { struct rx_fwinfo {
u16 Reserved1:12; u16 Reserved1:12;
u16 PartAggr:1; u16 PartAggr:1;
...@@ -278,7 +271,6 @@ struct rx_fwinfo { ...@@ -278,7 +271,6 @@ struct rx_fwinfo {
u8 Reserved4:1; u8 Reserved4:1;
u32 TSFL; u32 TSFL;
}; };
#endif #endif
...@@ -73,11 +73,11 @@ bool rtl92e_config_rf(struct net_device *dev) ...@@ -73,11 +73,11 @@ bool rtl92e_config_rf(struct net_device *dev)
break; break;
case RF90_PATH_B: case RF90_PATH_B:
u4RegValue = rtl92e_get_bb_reg(dev, pPhyReg->rfintfs, u4RegValue = rtl92e_get_bb_reg(dev, pPhyReg->rfintfs,
bRFSI_RFENV<<16); bRFSI_RFENV << 16);
break; break;
} }
rtl92e_set_bb_reg(dev, pPhyReg->rfintfe, bRFSI_RFENV<<16, 0x1); rtl92e_set_bb_reg(dev, pPhyReg->rfintfe, bRFSI_RFENV << 16, 0x1);
rtl92e_set_bb_reg(dev, pPhyReg->rfintfo, bRFSI_RFENV, 0x1); rtl92e_set_bb_reg(dev, pPhyReg->rfintfo, bRFSI_RFENV, 0x1);
...@@ -117,7 +117,7 @@ bool rtl92e_config_rf(struct net_device *dev) ...@@ -117,7 +117,7 @@ bool rtl92e_config_rf(struct net_device *dev)
break; break;
case RF90_PATH_B: case RF90_PATH_B:
rtl92e_set_bb_reg(dev, pPhyReg->rfintfs, rtl92e_set_bb_reg(dev, pPhyReg->rfintfs,
bRFSI_RFENV<<16, u4RegValue); bRFSI_RFENV << 16, u4RegValue);
break; break;
} }
......
...@@ -159,7 +159,6 @@ enum _RTL8192PCI_HW { ...@@ -159,7 +159,6 @@ enum _RTL8192PCI_HW {
WFCRC2 = 0x2f8, WFCRC2 = 0x2f8,
BW_OPMODE = 0x300, BW_OPMODE = 0x300,
#define BW_OPMODE_5G BIT1
#define BW_OPMODE_20MHZ BIT2 #define BW_OPMODE_20MHZ BIT2
IC_VERRSION = 0x301, IC_VERRSION = 0x301,
MSR = 0x303, MSR = 0x303,
......
...@@ -32,7 +32,6 @@ static u32 _rtl92e_calculate_bit_shift(u32 dwBitMask) ...@@ -32,7 +32,6 @@ static u32 _rtl92e_calculate_bit_shift(u32 dwBitMask)
void rtl92e_set_bb_reg(struct net_device *dev, u32 dwRegAddr, u32 dwBitMask, void rtl92e_set_bb_reg(struct net_device *dev, u32 dwRegAddr, u32 dwBitMask,
u32 dwData) u32 dwData)
{ {
u32 OriginalValue, BitShift, NewValue; u32 OriginalValue, BitShift, NewValue;
if (dwBitMask != bMaskDWord) { if (dwBitMask != bMaskDWord) {
...@@ -40,8 +39,9 @@ void rtl92e_set_bb_reg(struct net_device *dev, u32 dwRegAddr, u32 dwBitMask, ...@@ -40,8 +39,9 @@ void rtl92e_set_bb_reg(struct net_device *dev, u32 dwRegAddr, u32 dwBitMask,
BitShift = _rtl92e_calculate_bit_shift(dwBitMask); BitShift = _rtl92e_calculate_bit_shift(dwBitMask);
NewValue = (OriginalValue & ~dwBitMask) | (dwData << BitShift); NewValue = (OriginalValue & ~dwBitMask) | (dwData << BitShift);
rtl92e_writel(dev, dwRegAddr, NewValue); rtl92e_writel(dev, dwRegAddr, NewValue);
} else } else {
rtl92e_writel(dev, dwRegAddr, dwData); rtl92e_writel(dev, dwRegAddr, dwData);
}
} }
u32 rtl92e_get_bb_reg(struct net_device *dev, u32 dwRegAddr, u32 dwBitMask) u32 rtl92e_get_bb_reg(struct net_device *dev, u32 dwRegAddr, u32 dwBitMask)
...@@ -99,7 +99,6 @@ static u32 _rtl92e_phy_rf_read(struct net_device *dev, ...@@ -99,7 +99,6 @@ static u32 _rtl92e_phy_rf_read(struct net_device *dev,
rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter4, 0x300, 0x3); rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter4, 0x300, 0x3);
return ret; return ret;
} }
static void _rtl92e_phy_rf_write(struct net_device *dev, static void _rtl92e_phy_rf_write(struct net_device *dev,
...@@ -165,10 +164,10 @@ void rtl92e_set_rf_reg(struct net_device *dev, enum rf90_radio_path eRFPath, ...@@ -165,10 +164,10 @@ void rtl92e_set_rf_reg(struct net_device *dev, enum rf90_radio_path eRFPath,
_rtl92e_phy_rf_fw_write(dev, eRFPath, RegAddr, _rtl92e_phy_rf_fw_write(dev, eRFPath, RegAddr,
New_Value); New_Value);
} else } else {
_rtl92e_phy_rf_fw_write(dev, eRFPath, RegAddr, Data); _rtl92e_phy_rf_fw_write(dev, eRFPath, RegAddr, Data);
}
udelay(200); udelay(200);
} else { } else {
if (BitMask != bMask12Bits) { if (BitMask != bMask12Bits) {
Original_Value = _rtl92e_phy_rf_read(dev, eRFPath, Original_Value = _rtl92e_phy_rf_read(dev, eRFPath,
...@@ -177,8 +176,9 @@ void rtl92e_set_rf_reg(struct net_device *dev, enum rf90_radio_path eRFPath, ...@@ -177,8 +176,9 @@ void rtl92e_set_rf_reg(struct net_device *dev, enum rf90_radio_path eRFPath,
New_Value = (Original_Value & ~BitMask) | (Data << BitShift); New_Value = (Original_Value & ~BitMask) | (Data << BitShift);
_rtl92e_phy_rf_write(dev, eRFPath, RegAddr, New_Value); _rtl92e_phy_rf_write(dev, eRFPath, RegAddr, New_Value);
} else } else {
_rtl92e_phy_rf_write(dev, eRFPath, RegAddr, Data); _rtl92e_phy_rf_write(dev, eRFPath, RegAddr, Data);
}
} }
} }
...@@ -226,7 +226,6 @@ static u32 _rtl92e_phy_rf_fw_read(struct net_device *dev, ...@@ -226,7 +226,6 @@ static u32 _rtl92e_phy_rf_fw_read(struct net_device *dev,
return 0; return 0;
} }
return rtl92e_readl(dev, RF_DATA); return rtl92e_readl(dev, RF_DATA);
} }
static void _rtl92e_phy_rf_fw_write(struct net_device *dev, static void _rtl92e_phy_rf_fw_write(struct net_device *dev,
...@@ -247,10 +246,8 @@ static void _rtl92e_phy_rf_fw_write(struct net_device *dev, ...@@ -247,10 +246,8 @@ static void _rtl92e_phy_rf_fw_write(struct net_device *dev,
break; break;
} }
rtl92e_writel(dev, QPNR, Data); rtl92e_writel(dev, QPNR, Data);
} }
void rtl92e_config_mac(struct net_device *dev) void rtl92e_config_mac(struct net_device *dev)
{ {
u32 dwArrayLen = 0, i = 0; u32 dwArrayLen = 0, i = 0;
...@@ -267,12 +264,10 @@ void rtl92e_config_mac(struct net_device *dev) ...@@ -267,12 +264,10 @@ void rtl92e_config_mac(struct net_device *dev)
} }
for (i = 0; i < dwArrayLen; i += 3) { for (i = 0; i < dwArrayLen; i += 3) {
if (pdwArray[i] == 0x318) if (pdwArray[i] == 0x318)
pdwArray[i+2] = 0x00000800; pdwArray[i + 2] = 0x00000800;
rtl92e_set_bb_reg(dev, pdwArray[i], pdwArray[i+1], rtl92e_set_bb_reg(dev, pdwArray[i], pdwArray[i + 1],
pdwArray[i+2]); pdwArray[i + 2]);
} }
return;
} }
static void _rtl92e_phy_config_bb(struct net_device *dev, u8 ConfigType) static void _rtl92e_phy_config_bb(struct net_device *dev, u8 ConfigType)
...@@ -291,13 +286,13 @@ static void _rtl92e_phy_config_bb(struct net_device *dev, u8 ConfigType) ...@@ -291,13 +286,13 @@ static void _rtl92e_phy_config_bb(struct net_device *dev, u8 ConfigType)
for (i = 0; i < PHY_REGArrayLen; i += 2) { for (i = 0; i < PHY_REGArrayLen; i += 2) {
rtl92e_set_bb_reg(dev, Rtl819XPHY_REGArray_Table[i], rtl92e_set_bb_reg(dev, Rtl819XPHY_REGArray_Table[i],
bMaskDWord, bMaskDWord,
Rtl819XPHY_REGArray_Table[i+1]); Rtl819XPHY_REGArray_Table[i + 1]);
} }
} else if (ConfigType == BB_CONFIG_AGC_TAB) { } else if (ConfigType == BB_CONFIG_AGC_TAB) {
for (i = 0; i < AGCTAB_ArrayLen; i += 2) { for (i = 0; i < AGCTAB_ArrayLen; i += 2) {
rtl92e_set_bb_reg(dev, Rtl819XAGCTAB_Array_Table[i], rtl92e_set_bb_reg(dev, Rtl819XAGCTAB_Array_Table[i],
bMaskDWord, bMaskDWord,
Rtl819XAGCTAB_Array_Table[i+1]); Rtl819XAGCTAB_Array_Table[i + 1]);
} }
} }
} }
...@@ -370,7 +365,6 @@ bool rtl92e_check_bb_and_rf(struct net_device *dev, enum hw90_block CheckBlock, ...@@ -370,7 +365,6 @@ bool rtl92e_check_bb_and_rf(struct net_device *dev, enum hw90_block CheckBlock,
break; break;
} }
if (dwRegRead != WriteData[i]) { if (dwRegRead != WriteData[i]) {
netdev_warn(dev, "%s(): Check failed.\n", __func__); netdev_warn(dev, "%s(): Check failed.\n", __func__);
ret = false; ret = false;
...@@ -389,10 +383,10 @@ static bool _rtl92e_bb_config_para_file(struct net_device *dev) ...@@ -389,10 +383,10 @@ static bool _rtl92e_bb_config_para_file(struct net_device *dev)
u32 dwRegValue = 0; u32 dwRegValue = 0;
bRegValue = rtl92e_readb(dev, BB_GLOBAL_RESET); bRegValue = rtl92e_readb(dev, BB_GLOBAL_RESET);
rtl92e_writeb(dev, BB_GLOBAL_RESET, (bRegValue|BB_GLOBAL_RESET_BIT)); rtl92e_writeb(dev, BB_GLOBAL_RESET, (bRegValue | BB_GLOBAL_RESET_BIT));
dwRegValue = rtl92e_readl(dev, CPU_GEN); dwRegValue = rtl92e_readl(dev, CPU_GEN);
rtl92e_writel(dev, CPU_GEN, (dwRegValue&(~CPU_GEN_BB_RST))); rtl92e_writel(dev, CPU_GEN, (dwRegValue & (~CPU_GEN_BB_RST)));
for (eCheckItem = (enum hw90_block)HW90_BLOCK_PHY0; for (eCheckItem = (enum hw90_block)HW90_BLOCK_PHY0;
eCheckItem <= HW90_BLOCK_PHY1; eCheckItem++) { eCheckItem <= HW90_BLOCK_PHY1; eCheckItem++) {
...@@ -402,19 +396,18 @@ static bool _rtl92e_bb_config_para_file(struct net_device *dev) ...@@ -402,19 +396,18 @@ static bool _rtl92e_bb_config_para_file(struct net_device *dev)
if (!rtStatus) if (!rtStatus)
return rtStatus; return rtStatus;
} }
rtl92e_set_bb_reg(dev, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0x0); rtl92e_set_bb_reg(dev, rFPGA0_RFMOD, bCCKEn | bOFDMEn, 0x0);
_rtl92e_phy_config_bb(dev, BB_CONFIG_PHY_REG); _rtl92e_phy_config_bb(dev, BB_CONFIG_PHY_REG);
dwRegValue = rtl92e_readl(dev, CPU_GEN); dwRegValue = rtl92e_readl(dev, CPU_GEN);
rtl92e_writel(dev, CPU_GEN, (dwRegValue|CPU_GEN_BB_RST)); rtl92e_writel(dev, CPU_GEN, (dwRegValue | CPU_GEN_BB_RST));
_rtl92e_phy_config_bb(dev, BB_CONFIG_AGC_TAB); _rtl92e_phy_config_bb(dev, BB_CONFIG_AGC_TAB);
if (priv->ic_cut > VERSION_8190_BD) { if (priv->ic_cut > VERSION_8190_BD) {
dwRegValue = 0x0; dwRegValue = 0x0;
rtl92e_set_bb_reg(dev, rFPGA0_TxGainStage, rtl92e_set_bb_reg(dev, rFPGA0_TxGainStage,
(bXBTxAGC|bXCTxAGC|bXDTxAGC), dwRegValue); (bXBTxAGC | bXCTxAGC | bXDTxAGC), dwRegValue);
dwRegValue = priv->crystal_cap; dwRegValue = priv->crystal_cap;
rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter1, bXtalCap92x, rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter1, bXtalCap92x,
...@@ -470,7 +463,6 @@ void rtl92e_set_tx_power(struct net_device *dev, u8 channel) ...@@ -470,7 +463,6 @@ void rtl92e_set_tx_power(struct net_device *dev, u8 channel)
u8 rtl92e_config_rf_path(struct net_device *dev, enum rf90_radio_path eRFPath) u8 rtl92e_config_rf_path(struct net_device *dev, enum rf90_radio_path eRFPath)
{ {
int i; int i;
switch (eRFPath) { switch (eRFPath) {
...@@ -483,7 +475,6 @@ u8 rtl92e_config_rf_path(struct net_device *dev, enum rf90_radio_path eRFPath) ...@@ -483,7 +475,6 @@ u8 rtl92e_config_rf_path(struct net_device *dev, enum rf90_radio_path eRFPath)
rtl92e_set_rf_reg(dev, eRFPath, RTL8192E_RADIO_A_ARR[i], rtl92e_set_rf_reg(dev, eRFPath, RTL8192E_RADIO_A_ARR[i],
bMask12Bits, bMask12Bits,
RTL8192E_RADIO_A_ARR[i + 1]); RTL8192E_RADIO_A_ARR[i + 1]);
} }
break; break;
case RF90_PATH_B: case RF90_PATH_B:
...@@ -495,7 +486,6 @@ u8 rtl92e_config_rf_path(struct net_device *dev, enum rf90_radio_path eRFPath) ...@@ -495,7 +486,6 @@ u8 rtl92e_config_rf_path(struct net_device *dev, enum rf90_radio_path eRFPath)
rtl92e_set_rf_reg(dev, eRFPath, RTL8192E_RADIO_B_ARR[i], rtl92e_set_rf_reg(dev, eRFPath, RTL8192E_RADIO_B_ARR[i],
bMask12Bits, bMask12Bits,
RTL8192E_RADIO_B_ARR[i + 1]); RTL8192E_RADIO_B_ARR[i + 1]);
} }
break; break;
default: default:
...@@ -503,7 +493,6 @@ u8 rtl92e_config_rf_path(struct net_device *dev, enum rf90_radio_path eRFPath) ...@@ -503,7 +493,6 @@ u8 rtl92e_config_rf_path(struct net_device *dev, enum rf90_radio_path eRFPath)
} }
return 0; return 0;
} }
static void _rtl92e_set_tx_power_level(struct net_device *dev, u8 channel) static void _rtl92e_set_tx_power_level(struct net_device *dev, u8 channel)
...@@ -645,7 +634,7 @@ static u8 _rtl92e_phy_switch_channel_step(struct net_device *dev, u8 channel, ...@@ -645,7 +634,7 @@ static u8 _rtl92e_phy_switch_channel_step(struct net_device *dev, u8 channel,
rtl92e_set_rf_reg(dev, rtl92e_set_rf_reg(dev,
(enum rf90_radio_path)eRFPath, (enum rf90_radio_path)eRFPath,
CurrentCmd->Para1, bMask12Bits, CurrentCmd->Para1, bMask12Bits,
CurrentCmd->Para2<<7); CurrentCmd->Para2 << 7);
break; break;
default: default:
break; break;
...@@ -677,7 +666,6 @@ static void _rtl92e_phy_switch_channel(struct net_device *dev, u8 channel) ...@@ -677,7 +666,6 @@ static void _rtl92e_phy_switch_channel(struct net_device *dev, u8 channel)
static void _rtl92e_phy_switch_channel_work_item(struct net_device *dev) static void _rtl92e_phy_switch_channel_work_item(struct net_device *dev)
{ {
struct r8192_priv *priv = rtllib_priv(dev); struct r8192_priv *priv = rtllib_priv(dev);
_rtl92e_phy_switch_channel(dev, priv->chan); _rtl92e_phy_switch_channel(dev, priv->chan);
...@@ -694,7 +682,6 @@ u8 rtl92e_set_channel(struct net_device *dev, u8 channel) ...@@ -694,7 +682,6 @@ u8 rtl92e_set_channel(struct net_device *dev, u8 channel)
if (priv->sw_chnl_in_progress) if (priv->sw_chnl_in_progress)
return false; return false;
switch (priv->rtllib->mode) { switch (priv->rtllib->mode) {
case WIRELESS_MODE_B: case WIRELESS_MODE_B:
if (channel > 14) { if (channel > 14) {
...@@ -824,7 +811,6 @@ static void _rtl92e_cck_tx_power_track_bw_switch(struct net_device *dev) ...@@ -824,7 +811,6 @@ static void _rtl92e_cck_tx_power_track_bw_switch(struct net_device *dev)
static void _rtl92e_set_bw_mode_work_item(struct net_device *dev) static void _rtl92e_set_bw_mode_work_item(struct net_device *dev)
{ {
struct r8192_priv *priv = rtllib_priv(dev); struct r8192_priv *priv = rtllib_priv(dev);
u8 regBwOpMode; u8 regBwOpMode;
...@@ -880,7 +866,7 @@ static void _rtl92e_set_bw_mode_work_item(struct net_device *dev) ...@@ -880,7 +866,7 @@ static void _rtl92e_set_bw_mode_work_item(struct net_device *dev)
} }
rtl92e_set_bb_reg(dev, rCCK0_System, bCCKSideBand, rtl92e_set_bb_reg(dev, rCCK0_System, bCCKSideBand,
(priv->n_cur_40mhz_prime_sc>>1)); (priv->n_cur_40mhz_prime_sc >> 1));
rtl92e_set_bb_reg(dev, rOFDM1_LSTF, 0xC00, rtl92e_set_bb_reg(dev, rOFDM1_LSTF, 0xC00,
priv->n_cur_40mhz_prime_sc); priv->n_cur_40mhz_prime_sc);
...@@ -890,7 +876,6 @@ static void _rtl92e_set_bw_mode_work_item(struct net_device *dev) ...@@ -890,7 +876,6 @@ static void _rtl92e_set_bw_mode_work_item(struct net_device *dev)
netdev_err(dev, "%s(): unknown Bandwidth: %#X\n", __func__, netdev_err(dev, "%s(): unknown Bandwidth: %#X\n", __func__,
priv->current_chnl_bw); priv->current_chnl_bw);
break; break;
} }
rtl92e_set_bandwidth(dev, priv->current_chnl_bw); rtl92e_set_bandwidth(dev, priv->current_chnl_bw);
...@@ -904,7 +889,6 @@ void rtl92e_set_bw_mode(struct net_device *dev, enum ht_channel_width bandwidth, ...@@ -904,7 +889,6 @@ void rtl92e_set_bw_mode(struct net_device *dev, enum ht_channel_width bandwidth,
{ {
struct r8192_priv *priv = rtllib_priv(dev); struct r8192_priv *priv = rtllib_priv(dev);
if (priv->set_bw_mode_in_progress) if (priv->set_bw_mode_in_progress)
return; return;
...@@ -921,7 +905,6 @@ void rtl92e_set_bw_mode(struct net_device *dev, enum ht_channel_width bandwidth, ...@@ -921,7 +905,6 @@ void rtl92e_set_bw_mode(struct net_device *dev, enum ht_channel_width bandwidth,
priv->n_cur_40mhz_prime_sc = HAL_PRIME_CHNL_OFFSET_DONT_CARE; priv->n_cur_40mhz_prime_sc = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
_rtl92e_set_bw_mode_work_item(dev); _rtl92e_set_bw_mode_work_item(dev);
} }
void rtl92e_init_gain(struct net_device *dev, u8 Operation) void rtl92e_init_gain(struct net_device *dev, u8 Operation)
...@@ -993,7 +976,6 @@ void rtl92e_init_gain(struct net_device *dev, u8 Operation) ...@@ -993,7 +976,6 @@ void rtl92e_init_gain(struct net_device *dev, u8 Operation)
void rtl92e_set_rf_off(struct net_device *dev) void rtl92e_set_rf_off(struct net_device *dev)
{ {
rtl92e_set_bb_reg(dev, rFPGA0_XA_RFInterfaceOE, BIT4, 0x0); rtl92e_set_bb_reg(dev, rFPGA0_XA_RFInterfaceOE, BIT4, 0x0);
rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter4, 0x300, 0x0); rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter4, 0x300, 0x0);
rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter1, 0x18, 0x0); rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter1, 0x18, 0x0);
...@@ -1002,7 +984,6 @@ void rtl92e_set_rf_off(struct net_device *dev) ...@@ -1002,7 +984,6 @@ void rtl92e_set_rf_off(struct net_device *dev)
rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter1, 0x60, 0x0); rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter1, 0x60, 0x0);
rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter1, 0x4, 0x0); rtl92e_set_bb_reg(dev, rFPGA0_AnalogParameter1, 0x4, 0x0);
rtl92e_writeb(dev, ANAPAR_FOR_8192PCIE, 0x07); rtl92e_writeb(dev, ANAPAR_FOR_8192PCIE, 0x07);
} }
static bool _rtl92e_set_rf_power_state(struct net_device *dev, static bool _rtl92e_set_rf_power_state(struct net_device *dev,
...@@ -1099,9 +1080,8 @@ static bool _rtl92e_set_rf_power_state(struct net_device *dev, ...@@ -1099,9 +1080,8 @@ static bool _rtl92e_set_rf_power_state(struct net_device *dev,
break; break;
} }
if (bResult) { if (bResult)
priv->rtllib->rf_power_state = rf_power_state; priv->rtllib->rf_power_state = rf_power_state;
}
priv->set_rf_pwr_state_in_progress = false; priv->set_rf_pwr_state_in_progress = false;
return bResult; return bResult;
...@@ -1130,11 +1110,11 @@ void rtl92e_scan_op_backup(struct net_device *dev, u8 Operation) ...@@ -1130,11 +1110,11 @@ void rtl92e_scan_op_backup(struct net_device *dev, u8 Operation)
if (priv->up) { if (priv->up) {
switch (Operation) { switch (Operation) {
case SCAN_OPT_BACKUP: case SCAN_OPT_BACKUP:
priv->rtllib->InitialGainHandler(dev, IG_Backup); priv->rtllib->init_gain_handler(dev, IG_Backup);
break; break;
case SCAN_OPT_RESTORE: case SCAN_OPT_RESTORE:
priv->rtllib->InitialGainHandler(dev, IG_Restore); priv->rtllib->init_gain_handler(dev, IG_Restore);
break; break;
} }
} }
......
...@@ -7,7 +7,6 @@ ...@@ -7,7 +7,6 @@
#ifndef _R819XU_PHYREG_H #ifndef _R819XU_PHYREG_H
#define _R819XU_PHYREG_H #define _R819XU_PHYREG_H
#define RF_DATA 0x1d4 #define RF_DATA 0x1d4
#define rPMAC_Reset 0x100 #define rPMAC_Reset 0x100
...@@ -125,7 +124,6 @@ ...@@ -125,7 +124,6 @@
#define rOFDM0_TxCoeff5 0xcb4 #define rOFDM0_TxCoeff5 0xcb4
#define rOFDM0_TxCoeff6 0xcb8 #define rOFDM0_TxCoeff6 0xcb8
#define rOFDM1_LSTF 0xd00 #define rOFDM1_LSTF 0xd00
#define rOFDM1_TRxPathEnable 0xd04 #define rOFDM1_TRxPathEnable 0xd04
#define rOFDM1_CFO 0xd08 #define rOFDM1_CFO 0xd08
...@@ -163,7 +161,6 @@ ...@@ -163,7 +161,6 @@
#define rTxAGC_Mcs11_Mcs08 0xe18 #define rTxAGC_Mcs11_Mcs08 0xe18
#define rTxAGC_Mcs15_Mcs12 0xe1c #define rTxAGC_Mcs15_Mcs12 0xe1c
#define rZebra1_HSSIEnable 0x0 #define rZebra1_HSSIEnable 0x0
#define rZebra1_TRxEnable1 0x1 #define rZebra1_TRxEnable1 0x1
#define rZebra1_TRxEnable2 0x2 #define rZebra1_TRxEnable2 0x2
...@@ -269,7 +266,6 @@ ...@@ -269,7 +266,6 @@
#define b3WireAddressLength 0x400 #define b3WireAddressLength 0x400
#define b3WireRFPowerDown 0x1 #define b3WireRFPowerDown 0x1
/*#define bHWSISelect 0x8 */ /*#define bHWSISelect 0x8 */
#define b5GPAPEPolarity 0x40000000
#define b2GPAPEPolarity 0x80000000 #define b2GPAPEPolarity 0x80000000
#define bRFSW_TxDefaultAnt 0x3 #define bRFSW_TxDefaultAnt 0x3
#define bRFSW_TxOptionAnt 0x30 #define bRFSW_TxOptionAnt 0x30
...@@ -287,7 +283,6 @@ ...@@ -287,7 +283,6 @@
#define bRFSI_ANTSW 0x100 #define bRFSI_ANTSW 0x100
#define bRFSI_ANTSWB 0x200 #define bRFSI_ANTSWB 0x200
#define bRFSI_PAPE 0x400 #define bRFSI_PAPE 0x400
#define bRFSI_PAPE5G 0x800
#define bBandSelect 0x1 #define bBandSelect 0x1
#define bHTSIG2_GI 0x80 #define bHTSIG2_GI 0x80
#define bHTSIG2_Smoothing 0x01 #define bHTSIG2_Smoothing 0x01
...@@ -819,7 +814,6 @@ ...@@ -819,7 +814,6 @@
#define bOFDMPHY0_End 0xcff #define bOFDMPHY0_End 0xcff
#define bOFDMPHY1_End 0xdff #define bOFDMPHY1_End 0xdff
#define bPMACControl 0x0 #define bPMACControl 0x0
#define bWMACControl 0x1 #define bWMACControl 0x1
#define bWNICControl 0x2 #define bWNICControl 0x2
......
...@@ -101,7 +101,6 @@ void rtl92e_set_key(struct net_device *dev, u8 EntryNo, u8 KeyIndex, ...@@ -101,7 +101,6 @@ void rtl92e_set_key(struct net_device *dev, u8 EntryNo, u8 KeyIndex,
else else
usConfig |= BIT15 | (KeyType << 2) | KeyIndex; usConfig |= BIT15 | (KeyType << 2) | KeyIndex;
for (i = 0; i < CAM_CONTENT_COUNT; i++) { for (i = 0; i < CAM_CONTENT_COUNT; i++) {
TargetCommand = i + CAM_CONTENT_COUNT * EntryNo; TargetCommand = i + CAM_CONTENT_COUNT * EntryNo;
TargetCommand |= BIT31 | BIT16; TargetCommand |= BIT31 | BIT16;
...@@ -149,7 +148,6 @@ void rtl92e_cam_restore(struct net_device *dev) ...@@ -149,7 +148,6 @@ void rtl92e_cam_restore(struct net_device *dev)
if ((priv->rtllib->pairwise_key_type == KEY_TYPE_WEP40) || if ((priv->rtllib->pairwise_key_type == KEY_TYPE_WEP40) ||
(priv->rtllib->pairwise_key_type == KEY_TYPE_WEP104)) { (priv->rtllib->pairwise_key_type == KEY_TYPE_WEP104)) {
for (EntryId = 0; EntryId < 4; EntryId++) { for (EntryId = 0; EntryId < 4; EntryId++) {
MacAddr = CAM_CONST_ADDR[EntryId]; MacAddr = CAM_CONST_ADDR[EntryId];
if (priv->rtllib->swcamtable[EntryId].bused) { if (priv->rtllib->swcamtable[EntryId].bused) {
......
...@@ -231,7 +231,6 @@ struct r8192_priv { ...@@ -231,7 +231,6 @@ struct r8192_priv {
struct rt_stats stats; struct rt_stats stats;
struct iw_statistics wstats; struct iw_statistics wstats;
short (*rf_set_sens)(struct net_device *dev, short sens);
u8 (*rf_set_chan)(struct net_device *dev, u8 ch); u8 (*rf_set_chan)(struct net_device *dev, u8 ch);
struct rx_desc *rx_ring[MAX_RX_QUEUE]; struct rx_desc *rx_ring[MAX_RX_QUEUE];
...@@ -271,8 +270,6 @@ struct r8192_priv { ...@@ -271,8 +270,6 @@ struct r8192_priv {
short promisc; short promisc;
short chan; short chan;
short sens;
short max_sens;
bool ps_force; bool ps_force;
u32 irq_mask[2]; u32 irq_mask[2];
......
This diff is collapsed.
...@@ -27,8 +27,8 @@ static u32 _rtl92e_ethtool_get_link(struct net_device *dev) ...@@ -27,8 +27,8 @@ static u32 _rtl92e_ethtool_get_link(struct net_device *dev)
{ {
struct r8192_priv *priv = rtllib_priv(dev); struct r8192_priv *priv = rtllib_priv(dev);
return ((priv->rtllib->state == RTLLIB_LINKED) || return ((priv->rtllib->link_state == MAC80211_LINKED) ||
(priv->rtllib->state == RTLLIB_LINKED_SCANNING)); (priv->rtllib->link_state == MAC80211_LINKED_SCANNING));
} }
const struct ethtool_ops rtl819x_ethtool_ops = { const struct ethtool_ops rtl819x_ethtool_ops = {
......
...@@ -9,7 +9,6 @@ ...@@ -9,7 +9,6 @@
#include "r8190P_rtl8256.h" #include "r8190P_rtl8256.h"
#include "rtl_pm.h" #include "rtl_pm.h"
int rtl92e_suspend(struct device *dev_d) int rtl92e_suspend(struct device *dev_d)
{ {
struct net_device *dev = dev_get_drvdata(dev_d); struct net_device *dev = dev_get_drvdata(dev_d);
...@@ -62,7 +61,6 @@ int rtl92e_resume(struct device *dev_d) ...@@ -62,7 +61,6 @@ int rtl92e_resume(struct device *dev_d)
netdev_info(dev, "================>r8192E resume call.\n"); netdev_info(dev, "================>r8192E resume call.\n");
pci_read_config_dword(pdev, 0x40, &val); pci_read_config_dword(pdev, 0x40, &val);
if ((val & 0x0000ff00) != 0) if ((val & 0x0000ff00) != 0)
pci_write_config_dword(pdev, 0x40, val & 0xffff00ff); pci_write_config_dword(pdev, 0x40, val & 0xffff00ff);
......
...@@ -118,7 +118,7 @@ void rtl92e_ips_enter(struct net_device *dev) ...@@ -118,7 +118,7 @@ void rtl92e_ips_enter(struct net_device *dev)
rt_state = priv->rtllib->rf_power_state; rt_state = priv->rtllib->rf_power_state;
if (rt_state == rf_on && !psc->bSwRfProcessing && if (rt_state == rf_on && !psc->bSwRfProcessing &&
(priv->rtllib->state != RTLLIB_LINKED) && (priv->rtllib->link_state != MAC80211_LINKED) &&
(priv->rtllib->iw_mode != IW_MODE_MASTER)) { (priv->rtllib->iw_mode != IW_MODE_MASTER)) {
psc->eInactivePowerState = rf_off; psc->eInactivePowerState = rf_off;
_rtl92e_ps_update_rf_state(dev); _rtl92e_ps_update_rf_state(dev);
...@@ -209,7 +209,7 @@ void rtl92e_leisure_ps_enter(struct net_device *dev) ...@@ -209,7 +209,7 @@ void rtl92e_leisure_ps_enter(struct net_device *dev)
&priv->rtllib->pwr_save_ctrl; &priv->rtllib->pwr_save_ctrl;
if (!((priv->rtllib->iw_mode == IW_MODE_INFRA) && if (!((priv->rtllib->iw_mode == IW_MODE_INFRA) &&
(priv->rtllib->state == RTLLIB_LINKED)) (priv->rtllib->link_state == MAC80211_LINKED))
|| (priv->rtllib->iw_mode == IW_MODE_ADHOC) || || (priv->rtllib->iw_mode == IW_MODE_ADHOC) ||
(priv->rtllib->iw_mode == IW_MODE_MASTER)) (priv->rtllib->iw_mode == IW_MODE_MASTER))
return; return;
...@@ -217,14 +217,11 @@ void rtl92e_leisure_ps_enter(struct net_device *dev) ...@@ -217,14 +217,11 @@ void rtl92e_leisure_ps_enter(struct net_device *dev)
if (psc->bLeisurePs) { if (psc->bLeisurePs) {
if (psc->LpsIdleCount >= RT_CHECK_FOR_HANG_PERIOD) { if (psc->LpsIdleCount >= RT_CHECK_FOR_HANG_PERIOD) {
if (priv->rtllib->ps == RTLLIB_PS_DISABLED) { if (priv->rtllib->ps == RTLLIB_PS_DISABLED)
if (priv->rtllib->SetFwCmdHandler) _rtl92e_ps_set_mode(dev, RTLLIB_PS_MBCAST | RTLLIB_PS_UNICAST);
priv->rtllib->SetFwCmdHandler(dev, FW_CMD_LPS_ENTER); } else {
_rtl92e_ps_set_mode(dev, RTLLIB_PS_MBCAST |
RTLLIB_PS_UNICAST);
}
} else
psc->LpsIdleCount++; psc->LpsIdleCount++;
}
} }
} }
...@@ -235,10 +232,7 @@ void rtl92e_leisure_ps_leave(struct net_device *dev) ...@@ -235,10 +232,7 @@ void rtl92e_leisure_ps_leave(struct net_device *dev)
&priv->rtllib->pwr_save_ctrl; &priv->rtllib->pwr_save_ctrl;
if (psc->bLeisurePs) { if (psc->bLeisurePs) {
if (priv->rtllib->ps != RTLLIB_PS_DISABLED) { if (priv->rtllib->ps != RTLLIB_PS_DISABLED)
_rtl92e_ps_set_mode(dev, RTLLIB_PS_DISABLED); _rtl92e_ps_set_mode(dev, RTLLIB_PS_DISABLED);
if (priv->rtllib->SetFwCmdHandler)
priv->rtllib->SetFwCmdHandler(dev, FW_CMD_LPS_LEAVE);
}
} }
} }
...@@ -169,7 +169,7 @@ static int _rtl92e_wx_adapter_power_status(struct net_device *dev, ...@@ -169,7 +169,7 @@ static int _rtl92e_wx_adapter_power_status(struct net_device *dev,
priv->ps_force = false; priv->ps_force = false;
psc->bLeisurePs = true; psc->bLeisurePs = true;
} else { } else {
if (priv->rtllib->state == RTLLIB_LINKED) if (priv->rtllib->link_state == MAC80211_LINKED)
rtl92e_leisure_ps_leave(dev); rtl92e_leisure_ps_leave(dev);
priv->ps_force = true; priv->ps_force = true;
...@@ -311,10 +311,6 @@ static int _rtl92e_wx_get_range(struct net_device *dev, ...@@ -311,10 +311,6 @@ static int _rtl92e_wx_get_range(struct net_device *dev,
/* ~130 Mb/s real (802.11n) */ /* ~130 Mb/s real (802.11n) */
range->throughput = 130 * 1000 * 1000; range->throughput = 130 * 1000 * 1000;
if (priv->rf_set_sens != NULL)
/* signal level threshold range */
range->sensitivity = priv->max_sens;
range->max_qual.qual = 100; range->max_qual.qual = 100;
range->max_qual.level = 0; range->max_qual.level = 0;
range->max_qual.noise = 0; range->max_qual.noise = 0;
...@@ -346,9 +342,11 @@ static int _rtl92e_wx_get_range(struct net_device *dev, ...@@ -346,9 +342,11 @@ static int _rtl92e_wx_get_range(struct net_device *dev,
for (i = 0, val = 0; i < 14; i++) { for (i = 0, val = 0; i < 14; i++) {
if ((priv->rtllib->active_channel_map)[i + 1]) { if ((priv->rtllib->active_channel_map)[i + 1]) {
s32 freq_khz;
range->freq[val].i = i + 1; range->freq[val].i = i + 1;
range->freq[val].m = rtllib_wlan_frequencies[i] * freq_khz = ieee80211_channel_to_freq_khz(i + 1, NL80211_BAND_2GHZ);
100000; range->freq[val].m = freq_khz * 100;
range->freq[val].e = 1; range->freq[val].e = 1;
val++; val++;
} }
...@@ -377,10 +375,10 @@ static int _rtl92e_wx_set_scan(struct net_device *dev, ...@@ -377,10 +375,10 @@ static int _rtl92e_wx_set_scan(struct net_device *dev,
int ret; int ret;
if (!(ieee->softmac_features & IEEE_SOFTMAC_SCAN)) { if (!(ieee->softmac_features & IEEE_SOFTMAC_SCAN)) {
if ((ieee->state >= RTLLIB_ASSOCIATING) && if ((ieee->link_state >= RTLLIB_ASSOCIATING) &&
(ieee->state <= RTLLIB_ASSOCIATING_AUTHENTICATED)) (ieee->link_state <= RTLLIB_ASSOCIATING_AUTHENTICATED))
return 0; return 0;
if ((priv->rtllib->state == RTLLIB_LINKED) && if ((priv->rtllib->link_state == MAC80211_LINKED) &&
(priv->rtllib->CntAfterLink < 2)) (priv->rtllib->CntAfterLink < 2))
return 0; return 0;
} }
...@@ -393,7 +391,7 @@ static int _rtl92e_wx_set_scan(struct net_device *dev, ...@@ -393,7 +391,7 @@ static int _rtl92e_wx_set_scan(struct net_device *dev,
rt_state = priv->rtllib->rf_power_state; rt_state = priv->rtllib->rf_power_state;
if (!priv->up) if (!priv->up)
return -ENETDOWN; return -ENETDOWN;
if (priv->rtllib->link_detect_info.bBusyTraffic == true) if (priv->rtllib->link_detect_info.bBusyTraffic)
return -EAGAIN; return -EAGAIN;
if (wrqu->data.flags & IW_SCAN_THIS_ESSID) { if (wrqu->data.flags & IW_SCAN_THIS_ESSID) {
...@@ -411,7 +409,7 @@ static int _rtl92e_wx_set_scan(struct net_device *dev, ...@@ -411,7 +409,7 @@ static int _rtl92e_wx_set_scan(struct net_device *dev,
priv->rtllib->FirstIe_InScan = true; priv->rtllib->FirstIe_InScan = true;
if (priv->rtllib->state != RTLLIB_LINKED) { if (priv->rtllib->link_state != MAC80211_LINKED) {
if (rt_state == rf_off) { if (rt_state == rf_off) {
if (priv->rtllib->rf_off_reason > if (priv->rtllib->rf_off_reason >
RF_CHANGE_BY_IPS) { RF_CHANGE_BY_IPS) {
...@@ -425,10 +423,6 @@ static int _rtl92e_wx_set_scan(struct net_device *dev, ...@@ -425,10 +423,6 @@ static int _rtl92e_wx_set_scan(struct net_device *dev,
mutex_unlock(&priv->rtllib->ips_mutex); mutex_unlock(&priv->rtllib->ips_mutex);
} }
rtllib_stop_scan(priv->rtllib); rtllib_stop_scan(priv->rtllib);
if (priv->rtllib->LedControlHandler)
priv->rtllib->LedControlHandler(dev,
LED_CTL_SITE_SURVEY);
if (priv->rtllib->rf_power_state != rf_off) { if (priv->rtllib->rf_power_state != rf_off) {
priv->rtllib->actscanning = true; priv->rtllib->actscanning = true;
...@@ -574,9 +568,9 @@ static int _rtl92e_wx_set_frag(struct net_device *dev, ...@@ -574,9 +568,9 @@ static int _rtl92e_wx_set_frag(struct net_device *dev,
if (priv->hw_radio_off) if (priv->hw_radio_off)
return 0; return 0;
if (wrqu->frag.disabled) if (wrqu->frag.disabled) {
priv->rtllib->fts = DEFAULT_FRAG_THRESHOLD; priv->rtllib->fts = DEFAULT_FRAG_THRESHOLD;
else { } else {
if (wrqu->frag.value < MIN_FRAG_THRESHOLD || if (wrqu->frag.value < MIN_FRAG_THRESHOLD ||
wrqu->frag.value > MAX_FRAG_THRESHOLD) wrqu->frag.value > MAX_FRAG_THRESHOLD)
return -EINVAL; return -EINVAL;
...@@ -807,45 +801,6 @@ static int _rtl92e_wx_get_retry(struct net_device *dev, ...@@ -807,45 +801,6 @@ static int _rtl92e_wx_get_retry(struct net_device *dev,
return 0; return 0;
} }
static int _rtl92e_wx_get_sens(struct net_device *dev,
struct iw_request_info *info,
union iwreq_data *wrqu, char *extra)
{
struct r8192_priv *priv = rtllib_priv(dev);
if (priv->rf_set_sens == NULL)
return -1; /* we have not this support for this radio */
wrqu->sens.value = priv->sens;
return 0;
}
static int _rtl92e_wx_set_sens(struct net_device *dev,
struct iw_request_info *info,
union iwreq_data *wrqu, char *extra)
{
struct r8192_priv *priv = rtllib_priv(dev);
short err = 0;
if (priv->hw_radio_off)
return 0;
mutex_lock(&priv->wx_mutex);
if (priv->rf_set_sens == NULL) {
err = -1; /* we have not this support for this radio */
goto exit;
}
if (priv->rf_set_sens(dev, wrqu->sens.value) == 0)
priv->sens = wrqu->sens.value;
else
err = -EINVAL;
exit:
mutex_unlock(&priv->wx_mutex);
return err;
}
static int _rtl92e_wx_set_encode_ext(struct net_device *dev, static int _rtl92e_wx_set_encode_ext(struct net_device *dev,
struct iw_request_info *info, struct iw_request_info *info,
union iwreq_data *wrqu, char *extra) union iwreq_data *wrqu, char *extra)
...@@ -1066,8 +1021,6 @@ static iw_handler r8192_wx_handlers[] = { ...@@ -1066,8 +1021,6 @@ static iw_handler r8192_wx_handlers[] = {
[IW_IOCTL(SIOCGIWFREQ)] = _rtl92e_wx_get_freq, [IW_IOCTL(SIOCGIWFREQ)] = _rtl92e_wx_get_freq,
[IW_IOCTL(SIOCSIWMODE)] = _rtl92e_wx_set_mode, [IW_IOCTL(SIOCSIWMODE)] = _rtl92e_wx_set_mode,
[IW_IOCTL(SIOCGIWMODE)] = _rtl92e_wx_get_mode, [IW_IOCTL(SIOCGIWMODE)] = _rtl92e_wx_get_mode,
[IW_IOCTL(SIOCSIWSENS)] = _rtl92e_wx_set_sens,
[IW_IOCTL(SIOCGIWSENS)] = _rtl92e_wx_get_sens,
[IW_IOCTL(SIOCGIWRANGE)] = _rtl92e_wx_get_range, [IW_IOCTL(SIOCGIWRANGE)] = _rtl92e_wx_get_range,
[IW_IOCTL(SIOCSIWAP)] = _rtl92e_wx_set_wap, [IW_IOCTL(SIOCSIWAP)] = _rtl92e_wx_set_wap,
[IW_IOCTL(SIOCGIWAP)] = _rtl92e_wx_get_wap, [IW_IOCTL(SIOCGIWAP)] = _rtl92e_wx_get_wap,
...@@ -1171,7 +1124,7 @@ static struct iw_statistics *_rtl92e_get_wireless_stats(struct net_device *dev) ...@@ -1171,7 +1124,7 @@ static struct iw_statistics *_rtl92e_get_wireless_stats(struct net_device *dev)
int tmp_qual = 0; int tmp_qual = 0;
int tmp_noise = 0; int tmp_noise = 0;
if (ieee->state < RTLLIB_LINKED) { if (ieee->link_state < MAC80211_LINKED) {
wstats->qual.qual = 10; wstats->qual.qual = 10;
wstats->qual.level = 0; wstats->qual.level = 0;
wstats->qual.noise = 0x100 - 100; /* -100 dBm */ wstats->qual.noise = 0x100 - 100; /* -100 dBm */
......
...@@ -24,7 +24,6 @@ enum ht_extchnl_offset { ...@@ -24,7 +24,6 @@ enum ht_extchnl_offset {
}; };
struct ht_capab_ele { struct ht_capab_ele {
u8 AdvCoding:1; u8 AdvCoding:1;
u8 ChlWidth:1; u8 ChlWidth:1;
u8 MimoPwrSave:2; u8 MimoPwrSave:2;
...@@ -46,7 +45,6 @@ struct ht_capab_ele { ...@@ -46,7 +45,6 @@ struct ht_capab_ele {
u8 MCS[16]; u8 MCS[16];
u16 ExtHTCapInfo; u16 ExtHTCapInfo;
u8 TxBFCap[4]; u8 TxBFCap[4];
...@@ -55,7 +53,6 @@ struct ht_capab_ele { ...@@ -55,7 +53,6 @@ struct ht_capab_ele {
} __packed; } __packed;
struct ht_info_ele { struct ht_info_ele {
u8 ControlChl; u8 ControlChl;
...@@ -94,72 +91,54 @@ enum ht_aggre_mode { ...@@ -94,72 +91,54 @@ enum ht_aggre_mode {
HT_AGG_FORCE_DISABLE = 2, HT_AGG_FORCE_DISABLE = 2,
}; };
struct rt_hi_throughput { struct rt_hi_throughput {
u8 enable_ht; u8 enable_ht;
u8 bCurrentHTSupport; u8 bCurrentHTSupport;
u8 bRegBW40MHz;
u8 bRegBW40MHz; u8 bCurBW40MHz;
u8 bCurBW40MHz; u8 bRegShortGI40MHz;
u8 bCurShortGI40MHz;
u8 bRegShortGI40MHz; u8 bRegShortGI20MHz;
u8 bCurShortGI40MHz; u8 bCurShortGI20MHz;
u8 bRegSuppCCK;
u8 bRegShortGI20MHz; u8 bCurSuppCCK;
u8 bCurShortGI20MHz;
u8 bRegSuppCCK;
u8 bCurSuppCCK;
enum ht_spec_ver ePeerHTSpecVer; enum ht_spec_ver ePeerHTSpecVer;
struct ht_capab_ele SelfHTCap; struct ht_capab_ele SelfHTCap;
struct ht_info_ele SelfHTInfo; struct ht_info_ele SelfHTInfo;
u8 PeerHTCapBuf[32];
u8 PeerHTCapBuf[32]; u8 PeerHTInfoBuf[32];
u8 PeerHTInfoBuf[32]; u8 bAMSDU_Support;
u16 nAMSDU_MaxSize;
u8 bCurrent_AMSDU_Support;
u8 bAMSDU_Support; u16 nCurrent_AMSDU_MaxSize;
u16 nAMSDU_MaxSize; u8 bAMPDUEnable;
u8 bCurrent_AMSDU_Support; u8 bCurrentAMPDUEnable;
u16 nCurrent_AMSDU_MaxSize; u8 AMPDU_Factor;
u8 CurrentAMPDUFactor;
u8 bAMPDUEnable; u8 MPDU_Density;
u8 bCurrentAMPDUEnable;
u8 AMPDU_Factor;
u8 CurrentAMPDUFactor;
u8 MPDU_Density;
u8 current_mpdu_density; u8 current_mpdu_density;
enum ht_aggre_mode ForcedAMPDUMode; enum ht_aggre_mode ForcedAMPDUMode;
u8 forced_ampdu_factor; u8 forced_ampdu_factor;
u8 forced_mpdu_density; u8 forced_mpdu_density;
enum ht_aggre_mode ForcedAMSDUMode; enum ht_aggre_mode ForcedAMSDUMode;
u8 forced_short_gi; u8 forced_short_gi;
u8 current_op_mode; u8 current_op_mode;
u8 self_mimo_ps; u8 self_mimo_ps;
u8 peer_mimo_ps; u8 peer_mimo_ps;
enum ht_extchnl_offset CurSTAExtChnlOffset; enum ht_extchnl_offset CurSTAExtChnlOffset;
u8 cur_tx_bw40mhz; u8 cur_tx_bw40mhz;
u8 sw_bw_in_progress; u8 sw_bw_in_progress;
u8 reg_rt2rt_aggregation; u8 reg_rt2rt_aggregation;
u8 RT2RT_HT_Mode; u8 RT2RT_HT_Mode;
u8 current_rt2rt_aggregation; u8 current_rt2rt_aggregation;
u8 current_rt2rt_long_slot_time; u8 current_rt2rt_long_slot_time;
u8 sz_rt2rt_agg_buf[10]; u8 sz_rt2rt_agg_buf[10];
u8 reg_rx_reorder_enable; u8 reg_rx_reorder_enable;
u8 cur_rx_reorder_enable; u8 cur_rx_reorder_enable;
u8 rx_reorder_win_size; u8 rx_reorder_win_size;
u8 rx_reorder_pending_time; u8 rx_reorder_pending_time;
u16 rx_reorder_drop_counter; u16 rx_reorder_drop_counter;
u8 IOTPeer; u8 IOTPeer;
u32 iot_action; u32 iot_action;
u8 iot_ra_func; u8 iot_ra_func;
} __packed; } __packed;
......
...@@ -424,14 +424,12 @@ static u8 HT_PickMCSRate(struct rtllib_device *ieee, u8 *pOperateMCS) ...@@ -424,14 +424,12 @@ static u8 HT_PickMCSRate(struct rtllib_device *ieee, u8 *pOperateMCS)
} }
switch (ieee->mode) { switch (ieee->mode) {
case IEEE_A: case WIRELESS_MODE_B:
case IEEE_B: case WIRELESS_MODE_G:
case IEEE_G:
for (i = 0; i <= 15; i++) for (i = 0; i <= 15; i++)
pOperateMCS[i] = 0; pOperateMCS[i] = 0;
break; break;
case IEEE_N_24G: case WIRELESS_MODE_N_24G:
case IEEE_N_5G:
pOperateMCS[0] &= RATE_ADPT_1SS_MASK; pOperateMCS[0] &= RATE_ADPT_1SS_MASK;
pOperateMCS[1] &= RATE_ADPT_2SS_MASK; pOperateMCS[1] &= RATE_ADPT_2SS_MASK;
pOperateMCS[3] &= RATE_ADPT_MCS32_MASK; pOperateMCS[3] &= RATE_ADPT_MCS32_MASK;
...@@ -835,11 +833,11 @@ static void HTSetConnectBwModeCallback(struct rtllib_device *ieee) ...@@ -835,11 +833,11 @@ static void HTSetConnectBwModeCallback(struct rtllib_device *ieee)
ieee->set_chan(ieee->dev, ieee->set_chan(ieee->dev,
ieee->current_network.channel); ieee->current_network.channel);
ieee->SetBWModeHandler(ieee->dev, HT_CHANNEL_WIDTH_20_40, ieee->set_bw_mode_handler(ieee->dev, HT_CHANNEL_WIDTH_20_40,
ht_info->CurSTAExtChnlOffset); ht_info->CurSTAExtChnlOffset);
} else { } else {
ieee->set_chan(ieee->dev, ieee->current_network.channel); ieee->set_chan(ieee->dev, ieee->current_network.channel);
ieee->SetBWModeHandler(ieee->dev, HT_CHANNEL_WIDTH_20, ieee->set_bw_mode_handler(ieee->dev, HT_CHANNEL_WIDTH_20,
HT_EXTCHNL_OFFSET_NO_EXT); HT_EXTCHNL_OFFSET_NO_EXT);
} }
......
...@@ -104,7 +104,6 @@ struct acm { ...@@ -104,7 +104,6 @@ struct acm {
}; };
union qos_tclas { union qos_tclas {
struct _TYPE_GENERAL { struct _TYPE_GENERAL {
u8 Priority; u8 Priority;
u8 ClassifierType; u8 ClassifierType;
......
...@@ -53,6 +53,4 @@ struct rx_ts_record { ...@@ -53,6 +53,4 @@ struct rx_ts_record {
u8 num; u8 num;
}; };
#endif #endif
...@@ -38,6 +38,7 @@ ...@@ -38,6 +38,7 @@
#include <linux/netdevice.h> #include <linux/netdevice.h>
#include <linux/if_arp.h> /* ARPHRD_ETHER */ #include <linux/if_arp.h> /* ARPHRD_ETHER */
#include <net/cfg80211.h>
#include <net/lib80211.h> #include <net/lib80211.h>
#define MAX_PRECMD_CNT 16 #define MAX_PRECMD_CNT 16
...@@ -139,7 +140,7 @@ struct cb_desc { ...@@ -139,7 +140,7 @@ struct cb_desc {
u8 rata_index; u8 rata_index;
u8 queue_index; u8 queue_index;
u16 txbuf_size; u16 txbuf_size;
u8 RATRIndex; u8 ratr_index;
u8 bAMSDU:1; u8 bAMSDU:1;
u8 bFromAggrQ:1; u8 bFromAggrQ:1;
u8 reserved6:6; u8 reserved6:6;
...@@ -308,9 +309,7 @@ enum rt_op_mode { ...@@ -308,9 +309,7 @@ enum rt_op_mode {
}; };
#define aSifsTime \ #define aSifsTime \
(((priv->rtllib->current_network.mode == IEEE_A) \ ((priv->rtllib->current_network.mode == WIRELESS_MODE_N_24G) ? 16 : 10)
|| (priv->rtllib->current_network.mode == IEEE_N_24G) \
|| (priv->rtllib->current_network.mode == IEEE_N_5G)) ? 16 : 10)
#define MGMT_QUEUE_NUM 5 #define MGMT_QUEUE_NUM 5
...@@ -421,17 +420,6 @@ enum init_gain_op_type { ...@@ -421,17 +420,6 @@ enum init_gain_op_type {
IG_Max IG_Max
}; };
enum led_ctl_mode {
LED_CTL_POWER_ON = 1,
LED_CTL_LINK = 2,
LED_CTL_NO_LINK = 3,
LED_CTL_TX = 4,
LED_CTL_RX = 5,
LED_CTL_SITE_SURVEY = 6,
LED_CTL_POWER_OFF = 7,
LED_CTL_START_TO_LINK = 8,
};
enum wireless_mode { enum wireless_mode {
WIRELESS_MODE_UNKNOWN = 0x00, WIRELESS_MODE_UNKNOWN = 0x00,
WIRELESS_MODE_A = 0x01, WIRELESS_MODE_A = 0x01,
...@@ -439,7 +427,6 @@ enum wireless_mode { ...@@ -439,7 +427,6 @@ enum wireless_mode {
WIRELESS_MODE_G = 0x04, WIRELESS_MODE_G = 0x04,
WIRELESS_MODE_AUTO = 0x08, WIRELESS_MODE_AUTO = 0x08,
WIRELESS_MODE_N_24G = 0x10, WIRELESS_MODE_N_24G = 0x10,
WIRELESS_MODE_N_5G = 0x20
}; };
#ifndef ETH_P_PAE #ifndef ETH_P_PAE
...@@ -499,9 +486,6 @@ enum _REG_PREAMBLE_MODE { ...@@ -499,9 +486,6 @@ enum _REG_PREAMBLE_MODE {
#define RTLLIB_CCK_MODULATION (1<<0) #define RTLLIB_CCK_MODULATION (1<<0)
#define RTLLIB_OFDM_MODULATION (1<<1) #define RTLLIB_OFDM_MODULATION (1<<1)
#define RTLLIB_24GHZ_BAND (1<<0)
#define RTLLIB_52GHZ_BAND (1<<1)
#define RTLLIB_CCK_RATE_LEN 4 #define RTLLIB_CCK_RATE_LEN 4
#define RTLLIB_CCK_RATE_1MB 0x02 #define RTLLIB_CCK_RATE_1MB 0x02
#define RTLLIB_CCK_RATE_2MB 0x04 #define RTLLIB_CCK_RATE_2MB 0x04
...@@ -548,10 +532,8 @@ struct rtllib_rx_stats { ...@@ -548,10 +532,8 @@ struct rtllib_rx_stats {
u8 signal; u8 signal;
u8 noise; u8 noise;
u16 rate; /* in 100 kbps */ u16 rate; /* in 100 kbps */
u8 received_channel;
u8 control; u8 control;
u8 mask; u8 mask;
u8 freq;
u16 len; u16 len;
u64 tsf; u64 tsf;
u32 beacon_time; u32 beacon_time;
...@@ -1136,10 +1118,9 @@ struct rtllib_network { ...@@ -1136,10 +1118,9 @@ struct rtllib_network {
struct list_head list; struct list_head list;
}; };
enum rtllib_state { enum rtl_link_state {
/* the card is not linked at all */ /* the card is not linked at all */
RTLLIB_NOLINK = 0, MAC80211_NOLINK = 0,
/* RTLLIB_ASSOCIATING* are for BSS client mode /* RTLLIB_ASSOCIATING* are for BSS client mode
* the driver shall not perform RX filtering unless * the driver shall not perform RX filtering unless
...@@ -1164,14 +1145,14 @@ enum rtllib_state { ...@@ -1164,14 +1145,14 @@ enum rtllib_state {
/* the link is ok. the card associated to a BSS or linked /* the link is ok. the card associated to a BSS or linked
* to a ibss cell or acting as an AP and creating the bss * to a ibss cell or acting as an AP and creating the bss
*/ */
RTLLIB_LINKED, MAC80211_LINKED,
/* same as LINKED, but the driver shall apply RX filter /* same as LINKED, but the driver shall apply RX filter
* rules as we are in NO_LINK mode. As the card is still * rules as we are in NO_LINK mode. As the card is still
* logically linked, but it is doing a syncro site survey * logically linked, but it is doing a syncro site survey
* then it will be back to LINKED state. * then it will be back to LINKED state.
*/ */
RTLLIB_LINKED_SCANNING, MAC80211_LINKED_SCANNING,
}; };
#define DEFAULT_MAX_SCAN_AGE (15 * HZ) #define DEFAULT_MAX_SCAN_AGE (15 * HZ)
...@@ -1298,7 +1279,6 @@ enum fw_cmd_io_type { ...@@ -1298,7 +1279,6 @@ enum fw_cmd_io_type {
#define RT_MAX_LD_SLOT_NUM 10 #define RT_MAX_LD_SLOT_NUM 10
struct rt_link_detect { struct rt_link_detect {
u32 NumRecvBcnInPeriod; u32 NumRecvBcnInPeriod;
u32 NumRecvDataInPeriod; u32 NumRecvDataInPeriod;
...@@ -1316,7 +1296,6 @@ struct rt_link_detect { ...@@ -1316,7 +1296,6 @@ struct rt_link_detect {
}; };
struct sw_cam_table { struct sw_cam_table {
u8 macaddr[ETH_ALEN]; u8 macaddr[ETH_ALEN];
bool bused; bool bused;
u8 key_buf[16]; u8 key_buf[16];
...@@ -1509,7 +1488,7 @@ struct rtllib_device { ...@@ -1509,7 +1488,7 @@ struct rtllib_device {
*/ */
struct rtllib_network current_network; struct rtllib_network current_network;
enum rtllib_state state; enum rtl_link_state link_state;
int short_slot; int short_slot;
int mode; /* A, B, G */ int mode; /* A, B, G */
...@@ -1651,17 +1630,6 @@ struct rtllib_device { ...@@ -1651,17 +1630,6 @@ struct rtllib_device {
}; };
/* Callback functions */ /* Callback functions */
void (*set_security)(struct net_device *dev,
struct rtllib_security *sec);
/* Used to TX data frame by using txb structs.
* this is not used if in the softmac_features
* is set the flag IEEE_SOFTMAC_TX_QUEUE
*/
int (*hard_start_xmit)(struct rtllib_txb *txb,
struct net_device *dev);
int (*reset_port)(struct net_device *dev);
/* Softmac-generated frames (management) are TXed via this /* Softmac-generated frames (management) are TXed via this
* callback if the flag IEEE_SOFTMAC_SINGLE_QUEUE is * callback if the flag IEEE_SOFTMAC_SINGLE_QUEUE is
...@@ -1682,24 +1650,12 @@ struct rtllib_device { ...@@ -1682,24 +1650,12 @@ struct rtllib_device {
void (*softmac_data_hard_start_xmit)(struct sk_buff *skb, void (*softmac_data_hard_start_xmit)(struct sk_buff *skb,
struct net_device *dev, int rate); struct net_device *dev, int rate);
/* stops the HW queue for DATA frames. Useful to avoid
* waste time to TX data frame when we are reassociating
* This function can sleep.
*/
void (*data_hard_stop)(struct net_device *dev);
/* OK this is complementing to data_poll_hard_stop */
void (*data_hard_resume)(struct net_device *dev);
/* ask to the driver to retune the radio. /* ask to the driver to retune the radio.
* This function can sleep. the driver should ensure * This function can sleep. the driver should ensure
* the radio has been switched before return. * the radio has been switched before return.
*/ */
void (*set_chan)(struct net_device *dev, short ch); void (*set_chan)(struct net_device *dev, short ch);
void (*rtllib_start_hw_scan)(struct net_device *dev);
void (*rtllib_stop_hw_scan)(struct net_device *dev);
/* indicate the driver that the link state is changed /* indicate the driver that the link state is changed
* for example it may indicate the card is associated now. * for example it may indicate the card is associated now.
* Driver might be interested in this to apply RX filter * Driver might be interested in this to apply RX filter
...@@ -1729,22 +1685,16 @@ struct rtllib_device { ...@@ -1729,22 +1685,16 @@ struct rtllib_device {
/* check whether Tx hw resource available */ /* check whether Tx hw resource available */
short (*check_nic_enough_desc)(struct net_device *dev, int queue_index); short (*check_nic_enough_desc)(struct net_device *dev, int queue_index);
void (*SetBWModeHandler)(struct net_device *dev, void (*set_bw_mode_handler)(struct net_device *dev,
enum ht_channel_width bandwidth, enum ht_channel_width bandwidth,
enum ht_extchnl_offset Offset); enum ht_extchnl_offset Offset);
bool (*GetNmodeSupportBySecCfg)(struct net_device *dev); bool (*GetNmodeSupportBySecCfg)(struct net_device *dev);
void (*SetWirelessMode)(struct net_device *dev, u8 wireless_mode); void (*set_wireless_mode)(struct net_device *dev, u8 wireless_mode);
bool (*GetHalfNmodeSupportByAPsHandler)(struct net_device *dev); bool (*GetHalfNmodeSupportByAPsHandler)(struct net_device *dev);
u8 (*rtllib_ap_sec_type)(struct rtllib_device *ieee); u8 (*rtllib_ap_sec_type)(struct rtllib_device *ieee);
void (*InitialGainHandler)(struct net_device *dev, u8 Operation); void (*init_gain_handler)(struct net_device *dev, u8 Operation);
bool (*SetFwCmdHandler)(struct net_device *dev,
enum fw_cmd_io_type FwCmdIO);
void (*UpdateBeaconInterruptHandler)(struct net_device *dev,
bool start);
void (*ScanOperationBackupHandler)(struct net_device *dev, void (*ScanOperationBackupHandler)(struct net_device *dev,
u8 Operation); u8 Operation);
void (*LedControlHandler)(struct net_device *dev,
enum led_ctl_mode LedAction);
void (*SetHwRegHandler)(struct net_device *dev, u8 variable, u8 *val); void (*SetHwRegHandler)(struct net_device *dev, u8 variable, u8 *val);
void (*AllowAllDestAddrHandler)(struct net_device *dev, void (*AllowAllDestAddrHandler)(struct net_device *dev,
...@@ -1752,7 +1702,7 @@ struct rtllib_device { ...@@ -1752,7 +1702,7 @@ struct rtllib_device {
void (*rtllib_ips_leave_wq)(struct net_device *dev); void (*rtllib_ips_leave_wq)(struct net_device *dev);
void (*rtllib_ips_leave)(struct net_device *dev); void (*rtllib_ips_leave)(struct net_device *dev);
void (*LeisurePSLeave)(struct net_device *dev); void (*leisure_ps_leave)(struct net_device *dev);
/* This must be the last item so that it points to the data /* This must be the last item so that it points to the data
* allocated beyond this structure by alloc_rtllib * allocated beyond this structure by alloc_rtllib
...@@ -1760,12 +1710,7 @@ struct rtllib_device { ...@@ -1760,12 +1710,7 @@ struct rtllib_device {
u8 priv[]; u8 priv[];
}; };
#define IEEE_A (1<<0) #define IEEE_MODE_MASK (WIRELESS_MODE_B | WIRELESS_MODE_G)
#define IEEE_B (1<<1)
#define IEEE_G (1<<2)
#define IEEE_N_24G (1<<4)
#define IEEE_N_5G (1<<5)
#define IEEE_MODE_MASK (IEEE_A|IEEE_B|IEEE_G)
/* Generate a 802.11 header */ /* Generate a 802.11 header */
...@@ -2080,8 +2025,6 @@ void TsStartAddBaProcess(struct rtllib_device *ieee, ...@@ -2080,8 +2025,6 @@ void TsStartAddBaProcess(struct rtllib_device *ieee,
void RemovePeerTS(struct rtllib_device *ieee, u8 *Addr); void RemovePeerTS(struct rtllib_device *ieee, u8 *Addr);
void RemoveAllTS(struct rtllib_device *ieee); void RemoveAllTS(struct rtllib_device *ieee);
extern const long rtllib_wlan_frequencies[];
static inline const char *escape_essid(const char *essid, u8 essid_len) static inline const char *escape_essid(const char *essid, u8 essid_len)
{ {
static char escaped[IW_ESSID_MAX_SIZE * 2 + 1]; static char escaped[IW_ESSID_MAX_SIZE * 2 + 1];
......
...@@ -225,18 +225,6 @@ rtllib_rx_frame_mgmt(struct rtllib_device *ieee, struct sk_buff *skb, ...@@ -225,18 +225,6 @@ rtllib_rx_frame_mgmt(struct rtllib_device *ieee, struct sk_buff *skb,
return 0; return 0;
} }
/* See IEEE 802.1H for LLC/SNAP encapsulation/decapsulation
* Ethernet-II snap header (RFC1042 for most EtherTypes)
*/
static unsigned char rfc1042_header[] = {
0xaa, 0xaa, 0x03, 0x00, 0x00, 0x00
};
/* Bridge-Tunnel header (for EtherTypes ETH_P_AARP and ETH_P_IPX) */
static unsigned char bridge_tunnel_header[] = {
0xaa, 0xaa, 0x03, 0x00, 0x00, 0xf8
};
/* No encapsulation header if EtherType < 0x600 (=length) */ /* No encapsulation header if EtherType < 0x600 (=length) */
/* Called by rtllib_rx_frame_decrypt */ /* Called by rtllib_rx_frame_decrypt */
...@@ -264,8 +252,9 @@ static int rtllib_is_eapol_frame(struct rtllib_device *ieee, ...@@ -264,8 +252,9 @@ static int rtllib_is_eapol_frame(struct rtllib_device *ieee,
RTLLIB_FCTL_FROMDS && RTLLIB_FCTL_FROMDS &&
memcmp(hdr->addr1, dev->dev_addr, ETH_ALEN) == 0) { memcmp(hdr->addr1, dev->dev_addr, ETH_ALEN) == 0) {
/* FromDS frame with own addr as DA */ /* FromDS frame with own addr as DA */
} else } else {
return 0; return 0;
}
if (skb->len < 24 + 8) if (skb->len < 24 + 8)
return 0; return 0;
...@@ -433,8 +422,9 @@ static int is_duplicate_packet(struct rtllib_device *ieee, ...@@ -433,8 +422,9 @@ static int is_duplicate_packet(struct rtllib_device *ieee,
if (*last_frag + 1 != frag) if (*last_frag + 1 != frag)
/* out-of-order fragment */ /* out-of-order fragment */
goto drop; goto drop;
} else } else {
*last_seq = seq; *last_seq = seq;
}
*last_frag = frag; *last_frag = frag;
*last_time = jiffies; *last_time = jiffies;
...@@ -1206,11 +1196,11 @@ static void rtllib_rx_check_leave_lps(struct rtllib_device *ieee, u8 unicast, ...@@ -1206,11 +1196,11 @@ static void rtllib_rx_check_leave_lps(struct rtllib_device *ieee, u8 unicast,
u8 nr_subframes) u8 nr_subframes)
{ {
if (unicast) { if (unicast) {
if (ieee->state == RTLLIB_LINKED) { if (ieee->link_state == MAC80211_LINKED) {
if (((ieee->link_detect_info.NumRxUnicastOkInPeriod + if (((ieee->link_detect_info.NumRxUnicastOkInPeriod +
ieee->link_detect_info.NumTxOkInPeriod) > 8) || ieee->link_detect_info.NumTxOkInPeriod) > 8) ||
(ieee->link_detect_info.NumRxUnicastOkInPeriod > 2)) { (ieee->link_detect_info.NumRxUnicastOkInPeriod > 2)) {
ieee->LeisurePSLeave(ieee->dev); ieee->leisure_ps_leave(ieee->dev);
} }
} }
} }
...@@ -2127,7 +2117,7 @@ int rtllib_parse_info_param(struct rtllib_device *ieee, ...@@ -2127,7 +2117,7 @@ int rtllib_parse_info_param(struct rtllib_device *ieee,
network->tim.tim_period = info_element->data[1]; network->tim.tim_period = info_element->data[1];
network->dtim_period = info_element->data[1]; network->dtim_period = info_element->data[1];
if (ieee->state != RTLLIB_LINKED) if (ieee->link_state != MAC80211_LINKED)
break; break;
network->last_dtim_sta_time = jiffies; network->last_dtim_sta_time = jiffies;
...@@ -2311,11 +2301,7 @@ static inline int rtllib_network_init( ...@@ -2311,11 +2301,7 @@ static inline int rtllib_network_init(
network->CountryIeLen = 0; network->CountryIeLen = 0;
memset(network->CountryIeBuf, 0, MAX_IE_LEN); memset(network->CountryIeBuf, 0, MAX_IE_LEN);
HTInitializeBssDesc(&network->bssht); HTInitializeBssDesc(&network->bssht);
if (stats->freq == RTLLIB_52GHZ_BAND) { network->flags |= NETWORK_HAS_CCK;
/* for A band (No DS info) */
network->channel = stats->received_channel;
} else
network->flags |= NETWORK_HAS_CCK;
network->wpa_ie_len = 0; network->wpa_ie_len = 0;
network->rsn_ie_len = 0; network->rsn_ie_len = 0;
...@@ -2329,14 +2315,11 @@ static inline int rtllib_network_init( ...@@ -2329,14 +2315,11 @@ static inline int rtllib_network_init(
return 1; return 1;
network->mode = 0; network->mode = 0;
if (stats->freq == RTLLIB_52GHZ_BAND)
network->mode = IEEE_A; if (network->flags & NETWORK_HAS_OFDM)
else { network->mode |= WIRELESS_MODE_G;
if (network->flags & NETWORK_HAS_OFDM) if (network->flags & NETWORK_HAS_CCK)
network->mode |= IEEE_G; network->mode |= WIRELESS_MODE_B;
if (network->flags & NETWORK_HAS_CCK)
network->mode |= IEEE_B;
}
if (network->mode == 0) { if (network->mode == 0) {
netdev_dbg(ieee->dev, "Filtered out '%s (%pM)' network.\n", netdev_dbg(ieee->dev, "Filtered out '%s (%pM)' network.\n",
...@@ -2346,10 +2329,8 @@ static inline int rtllib_network_init( ...@@ -2346,10 +2329,8 @@ static inline int rtllib_network_init(
} }
if (network->bssht.bd_support_ht) { if (network->bssht.bd_support_ht) {
if (network->mode == IEEE_A) if (network->mode & (WIRELESS_MODE_G | WIRELESS_MODE_B))
network->mode = IEEE_N_5G; network->mode = WIRELESS_MODE_N_24G;
else if (network->mode & (IEEE_G | IEEE_B))
network->mode = IEEE_N_24G;
} }
if (rtllib_is_empty_essid(network->ssid, network->ssid_len)) if (rtllib_is_empty_essid(network->ssid, network->ssid_len))
network->flags |= NETWORK_EMPTY_ESSID; network->flags |= NETWORK_EMPTY_ESSID;
...@@ -2595,8 +2576,8 @@ static inline void rtllib_process_probe_response( ...@@ -2595,8 +2576,8 @@ static inline void rtllib_process_probe_response(
if (is_same_network(&ieee->current_network, network, if (is_same_network(&ieee->current_network, network,
(network->ssid_len ? 1 : 0))) { (network->ssid_len ? 1 : 0))) {
update_network(ieee, &ieee->current_network, network); update_network(ieee, &ieee->current_network, network);
if ((ieee->current_network.mode == IEEE_N_24G || if ((ieee->current_network.mode == WIRELESS_MODE_N_24G ||
ieee->current_network.mode == IEEE_G) && ieee->current_network.mode == WIRELESS_MODE_G) &&
ieee->current_network.berp_info_valid) { ieee->current_network.berp_info_valid) {
if (ieee->current_network.erp_value & ERP_UseProtection) if (ieee->current_network.erp_value & ERP_UseProtection)
ieee->current_network.buseprotection = true; ieee->current_network.buseprotection = true;
...@@ -2604,7 +2585,7 @@ static inline void rtllib_process_probe_response( ...@@ -2604,7 +2585,7 @@ static inline void rtllib_process_probe_response(
ieee->current_network.buseprotection = false; ieee->current_network.buseprotection = false;
} }
if (is_beacon(frame_ctl)) { if (is_beacon(frame_ctl)) {
if (ieee->state >= RTLLIB_LINKED) if (ieee->link_state >= MAC80211_LINKED)
ieee->link_detect_info.NumRecvBcnInPeriod++; ieee->link_detect_info.NumRecvBcnInPeriod++;
} }
} }
...@@ -2662,7 +2643,7 @@ static inline void rtllib_process_probe_response( ...@@ -2662,7 +2643,7 @@ static inline void rtllib_process_probe_response(
|| ((ieee->current_network.ssid_len == network->ssid_len) && || ((ieee->current_network.ssid_len == network->ssid_len) &&
(strncmp(ieee->current_network.ssid, network->ssid, (strncmp(ieee->current_network.ssid, network->ssid,
network->ssid_len) == 0) && network->ssid_len) == 0) &&
(ieee->state == RTLLIB_NOLINK)))) (ieee->link_state == MAC80211_NOLINK))))
renew = 1; renew = 1;
update_network(ieee, target, network); update_network(ieee, target, network);
if (renew && (ieee->softmac_features & IEEE_SOFTMAC_ASSOCIATE)) if (renew && (ieee->softmac_features & IEEE_SOFTMAC_ASSOCIATE))
...@@ -2673,7 +2654,7 @@ static inline void rtllib_process_probe_response( ...@@ -2673,7 +2654,7 @@ static inline void rtllib_process_probe_response(
if (is_beacon(frame_ctl) && if (is_beacon(frame_ctl) &&
is_same_network(&ieee->current_network, network, is_same_network(&ieee->current_network, network,
(network->ssid_len ? 1 : 0)) && (network->ssid_len ? 1 : 0)) &&
(ieee->state == RTLLIB_LINKED)) { (ieee->link_state == MAC80211_LINKED)) {
ieee->handle_beacon(ieee->dev, beacon, &ieee->current_network); ieee->handle_beacon(ieee->dev, beacon, &ieee->current_network);
} }
free_network: free_network:
...@@ -2702,7 +2683,7 @@ static void rtllib_rx_mgt(struct rtllib_device *ieee, ...@@ -2702,7 +2683,7 @@ static void rtllib_rx_mgt(struct rtllib_device *ieee,
if (ieee->sta_sleep || (ieee->ps != RTLLIB_PS_DISABLED && if (ieee->sta_sleep || (ieee->ps != RTLLIB_PS_DISABLED &&
ieee->iw_mode == IW_MODE_INFRA && ieee->iw_mode == IW_MODE_INFRA &&
ieee->state == RTLLIB_LINKED)) ieee->link_state == MAC80211_LINKED))
schedule_work(&ieee->ps_task); schedule_work(&ieee->ps_task);
break; break;
...@@ -2719,7 +2700,7 @@ static void rtllib_rx_mgt(struct rtllib_device *ieee, ...@@ -2719,7 +2700,7 @@ static void rtllib_rx_mgt(struct rtllib_device *ieee,
if ((ieee->softmac_features & IEEE_SOFTMAC_PROBERS) && if ((ieee->softmac_features & IEEE_SOFTMAC_PROBERS) &&
((ieee->iw_mode == IW_MODE_ADHOC || ((ieee->iw_mode == IW_MODE_ADHOC ||
ieee->iw_mode == IW_MODE_MASTER) && ieee->iw_mode == IW_MODE_MASTER) &&
ieee->state == RTLLIB_LINKED)) ieee->link_state == MAC80211_LINKED))
rtllib_rx_probe_rq(ieee, skb); rtllib_rx_probe_rq(ieee, skb);
break; break;
} }
......
This diff is collapsed.
...@@ -15,16 +15,6 @@ ...@@ -15,16 +15,6 @@
#include "rtllib.h" #include "rtllib.h"
#include "dot11d.h" #include "dot11d.h"
/* FIXME: add A freqs */
const long rtllib_wlan_frequencies[] = {
2412, 2417, 2422, 2427,
2432, 2437, 2442, 2447,
2452, 2457, 2462, 2467,
2472, 2484
};
EXPORT_SYMBOL(rtllib_wlan_frequencies);
int rtllib_wx_set_freq(struct rtllib_device *ieee, struct iw_request_info *a, int rtllib_wx_set_freq(struct rtllib_device *ieee, struct iw_request_info *a,
union iwreq_data *wrqu, char *b) union iwreq_data *wrqu, char *b)
...@@ -43,15 +33,8 @@ int rtllib_wx_set_freq(struct rtllib_device *ieee, struct iw_request_info *a, ...@@ -43,15 +33,8 @@ int rtllib_wx_set_freq(struct rtllib_device *ieee, struct iw_request_info *a,
if (fwrq->e == 1) { if (fwrq->e == 1) {
if ((fwrq->m >= (int)2.412e8 && if ((fwrq->m >= (int)2.412e8 &&
fwrq->m <= (int)2.487e8)) { fwrq->m <= (int)2.487e8)) {
int f = fwrq->m / 100000; fwrq->m = ieee80211_freq_khz_to_channel(fwrq->m / 100);
int c = 0;
while ((c < 14) && (f != rtllib_wlan_frequencies[c]))
c++;
/* hack to fall through */
fwrq->e = 0; fwrq->e = 0;
fwrq->m = c + 1;
} }
} }
...@@ -70,7 +53,7 @@ int rtllib_wx_set_freq(struct rtllib_device *ieee, struct iw_request_info *a, ...@@ -70,7 +53,7 @@ int rtllib_wx_set_freq(struct rtllib_device *ieee, struct iw_request_info *a,
if (ieee->iw_mode == IW_MODE_ADHOC || if (ieee->iw_mode == IW_MODE_ADHOC ||
ieee->iw_mode == IW_MODE_MASTER) ieee->iw_mode == IW_MODE_MASTER)
if (ieee->state == RTLLIB_LINKED) { if (ieee->link_state == MAC80211_LINKED) {
rtllib_stop_send_beacons(ieee); rtllib_stop_send_beacons(ieee);
rtllib_start_send_beacons(ieee); rtllib_start_send_beacons(ieee);
} }
...@@ -83,7 +66,6 @@ int rtllib_wx_set_freq(struct rtllib_device *ieee, struct iw_request_info *a, ...@@ -83,7 +66,6 @@ int rtllib_wx_set_freq(struct rtllib_device *ieee, struct iw_request_info *a,
} }
EXPORT_SYMBOL(rtllib_wx_set_freq); EXPORT_SYMBOL(rtllib_wx_set_freq);
int rtllib_wx_get_freq(struct rtllib_device *ieee, int rtllib_wx_get_freq(struct rtllib_device *ieee,
struct iw_request_info *a, struct iw_request_info *a,
union iwreq_data *wrqu, char *b) union iwreq_data *wrqu, char *b)
...@@ -92,8 +74,8 @@ int rtllib_wx_get_freq(struct rtllib_device *ieee, ...@@ -92,8 +74,8 @@ int rtllib_wx_get_freq(struct rtllib_device *ieee,
if (ieee->current_network.channel == 0) if (ieee->current_network.channel == 0)
return -1; return -1;
fwrq->m = rtllib_wlan_frequencies[ieee->current_network.channel-1] * fwrq->m = ieee80211_channel_to_freq_khz(ieee->current_network.channel,
100000; NL80211_BAND_2GHZ) * 100;
fwrq->e = 1; fwrq->e = 1;
return 0; return 0;
} }
...@@ -113,8 +95,8 @@ int rtllib_wx_get_wap(struct rtllib_device *ieee, ...@@ -113,8 +95,8 @@ int rtllib_wx_get_wap(struct rtllib_device *ieee,
/* We want avoid to give to the user inconsistent infos*/ /* We want avoid to give to the user inconsistent infos*/
spin_lock_irqsave(&ieee->lock, flags); spin_lock_irqsave(&ieee->lock, flags);
if (ieee->state != RTLLIB_LINKED && if (ieee->link_state != MAC80211_LINKED &&
ieee->state != RTLLIB_LINKED_SCANNING && ieee->link_state != MAC80211_LINKED_SCANNING &&
ieee->wap_set == 0) ieee->wap_set == 0)
eth_zero_addr(wrqu->ap_addr.sa_data); eth_zero_addr(wrqu->ap_addr.sa_data);
...@@ -128,13 +110,11 @@ int rtllib_wx_get_wap(struct rtllib_device *ieee, ...@@ -128,13 +110,11 @@ int rtllib_wx_get_wap(struct rtllib_device *ieee,
} }
EXPORT_SYMBOL(rtllib_wx_get_wap); EXPORT_SYMBOL(rtllib_wx_get_wap);
int rtllib_wx_set_wap(struct rtllib_device *ieee, int rtllib_wx_set_wap(struct rtllib_device *ieee,
struct iw_request_info *info, struct iw_request_info *info,
union iwreq_data *awrq, union iwreq_data *awrq,
char *extra) char *extra)
{ {
int ret = 0; int ret = 0;
unsigned long flags; unsigned long flags;
...@@ -164,7 +144,6 @@ int rtllib_wx_set_wap(struct rtllib_device *ieee, ...@@ -164,7 +144,6 @@ int rtllib_wx_set_wap(struct rtllib_device *ieee,
goto out; goto out;
} }
if (ifup) if (ifup)
rtllib_stop_protocol(ieee, true); rtllib_stop_protocol(ieee, true);
...@@ -205,8 +184,8 @@ int rtllib_wx_get_essid(struct rtllib_device *ieee, struct iw_request_info *a, ...@@ -205,8 +184,8 @@ int rtllib_wx_get_essid(struct rtllib_device *ieee, struct iw_request_info *a,
goto out; goto out;
} }
if (ieee->state != RTLLIB_LINKED && if (ieee->link_state != MAC80211_LINKED &&
ieee->state != RTLLIB_LINKED_SCANNING && ieee->link_state != MAC80211_LINKED_SCANNING &&
ieee->ssid_set == 0) { ieee->ssid_set == 0) {
ret = -1; ret = -1;
goto out; goto out;
...@@ -220,7 +199,6 @@ int rtllib_wx_get_essid(struct rtllib_device *ieee, struct iw_request_info *a, ...@@ -220,7 +199,6 @@ int rtllib_wx_get_essid(struct rtllib_device *ieee, struct iw_request_info *a,
spin_unlock_irqrestore(&ieee->lock, flags); spin_unlock_irqrestore(&ieee->lock, flags);
return ret; return ret;
} }
EXPORT_SYMBOL(rtllib_wx_get_essid); EXPORT_SYMBOL(rtllib_wx_get_essid);
...@@ -228,10 +206,9 @@ int rtllib_wx_set_rate(struct rtllib_device *ieee, ...@@ -228,10 +206,9 @@ int rtllib_wx_set_rate(struct rtllib_device *ieee,
struct iw_request_info *info, struct iw_request_info *info,
union iwreq_data *wrqu, char *extra) union iwreq_data *wrqu, char *extra)
{ {
u32 target_rate = wrqu->bitrate.value; u32 target_rate = wrqu->bitrate.value;
ieee->rate = target_rate/100000; ieee->rate = target_rate / 100000;
return 0; return 0;
} }
EXPORT_SYMBOL(rtllib_wx_set_rate); EXPORT_SYMBOL(rtllib_wx_set_rate);
...@@ -250,14 +227,13 @@ int rtllib_wx_get_rate(struct rtllib_device *ieee, ...@@ -250,14 +227,13 @@ int rtllib_wx_get_rate(struct rtllib_device *ieee,
} }
EXPORT_SYMBOL(rtllib_wx_get_rate); EXPORT_SYMBOL(rtllib_wx_get_rate);
int rtllib_wx_set_rts(struct rtllib_device *ieee, int rtllib_wx_set_rts(struct rtllib_device *ieee,
struct iw_request_info *info, struct iw_request_info *info,
union iwreq_data *wrqu, char *extra) union iwreq_data *wrqu, char *extra)
{ {
if (wrqu->rts.disabled || !wrqu->rts.fixed) if (wrqu->rts.disabled || !wrqu->rts.fixed) {
ieee->rts = DEFAULT_RTS_THRESHOLD; ieee->rts = DEFAULT_RTS_THRESHOLD;
else { } else {
if (wrqu->rts.value < MIN_RTS_THRESHOLD || if (wrqu->rts.value < MIN_RTS_THRESHOLD ||
wrqu->rts.value > MAX_RTS_THRESHOLD) wrqu->rts.value > MAX_RTS_THRESHOLD)
return -EINVAL; return -EINVAL;
...@@ -332,6 +308,7 @@ void rtllib_wx_sync_scan_wq(void *data) ...@@ -332,6 +308,7 @@ void rtllib_wx_sync_scan_wq(void *data)
enum ht_channel_width bandwidth = 0; enum ht_channel_width bandwidth = 0;
int b40M = 0; int b40M = 0;
mutex_lock(&ieee->wx_mutex);
if (!(ieee->softmac_features & IEEE_SOFTMAC_SCAN)) { if (!(ieee->softmac_features & IEEE_SOFTMAC_SCAN)) {
rtllib_start_scan_syncro(ieee, 0); rtllib_start_scan_syncro(ieee, 0);
goto out; goto out;
...@@ -339,17 +316,14 @@ void rtllib_wx_sync_scan_wq(void *data) ...@@ -339,17 +316,14 @@ void rtllib_wx_sync_scan_wq(void *data)
chan = ieee->current_network.channel; chan = ieee->current_network.channel;
ieee->LeisurePSLeave(ieee->dev); ieee->leisure_ps_leave(ieee->dev);
/* notify AP to be in PS mode */ /* notify AP to be in PS mode */
rtllib_sta_ps_send_null_frame(ieee, 1); rtllib_sta_ps_send_null_frame(ieee, 1);
rtllib_sta_ps_send_null_frame(ieee, 1); rtllib_sta_ps_send_null_frame(ieee, 1);
rtllib_stop_all_queues(ieee); rtllib_stop_all_queues(ieee);
if (ieee->data_hard_stop)
ieee->data_hard_stop(ieee->dev);
rtllib_stop_send_beacons(ieee); rtllib_stop_send_beacons(ieee);
ieee->state = RTLLIB_LINKED_SCANNING; ieee->link_state = MAC80211_LINKED_SCANNING;
ieee->link_change(ieee->dev); ieee->link_change(ieee->dev);
/* wait for ps packet to be kicked out successfully */ /* wait for ps packet to be kicked out successfully */
msleep(50); msleep(50);
...@@ -361,7 +335,7 @@ void rtllib_wx_sync_scan_wq(void *data) ...@@ -361,7 +335,7 @@ void rtllib_wx_sync_scan_wq(void *data)
b40M = 1; b40M = 1;
chan_offset = ieee->ht_info->CurSTAExtChnlOffset; chan_offset = ieee->ht_info->CurSTAExtChnlOffset;
bandwidth = (enum ht_channel_width)ieee->ht_info->bCurBW40MHz; bandwidth = (enum ht_channel_width)ieee->ht_info->bCurBW40MHz;
ieee->SetBWModeHandler(ieee->dev, HT_CHANNEL_WIDTH_20, ieee->set_bw_mode_handler(ieee->dev, HT_CHANNEL_WIDTH_20,
HT_EXTCHNL_OFFSET_NO_EXT); HT_EXTCHNL_OFFSET_NO_EXT);
} }
...@@ -374,14 +348,14 @@ void rtllib_wx_sync_scan_wq(void *data) ...@@ -374,14 +348,14 @@ void rtllib_wx_sync_scan_wq(void *data)
ieee->set_chan(ieee->dev, chan - 2); ieee->set_chan(ieee->dev, chan - 2);
else else
ieee->set_chan(ieee->dev, chan); ieee->set_chan(ieee->dev, chan);
ieee->SetBWModeHandler(ieee->dev, bandwidth, chan_offset); ieee->set_bw_mode_handler(ieee->dev, bandwidth, chan_offset);
} else { } else {
ieee->set_chan(ieee->dev, chan); ieee->set_chan(ieee->dev, chan);
} }
ieee->ScanOperationBackupHandler(ieee->dev, SCAN_OPT_RESTORE); ieee->ScanOperationBackupHandler(ieee->dev, SCAN_OPT_RESTORE);
ieee->state = RTLLIB_LINKED; ieee->link_state = MAC80211_LINKED;
ieee->link_change(ieee->dev); ieee->link_change(ieee->dev);
/* Notify AP that I wake up again */ /* Notify AP that I wake up again */
...@@ -392,10 +366,6 @@ void rtllib_wx_sync_scan_wq(void *data) ...@@ -392,10 +366,6 @@ void rtllib_wx_sync_scan_wq(void *data)
ieee->link_detect_info.NumRecvBcnInPeriod = 1; ieee->link_detect_info.NumRecvBcnInPeriod = 1;
ieee->link_detect_info.NumRecvDataInPeriod = 1; ieee->link_detect_info.NumRecvDataInPeriod = 1;
} }
if (ieee->data_hard_resume)
ieee->data_hard_resume(ieee->dev);
if (ieee->iw_mode == IW_MODE_ADHOC || ieee->iw_mode == IW_MODE_MASTER) if (ieee->iw_mode == IW_MODE_ADHOC || ieee->iw_mode == IW_MODE_MASTER)
rtllib_start_send_beacons(ieee); rtllib_start_send_beacons(ieee);
...@@ -403,7 +373,6 @@ void rtllib_wx_sync_scan_wq(void *data) ...@@ -403,7 +373,6 @@ void rtllib_wx_sync_scan_wq(void *data)
out: out:
mutex_unlock(&ieee->wx_mutex); mutex_unlock(&ieee->wx_mutex);
} }
int rtllib_wx_set_scan(struct rtllib_device *ieee, struct iw_request_info *a, int rtllib_wx_set_scan(struct rtllib_device *ieee, struct iw_request_info *a,
...@@ -411,21 +380,18 @@ int rtllib_wx_set_scan(struct rtllib_device *ieee, struct iw_request_info *a, ...@@ -411,21 +380,18 @@ int rtllib_wx_set_scan(struct rtllib_device *ieee, struct iw_request_info *a,
{ {
int ret = 0; int ret = 0;
mutex_lock(&ieee->wx_mutex);
if (ieee->iw_mode == IW_MODE_MONITOR || !(ieee->proto_started)) { if (ieee->iw_mode == IW_MODE_MONITOR || !(ieee->proto_started)) {
ret = -1; ret = -1;
goto out; goto out;
} }
if (ieee->state == RTLLIB_LINKED) { if (ieee->link_state == MAC80211_LINKED) {
schedule_work(&ieee->wx_sync_scan_wq); schedule_work(&ieee->wx_sync_scan_wq);
/* intentionally forget to up sem */ /* intentionally forget to up sem */
return 0; return 0;
} }
out: out:
mutex_unlock(&ieee->wx_mutex);
return ret; return ret;
} }
EXPORT_SYMBOL(rtllib_wx_set_scan); EXPORT_SYMBOL(rtllib_wx_set_scan);
...@@ -434,7 +400,6 @@ int rtllib_wx_set_essid(struct rtllib_device *ieee, ...@@ -434,7 +400,6 @@ int rtllib_wx_set_essid(struct rtllib_device *ieee,
struct iw_request_info *a, struct iw_request_info *a,
union iwreq_data *wrqu, char *extra) union iwreq_data *wrqu, char *extra)
{ {
int ret = 0, len; int ret = 0, len;
short proto_started; short proto_started;
unsigned long flags; unsigned long flags;
...@@ -454,7 +419,6 @@ int rtllib_wx_set_essid(struct rtllib_device *ieee, ...@@ -454,7 +419,6 @@ int rtllib_wx_set_essid(struct rtllib_device *ieee,
if (proto_started) if (proto_started)
rtllib_stop_protocol(ieee, true); rtllib_stop_protocol(ieee, true);
/* this is just to be sure that the GET wx callback /* this is just to be sure that the GET wx callback
* has consistent infos. not needed otherwise * has consistent infos. not needed otherwise
*/ */
...@@ -492,7 +456,6 @@ int rtllib_wx_set_rawtx(struct rtllib_device *ieee, ...@@ -492,7 +456,6 @@ int rtllib_wx_set_rawtx(struct rtllib_device *ieee,
struct iw_request_info *info, struct iw_request_info *info,
union iwreq_data *wrqu, char *extra) union iwreq_data *wrqu, char *extra)
{ {
int *parms = (int *)extra; int *parms = (int *)extra;
int enable = (parms[0] > 0); int enable = (parms[0] > 0);
short prev = ieee->raw_tx; short prev = ieee->raw_tx;
...@@ -508,12 +471,8 @@ int rtllib_wx_set_rawtx(struct rtllib_device *ieee, ...@@ -508,12 +471,8 @@ int rtllib_wx_set_rawtx(struct rtllib_device *ieee,
ieee->raw_tx ? "enabled" : "disabled"); ieee->raw_tx ? "enabled" : "disabled");
if (ieee->iw_mode == IW_MODE_MONITOR) { if (ieee->iw_mode == IW_MODE_MONITOR) {
if (prev == 0 && ieee->raw_tx) { if (prev == 0 && ieee->raw_tx)
if (ieee->data_hard_resume)
ieee->data_hard_resume(ieee->dev);
netif_carrier_on(ieee->dev); netif_carrier_on(ieee->dev);
}
if (prev && ieee->raw_tx == 1) if (prev && ieee->raw_tx == 1)
netif_carrier_off(ieee->dev); netif_carrier_off(ieee->dev);
...@@ -530,14 +489,13 @@ int rtllib_wx_get_name(struct rtllib_device *ieee, struct iw_request_info *info, ...@@ -530,14 +489,13 @@ int rtllib_wx_get_name(struct rtllib_device *ieee, struct iw_request_info *info,
{ {
const char *b = ieee->modulation & RTLLIB_CCK_MODULATION ? "b" : ""; const char *b = ieee->modulation & RTLLIB_CCK_MODULATION ? "b" : "";
const char *g = ieee->modulation & RTLLIB_OFDM_MODULATION ? "g" : ""; const char *g = ieee->modulation & RTLLIB_OFDM_MODULATION ? "g" : "";
const char *n = ieee->mode & (IEEE_N_24G | IEEE_N_5G) ? "n" : ""; const char *n = ieee->mode & (WIRELESS_MODE_N_24G) ? "n" : "";
scnprintf(wrqu->name, sizeof(wrqu->name), "802.11%s%s%s", b, g, n); scnprintf(wrqu->name, sizeof(wrqu->name), "802.11%s%s%s", b, g, n);
return 0; return 0;
} }
EXPORT_SYMBOL(rtllib_wx_get_name); EXPORT_SYMBOL(rtllib_wx_get_name);
/* this is mostly stolen from hostap */ /* this is mostly stolen from hostap */
int rtllib_wx_set_power(struct rtllib_device *ieee, int rtllib_wx_set_power(struct rtllib_device *ieee,
struct iw_request_info *info, struct iw_request_info *info,
...@@ -583,12 +541,10 @@ int rtllib_wx_set_power(struct rtllib_device *ieee, ...@@ -583,12 +541,10 @@ int rtllib_wx_set_power(struct rtllib_device *ieee,
default: default:
ret = -EINVAL; ret = -EINVAL;
goto exit; goto exit;
} }
exit: exit:
mutex_unlock(&ieee->wx_mutex); mutex_unlock(&ieee->wx_mutex);
return ret; return ret;
} }
EXPORT_SYMBOL(rtllib_wx_set_power); EXPORT_SYMBOL(rtllib_wx_set_power);
...@@ -625,6 +581,5 @@ int rtllib_wx_get_power(struct rtllib_device *ieee, ...@@ -625,6 +581,5 @@ int rtllib_wx_get_power(struct rtllib_device *ieee,
exit: exit:
mutex_unlock(&ieee->wx_mutex); mutex_unlock(&ieee->wx_mutex);
return 0; return 0;
} }
EXPORT_SYMBOL(rtllib_wx_get_power); EXPORT_SYMBOL(rtllib_wx_get_power);
...@@ -406,7 +406,7 @@ static void rtllib_query_protectionmode(struct rtllib_device *ieee, ...@@ -406,7 +406,7 @@ static void rtllib_query_protectionmode(struct rtllib_device *ieee,
if (is_broadcast_ether_addr(skb->data + 16)) if (is_broadcast_ether_addr(skb->data + 16))
return; return;
if (ieee->mode < IEEE_N_24G) { if (ieee->mode < WIRELESS_MODE_N_24G) {
if (skb->len > ieee->rts) { if (skb->len > ieee->rts) {
tcb_desc->bRTSEnable = true; tcb_desc->bRTSEnable = true;
tcb_desc->rts_rate = MGN_24M; tcb_desc->rts_rate = MGN_24M;
...@@ -486,7 +486,7 @@ static void rtllib_txrate_selectmode(struct rtllib_device *ieee, ...@@ -486,7 +486,7 @@ static void rtllib_txrate_selectmode(struct rtllib_device *ieee,
!tcb_desc->tx_use_drv_assinged_rate) { !tcb_desc->tx_use_drv_assinged_rate) {
if (ieee->iw_mode == IW_MODE_INFRA || if (ieee->iw_mode == IW_MODE_INFRA ||
ieee->iw_mode == IW_MODE_ADHOC) ieee->iw_mode == IW_MODE_ADHOC)
tcb_desc->RATRIndex = 0; tcb_desc->ratr_index = 0;
} }
} }
...@@ -572,8 +572,7 @@ static int rtllib_xmit_inter(struct sk_buff *skb, struct net_device *dev) ...@@ -572,8 +572,7 @@ static int rtllib_xmit_inter(struct sk_buff *skb, struct net_device *dev)
/* If there is no driver handler to take the TXB, don't bother /* If there is no driver handler to take the TXB, don't bother
* creating it... * creating it...
*/ */
if ((!ieee->hard_start_xmit && !(ieee->softmac_features & if (!(ieee->softmac_features & IEEE_SOFTMAC_TX_QUEUE) ||
IEEE_SOFTMAC_TX_QUEUE)) ||
((!ieee->softmac_data_hard_start_xmit && ((!ieee->softmac_data_hard_start_xmit &&
(ieee->softmac_features & IEEE_SOFTMAC_TX_QUEUE)))) { (ieee->softmac_features & IEEE_SOFTMAC_TX_QUEUE)))) {
netdev_warn(ieee->dev, "No xmit handler.\n"); netdev_warn(ieee->dev, "No xmit handler.\n");
...@@ -892,7 +891,7 @@ static int rtllib_xmit_inter(struct sk_buff *skb, struct net_device *dev) ...@@ -892,7 +891,7 @@ static int rtllib_xmit_inter(struct sk_buff *skb, struct net_device *dev)
tcb_desc->tx_dis_rate_fallback = 1; tcb_desc->tx_dis_rate_fallback = 1;
} }
tcb_desc->RATRIndex = 7; tcb_desc->ratr_index = 7;
tcb_desc->tx_use_drv_assinged_rate = 1; tcb_desc->tx_use_drv_assinged_rate = 1;
} else { } else {
if (is_multicast_ether_addr(header.addr1)) if (is_multicast_ether_addr(header.addr1))
...@@ -916,7 +915,7 @@ static int rtllib_xmit_inter(struct sk_buff *skb, struct net_device *dev) ...@@ -916,7 +915,7 @@ static int rtllib_xmit_inter(struct sk_buff *skb, struct net_device *dev)
tcb_desc->tx_dis_rate_fallback = 1; tcb_desc->tx_dis_rate_fallback = 1;
} }
tcb_desc->RATRIndex = 7; tcb_desc->ratr_index = 7;
tcb_desc->tx_use_drv_assinged_rate = 1; tcb_desc->tx_use_drv_assinged_rate = 1;
tcb_desc->bdhcp = 1; tcb_desc->bdhcp = 1;
} }
...@@ -938,11 +937,6 @@ static int rtllib_xmit_inter(struct sk_buff *skb, struct net_device *dev) ...@@ -938,11 +937,6 @@ static int rtllib_xmit_inter(struct sk_buff *skb, struct net_device *dev)
dev->stats.tx_bytes += le16_to_cpu(txb->payload_size); dev->stats.tx_bytes += le16_to_cpu(txb->payload_size);
rtllib_softmac_xmit(txb, ieee); rtllib_softmac_xmit(txb, ieee);
} else { } else {
if ((*ieee->hard_start_xmit)(txb, dev) == 0) {
stats->tx_packets++;
stats->tx_bytes += le16_to_cpu(txb->payload_size);
return 0;
}
rtllib_txb_free(txb); rtllib_txb_free(txb);
} }
} }
......
...@@ -19,7 +19,7 @@ ...@@ -19,7 +19,7 @@
#include "rtllib.h" #include "rtllib.h"
static const char * const rtllib_modes[] = { static const char * const rtllib_modes[] = {
"a", "b", "g", "?", "N-24G", "N-5G" "a", "b", "g", "?", "N-24G"
}; };
#define MAX_CUSTOM_LEN 64 #define MAX_CUSTOM_LEN 64
...@@ -118,7 +118,7 @@ static inline char *rtl819x_translate_scan(struct rtllib_device *ieee, ...@@ -118,7 +118,7 @@ static inline char *rtl819x_translate_scan(struct rtllib_device *ieee,
max_rate = rate; max_rate = rate;
} }
if (network->mode >= IEEE_N_24G) { if (network->mode >= WIRELESS_MODE_N_24G) {
struct ht_capab_ele *ht_cap = NULL; struct ht_capab_ele *ht_cap = NULL;
bool is40M = false, isShortGI = false; bool is40M = false, isShortGI = false;
u8 max_mcs = 0; u8 max_mcs = 0;
...@@ -416,22 +416,6 @@ int rtllib_wx_set_encode(struct rtllib_device *ieee, ...@@ -416,22 +416,6 @@ int rtllib_wx_set_encode(struct rtllib_device *ieee,
*/ */
sec.flags |= SEC_LEVEL; sec.flags |= SEC_LEVEL;
sec.level = SEC_LEVEL_1; /* 40 and 104 bit WEP */ sec.level = SEC_LEVEL_1; /* 40 and 104 bit WEP */
if (ieee->set_security)
ieee->set_security(dev, &sec);
/* Do not reset port if card is in Managed mode since resetting will
* generate new IEEE 802.11 authentication which may end up in looping
* with IEEE 802.1X. If your hardware requires a reset after WEP
* configuration (for example... Prism2), implement the reset_port in
* the callbacks structures used to initialize the 802.11 stack.
*/
if (ieee->reset_on_keychange &&
ieee->iw_mode != IW_MODE_INFRA &&
ieee->reset_port && ieee->reset_port(dev)) {
netdev_dbg(dev, "%s: reset_port failed\n", dev->name);
return -EINVAL;
}
return 0; return 0;
} }
EXPORT_SYMBOL(rtllib_wx_set_encode); EXPORT_SYMBOL(rtllib_wx_set_encode);
...@@ -623,15 +607,6 @@ int rtllib_wx_set_encode_ext(struct rtllib_device *ieee, ...@@ -623,15 +607,6 @@ int rtllib_wx_set_encode_ext(struct rtllib_device *ieee,
sec.flags &= ~SEC_LEVEL; sec.flags &= ~SEC_LEVEL;
} }
done: done:
if (ieee->set_security)
ieee->set_security(ieee->dev, &sec);
if (ieee->reset_on_keychange &&
ieee->iw_mode != IW_MODE_INFRA &&
ieee->reset_port && ieee->reset_port(dev)) {
netdev_dbg(ieee->dev, "Port reset failed\n");
return -EINVAL;
}
return ret; return ret;
} }
EXPORT_SYMBOL(rtllib_wx_set_encode_ext); EXPORT_SYMBOL(rtllib_wx_set_encode_ext);
...@@ -644,7 +619,7 @@ int rtllib_wx_set_mlme(struct rtllib_device *ieee, ...@@ -644,7 +619,7 @@ int rtllib_wx_set_mlme(struct rtllib_device *ieee,
bool deauth = false; bool deauth = false;
struct iw_mlme *mlme = (struct iw_mlme *)extra; struct iw_mlme *mlme = (struct iw_mlme *)extra;
if (ieee->state != RTLLIB_LINKED) if (ieee->link_state != MAC80211_LINKED)
return -ENOLINK; return -ENOLINK;
mutex_lock(&ieee->wx_mutex); mutex_lock(&ieee->wx_mutex);
......
...@@ -2275,7 +2275,10 @@ void Hal_EfuseParseBTCoexistInfo_8723B( ...@@ -2275,7 +2275,10 @@ void Hal_EfuseParseBTCoexistInfo_8723B(
pHalData->EEPROMBluetoothAntNum = tempval & BIT(0); pHalData->EEPROMBluetoothAntNum = tempval & BIT(0);
/* EFUSE_0xC3[6] == 0, S1(Main)-RF_PATH_A; */ /* EFUSE_0xC3[6] == 0, S1(Main)-RF_PATH_A; */
/* EFUSE_0xC3[6] == 1, S0(Aux)-RF_PATH_B */ /* EFUSE_0xC3[6] == 1, S0(Aux)-RF_PATH_B */
pHalData->ant_path = (tempval & BIT(6))? RF_PATH_B : RF_PATH_A; if (tempval & BIT(6))
pHalData->ant_path = RF_PATH_B;
else
pHalData->ant_path = RF_PATH_A;
} else { } else {
pHalData->EEPROMBluetoothAntNum = Ant_x1; pHalData->EEPROMBluetoothAntNum = Ant_x1;
if (pHalData->PackageType == PACKAGE_QFN68) if (pHalData->PackageType == PACKAGE_QFN68)
......
...@@ -16,9 +16,9 @@ ...@@ -16,9 +16,9 @@
/* if mode == 0, then the sta is allowed once the addr is hit. */ /* if mode == 0, then the sta is allowed once the addr is hit. */
/* if mode == 1, then the sta is rejected once the addr is non-hit. */ /* if mode == 1, then the sta is rejected once the addr is non-hit. */
struct rtw_wlan_acl_node { struct rtw_wlan_acl_node {
struct list_head list; struct list_head list;
u8 addr[ETH_ALEN]; u8 addr[ETH_ALEN];
u8 valid; u8 valid;
}; };
/* mode = 0, disable */ /* mode = 0, disable */
...@@ -340,19 +340,19 @@ struct sta_priv { ...@@ -340,19 +340,19 @@ struct sta_priv {
static inline u32 wifi_mac_hash(u8 *mac) static inline u32 wifi_mac_hash(u8 *mac)
{ {
u32 x; u32 x;
x = mac[0]; x = mac[0];
x = (x << 2) ^ mac[1]; x = (x << 2) ^ mac[1];
x = (x << 2) ^ mac[2]; x = (x << 2) ^ mac[2];
x = (x << 2) ^ mac[3]; x = (x << 2) ^ mac[3];
x = (x << 2) ^ mac[4]; x = (x << 2) ^ mac[4];
x = (x << 2) ^ mac[5]; x = (x << 2) ^ mac[5];
x ^= x >> 8; x ^= x >> 8;
x = x & (NUM_STA - 1); x = x & (NUM_STA - 1);
return x; return x;
} }
......
...@@ -382,27 +382,21 @@ static int rtsx_control_thread(void *__dev) ...@@ -382,27 +382,21 @@ static int rtsx_control_thread(void *__dev)
if (chip->srb->sc_data_direction == DMA_BIDIRECTIONAL) { if (chip->srb->sc_data_direction == DMA_BIDIRECTIONAL) {
dev_err(&dev->pci->dev, "UNKNOWN data direction\n"); dev_err(&dev->pci->dev, "UNKNOWN data direction\n");
chip->srb->result = DID_ERROR << 16; chip->srb->result = DID_ERROR << 16;
} } else if (chip->srb->device->id) {
/* reject if target != 0 or if LUN is higher than
/* reject if target != 0 or if LUN is higher than * the maximum known LUN
* the maximum known LUN */
*/
else if (chip->srb->device->id) {
dev_err(&dev->pci->dev, "Bad target number (%d:%d)\n", dev_err(&dev->pci->dev, "Bad target number (%d:%d)\n",
chip->srb->device->id, chip->srb->device->id,
(u8)chip->srb->device->lun); (u8)chip->srb->device->lun);
chip->srb->result = DID_BAD_TARGET << 16; chip->srb->result = DID_BAD_TARGET << 16;
} } else if (chip->srb->device->lun > chip->max_lun) {
else if (chip->srb->device->lun > chip->max_lun) {
dev_err(&dev->pci->dev, "Bad LUN (%d:%d)\n", dev_err(&dev->pci->dev, "Bad LUN (%d:%d)\n",
chip->srb->device->id, chip->srb->device->id,
(u8)chip->srb->device->lun); (u8)chip->srb->device->lun);
chip->srb->result = DID_BAD_TARGET << 16; chip->srb->result = DID_BAD_TARGET << 16;
} } else {
/* we've got a command, let's do it! */
/* we've got a command, let's do it! */
else {
scsi_show_command(chip); scsi_show_command(chip);
rtsx_invoke_transport(chip->srb, chip); rtsx_invoke_transport(chip->srb, chip);
} }
......
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: GPL-2.0
config FB_SM750 config FB_SM750
tristate "Silicon Motion SM750 framebuffer support" tristate "Silicon Motion SM750 framebuffer support"
depends on FB && PCI depends on FB && PCI && HAS_IOPORT
select FB_MODE_HELPERS select FB_MODE_HELPERS
select FB_CFB_FILLRECT select FB_CFB_FILLRECT
select FB_CFB_COPYAREA select FB_CFB_COPYAREA
......
...@@ -78,8 +78,6 @@ struct vchiq_service_params_kernel { ...@@ -78,8 +78,6 @@ struct vchiq_service_params_kernel {
short version_min; /* Update for incompatible changes */ short version_min; /* Update for incompatible changes */
}; };
struct vchiq_instance;
extern int vchiq_initialise(struct vchiq_instance **pinstance); extern int vchiq_initialise(struct vchiq_instance **pinstance);
extern int vchiq_shutdown(struct vchiq_instance *instance); extern int vchiq_shutdown(struct vchiq_instance *instance);
extern int vchiq_connect(struct vchiq_instance *instance); extern int vchiq_connect(struct vchiq_instance *instance);
......
...@@ -415,7 +415,7 @@ free_pagelist(struct vchiq_instance *instance, struct vchiq_pagelist_info *pagel ...@@ -415,7 +415,7 @@ free_pagelist(struct vchiq_instance *instance, struct vchiq_pagelist_info *pagel
pagelistinfo->scatterlist_mapped = 0; pagelistinfo->scatterlist_mapped = 0;
/* Deal with any partial cache lines (fragments) */ /* Deal with any partial cache lines (fragments) */
if (pagelist->type >= PAGELIST_READ_WITH_FRAGMENTS) { if (pagelist->type >= PAGELIST_READ_WITH_FRAGMENTS && g_fragments_base) {
char *fragments = g_fragments_base + char *fragments = g_fragments_base +
(pagelist->type - PAGELIST_READ_WITH_FRAGMENTS) * (pagelist->type - PAGELIST_READ_WITH_FRAGMENTS) *
g_fragments_size; g_fragments_size;
...@@ -462,7 +462,7 @@ free_pagelist(struct vchiq_instance *instance, struct vchiq_pagelist_info *pagel ...@@ -462,7 +462,7 @@ free_pagelist(struct vchiq_instance *instance, struct vchiq_pagelist_info *pagel
cleanup_pagelistinfo(instance, pagelistinfo); cleanup_pagelistinfo(instance, pagelistinfo);
} }
int vchiq_platform_init(struct platform_device *pdev, struct vchiq_state *state) static int vchiq_platform_init(struct platform_device *pdev, struct vchiq_state *state)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct vchiq_drvdata *drvdata = platform_get_drvdata(pdev); struct vchiq_drvdata *drvdata = platform_get_drvdata(pdev);
......
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: GPL-2.0
config VT6655 config VT6655
tristate "VIA Technologies VT6655 support" tristate "VIA Technologies VT6655 support"
depends on PCI && MAC80211 && m depends on PCI && HAS_IOPORT && MAC80211 && m
help help
This is a vendor-written driver for VIA VT6655. This is a vendor-written driver for VIA VT6655.
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -6,27 +6,6 @@ ...@@ -6,27 +6,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -6,27 +6,6 @@ ...@@ -6,27 +6,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
...@@ -114,22 +93,8 @@ struct p80211msg_dot11req_scan_results { ...@@ -114,22 +93,8 @@ struct p80211msg_dot11req_scan_results {
struct p80211item_uint32 cfpollreq; struct p80211item_uint32 cfpollreq;
struct p80211item_uint32 privacy; struct p80211item_uint32 privacy;
struct p80211item_uint32 capinfo; struct p80211item_uint32 capinfo;
struct p80211item_uint32 basicrate1; struct p80211item_uint32 basicrate[8];
struct p80211item_uint32 basicrate2; struct p80211item_uint32 supprate[8];
struct p80211item_uint32 basicrate3;
struct p80211item_uint32 basicrate4;
struct p80211item_uint32 basicrate5;
struct p80211item_uint32 basicrate6;
struct p80211item_uint32 basicrate7;
struct p80211item_uint32 basicrate8;
struct p80211item_uint32 supprate1;
struct p80211item_uint32 supprate2;
struct p80211item_uint32 supprate3;
struct p80211item_uint32 supprate4;
struct p80211item_uint32 supprate5;
struct p80211item_uint32 supprate6;
struct p80211item_uint32 supprate7;
struct p80211item_uint32 supprate8;
} __packed; } __packed;
struct p80211msg_dot11req_start { struct p80211msg_dot11req_start {
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -9,27 +9,6 @@ ...@@ -9,27 +9,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
...@@ -437,42 +416,22 @@ int prism2mgmt_scan_results(struct wlandevice *wlandev, void *msgp) ...@@ -437,42 +416,22 @@ int prism2mgmt_scan_results(struct wlandevice *wlandev, void *msgp)
if (item->supprates[count] == 0) if (item->supprates[count] == 0)
break; break;
#define REQBASICRATE(N) \ for (int i = 0; i < 8; i++) {
do { \ if (count > i &&
if ((count >= (N)) && DOT11_RATE5_ISBASIC_GET( \ DOT11_RATE5_ISBASIC_GET(item->supprates[i])) {
item->supprates[(N) - 1])) { \ req->basicrate[i].data = item->supprates[i];
req->basicrate ## N .data = item->supprates[(N) - 1]; \ req->basicrate[i].status =
req->basicrate ## N .status = \ P80211ENUM_msgitem_status_data_ok;
P80211ENUM_msgitem_status_data_ok; \ }
} \ }
} while (0)
for (int i = 0; i < 8; i++) {
REQBASICRATE(1); if (count > i) {
REQBASICRATE(2); req->supprate[i].data = item->supprates[i];
REQBASICRATE(3); req->supprate[i].status =
REQBASICRATE(4); P80211ENUM_msgitem_status_data_ok;
REQBASICRATE(5); }
REQBASICRATE(6); }
REQBASICRATE(7);
REQBASICRATE(8);
#define REQSUPPRATE(N) \
do { \
if (count >= (N)) { \
req->supprate ## N .data = item->supprates[(N) - 1]; \
req->supprate ## N .status = \
P80211ENUM_msgitem_status_data_ok; \
} \
} while (0)
REQSUPPRATE(1);
REQSUPPRATE(2);
REQSUPPRATE(3);
REQSUPPRATE(4);
REQSUPPRATE(5);
REQSUPPRATE(6);
REQSUPPRATE(7);
REQSUPPRATE(8);
/* beacon period */ /* beacon period */
req->beaconperiod.status = P80211ENUM_msgitem_status_data_ok; req->beaconperiod.status = P80211ENUM_msgitem_status_data_ok;
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
...@@ -8,27 +8,6 @@ ...@@ -8,27 +8,6 @@
* *
* linux-wlan * linux-wlan
* *
* The contents of this file are subject to the Mozilla Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the
* terms of the GNU Public License version 2 (the "GPL"), in which
* case the provisions of the GPL are applicable instead of the
* above. If you wish to allow the use of your version of this file
* only under the terms of the GPL and not to allow others to use
* your version of this file under the MPL, indicate your decision
* by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL. If you do not delete
* the provisions above, a recipient may use your version of this
* file under either the MPL or the GPL.
*
* -------------------------------------------------------------------- * --------------------------------------------------------------------
* *
* Inquiries regarding the linux-wlan Open Source project can be * Inquiries regarding the linux-wlan Open Source project can be
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment