rt2x00: Optimize configuration handling
Implement latest changed from mac80211 configuration handling to optmize configuration handling in rt2x00. * Remove set_retry_limit callback function, handled through config() * Move config_antenna to its own callback function, it isn't handled by mac80211 anymore * Use IEEE80211_CONF_CHANGED_* flags and remove manual checks * Removed deprecated short slot setting through config() and put it in config_erp() through which mac80211 now configures it * Remove config_phymode() and move contents to config_erp() since it only managed the basic rates which is now determined by mac80211 through config_erp(). Signed-off-by: Ivo van Doorn <IvDoorn@gmail.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
committed by
John W. Linville
parent
3f64b435ab
commit
e4ea1c403a
@ -396,12 +396,74 @@ static void rt2400pci_config_erp(struct rt2x00_dev *rt2x00dev,
|
||||
rt2x00_set_field32(®, ARCSR5_SERVICE, 0x84);
|
||||
rt2x00_set_field32(®, ARCSR2_LENGTH, get_duration(ACK_SIZE, 110));
|
||||
rt2x00pci_register_write(rt2x00dev, ARCSR5, reg);
|
||||
|
||||
rt2x00pci_register_write(rt2x00dev, ARCSR1, erp->basic_rates);
|
||||
|
||||
rt2x00pci_register_read(rt2x00dev, CSR11, ®);
|
||||
rt2x00_set_field32(®, CSR11_SLOT_TIME, erp->slot_time);
|
||||
rt2x00pci_register_write(rt2x00dev, CSR11, reg);
|
||||
|
||||
rt2x00pci_register_read(rt2x00dev, CSR18, ®);
|
||||
rt2x00_set_field32(®, CSR18_SIFS, erp->sifs);
|
||||
rt2x00_set_field32(®, CSR18_PIFS, erp->pifs);
|
||||
rt2x00pci_register_write(rt2x00dev, CSR18, reg);
|
||||
|
||||
rt2x00pci_register_read(rt2x00dev, CSR19, ®);
|
||||
rt2x00_set_field32(®, CSR19_DIFS, erp->difs);
|
||||
rt2x00_set_field32(®, CSR19_EIFS, erp->eifs);
|
||||
rt2x00pci_register_write(rt2x00dev, CSR19, reg);
|
||||
}
|
||||
|
||||
static void rt2400pci_config_phymode(struct rt2x00_dev *rt2x00dev,
|
||||
const int basic_rate_mask)
|
||||
static void rt2400pci_config_ant(struct rt2x00_dev *rt2x00dev,
|
||||
struct antenna_setup *ant)
|
||||
{
|
||||
rt2x00pci_register_write(rt2x00dev, ARCSR1, basic_rate_mask);
|
||||
u8 r1;
|
||||
u8 r4;
|
||||
|
||||
/*
|
||||
* We should never come here because rt2x00lib is supposed
|
||||
* to catch this and send us the correct antenna explicitely.
|
||||
*/
|
||||
BUG_ON(ant->rx == ANTENNA_SW_DIVERSITY ||
|
||||
ant->tx == ANTENNA_SW_DIVERSITY);
|
||||
|
||||
rt2400pci_bbp_read(rt2x00dev, 4, &r4);
|
||||
rt2400pci_bbp_read(rt2x00dev, 1, &r1);
|
||||
|
||||
/*
|
||||
* Configure the TX antenna.
|
||||
*/
|
||||
switch (ant->tx) {
|
||||
case ANTENNA_HW_DIVERSITY:
|
||||
rt2x00_set_field8(&r1, BBP_R1_TX_ANTENNA, 1);
|
||||
break;
|
||||
case ANTENNA_A:
|
||||
rt2x00_set_field8(&r1, BBP_R1_TX_ANTENNA, 0);
|
||||
break;
|
||||
case ANTENNA_B:
|
||||
default:
|
||||
rt2x00_set_field8(&r1, BBP_R1_TX_ANTENNA, 2);
|
||||
break;
|
||||
}
|
||||
|
||||
/*
|
||||
* Configure the RX antenna.
|
||||
*/
|
||||
switch (ant->rx) {
|
||||
case ANTENNA_HW_DIVERSITY:
|
||||
rt2x00_set_field8(&r4, BBP_R4_RX_ANTENNA, 1);
|
||||
break;
|
||||
case ANTENNA_A:
|
||||
rt2x00_set_field8(&r4, BBP_R4_RX_ANTENNA, 0);
|
||||
break;
|
||||
case ANTENNA_B:
|
||||
default:
|
||||
rt2x00_set_field8(&r4, BBP_R4_RX_ANTENNA, 2);
|
||||
break;
|
||||
}
|
||||
|
||||
rt2400pci_bbp_write(rt2x00dev, 4, r4);
|
||||
rt2400pci_bbp_write(rt2x00dev, 1, r1);
|
||||
}
|
||||
|
||||
static void rt2400pci_config_channel(struct rt2x00_dev *rt2x00dev,
|
||||
@ -460,56 +522,17 @@ static void rt2400pci_config_txpower(struct rt2x00_dev *rt2x00dev, int txpower)
|
||||
rt2400pci_bbp_write(rt2x00dev, 3, TXPOWER_TO_DEV(txpower));
|
||||
}
|
||||
|
||||
static void rt2400pci_config_antenna(struct rt2x00_dev *rt2x00dev,
|
||||
struct antenna_setup *ant)
|
||||
static void rt2400pci_config_retry_limit(struct rt2x00_dev *rt2x00dev,
|
||||
struct rt2x00lib_conf *libconf)
|
||||
{
|
||||
u8 r1;
|
||||
u8 r4;
|
||||
u32 reg;
|
||||
|
||||
/*
|
||||
* We should never come here because rt2x00lib is supposed
|
||||
* to catch this and send us the correct antenna explicitely.
|
||||
*/
|
||||
BUG_ON(ant->rx == ANTENNA_SW_DIVERSITY ||
|
||||
ant->tx == ANTENNA_SW_DIVERSITY);
|
||||
|
||||
rt2400pci_bbp_read(rt2x00dev, 4, &r4);
|
||||
rt2400pci_bbp_read(rt2x00dev, 1, &r1);
|
||||
|
||||
/*
|
||||
* Configure the TX antenna.
|
||||
*/
|
||||
switch (ant->tx) {
|
||||
case ANTENNA_HW_DIVERSITY:
|
||||
rt2x00_set_field8(&r1, BBP_R1_TX_ANTENNA, 1);
|
||||
break;
|
||||
case ANTENNA_A:
|
||||
rt2x00_set_field8(&r1, BBP_R1_TX_ANTENNA, 0);
|
||||
break;
|
||||
case ANTENNA_B:
|
||||
default:
|
||||
rt2x00_set_field8(&r1, BBP_R1_TX_ANTENNA, 2);
|
||||
break;
|
||||
}
|
||||
|
||||
/*
|
||||
* Configure the RX antenna.
|
||||
*/
|
||||
switch (ant->rx) {
|
||||
case ANTENNA_HW_DIVERSITY:
|
||||
rt2x00_set_field8(&r4, BBP_R4_RX_ANTENNA, 1);
|
||||
break;
|
||||
case ANTENNA_A:
|
||||
rt2x00_set_field8(&r4, BBP_R4_RX_ANTENNA, 0);
|
||||
break;
|
||||
case ANTENNA_B:
|
||||
default:
|
||||
rt2x00_set_field8(&r4, BBP_R4_RX_ANTENNA, 2);
|
||||
break;
|
||||
}
|
||||
|
||||
rt2400pci_bbp_write(rt2x00dev, 4, r4);
|
||||
rt2400pci_bbp_write(rt2x00dev, 1, r1);
|
||||
rt2x00pci_register_read(rt2x00dev, CSR11, ®);
|
||||
rt2x00_set_field32(®, CSR11_LONG_RETRY,
|
||||
libconf->conf->long_frame_max_tx_count);
|
||||
rt2x00_set_field32(®, CSR11_SHORT_RETRY,
|
||||
libconf->conf->short_frame_max_tx_count);
|
||||
rt2x00pci_register_write(rt2x00dev, CSR11, reg);
|
||||
}
|
||||
|
||||
static void rt2400pci_config_duration(struct rt2x00_dev *rt2x00dev,
|
||||
@ -517,20 +540,6 @@ static void rt2400pci_config_duration(struct rt2x00_dev *rt2x00dev,
|
||||
{
|
||||
u32 reg;
|
||||
|
||||
rt2x00pci_register_read(rt2x00dev, CSR11, ®);
|
||||
rt2x00_set_field32(®, CSR11_SLOT_TIME, libconf->slot_time);
|
||||
rt2x00pci_register_write(rt2x00dev, CSR11, reg);
|
||||
|
||||
rt2x00pci_register_read(rt2x00dev, CSR18, ®);
|
||||
rt2x00_set_field32(®, CSR18_SIFS, libconf->sifs);
|
||||
rt2x00_set_field32(®, CSR18_PIFS, libconf->pifs);
|
||||
rt2x00pci_register_write(rt2x00dev, CSR18, reg);
|
||||
|
||||
rt2x00pci_register_read(rt2x00dev, CSR19, ®);
|
||||
rt2x00_set_field32(®, CSR19_DIFS, libconf->difs);
|
||||
rt2x00_set_field32(®, CSR19_EIFS, libconf->eifs);
|
||||
rt2x00pci_register_write(rt2x00dev, CSR19, reg);
|
||||
|
||||
rt2x00pci_register_read(rt2x00dev, TXCSR1, ®);
|
||||
rt2x00_set_field32(®, TXCSR1_TSF_OFFSET, IEEE80211_HEADER);
|
||||
rt2x00_set_field32(®, TXCSR1_AUTORESPONDER, 1);
|
||||
@ -548,16 +557,14 @@ static void rt2400pci_config(struct rt2x00_dev *rt2x00dev,
|
||||
struct rt2x00lib_conf *libconf,
|
||||
const unsigned int flags)
|
||||
{
|
||||
if (flags & CONFIG_UPDATE_PHYMODE)
|
||||
rt2400pci_config_phymode(rt2x00dev, libconf->basic_rates);
|
||||
if (flags & CONFIG_UPDATE_CHANNEL)
|
||||
if (flags & IEEE80211_CONF_CHANGE_CHANNEL)
|
||||
rt2400pci_config_channel(rt2x00dev, &libconf->rf);
|
||||
if (flags & CONFIG_UPDATE_TXPOWER)
|
||||
if (flags & IEEE80211_CONF_CHANGE_POWER)
|
||||
rt2400pci_config_txpower(rt2x00dev,
|
||||
libconf->conf->power_level);
|
||||
if (flags & CONFIG_UPDATE_ANTENNA)
|
||||
rt2400pci_config_antenna(rt2x00dev, &libconf->ant);
|
||||
if (flags & (CONFIG_UPDATE_SLOT_TIME | CONFIG_UPDATE_BEACON_INT))
|
||||
if (flags & IEEE80211_CONF_CHANGE_RETRY_LIMITS)
|
||||
rt2400pci_config_retry_limit(rt2x00dev, libconf);
|
||||
if (flags & IEEE80211_CONF_CHANGE_BEACON_INTERVAL)
|
||||
rt2400pci_config_duration(rt2x00dev, libconf);
|
||||
}
|
||||
|
||||
@ -1502,20 +1509,6 @@ static int rt2400pci_probe_hw(struct rt2x00_dev *rt2x00dev)
|
||||
/*
|
||||
* IEEE80211 stack callback functions.
|
||||
*/
|
||||
static int rt2400pci_set_retry_limit(struct ieee80211_hw *hw,
|
||||
u32 short_retry, u32 long_retry)
|
||||
{
|
||||
struct rt2x00_dev *rt2x00dev = hw->priv;
|
||||
u32 reg;
|
||||
|
||||
rt2x00pci_register_read(rt2x00dev, CSR11, ®);
|
||||
rt2x00_set_field32(®, CSR11_LONG_RETRY, long_retry);
|
||||
rt2x00_set_field32(®, CSR11_SHORT_RETRY, short_retry);
|
||||
rt2x00pci_register_write(rt2x00dev, CSR11, reg);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int rt2400pci_conf_tx(struct ieee80211_hw *hw, u16 queue,
|
||||
const struct ieee80211_tx_queue_params *params)
|
||||
{
|
||||
@ -1601,8 +1594,8 @@ static const struct rt2x00lib_ops rt2400pci_rt2x00_ops = {
|
||||
.config_filter = rt2400pci_config_filter,
|
||||
.config_intf = rt2400pci_config_intf,
|
||||
.config_erp = rt2400pci_config_erp,
|
||||
.config_ant = rt2400pci_config_ant,
|
||||
.config = rt2400pci_config,
|
||||
.set_retry_limit = rt2400pci_set_retry_limit,
|
||||
};
|
||||
|
||||
static const struct data_queue_desc rt2400pci_queue_rx = {
|
||||
|
Reference in New Issue
Block a user