Commit 3195c1f3 authored by Tomas Winkler's avatar Tomas Winkler Committed by John W. Linville

iwlwifi: refactor rxon time command

This patch refactors rxon time command. It removes the usage of union tsf
in favor of u64 value and hopefully makes code more readable.  There are
no functional changes in this patch.
Signed-off-by: default avatarTomas Winkler <tomas.winkler@intel.com>
Signed-off-by: default avatarZhu Yi <yi.zhu@intel.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 5d664a41
...@@ -636,23 +636,22 @@ static void iwl_activate_qos(struct iwl_priv *priv, u8 force) ...@@ -636,23 +636,22 @@ static void iwl_activate_qos(struct iwl_priv *priv, u8 force)
#define MAX_UCODE_BEACON_INTERVAL 4096 #define MAX_UCODE_BEACON_INTERVAL 4096
static __le16 iwl4965_adjust_beacon_interval(u16 beacon_val) static u16 iwl_adjust_beacon_interval(u16 beacon_val)
{ {
u16 new_val = 0; u16 new_val = 0;
u16 beacon_factor = 0; u16 beacon_factor = 0;
beacon_factor = beacon_factor = (beacon_val + MAX_UCODE_BEACON_INTERVAL)
(beacon_val + MAX_UCODE_BEACON_INTERVAL) / MAX_UCODE_BEACON_INTERVAL;
/ MAX_UCODE_BEACON_INTERVAL;
new_val = beacon_val / beacon_factor; new_val = beacon_val / beacon_factor;
return cpu_to_le16(new_val); return new_val;
} }
static void iwl4965_setup_rxon_timing(struct iwl_priv *priv) static void iwl_setup_rxon_timing(struct iwl_priv *priv)
{ {
u64 interval_tm_unit; u64 tsf;
u64 tsf, result; s32 interval_tm, rem;
unsigned long flags; unsigned long flags;
struct ieee80211_conf *conf = NULL; struct ieee80211_conf *conf = NULL;
u16 beacon_int = 0; u16 beacon_int = 0;
...@@ -660,49 +659,32 @@ static void iwl4965_setup_rxon_timing(struct iwl_priv *priv) ...@@ -660,49 +659,32 @@ static void iwl4965_setup_rxon_timing(struct iwl_priv *priv)
conf = ieee80211_get_hw_conf(priv->hw); conf = ieee80211_get_hw_conf(priv->hw);
spin_lock_irqsave(&priv->lock, flags); spin_lock_irqsave(&priv->lock, flags);
priv->rxon_timing.timestamp.dw[1] = cpu_to_le32(priv->timestamp >> 32); priv->rxon_timing.timestamp = cpu_to_le64(priv->timestamp);
priv->rxon_timing.timestamp.dw[0] =
cpu_to_le32(priv->timestamp & 0xFFFFFFFF);
priv->rxon_timing.listen_interval = cpu_to_le16(conf->listen_interval); priv->rxon_timing.listen_interval = cpu_to_le16(conf->listen_interval);
tsf = priv->timestamp;
beacon_int = priv->beacon_int;
spin_unlock_irqrestore(&priv->lock, flags);
if (priv->iw_mode == NL80211_IFTYPE_STATION) { if (priv->iw_mode == NL80211_IFTYPE_STATION) {
if (beacon_int == 0) { beacon_int = iwl_adjust_beacon_interval(priv->beacon_int);
priv->rxon_timing.beacon_interval = cpu_to_le16(100);
priv->rxon_timing.beacon_init_val = cpu_to_le32(102400);
} else {
priv->rxon_timing.beacon_interval =
cpu_to_le16(beacon_int);
priv->rxon_timing.beacon_interval =
iwl4965_adjust_beacon_interval(
le16_to_cpu(priv->rxon_timing.beacon_interval));
}
priv->rxon_timing.atim_window = 0; priv->rxon_timing.atim_window = 0;
} else { } else {
priv->rxon_timing.beacon_interval = beacon_int = iwl_adjust_beacon_interval(conf->beacon_int);
iwl4965_adjust_beacon_interval(conf->beacon_int);
/* TODO: we need to get atim_window from upper stack /* TODO: we need to get atim_window from upper stack
* for now we set to 0 */ * for now we set to 0 */
priv->rxon_timing.atim_window = 0; priv->rxon_timing.atim_window = 0;
} }
interval_tm_unit = priv->rxon_timing.beacon_interval = cpu_to_le16(beacon_int);
(le16_to_cpu(priv->rxon_timing.beacon_interval) * 1024);
result = do_div(tsf, interval_tm_unit);
priv->rxon_timing.beacon_init_val =
cpu_to_le32((u32) ((u64) interval_tm_unit - result));
IWL_DEBUG_ASSOC tsf = priv->timestamp; /* tsf is modifed by do_div: copy it */
("beacon interval %d beacon timer %d beacon tim %d\n", interval_tm = beacon_int * 1024;
le16_to_cpu(priv->rxon_timing.beacon_interval), rem = do_div(tsf, interval_tm);
le32_to_cpu(priv->rxon_timing.beacon_init_val), priv->rxon_timing.beacon_init_val = cpu_to_le32(interval_tm - rem);
le16_to_cpu(priv->rxon_timing.atim_window));
spin_unlock_irqrestore(&priv->lock, flags);
IWL_DEBUG_ASSOC("beacon interval %d beacon timer %d beacon tim %d\n",
le16_to_cpu(priv->rxon_timing.beacon_interval),
le32_to_cpu(priv->rxon_timing.beacon_init_val),
le16_to_cpu(priv->rxon_timing.atim_window));
} }
static void iwl_set_flags_for_band(struct iwl_priv *priv, static void iwl_set_flags_for_band(struct iwl_priv *priv,
...@@ -2488,8 +2470,7 @@ static void iwl4965_post_associate(struct iwl_priv *priv) ...@@ -2488,8 +2470,7 @@ static void iwl4965_post_associate(struct iwl_priv *priv)
priv->staging_rxon.filter_flags &= ~RXON_FILTER_ASSOC_MSK; priv->staging_rxon.filter_flags &= ~RXON_FILTER_ASSOC_MSK;
iwl4965_commit_rxon(priv); iwl4965_commit_rxon(priv);
memset(&priv->rxon_timing, 0, sizeof(struct iwl4965_rxon_time_cmd)); iwl_setup_rxon_timing(priv);
iwl4965_setup_rxon_timing(priv);
ret = iwl_send_cmd_pdu(priv, REPLY_RXON_TIMING, ret = iwl_send_cmd_pdu(priv, REPLY_RXON_TIMING,
sizeof(priv->rxon_timing), &priv->rxon_timing); sizeof(priv->rxon_timing), &priv->rxon_timing);
if (ret) if (ret)
...@@ -2879,15 +2860,14 @@ static void iwl4965_config_ap(struct iwl_priv *priv) ...@@ -2879,15 +2860,14 @@ static void iwl4965_config_ap(struct iwl_priv *priv)
return; return;
/* The following should be done only at AP bring up */ /* The following should be done only at AP bring up */
if (!(iwl_is_associated(priv))) { if (!iwl_is_associated(priv)) {
/* RXON - unassoc (to set timing command) */ /* RXON - unassoc (to set timing command) */
priv->staging_rxon.filter_flags &= ~RXON_FILTER_ASSOC_MSK; priv->staging_rxon.filter_flags &= ~RXON_FILTER_ASSOC_MSK;
iwl4965_commit_rxon(priv); iwl4965_commit_rxon(priv);
/* RXON Timing */ /* RXON Timing */
memset(&priv->rxon_timing, 0, sizeof(struct iwl4965_rxon_time_cmd)); iwl_setup_rxon_timing(priv);
iwl4965_setup_rxon_timing(priv);
ret = iwl_send_cmd_pdu(priv, REPLY_RXON_TIMING, ret = iwl_send_cmd_pdu(priv, REPLY_RXON_TIMING,
sizeof(priv->rxon_timing), &priv->rxon_timing); sizeof(priv->rxon_timing), &priv->rxon_timing);
if (ret) if (ret)
......
...@@ -482,11 +482,6 @@ struct iwl_alive_resp { ...@@ -482,11 +482,6 @@ struct iwl_alive_resp {
} __attribute__ ((packed)); } __attribute__ ((packed));
union tsf {
u8 byte[8];
__le16 word[4];
__le32 dw[2];
};
/* /*
* REPLY_ERROR = 0x2 (response only, not a command) * REPLY_ERROR = 0x2 (response only, not a command)
...@@ -497,7 +492,7 @@ struct iwl_error_resp { ...@@ -497,7 +492,7 @@ struct iwl_error_resp {
u8 reserved1; u8 reserved1;
__le16 bad_cmd_seq_num; __le16 bad_cmd_seq_num;
__le32 error_info; __le32 error_info;
union tsf timestamp; __le64 timestamp;
} __attribute__ ((packed)); } __attribute__ ((packed));
/****************************************************************************** /******************************************************************************
...@@ -684,8 +679,8 @@ struct iwl4965_rxon_assoc_cmd { ...@@ -684,8 +679,8 @@ struct iwl4965_rxon_assoc_cmd {
/* /*
* REPLY_RXON_TIMING = 0x14 (command, has simple generic response) * REPLY_RXON_TIMING = 0x14 (command, has simple generic response)
*/ */
struct iwl4965_rxon_time_cmd { struct iwl_rxon_time_cmd {
union tsf timestamp; __le64 timestamp;
__le16 beacon_interval; __le16 beacon_interval;
__le16 atim_window; __le16 atim_window;
__le32 beacon_init_val; __le32 beacon_init_val;
......
...@@ -275,7 +275,6 @@ struct iwl_cmd { ...@@ -275,7 +275,6 @@ struct iwl_cmd {
u16 val16; u16 val16;
u32 val32; u32 val32;
struct iwl4965_bt_cmd bt; struct iwl4965_bt_cmd bt;
struct iwl4965_rxon_time_cmd rxon_time;
struct iwl_powertable_cmd powertable; struct iwl_powertable_cmd powertable;
struct iwl_qosparam_cmd qosparam; struct iwl_qosparam_cmd qosparam;
struct iwl_tx_cmd tx; struct iwl_tx_cmd tx;
...@@ -851,7 +850,7 @@ struct iwl_priv { ...@@ -851,7 +850,7 @@ struct iwl_priv {
u8 ucode_write_complete; /* the image write is complete */ u8 ucode_write_complete; /* the image write is complete */
struct iwl4965_rxon_time_cmd rxon_timing; struct iwl_rxon_time_cmd rxon_timing;
/* We declare this const so it can only be /* We declare this const so it can only be
* changed via explicit cast within the * changed via explicit cast within the
......
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