diff options
author | Jouni Malinen <jouni.malinen@atheros.com> | 2008-10-29 19:35:17 +0200 |
---|---|---|
committer | Jouni Malinen <j@w1.fi> | 2008-10-29 19:35:17 +0200 |
commit | fefee8a74d4ce8dbf7ec55e082d0f70c5259ed70 (patch) | |
tree | 65daecefe78c7f0ab4a703b2f6ad891f34aff1c3 | |
parent | 4c99a969e3aefd92e1376e7475b108ca3927db4f (diff) | |
download | external_wpa_supplicant_8_ti-fefee8a74d4ce8dbf7ec55e082d0f70c5259ed70.zip external_wpa_supplicant_8_ti-fefee8a74d4ce8dbf7ec55e082d0f70c5259ed70.tar.gz external_wpa_supplicant_8_ti-fefee8a74d4ce8dbf7ec55e082d0f70c5259ed70.tar.bz2 |
driver_nl80211: Added TX queue parameter configuration
-rw-r--r-- | hostapd/driver_nl80211.c | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/hostapd/driver_nl80211.c b/hostapd/driver_nl80211.c index 7d1d058..87d5837 100644 --- a/hostapd/driver_nl80211.c +++ b/hostapd/driver_nl80211.c @@ -920,7 +920,48 @@ static int i802_set_regulatory_domain(void *priv, unsigned int rd) static int i802_set_tx_queue_params(void *priv, int queue, int aifs, int cw_min, int cw_max, int burst_time) { +#ifdef NL80211_ATTR_WIPHY_TXQ_PARAMS + struct i802_driver_data *drv = priv; + struct nl_msg *msg; + struct nlattr *txq, *params; + + msg = nlmsg_alloc(); + if (!msg) + return -1; + + genlmsg_put(msg, 0, 0, genl_family_get_id(drv->nl80211), 0, + 0, NL80211_CMD_SET_WIPHY, 0); + + NLA_PUT_U32(msg, NL80211_ATTR_IFINDEX, if_nametoindex(drv->iface)); + + txq = nla_nest_start(msg, NL80211_ATTR_WIPHY_TXQ_PARAMS); + if (!txq) + goto nla_put_failure; + + /* We are only sending parameters for a single TXQ at a time */ + params = nla_nest_start(msg, 1); + if (!params) + goto nla_put_failure; + + NLA_PUT_U8(msg, NL80211_TXQ_ATTR_QUEUE, queue); + /* Burst time is configured in units of 0.1 msec and TXOP parameter in + * 32 usec, so need to convert the value here. */ + NLA_PUT_U16(msg, NL80211_TXQ_ATTR_TXOP, (burst_time * 100 + 16) / 32); + NLA_PUT_U16(msg, NL80211_TXQ_ATTR_CWMIN, cw_min); + NLA_PUT_U16(msg, NL80211_TXQ_ATTR_CWMAX, cw_max); + NLA_PUT_U8(msg, NL80211_TXQ_ATTR_AIFS, aifs); + + nla_nest_end(msg, params); + + nla_nest_end(msg, txq); + + if (send_and_recv_msgs(drv, msg, NULL, NULL) == 0) + return 0; + nla_put_failure: + return -1; +#else /* NL80211_ATTR_WIPHY_TXQ_PARAMS */ return -1; +#endif /* NL80211_ATTR_WIPHY_TXQ_PARAMS */ } |