Return-path: Received: from plane.gmane.org ([80.91.229.3]:35052 "EHLO plane.gmane.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751429AbaA3LUq (ORCPT ); Thu, 30 Jan 2014 06:20:46 -0500 Received: from list by plane.gmane.org with local (Exim 4.69) (envelope-from ) id 1W8pfp-0002Ih-2z for linux-wireless@vger.kernel.org; Thu, 30 Jan 2014 12:20:45 +0100 Received: from gw.alumnux.com ([121.243.14.254]) by main.gmane.org with esmtp (Gmexim 0.1 (Debian)) id 1AlnuQ-0007hv-00 for ; Thu, 30 Jan 2014 12:20:45 +0100 Received: from royujjal by gw.alumnux.com with local (Gmexim 0.1 (Debian)) id 1AlnuQ-0007hv-00 for ; Thu, 30 Jan 2014 12:20:45 +0100 To: linux-wireless@vger.kernel.org From: Ujjal Roy Subject: Re: [PATCHv2] iw: add support to set/get retry limit Date: Thu, 30 Jan 2014 11:20:16 +0000 (UTC) Message-ID: (sfid-20140130_122058_619761_834D4AB4) References: <1389273736-9486-1-git-send-email-royujjal@gmail.com> (sfid-20140109_142238_521185_44E25359) <1390575602.4257.44.camel@jlt4.sipsolutions.net> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Sender: linux-wireless-owner@vger.kernel.org List-ID: Johannes Berg writes: > > +COMMAND(set, retry, " []", > > + NL80211_CMD_SET_WIPHY, 0, CIB_PHY, handle_retry, > > + "Set retry limit."); > > This seems odd to me, why would you want to allow setting the short > limit while not changing the long one, but not the other way around? Sorry for late response and thanks for the suggestion. The modified patch is below after 3 dashes. --- Show the retry limit in phy details and also configure the retry limit. Signed-off-by: Ujjal Roy --- info.c | 16 ++++++++++++++++ phy.c | 64 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 80 insertions(+) diff --git a/info.c b/info.c index a696503..001b317 100644 --- a/info.c +++ b/info.c @@ -246,6 +246,22 @@ next: printf("\tRTS threshold: %d\n", rts); } + if (tb_msg[NL80211_ATTR_WIPHY_RETRY_SHORT] || + tb_msg[NL80211_ATTR_WIPHY_RETRY_LONG]) { + unsigned char retry_short = 0, retry_long = 0; + + if (tb_msg[NL80211_ATTR_WIPHY_RETRY_SHORT]) + retry_short = nla_get_u8(tb_msg[NL80211_ATTR_WIPHY_RETRY_SHORT]); + if (tb_msg[NL80211_ATTR_WIPHY_RETRY_LONG]) + retry_long = nla_get_u8(tb_msg[NL80211_ATTR_WIPHY_RETRY_LONG]); + if (retry_short == retry_long) { + printf("\tRetry short long limit: %d\n", retry_short); + } else { + printf("\tRetry short limit: %d\n", retry_short); + printf("\tRetry long limit: %d\n", retry_long); + } + } + if (tb_msg[NL80211_ATTR_WIPHY_COVERAGE_CLASS]) { unsigned char coverage; diff --git a/phy.c b/phy.c index 68f40f6..517d203 100644 --- a/phy.c +++ b/phy.c @@ -232,6 +232,70 @@ COMMAND(set, rts, "", NL80211_CMD_SET_WIPHY, 0, CIB_PHY, handle_rts, "Set rts threshold."); +static int handle_retry(struct nl80211_state *state, + struct nl_cb *cb, struct nl_msg *msg, + int argc, char **argv, enum id_input id) +{ + unsigned int retry_short = 0, retry_long = 0; + bool have_retry_s = false, have_retry_l = false; + int i; + enum { + S_NONE, + S_SHORT, + S_LONG, + } parser_state = S_NONE; + + if (!argc || (argc != 2 && argc != 4)) + return 1; + + for (i = 0; i < argc; i++) { + char *end; + unsigned int tmpul; + + if (strcmp(argv[i], "short") == 0) { + if (have_retry_s) + return 1; + parser_state = S_SHORT; + have_retry_s = true; + } else if (strcmp(argv[i], "long") == 0) { + if (have_retry_l) + return 1; + parser_state = S_LONG; + have_retry_l = true; + } else { + tmpul = strtoul(argv[i], &end, 10); + if (*end != '\0') + return 1; + if (!tmpul || tmpul > 255) + return -EINVAL; + switch (parser_state) { + case S_SHORT: + retry_short = tmpul; + break; + case S_LONG: + retry_long = tmpul; + break; + default: + return 1; + } + } + } + + if (!have_retry_s && !have_retry_l) + return 1; + if (have_retry_s) + NLA_PUT_U8(msg, NL80211_ATTR_WIPHY_RETRY_SHORT, retry_short); + if (have_retry_l) + NLA_PUT_U8(msg, NL80211_ATTR_WIPHY_RETRY_LONG, retry_long); + + return 0; + nla_put_failure: + return -ENOBUFS; +} +COMMAND(set, retry, "[short ] [long ]", + NL80211_CMD_SET_WIPHY, 0, CIB_PHY, handle_retry, + "Set retry limit."); + static int handle_netns(struct nl80211_state *state, struct nl_cb *cb, struct nl_msg *msg, -- 1.8.1.4