Commit e31a54c5 authored by Stanislav Yakovlev's avatar Stanislav Yakovlev Committed by Ben Hutchings

net/wireless: ipw2x00: add supported cipher suites to wiphy initialization

commit a141e6a0 upstream.

Driver doesn't report its supported cipher suites through cfg80211
interface. It still uses wext interface and probably will not work
through nl80211, but will at least correctly advertise supported
features.

Bug was reported by Omar Siam.
https://bugzilla.kernel.org/show_bug.cgi?id=43049Signed-off-by: default avatarStanislav Yakovlev <stas.yakovlev@gmail.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent e6a46daa
/*
* Intel Pro/Wireless 2100, 2200BG, 2915ABG network connection driver
*
* Copyright 2012 Stanislav Yakovlev <stas.yakovlev@gmail.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
#ifndef __IPW_H__
#define __IPW_H__
#include <linux/ieee80211.h>
static const u32 ipw_cipher_suites[] = {
WLAN_CIPHER_SUITE_WEP40,
WLAN_CIPHER_SUITE_WEP104,
WLAN_CIPHER_SUITE_TKIP,
WLAN_CIPHER_SUITE_CCMP,
};
#endif
...@@ -166,6 +166,7 @@ that only one external action is invoked at a time. ...@@ -166,6 +166,7 @@ that only one external action is invoked at a time.
#include <net/lib80211.h> #include <net/lib80211.h>
#include "ipw2100.h" #include "ipw2100.h"
#include "ipw.h"
#define IPW2100_VERSION "git-1.2.2" #define IPW2100_VERSION "git-1.2.2"
...@@ -1955,6 +1956,9 @@ static int ipw2100_wdev_init(struct net_device *dev) ...@@ -1955,6 +1956,9 @@ static int ipw2100_wdev_init(struct net_device *dev)
wdev->wiphy->bands[IEEE80211_BAND_2GHZ] = bg_band; wdev->wiphy->bands[IEEE80211_BAND_2GHZ] = bg_band;
} }
wdev->wiphy->cipher_suites = ipw_cipher_suites;
wdev->wiphy->n_cipher_suites = ARRAY_SIZE(ipw_cipher_suites);
set_wiphy_dev(wdev->wiphy, &priv->pci_dev->dev); set_wiphy_dev(wdev->wiphy, &priv->pci_dev->dev);
if (wiphy_register(wdev->wiphy)) { if (wiphy_register(wdev->wiphy)) {
ipw2100_down(priv); ipw2100_down(priv);
......
...@@ -34,6 +34,7 @@ ...@@ -34,6 +34,7 @@
#include <linux/slab.h> #include <linux/slab.h>
#include <net/cfg80211-wext.h> #include <net/cfg80211-wext.h>
#include "ipw2200.h" #include "ipw2200.h"
#include "ipw.h"
#ifndef KBUILD_EXTMOD #ifndef KBUILD_EXTMOD
...@@ -11535,6 +11536,9 @@ static int ipw_wdev_init(struct net_device *dev) ...@@ -11535,6 +11536,9 @@ static int ipw_wdev_init(struct net_device *dev)
wdev->wiphy->bands[IEEE80211_BAND_5GHZ] = a_band; wdev->wiphy->bands[IEEE80211_BAND_5GHZ] = a_band;
} }
wdev->wiphy->cipher_suites = ipw_cipher_suites;
wdev->wiphy->n_cipher_suites = ARRAY_SIZE(ipw_cipher_suites);
set_wiphy_dev(wdev->wiphy, &priv->pci_dev->dev); set_wiphy_dev(wdev->wiphy, &priv->pci_dev->dev);
/* With that information in place, we can now register the wiphy... */ /* With that information in place, we can now register the wiphy... */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment