Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
linux
linux-davinci
Commits
8494347e
Commit
8494347e
authored
Nov 16, 2009
by
David S. Miller
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of
git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6
parents
91e9c07b
505c9247
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
45 additions
and
165 deletions
+45
-165
MAINTAINERS
MAINTAINERS
+2
-1
drivers/net/wireless/ipw2x00/ipw2100.c
drivers/net/wireless/ipw2x00/ipw2100.c
+3
-3
drivers/net/wireless/ipw2x00/ipw2200.c
drivers/net/wireless/ipw2x00/ipw2200.c
+28
-113
drivers/net/wireless/ipw2x00/libipw.h
drivers/net/wireless/ipw2x00/libipw.h
+2
-6
drivers/net/wireless/ipw2x00/libipw_module.c
drivers/net/wireless/ipw2x00/libipw_module.c
+3
-39
drivers/net/wireless/p54/p54usb.c
drivers/net/wireless/p54/p54usb.c
+7
-3
No files found.
MAINTAINERS
View file @
8494347e
...
@@ -4281,6 +4281,7 @@ F: drivers/video/aty/aty128fb.c
...
@@ -4281,6 +4281,7 @@ F: drivers/video/aty/aty128fb.c
RALINK RT2X00 WIRELESS LAN DRIVER
RALINK RT2X00 WIRELESS LAN DRIVER
P: rt2x00 project
P: rt2x00 project
M: Ivo van Doorn <IvDoorn@gmail.com>
M: Ivo van Doorn <IvDoorn@gmail.com>
M: Gertjan van Wingerde <gwingerde@gmail.com>
L: linux-wireless@vger.kernel.org
L: linux-wireless@vger.kernel.org
L: users@rt2x00.serialmonkey.com (moderated for non-subscribers)
L: users@rt2x00.serialmonkey.com (moderated for non-subscribers)
W: http://rt2x00.serialmonkey.com/
W: http://rt2x00.serialmonkey.com/
...
@@ -4368,7 +4369,7 @@ RFKILL
...
@@ -4368,7 +4369,7 @@ RFKILL
M: Johannes Berg <johannes@sipsolutions.net>
M: Johannes Berg <johannes@sipsolutions.net>
L: linux-wireless@vger.kernel.org
L: linux-wireless@vger.kernel.org
S: Maintained
S: Maintained
F Documentation/rfkill.txt
F
:
Documentation/rfkill.txt
F: net/rfkill/
F: net/rfkill/
RISCOM8 DRIVER
RISCOM8 DRIVER
...
...
drivers/net/wireless/ipw2x00/ipw2100.c
View file @
8494347e
...
@@ -6029,7 +6029,7 @@ static struct net_device *ipw2100_alloc_device(struct pci_dev *pci_dev,
...
@@ -6029,7 +6029,7 @@ static struct net_device *ipw2100_alloc_device(struct pci_dev *pci_dev,
struct
ipw2100_priv
*
priv
;
struct
ipw2100_priv
*
priv
;
struct
net_device
*
dev
;
struct
net_device
*
dev
;
dev
=
alloc_ieee80211
(
sizeof
(
struct
ipw2100_priv
)
,
0
);
dev
=
alloc_ieee80211
(
sizeof
(
struct
ipw2100_priv
));
if
(
!
dev
)
if
(
!
dev
)
return
NULL
;
return
NULL
;
priv
=
libipw_priv
(
dev
);
priv
=
libipw_priv
(
dev
);
...
@@ -6342,7 +6342,7 @@ static int ipw2100_pci_init_one(struct pci_dev *pci_dev,
...
@@ -6342,7 +6342,7 @@ static int ipw2100_pci_init_one(struct pci_dev *pci_dev,
sysfs_remove_group
(
&
pci_dev
->
dev
.
kobj
,
sysfs_remove_group
(
&
pci_dev
->
dev
.
kobj
,
&
ipw2100_attribute_group
);
&
ipw2100_attribute_group
);
free_ieee80211
(
dev
,
0
);
free_ieee80211
(
dev
);
pci_set_drvdata
(
pci_dev
,
NULL
);
pci_set_drvdata
(
pci_dev
,
NULL
);
}
}
...
@@ -6400,7 +6400,7 @@ static void __devexit ipw2100_pci_remove_one(struct pci_dev *pci_dev)
...
@@ -6400,7 +6400,7 @@ static void __devexit ipw2100_pci_remove_one(struct pci_dev *pci_dev)
if
(
dev
->
base_addr
)
if
(
dev
->
base_addr
)
iounmap
((
void
__iomem
*
)
dev
->
base_addr
);
iounmap
((
void
__iomem
*
)
dev
->
base_addr
);
free_ieee80211
(
dev
,
0
);
free_ieee80211
(
dev
);
}
}
pci_release_regions
(
pci_dev
);
pci_release_regions
(
pci_dev
);
...
...
drivers/net/wireless/ipw2x00/ipw2200.c
View file @
8494347e
...
@@ -103,25 +103,6 @@ static int antenna = CFG_SYS_ANTENNA_BOTH;
...
@@ -103,25 +103,6 @@ static int antenna = CFG_SYS_ANTENNA_BOTH;
static
int
rtap_iface
=
0
;
/* def: 0 -- do not create rtap interface */
static
int
rtap_iface
=
0
;
/* def: 0 -- do not create rtap interface */
#endif
#endif
static
struct
ieee80211_rate
ipw2200_rates
[]
=
{
{
.
bitrate
=
10
},
{
.
bitrate
=
20
,
.
flags
=
IEEE80211_RATE_SHORT_PREAMBLE
},
{
.
bitrate
=
55
,
.
flags
=
IEEE80211_RATE_SHORT_PREAMBLE
},
{
.
bitrate
=
110
,
.
flags
=
IEEE80211_RATE_SHORT_PREAMBLE
},
{
.
bitrate
=
60
},
{
.
bitrate
=
90
},
{
.
bitrate
=
120
},
{
.
bitrate
=
180
},
{
.
bitrate
=
240
},
{
.
bitrate
=
360
},
{
.
bitrate
=
480
},
{
.
bitrate
=
540
}
};
#define ipw2200_a_rates (ipw2200_rates + 4)
#define ipw2200_num_a_rates 8
#define ipw2200_bg_rates (ipw2200_rates + 0)
#define ipw2200_num_bg_rates 12
#ifdef CONFIG_IPW2200_QOS
#ifdef CONFIG_IPW2200_QOS
static
int
qos_enable
=
0
;
static
int
qos_enable
=
0
;
...
@@ -8673,6 +8654,24 @@ static int ipw_sw_reset(struct ipw_priv *priv, int option)
...
@@ -8673,6 +8654,24 @@ static int ipw_sw_reset(struct ipw_priv *priv, int option)
*
*
*/
*/
static
int
ipw_wx_get_name
(
struct
net_device
*
dev
,
struct
iw_request_info
*
info
,
union
iwreq_data
*
wrqu
,
char
*
extra
)
{
struct
ipw_priv
*
priv
=
libipw_priv
(
dev
);
mutex_lock
(
&
priv
->
mutex
);
if
(
priv
->
status
&
STATUS_RF_KILL_MASK
)
strcpy
(
wrqu
->
name
,
"radio off"
);
else
if
(
!
(
priv
->
status
&
STATUS_ASSOCIATED
))
strcpy
(
wrqu
->
name
,
"unassociated"
);
else
snprintf
(
wrqu
->
name
,
IFNAMSIZ
,
"IEEE 802.11%c"
,
ipw_modes
[
priv
->
assoc_request
.
ieee_mode
]);
IPW_DEBUG_WX
(
"Name: %s
\n
"
,
wrqu
->
name
);
mutex_unlock
(
&
priv
->
mutex
);
return
0
;
}
static
int
ipw_set_channel
(
struct
ipw_priv
*
priv
,
u8
channel
)
static
int
ipw_set_channel
(
struct
ipw_priv
*
priv
,
u8
channel
)
{
{
if
(
channel
==
0
)
{
if
(
channel
==
0
)
{
...
@@ -9972,7 +9971,7 @@ static int ipw_wx_sw_reset(struct net_device *dev,
...
@@ -9972,7 +9971,7 @@ static int ipw_wx_sw_reset(struct net_device *dev,
/* Rebase the WE IOCTLs to zero for the handler array */
/* Rebase the WE IOCTLs to zero for the handler array */
#define IW_IOCTL(x) [(x)-SIOCSIWCOMMIT]
#define IW_IOCTL(x) [(x)-SIOCSIWCOMMIT]
static
iw_handler
ipw_wx_handlers
[]
=
{
static
iw_handler
ipw_wx_handlers
[]
=
{
IW_IOCTL
(
SIOCGIWNAME
)
=
(
iw_handler
)
cfg80211_wext_giw
name
,
IW_IOCTL
(
SIOCGIWNAME
)
=
ipw_wx_get_
name
,
IW_IOCTL
(
SIOCSIWFREQ
)
=
ipw_wx_set_freq
,
IW_IOCTL
(
SIOCSIWFREQ
)
=
ipw_wx_set_freq
,
IW_IOCTL
(
SIOCGIWFREQ
)
=
ipw_wx_get_freq
,
IW_IOCTL
(
SIOCGIWFREQ
)
=
ipw_wx_get_freq
,
IW_IOCTL
(
SIOCSIWMODE
)
=
ipw_wx_set_mode
,
IW_IOCTL
(
SIOCSIWMODE
)
=
ipw_wx_set_mode
,
...
@@ -11416,100 +11415,16 @@ static void ipw_bg_down(struct work_struct *work)
...
@@ -11416,100 +11415,16 @@ static void ipw_bg_down(struct work_struct *work)
/* Called by register_netdev() */
/* Called by register_netdev() */
static
int
ipw_net_init
(
struct
net_device
*
dev
)
static
int
ipw_net_init
(
struct
net_device
*
dev
)
{
{
int
i
,
rc
=
0
;
struct
ipw_priv
*
priv
=
libipw_priv
(
dev
);
struct
ipw_priv
*
priv
=
libipw_priv
(
dev
);
const
struct
libipw_geo
*
geo
=
libipw_get_geo
(
priv
->
ieee
);
struct
wireless_dev
*
wdev
=
&
priv
->
ieee
->
wdev
;
mutex_lock
(
&
priv
->
mutex
);
mutex_lock
(
&
priv
->
mutex
);
if
(
ipw_up
(
priv
))
{
if
(
ipw_up
(
priv
))
{
rc
=
-
EIO
;
mutex_unlock
(
&
priv
->
mutex
);
goto
out
;
return
-
EIO
;
}
memcpy
(
wdev
->
wiphy
->
perm_addr
,
priv
->
mac_addr
,
ETH_ALEN
);
/* fill-out priv->ieee->bg_band */
if
(
geo
->
bg_channels
)
{
struct
ieee80211_supported_band
*
bg_band
=
&
priv
->
ieee
->
bg_band
;
bg_band
->
band
=
IEEE80211_BAND_2GHZ
;
bg_band
->
n_channels
=
geo
->
bg_channels
;
bg_band
->
channels
=
kzalloc
(
geo
->
bg_channels
*
sizeof
(
struct
ieee80211_channel
),
GFP_KERNEL
);
/* translate geo->bg to bg_band.channels */
for
(
i
=
0
;
i
<
geo
->
bg_channels
;
i
++
)
{
bg_band
->
channels
[
i
].
band
=
IEEE80211_BAND_2GHZ
;
bg_band
->
channels
[
i
].
center_freq
=
geo
->
bg
[
i
].
freq
;
bg_band
->
channels
[
i
].
hw_value
=
geo
->
bg
[
i
].
channel
;
bg_band
->
channels
[
i
].
max_power
=
geo
->
bg
[
i
].
max_power
;
if
(
geo
->
bg
[
i
].
flags
&
LIBIPW_CH_PASSIVE_ONLY
)
bg_band
->
channels
[
i
].
flags
|=
IEEE80211_CHAN_PASSIVE_SCAN
;
if
(
geo
->
bg
[
i
].
flags
&
LIBIPW_CH_NO_IBSS
)
bg_band
->
channels
[
i
].
flags
|=
IEEE80211_CHAN_NO_IBSS
;
if
(
geo
->
bg
[
i
].
flags
&
LIBIPW_CH_RADAR_DETECT
)
bg_band
->
channels
[
i
].
flags
|=
IEEE80211_CHAN_RADAR
;
/* No equivalent for LIBIPW_CH_80211H_RULES,
LIBIPW_CH_UNIFORM_SPREADING, or
LIBIPW_CH_B_ONLY... */
}
/* point at bitrate info */
bg_band
->
bitrates
=
ipw2200_bg_rates
;
bg_band
->
n_bitrates
=
ipw2200_num_bg_rates
;
wdev
->
wiphy
->
bands
[
IEEE80211_BAND_2GHZ
]
=
bg_band
;
}
/* fill-out priv->ieee->a_band */
if
(
geo
->
a_channels
)
{
struct
ieee80211_supported_band
*
a_band
=
&
priv
->
ieee
->
a_band
;
a_band
->
band
=
IEEE80211_BAND_5GHZ
;
a_band
->
n_channels
=
geo
->
a_channels
;
a_band
->
channels
=
kzalloc
(
geo
->
a_channels
*
sizeof
(
struct
ieee80211_channel
),
GFP_KERNEL
);
/* translate geo->bg to a_band.channels */
for
(
i
=
0
;
i
<
geo
->
a_channels
;
i
++
)
{
a_band
->
channels
[
i
].
band
=
IEEE80211_BAND_2GHZ
;
a_band
->
channels
[
i
].
center_freq
=
geo
->
a
[
i
].
freq
;
a_band
->
channels
[
i
].
hw_value
=
geo
->
a
[
i
].
channel
;
a_band
->
channels
[
i
].
max_power
=
geo
->
a
[
i
].
max_power
;
if
(
geo
->
a
[
i
].
flags
&
LIBIPW_CH_PASSIVE_ONLY
)
a_band
->
channels
[
i
].
flags
|=
IEEE80211_CHAN_PASSIVE_SCAN
;
if
(
geo
->
a
[
i
].
flags
&
LIBIPW_CH_NO_IBSS
)
a_band
->
channels
[
i
].
flags
|=
IEEE80211_CHAN_NO_IBSS
;
if
(
geo
->
a
[
i
].
flags
&
LIBIPW_CH_RADAR_DETECT
)
a_band
->
channels
[
i
].
flags
|=
IEEE80211_CHAN_RADAR
;
/* No equivalent for LIBIPW_CH_80211H_RULES,
LIBIPW_CH_UNIFORM_SPREADING, or
LIBIPW_CH_B_ONLY... */
}
/* point at bitrate info */
a_band
->
bitrates
=
ipw2200_a_rates
;
a_band
->
n_bitrates
=
ipw2200_num_a_rates
;
wdev
->
wiphy
->
bands
[
IEEE80211_BAND_5GHZ
]
=
a_band
;
}
set_wiphy_dev
(
wdev
->
wiphy
,
&
priv
->
pci_dev
->
dev
);
/* With that information in place, we can now register the wiphy... */
if
(
wiphy_register
(
wdev
->
wiphy
))
{
rc
=
-
EIO
;
goto
out
;
}
}
out:
mutex_unlock
(
&
priv
->
mutex
);
mutex_unlock
(
&
priv
->
mutex
);
return
rc
;
return
0
;
}
}
/* PCI driver stuff */
/* PCI driver stuff */
...
@@ -11640,7 +11555,7 @@ static int ipw_prom_alloc(struct ipw_priv *priv)
...
@@ -11640,7 +11555,7 @@ static int ipw_prom_alloc(struct ipw_priv *priv)
if
(
priv
->
prom_net_dev
)
if
(
priv
->
prom_net_dev
)
return
-
EPERM
;
return
-
EPERM
;
priv
->
prom_net_dev
=
alloc_ieee80211
(
sizeof
(
struct
ipw_prom_priv
)
,
1
);
priv
->
prom_net_dev
=
alloc_ieee80211
(
sizeof
(
struct
ipw_prom_priv
));
if
(
priv
->
prom_net_dev
==
NULL
)
if
(
priv
->
prom_net_dev
==
NULL
)
return
-
ENOMEM
;
return
-
ENOMEM
;
...
@@ -11659,7 +11574,7 @@ static int ipw_prom_alloc(struct ipw_priv *priv)
...
@@ -11659,7 +11574,7 @@ static int ipw_prom_alloc(struct ipw_priv *priv)
rc
=
register_netdev
(
priv
->
prom_net_dev
);
rc
=
register_netdev
(
priv
->
prom_net_dev
);
if
(
rc
)
{
if
(
rc
)
{
free_ieee80211
(
priv
->
prom_net_dev
,
1
);
free_ieee80211
(
priv
->
prom_net_dev
);
priv
->
prom_net_dev
=
NULL
;
priv
->
prom_net_dev
=
NULL
;
return
rc
;
return
rc
;
}
}
...
@@ -11673,7 +11588,7 @@ static void ipw_prom_free(struct ipw_priv *priv)
...
@@ -11673,7 +11588,7 @@ static void ipw_prom_free(struct ipw_priv *priv)
return
;
return
;
unregister_netdev
(
priv
->
prom_net_dev
);
unregister_netdev
(
priv
->
prom_net_dev
);
free_ieee80211
(
priv
->
prom_net_dev
,
1
);
free_ieee80211
(
priv
->
prom_net_dev
);
priv
->
prom_net_dev
=
NULL
;
priv
->
prom_net_dev
=
NULL
;
}
}
...
@@ -11701,7 +11616,7 @@ static int __devinit ipw_pci_probe(struct pci_dev *pdev,
...
@@ -11701,7 +11616,7 @@ static int __devinit ipw_pci_probe(struct pci_dev *pdev,
struct
ipw_priv
*
priv
;
struct
ipw_priv
*
priv
;
int
i
;
int
i
;
net_dev
=
alloc_ieee80211
(
sizeof
(
struct
ipw_priv
)
,
0
);
net_dev
=
alloc_ieee80211
(
sizeof
(
struct
ipw_priv
));
if
(
net_dev
==
NULL
)
{
if
(
net_dev
==
NULL
)
{
err
=
-
ENOMEM
;
err
=
-
ENOMEM
;
goto
out
;
goto
out
;
...
@@ -11849,7 +11764,7 @@ static int __devinit ipw_pci_probe(struct pci_dev *pdev,
...
@@ -11849,7 +11764,7 @@ static int __devinit ipw_pci_probe(struct pci_dev *pdev,
pci_disable_device
(
pdev
);
pci_disable_device
(
pdev
);
pci_set_drvdata
(
pdev
,
NULL
);
pci_set_drvdata
(
pdev
,
NULL
);
out_free_ieee80211:
out_free_ieee80211:
free_ieee80211
(
priv
->
net_dev
,
0
);
free_ieee80211
(
priv
->
net_dev
);
out:
out:
return
err
;
return
err
;
}
}
...
@@ -11916,7 +11831,7 @@ static void __devexit ipw_pci_remove(struct pci_dev *pdev)
...
@@ -11916,7 +11831,7 @@ static void __devexit ipw_pci_remove(struct pci_dev *pdev)
pci_release_regions
(
pdev
);
pci_release_regions
(
pdev
);
pci_disable_device
(
pdev
);
pci_disable_device
(
pdev
);
pci_set_drvdata
(
pdev
,
NULL
);
pci_set_drvdata
(
pdev
,
NULL
);
free_ieee80211
(
priv
->
net_dev
,
0
);
free_ieee80211
(
priv
->
net_dev
);
free_firmware
();
free_firmware
();
}
}
...
...
drivers/net/wireless/ipw2x00/libipw.h
View file @
8494347e
...
@@ -31,7 +31,6 @@
...
@@ -31,7 +31,6 @@
#include <linux/ieee80211.h>
#include <linux/ieee80211.h>
#include <net/lib80211.h>
#include <net/lib80211.h>
#include <net/cfg80211.h>
#define LIBIPW_VERSION "git-1.1.13"
#define LIBIPW_VERSION "git-1.1.13"
...
@@ -784,15 +783,12 @@ struct libipw_geo {
...
@@ -784,15 +783,12 @@ struct libipw_geo {
struct
libipw_device
{
struct
libipw_device
{
struct
net_device
*
dev
;
struct
net_device
*
dev
;
struct
wireless_dev
wdev
;
struct
libipw_security
sec
;
struct
libipw_security
sec
;
/* Bookkeeping structures */
/* Bookkeeping structures */
struct
libipw_stats
ieee_stats
;
struct
libipw_stats
ieee_stats
;
struct
libipw_geo
geo
;
struct
libipw_geo
geo
;
struct
ieee80211_supported_band
bg_band
;
struct
ieee80211_supported_band
a_band
;
/* Probe / Beacon management */
/* Probe / Beacon management */
struct
list_head
network_free_list
;
struct
list_head
network_free_list
;
...
@@ -1018,8 +1014,8 @@ static inline int libipw_is_cck_rate(u8 rate)
...
@@ -1018,8 +1014,8 @@ static inline int libipw_is_cck_rate(u8 rate)
}
}
/* ieee80211.c */
/* ieee80211.c */
extern
void
free_ieee80211
(
struct
net_device
*
dev
,
int
monitor
);
extern
void
free_ieee80211
(
struct
net_device
*
dev
);
extern
struct
net_device
*
alloc_ieee80211
(
int
sizeof_priv
,
int
monitor
);
extern
struct
net_device
*
alloc_ieee80211
(
int
sizeof_priv
);
extern
int
libipw_change_mtu
(
struct
net_device
*
dev
,
int
new_mtu
);
extern
int
libipw_change_mtu
(
struct
net_device
*
dev
,
int
new_mtu
);
extern
void
libipw_networks_age
(
struct
libipw_device
*
ieee
,
extern
void
libipw_networks_age
(
struct
libipw_device
*
ieee
,
...
...
drivers/net/wireless/ipw2x00/libipw_module.c
View file @
8494347e
...
@@ -62,9 +62,6 @@ MODULE_DESCRIPTION(DRV_DESCRIPTION);
...
@@ -62,9 +62,6 @@ MODULE_DESCRIPTION(DRV_DESCRIPTION);
MODULE_AUTHOR
(
DRV_COPYRIGHT
);
MODULE_AUTHOR
(
DRV_COPYRIGHT
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
struct
cfg80211_ops
libipw_config_ops
=
{
};
void
*
libipw_wiphy_privid
=
&
libipw_wiphy_privid
;
static
int
libipw_networks_allocate
(
struct
libipw_device
*
ieee
)
static
int
libipw_networks_allocate
(
struct
libipw_device
*
ieee
)
{
{
if
(
ieee
->
networks
)
if
(
ieee
->
networks
)
...
@@ -143,7 +140,7 @@ int libipw_change_mtu(struct net_device *dev, int new_mtu)
...
@@ -143,7 +140,7 @@ int libipw_change_mtu(struct net_device *dev, int new_mtu)
}
}
EXPORT_SYMBOL
(
libipw_change_mtu
);
EXPORT_SYMBOL
(
libipw_change_mtu
);
struct
net_device
*
alloc_ieee80211
(
int
sizeof_priv
,
int
monitor
)
struct
net_device
*
alloc_ieee80211
(
int
sizeof_priv
)
{
{
struct
libipw_device
*
ieee
;
struct
libipw_device
*
ieee
;
struct
net_device
*
dev
;
struct
net_device
*
dev
;
...
@@ -160,31 +157,10 @@ struct net_device *alloc_ieee80211(int sizeof_priv, int monitor)
...
@@ -160,31 +157,10 @@ struct net_device *alloc_ieee80211(int sizeof_priv, int monitor)
ieee
->
dev
=
dev
;
ieee
->
dev
=
dev
;
if
(
!
monitor
)
{
ieee
->
wdev
.
wiphy
=
wiphy_new
(
&
libipw_config_ops
,
0
);
if
(
!
ieee
->
wdev
.
wiphy
)
{
LIBIPW_ERROR
(
"Unable to allocate wiphy.
\n
"
);
goto
failed_free_netdev
;
}
ieee
->
dev
->
ieee80211_ptr
=
&
ieee
->
wdev
;
ieee
->
wdev
.
iftype
=
NL80211_IFTYPE_STATION
;
/* Fill-out wiphy structure bits we know... Not enough info
here to call set_wiphy_dev or set MAC address or channel info
-- have to do that in ->ndo_init... */
ieee
->
wdev
.
wiphy
->
privid
=
libipw_wiphy_privid
;
ieee
->
wdev
.
wiphy
->
max_scan_ssids
=
1
;
ieee
->
wdev
.
wiphy
->
max_scan_ie_len
=
0
;
ieee
->
wdev
.
wiphy
->
interface_modes
=
BIT
(
NL80211_IFTYPE_STATION
)
|
BIT
(
NL80211_IFTYPE_ADHOC
);
}
err
=
libipw_networks_allocate
(
ieee
);
err
=
libipw_networks_allocate
(
ieee
);
if
(
err
)
{
if
(
err
)
{
LIBIPW_ERROR
(
"Unable to allocate beacon storage: %d
\n
"
,
err
);
LIBIPW_ERROR
(
"Unable to allocate beacon storage: %d
\n
"
,
err
);
goto
failed_free_
wiphy
;
goto
failed_free_
netdev
;
}
}
libipw_networks_initialize
(
ieee
);
libipw_networks_initialize
(
ieee
);
...
@@ -217,31 +193,19 @@ struct net_device *alloc_ieee80211(int sizeof_priv, int monitor)
...
@@ -217,31 +193,19 @@ struct net_device *alloc_ieee80211(int sizeof_priv, int monitor)
return
dev
;
return
dev
;
failed_free_wiphy:
if
(
!
monitor
)
wiphy_free
(
ieee
->
wdev
.
wiphy
);
failed_free_netdev:
failed_free_netdev:
free_netdev
(
dev
);
free_netdev
(
dev
);
failed:
failed:
return
NULL
;
return
NULL
;
}
}
void
free_ieee80211
(
struct
net_device
*
dev
,
int
monitor
)
void
free_ieee80211
(
struct
net_device
*
dev
)
{
{
struct
libipw_device
*
ieee
=
netdev_priv
(
dev
);
struct
libipw_device
*
ieee
=
netdev_priv
(
dev
);
lib80211_crypt_info_free
(
&
ieee
->
crypt_info
);
lib80211_crypt_info_free
(
&
ieee
->
crypt_info
);
libipw_networks_free
(
ieee
);
libipw_networks_free
(
ieee
);
/* free cfg80211 resources */
if
(
!
monitor
)
{
wiphy_unregister
(
ieee
->
wdev
.
wiphy
);
kfree
(
ieee
->
a_band
.
channels
);
kfree
(
ieee
->
bg_band
.
channels
);
wiphy_free
(
ieee
->
wdev
.
wiphy
);
}
free_netdev
(
dev
);
free_netdev
(
dev
);
}
}
...
...
drivers/net/wireless/p54/p54usb.c
View file @
8494347e
...
@@ -426,12 +426,16 @@ static const char p54u_romboot_3887[] = "~~~~";
...
@@ -426,12 +426,16 @@ static const char p54u_romboot_3887[] = "~~~~";
static
int
p54u_firmware_reset_3887
(
struct
ieee80211_hw
*
dev
)
static
int
p54u_firmware_reset_3887
(
struct
ieee80211_hw
*
dev
)
{
{
struct
p54u_priv
*
priv
=
dev
->
priv
;
struct
p54u_priv
*
priv
=
dev
->
priv
;
u8
buf
[
4
]
;
u8
*
buf
;
int
ret
;
int
ret
;
memcpy
(
&
buf
,
p54u_romboot_3887
,
sizeof
(
buf
));
buf
=
kmalloc
(
4
,
GFP_KERNEL
);
if
(
!
buf
)
return
-
ENOMEM
;
memcpy
(
buf
,
p54u_romboot_3887
,
4
);
ret
=
p54u_bulk_msg
(
priv
,
P54U_PIPE_DATA
,
ret
=
p54u_bulk_msg
(
priv
,
P54U_PIPE_DATA
,
buf
,
sizeof
(
buf
));
buf
,
4
);
kfree
(
buf
);
if
(
ret
)
if
(
ret
)
dev_err
(
&
priv
->
udev
->
dev
,
"(p54usb) unable to jump to "
dev_err
(
&
priv
->
udev
->
dev
,
"(p54usb) unable to jump to "
"boot ROM (%d)!
\n
"
,
ret
);
"boot ROM (%d)!
\n
"
,
ret
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment