[RFCv2,4/6] mac80211: minstrel - implement get_expected_throughput() API
Commit Message
From: Antonio Quartulli <antonio@open-mesh.com>
Cc: Felix Fietkau <nbd@openwrt.org>
Signed-off-by: Antonio Quartulli <antonio@open-mesh.com>
---
net/mac80211/rc80211_minstrel.c | 15 +++++++++++++++
1 file changed, 15 insertions(+)
Comments
On 30/03/14 22:35, Antonio Quartulli wrote:
> +static u32
> +minstrel_get_expected_throughput(void *priv, void *priv_sta,
> + struct ieee80211_supported_band *sband)
> +{
> + struct minstrel_sta_info *mi = priv_sta;
> + int idx = mi->max_tp_rate[0];
> + u32 bitrate, ret;
> +
> + bitrate = sband->bitrates[mi->r[idx].rix].bitrate;
> + ret = bitrate * MINSTREL_TRUNC(mi->r[idx].probability * 1000) / 1000;
Thanks to the point raised by Andrew Lunn I just realised that this
value is expressed in Mbps/10 and so should be converted to Mbps/100
before being returned (assuming we agree on using this unit).
Cheers,
On Sun, 2014-03-30 at 22:35 +0200, Antonio Quartulli wrote:
> +static u32
> +minstrel_get_expected_throughput(void *priv, void *priv_sta,
> + struct ieee80211_supported_band *sband)
> +{
> + struct minstrel_sta_info *mi = priv_sta;
> + int idx = mi->max_tp_rate[0];
> + u32 bitrate, ret;
> +
> + bitrate = sband->bitrates[mi->r[idx].rix].bitrate;
> + ret = bitrate * MINSTREL_TRUNC(mi->r[idx].probability * 1000) / 1000;
> +
> + return ret;
You don't need a ret variable.
johannes
On 08/04/14 12:05, Johannes Berg wrote:
> On Sun, 2014-03-30 at 22:35 +0200, Antonio Quartulli wrote:
>
>> +static u32
>> +minstrel_get_expected_throughput(void *priv, void *priv_sta,
>> + struct ieee80211_supported_band *sband)
>> +{
>> + struct minstrel_sta_info *mi = priv_sta;
>> + int idx = mi->max_tp_rate[0];
>> + u32 bitrate, ret;
>> +
>> + bitrate = sband->bitrates[mi->r[idx].rix].bitrate;
>> + ret = bitrate * MINSTREL_TRUNC(mi->r[idx].probability * 1000) / 1000;
>> +
>> + return ret;
>
> You don't need a ret variable.
True.
thanks!
@@ -657,6 +657,20 @@ minstrel_free(void *priv)
kfree(priv);
}
+static u32
+minstrel_get_expected_throughput(void *priv, void *priv_sta,
+ struct ieee80211_supported_band *sband)
+{
+ struct minstrel_sta_info *mi = priv_sta;
+ int idx = mi->max_tp_rate[0];
+ u32 bitrate, ret;
+
+ bitrate = sband->bitrates[mi->r[idx].rix].bitrate;
+ ret = bitrate * MINSTREL_TRUNC(mi->r[idx].probability * 1000) / 1000;
+
+ return ret;
+}
+
const struct rate_control_ops mac80211_minstrel = {
.name = "minstrel",
.tx_status = minstrel_tx_status,
@@ -670,6 +684,7 @@ const struct rate_control_ops mac80211_minstrel = {
.add_sta_debugfs = minstrel_add_sta_debugfs,
.remove_sta_debugfs = minstrel_remove_sta_debugfs,
#endif
+ .get_expected_throughput = minstrel_get_expected_throughput,
};
int __init