Commit 88f07e70 authored by Maxim Altshul's avatar Maxim Altshul Committed by Kalle Valo

wlcore/wl18xx: Add functionality to accept TX rate per link

FW will provide a TX rate per link for each FW status,
and wlcore will be able to store the information for
the use of the mesh hwmp module.

This is used mainly in mesh.
Rates are reported when a mesh interface is up.
Signed-off-by: default avatarMaxim Altshul <maxim.altshul@ti.com>
Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
parent c940de10
...@@ -1214,6 +1214,10 @@ static void wl18xx_convert_fw_status(struct wl1271 *wl, void *raw_fw_status, ...@@ -1214,6 +1214,10 @@ static void wl18xx_convert_fw_status(struct wl1271 *wl, void *raw_fw_status,
int_fw_status->counters.tx_voice_released_blks; int_fw_status->counters.tx_voice_released_blks;
fw_status->counters.tx_last_rate = fw_status->counters.tx_last_rate =
int_fw_status->counters.tx_last_rate; int_fw_status->counters.tx_last_rate;
fw_status->counters.tx_last_rate_mbps =
int_fw_status->counters.tx_last_rate_mbps;
fw_status->counters.hlid =
int_fw_status->counters.hlid;
fw_status->log_start_addr = le32_to_cpu(int_fw_status->log_start_addr); fw_status->log_start_addr = le32_to_cpu(int_fw_status->log_start_addr);
......
...@@ -30,9 +30,9 @@ ...@@ -30,9 +30,9 @@
static static
void wl18xx_get_last_tx_rate(struct wl1271 *wl, struct ieee80211_vif *vif, void wl18xx_get_last_tx_rate(struct wl1271 *wl, struct ieee80211_vif *vif,
u8 band, struct ieee80211_tx_rate *rate) u8 band, struct ieee80211_tx_rate *rate, u8 hlid)
{ {
u8 fw_rate = wl->fw_status->counters.tx_last_rate; u8 fw_rate = wl->links[hlid].fw_rate_idx;
if (fw_rate > CONF_HW_RATE_INDEX_MAX) { if (fw_rate > CONF_HW_RATE_INDEX_MAX) {
wl1271_error("last Tx rate invalid: %d", fw_rate); wl1271_error("last Tx rate invalid: %d", fw_rate);
...@@ -79,6 +79,7 @@ static void wl18xx_tx_complete_packet(struct wl1271 *wl, u8 tx_stat_byte) ...@@ -79,6 +79,7 @@ static void wl18xx_tx_complete_packet(struct wl1271 *wl, u8 tx_stat_byte)
struct sk_buff *skb; struct sk_buff *skb;
int id = tx_stat_byte & WL18XX_TX_STATUS_DESC_ID_MASK; int id = tx_stat_byte & WL18XX_TX_STATUS_DESC_ID_MASK;
bool tx_success; bool tx_success;
struct wl1271_tx_hw_descr *tx_desc;
/* check for id legality */ /* check for id legality */
if (unlikely(id >= wl->num_tx_desc || wl->tx_frames[id] == NULL)) { if (unlikely(id >= wl->num_tx_desc || wl->tx_frames[id] == NULL)) {
...@@ -91,6 +92,7 @@ static void wl18xx_tx_complete_packet(struct wl1271 *wl, u8 tx_stat_byte) ...@@ -91,6 +92,7 @@ static void wl18xx_tx_complete_packet(struct wl1271 *wl, u8 tx_stat_byte)
skb = wl->tx_frames[id]; skb = wl->tx_frames[id];
info = IEEE80211_SKB_CB(skb); info = IEEE80211_SKB_CB(skb);
tx_desc = (struct wl1271_tx_hw_descr *)skb->data;
if (wl12xx_is_dummy_packet(wl, skb)) { if (wl12xx_is_dummy_packet(wl, skb)) {
wl1271_free_tx_id(wl, id); wl1271_free_tx_id(wl, id);
...@@ -105,7 +107,9 @@ static void wl18xx_tx_complete_packet(struct wl1271 *wl, u8 tx_stat_byte) ...@@ -105,7 +107,9 @@ static void wl18xx_tx_complete_packet(struct wl1271 *wl, u8 tx_stat_byte)
* the info->status structures * the info->status structures
*/ */
wl18xx_get_last_tx_rate(wl, info->control.vif, wl18xx_get_last_tx_rate(wl, info->control.vif,
info->band, &info->status.rates[0]); info->band,
&info->status.rates[0],
tx_desc->hlid);
info->status.rates[0].count = 1; /* no data about retries */ info->status.rates[0].count = 1; /* no data about retries */
info->status.ack_signal = -1; info->status.ack_signal = -1;
...@@ -144,12 +148,22 @@ void wl18xx_tx_immediate_complete(struct wl1271 *wl) ...@@ -144,12 +148,22 @@ void wl18xx_tx_immediate_complete(struct wl1271 *wl)
struct wl18xx_fw_status_priv *status_priv = struct wl18xx_fw_status_priv *status_priv =
(struct wl18xx_fw_status_priv *)wl->fw_status->priv; (struct wl18xx_fw_status_priv *)wl->fw_status->priv;
struct wl18xx_priv *priv = wl->priv; struct wl18xx_priv *priv = wl->priv;
u8 i; u8 i, hlid;
/* nothing to do here */ /* nothing to do here */
if (priv->last_fw_rls_idx == status_priv->fw_release_idx) if (priv->last_fw_rls_idx == status_priv->fw_release_idx)
return; return;
/* update rates per link */
hlid = wl->fw_status->counters.hlid;
if (hlid < WLCORE_MAX_LINKS) {
wl->links[hlid].fw_rate_idx =
wl->fw_status->counters.tx_last_rate;
wl->links[hlid].fw_rate_mbps =
wl->fw_status->counters.tx_last_rate_mbps;
}
/* freed Tx descriptors */ /* freed Tx descriptors */
wl1271_debug(DEBUG_TX, "last released desc = %d, current idx = %d", wl1271_debug(DEBUG_TX, "last released desc = %d, current idx = %d",
priv->last_fw_rls_idx, status_priv->fw_release_idx); priv->last_fw_rls_idx, status_priv->fw_release_idx);
......
...@@ -125,7 +125,11 @@ struct wl18xx_fw_packet_counters { ...@@ -125,7 +125,11 @@ struct wl18xx_fw_packet_counters {
/* Tx rate of the last transmitted packet */ /* Tx rate of the last transmitted packet */
u8 tx_last_rate; u8 tx_last_rate;
u8 padding[2]; /* Tx rate or Tx rate estimate pre-calculated by fw in mbps units */
u8 tx_last_rate_mbps;
/* hlid for which the rates were reported */
u8 hlid;
} __packed; } __packed;
/* FW status registers */ /* FW status registers */
......
...@@ -4986,6 +4986,7 @@ static int wl12xx_sta_add(struct wl1271 *wl, ...@@ -4986,6 +4986,7 @@ static int wl12xx_sta_add(struct wl1271 *wl,
return ret; return ret;
wl_sta = (struct wl1271_station *)sta->drv_priv; wl_sta = (struct wl1271_station *)sta->drv_priv;
wl_sta->wl = wl;
hlid = wl_sta->hlid; hlid = wl_sta->hlid;
ret = wl12xx_cmd_add_peer(wl, wlvif, sta, hlid); ret = wl12xx_cmd_add_peer(wl, wlvif, sta, hlid);
......
...@@ -222,6 +222,13 @@ int wlcore_rx(struct wl1271 *wl, struct wl_fw_status *status) ...@@ -222,6 +222,13 @@ int wlcore_rx(struct wl1271 *wl, struct wl_fw_status *status)
enum wl_rx_buf_align rx_align; enum wl_rx_buf_align rx_align;
int ret = 0; int ret = 0;
/* update rates per link */
hlid = status->counters.hlid;
if (hlid < WLCORE_MAX_LINKS)
wl->links[hlid].fw_rate_mbps =
status->counters.tx_last_rate_mbps;
while (drv_rx_counter != fw_rx_counter) { while (drv_rx_counter != fw_rx_counter) {
buf_size = 0; buf_size = 0;
rx_counter = drv_rx_counter; rx_counter = drv_rx_counter;
......
...@@ -171,6 +171,12 @@ struct wl_fw_status { ...@@ -171,6 +171,12 @@ struct wl_fw_status {
/* Tx rate of the last transmitted packet */ /* Tx rate of the last transmitted packet */
u8 tx_last_rate; u8 tx_last_rate;
/* Tx rate or Tx rate estimate pre calculated by fw in mbps */
u8 tx_last_rate_mbps;
/* hlid for which the rates were reported */
u8 hlid;
} counters; } counters;
u32 log_start_addr; u32 log_start_addr;
...@@ -273,6 +279,12 @@ struct wl1271_link { ...@@ -273,6 +279,12 @@ struct wl1271_link {
/* bitmap of TIDs where RX BA sessions are active for this link */ /* bitmap of TIDs where RX BA sessions are active for this link */
u8 ba_bitmap; u8 ba_bitmap;
/* the last fw rate index we used for this link */
u8 fw_rate_idx;
/* the last fw rate [Mbps] we used for this link */
u8 fw_rate_mbps;
/* The wlvif this link belongs to. Might be null for global links */ /* The wlvif this link belongs to. Might be null for global links */
struct wl12xx_vif *wlvif; struct wl12xx_vif *wlvif;
...@@ -335,6 +347,7 @@ struct wl1271_station { ...@@ -335,6 +347,7 @@ struct wl1271_station {
* Used in both AP and STA mode. * Used in both AP and STA mode.
*/ */
u64 total_freed_pkts; u64 total_freed_pkts;
struct wl1271 *wl;
}; };
struct wl12xx_vif { struct wl12xx_vif {
......
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