diff options
author | John W. Linville <linville@tuxdriver.com> | 2011-03-15 14:16:48 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2011-03-15 14:16:48 -0400 |
commit | 106af2c99a5249b809aaed45b8353ac087821f4a (patch) | |
tree | b9d13cc35cfdc3b763408287b4e50daf32fda53b /net/wireless | |
parent | 0c0217b016ba8a970a6f6ab62ad0d858f39881ca (diff) | |
parent | 7d2c16befae67b901e6750b845661c1fdffd19f1 (diff) |
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-next-2.6 into for-davem
Diffstat (limited to 'net/wireless')
-rw-r--r-- | net/wireless/ethtool.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/net/wireless/ethtool.c b/net/wireless/ethtool.c index ca4c825be93d..9bde4d1d3e9b 100644 --- a/net/wireless/ethtool.c +++ b/net/wireless/ethtool.c | |||
@@ -1,5 +1,6 @@ | |||
1 | #include <linux/utsname.h> | 1 | #include <linux/utsname.h> |
2 | #include <net/cfg80211.h> | 2 | #include <net/cfg80211.h> |
3 | #include "core.h" | ||
3 | #include "ethtool.h" | 4 | #include "ethtool.h" |
4 | 5 | ||
5 | static void cfg80211_get_drvinfo(struct net_device *dev, | 6 | static void cfg80211_get_drvinfo(struct net_device *dev, |
@@ -37,9 +38,41 @@ static void cfg80211_get_regs(struct net_device *dev, struct ethtool_regs *regs, | |||
37 | regs->len = 0; | 38 | regs->len = 0; |
38 | } | 39 | } |
39 | 40 | ||
41 | static void cfg80211_get_ringparam(struct net_device *dev, | ||
42 | struct ethtool_ringparam *rp) | ||
43 | { | ||
44 | struct wireless_dev *wdev = dev->ieee80211_ptr; | ||
45 | struct cfg80211_registered_device *rdev = wiphy_to_dev(wdev->wiphy); | ||
46 | |||
47 | memset(rp, 0, sizeof(*rp)); | ||
48 | |||
49 | if (rdev->ops->get_ringparam) | ||
50 | rdev->ops->get_ringparam(wdev->wiphy, | ||
51 | &rp->tx_pending, &rp->tx_max_pending, | ||
52 | &rp->rx_pending, &rp->rx_max_pending); | ||
53 | } | ||
54 | |||
55 | static int cfg80211_set_ringparam(struct net_device *dev, | ||
56 | struct ethtool_ringparam *rp) | ||
57 | { | ||
58 | struct wireless_dev *wdev = dev->ieee80211_ptr; | ||
59 | struct cfg80211_registered_device *rdev = wiphy_to_dev(wdev->wiphy); | ||
60 | |||
61 | if (rp->rx_mini_pending != 0 || rp->rx_jumbo_pending != 0) | ||
62 | return -EINVAL; | ||
63 | |||
64 | if (rdev->ops->set_ringparam) | ||
65 | return rdev->ops->set_ringparam(wdev->wiphy, | ||
66 | rp->tx_pending, rp->rx_pending); | ||
67 | |||
68 | return -ENOTSUPP; | ||
69 | } | ||
70 | |||
40 | const struct ethtool_ops cfg80211_ethtool_ops = { | 71 | const struct ethtool_ops cfg80211_ethtool_ops = { |
41 | .get_drvinfo = cfg80211_get_drvinfo, | 72 | .get_drvinfo = cfg80211_get_drvinfo, |
42 | .get_regs_len = cfg80211_get_regs_len, | 73 | .get_regs_len = cfg80211_get_regs_len, |
43 | .get_regs = cfg80211_get_regs, | 74 | .get_regs = cfg80211_get_regs, |
44 | .get_link = ethtool_op_get_link, | 75 | .get_link = ethtool_op_get_link, |
76 | .get_ringparam = cfg80211_get_ringparam, | ||
77 | .set_ringparam = cfg80211_set_ringparam, | ||
45 | }; | 78 | }; |