aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEliad Peller <eliad@wizery.com>2011-06-23 19:24:54 +0300
committerKeith Deacon <kdeacon@ti.com>2011-11-15 20:45:51 -0600
commit875aac6b8af0f696482fdf5cc4db3bb792e0e8b1 (patch)
tree99463dfb910c9941cda4010b39178b3794590d94
parentb061cc23fbd36b2f7d708e95471a90e4aefbded4 (diff)
downloadandroid_external_wpa_supplicant_8-875aac6b8af0f696482fdf5cc4db3bb792e0e8b1.tar.gz
android_external_wpa_supplicant_8-875aac6b8af0f696482fdf5cc4db3bb792e0e8b1.tar.bz2
android_external_wpa_supplicant_8-875aac6b8af0f696482fdf5cc4db3bb792e0e8b1.zip
nl80211: send uapsd_queues and max_sp values on sta additon
When a new station is added, send its configured WME params. Change-Id: I6f0ea3029131533f6a9430ae9fd853cb854d949d Signed-off-by: Eliad Peller <eliad@wizery.com> Signed-off-by: Vishal Mahaveer <a0271468@ti.com>
-rw-r--r--src/drivers/driver_nl80211.c16
1 files changed, 15 insertions, 1 deletions
diff --git a/src/drivers/driver_nl80211.c b/src/drivers/driver_nl80211.c
index 58cfaf37..1da1fd4a 100644
--- a/src/drivers/driver_nl80211.c
+++ b/src/drivers/driver_nl80211.c
@@ -3958,7 +3958,7 @@ static int wpa_driver_nl80211_sta_add(void *priv,
{
struct i802_bss *bss = priv;
struct wpa_driver_nl80211_data *drv = bss->drv;
- struct nl_msg *msg;
+ struct nl_msg *msg, *wme = NULL;
struct nl80211_sta_flag_update upd;
int ret = -ENOBUFS;
@@ -3987,13 +3987,27 @@ static int wpa_driver_nl80211_sta_add(void *priv,
upd.set = upd.mask;
NLA_PUT(msg, NL80211_ATTR_STA_FLAGS2, sizeof(upd), &upd);
+ wme = nlmsg_alloc();
+ if (!wme)
+ goto nla_put_failure;
+
+ NLA_PUT_U8(wme, NL80211_STA_WME_UAPSD_QUEUES, params->uapsd_queues);
+ NLA_PUT_U8(wme, NL80211_STA_WME_MAX_SP, params->max_sp);
+ nla_put_nested(msg, NL80211_ATTR_STA_WME, wme);
+
+ nlmsg_free(wme);
+
ret = send_and_recv_msgs(drv, msg, NULL, NULL);
if (ret)
wpa_printf(MSG_DEBUG, "nl80211: NL80211_CMD_NEW_STATION "
"result: %d (%s)", ret, strerror(-ret));
if (ret == -EEXIST)
ret = 0;
+
+ return ret;
nla_put_failure:
+ if (wme)
+ nlmsg_free(wme);
return ret;
}