Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
e5c1a0aa
Commit
e5c1a0aa
authored
Mar 03, 2010
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-next-2.6
parents
1cd4efdd
31f66be4
Changes
17
Hide whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
237 additions
and
168 deletions
+237
-168
drivers/net/wireless/airo.c
drivers/net/wireless/airo.c
+2
-1
drivers/net/wireless/ath/ar9170/ar9170.h
drivers/net/wireless/ath/ar9170/ar9170.h
+1
-0
drivers/net/wireless/ath/ar9170/main.c
drivers/net/wireless/ath/ar9170/main.c
+7
-3
drivers/net/wireless/ath/ar9170/usb.c
drivers/net/wireless/ath/ar9170/usb.c
+103
-67
drivers/net/wireless/ath/ath9k/rc.c
drivers/net/wireless/ath/ath9k/rc.c
+3
-3
drivers/net/wireless/ath/ath9k/xmit.c
drivers/net/wireless/ath/ath9k/xmit.c
+2
-2
drivers/net/wireless/iwlwifi/iwl-agn.c
drivers/net/wireless/iwlwifi/iwl-agn.c
+79
-78
drivers/net/wireless/iwlwifi/iwl-dev.h
drivers/net/wireless/iwlwifi/iwl-dev.h
+2
-0
drivers/net/wireless/rt2x00/rt2800pci.c
drivers/net/wireless/rt2x00/rt2800pci.c
+1
-1
drivers/net/wireless/rt2x00/rt2x00soc.c
drivers/net/wireless/rt2x00/rt2x00soc.c
+1
-0
drivers/net/wireless/rt2x00/rt73usb.c
drivers/net/wireless/rt2x00/rt73usb.c
+2
-0
drivers/net/wireless/zd1211rw/zd_mac.c
drivers/net/wireless/zd1211rw/zd_mac.c
+4
-6
include/linux/rfkill.h
include/linux/rfkill.h
+1
-1
include/net/mac80211.h
include/net/mac80211.h
+2
-1
net/mac80211/mlme.c
net/mac80211/mlme.c
+16
-3
net/mac80211/rate.h
net/mac80211/rate.h
+3
-2
net/rfkill/input.c
net/rfkill/input.c
+8
-0
No files found.
drivers/net/wireless/airo.c
View file @
e5c1a0aa
...
@@ -5255,7 +5255,8 @@ static int set_wep_key(struct airo_info *ai, u16 index, const char *key,
...
@@ -5255,7 +5255,8 @@ static int set_wep_key(struct airo_info *ai, u16 index, const char *key,
WepKeyRid
wkr
;
WepKeyRid
wkr
;
int
rc
;
int
rc
;
WARN_ON
(
keylen
==
0
);
if
(
WARN_ON
(
keylen
==
0
))
return
-
1
;
memset
(
&
wkr
,
0
,
sizeof
(
wkr
));
memset
(
&
wkr
,
0
,
sizeof
(
wkr
));
wkr
.
len
=
cpu_to_le16
(
sizeof
(
wkr
));
wkr
.
len
=
cpu_to_le16
(
sizeof
(
wkr
));
...
...
drivers/net/wireless/ath/ar9170/ar9170.h
View file @
e5c1a0aa
...
@@ -166,6 +166,7 @@ struct ar9170 {
...
@@ -166,6 +166,7 @@ struct ar9170 {
struct
ath_common
common
;
struct
ath_common
common
;
struct
mutex
mutex
;
struct
mutex
mutex
;
enum
ar9170_device_state
state
;
enum
ar9170_device_state
state
;
bool
registered
;
unsigned
long
bad_hw_nagger
;
unsigned
long
bad_hw_nagger
;
int
(
*
open
)(
struct
ar9170
*
);
int
(
*
open
)(
struct
ar9170
*
);
...
...
drivers/net/wireless/ath/ar9170/main.c
View file @
e5c1a0aa
...
@@ -2701,7 +2701,8 @@ int ar9170_register(struct ar9170 *ar, struct device *pdev)
...
@@ -2701,7 +2701,8 @@ int ar9170_register(struct ar9170 *ar, struct device *pdev)
dev_info
(
pdev
,
"Atheros AR9170 is registered as '%s'
\n
"
,
dev_info
(
pdev
,
"Atheros AR9170 is registered as '%s'
\n
"
,
wiphy_name
(
ar
->
hw
->
wiphy
));
wiphy_name
(
ar
->
hw
->
wiphy
));
return
err
;
ar
->
registered
=
true
;
return
0
;
err_unreg:
err_unreg:
ieee80211_unregister_hw
(
ar
->
hw
);
ieee80211_unregister_hw
(
ar
->
hw
);
...
@@ -2712,11 +2713,14 @@ int ar9170_register(struct ar9170 *ar, struct device *pdev)
...
@@ -2712,11 +2713,14 @@ int ar9170_register(struct ar9170 *ar, struct device *pdev)
void
ar9170_unregister
(
struct
ar9170
*
ar
)
void
ar9170_unregister
(
struct
ar9170
*
ar
)
{
{
if
(
ar
->
registered
)
{
#ifdef CONFIG_AR9170_LEDS
#ifdef CONFIG_AR9170_LEDS
ar9170_unregister_leds
(
ar
);
ar9170_unregister_leds
(
ar
);
#endif
/* CONFIG_AR9170_LEDS */
#endif
/* CONFIG_AR9170_LEDS */
kfree_skb
(
ar
->
rx_failover
);
ieee80211_unregister_hw
(
ar
->
hw
);
ieee80211_unregister_hw
(
ar
->
hw
);
}
kfree_skb
(
ar
->
rx_failover
);
mutex_destroy
(
&
ar
->
mutex
);
mutex_destroy
(
&
ar
->
mutex
);
}
}
drivers/net/wireless/ath/ar9170/usb.c
View file @
e5c1a0aa
...
@@ -582,43 +582,6 @@ static int ar9170_usb_upload(struct ar9170_usb *aru, const void *data,
...
@@ -582,43 +582,6 @@ static int ar9170_usb_upload(struct ar9170_usb *aru, const void *data,
return
0
;
return
0
;
}
}
static
int
ar9170_usb_request_firmware
(
struct
ar9170_usb
*
aru
)
{
int
err
=
0
;
err
=
request_firmware
(
&
aru
->
firmware
,
"ar9170.fw"
,
&
aru
->
udev
->
dev
);
if
(
!
err
)
{
aru
->
init_values
=
NULL
;
return
0
;
}
if
(
aru
->
req_one_stage_fw
)
{
dev_err
(
&
aru
->
udev
->
dev
,
"ar9170.fw firmware file "
"not found and is required for this device
\n
"
);
return
-
EINVAL
;
}
dev_err
(
&
aru
->
udev
->
dev
,
"ar9170.fw firmware file "
"not found, trying old firmware...
\n
"
);
err
=
request_firmware
(
&
aru
->
init_values
,
"ar9170-1.fw"
,
&
aru
->
udev
->
dev
);
if
(
err
)
{
dev_err
(
&
aru
->
udev
->
dev
,
"file with init values not found.
\n
"
);
return
err
;
}
err
=
request_firmware
(
&
aru
->
firmware
,
"ar9170-2.fw"
,
&
aru
->
udev
->
dev
);
if
(
err
)
{
release_firmware
(
aru
->
init_values
);
dev_err
(
&
aru
->
udev
->
dev
,
"firmware file not found.
\n
"
);
return
err
;
}
return
err
;
}
static
int
ar9170_usb_reset
(
struct
ar9170_usb
*
aru
)
static
int
ar9170_usb_reset
(
struct
ar9170_usb
*
aru
)
{
{
int
ret
,
lock
=
(
aru
->
intf
->
condition
!=
USB_INTERFACE_BINDING
);
int
ret
,
lock
=
(
aru
->
intf
->
condition
!=
USB_INTERFACE_BINDING
);
...
@@ -757,6 +720,103 @@ static int ar9170_usb_init_device(struct ar9170_usb *aru)
...
@@ -757,6 +720,103 @@ static int ar9170_usb_init_device(struct ar9170_usb *aru)
return
err
;
return
err
;
}
}
static
void
ar9170_usb_firmware_failed
(
struct
ar9170_usb
*
aru
)
{
struct
device
*
parent
=
aru
->
udev
->
dev
.
parent
;
/* unbind anything failed */
if
(
parent
)
down
(
&
parent
->
sem
);
device_release_driver
(
&
aru
->
udev
->
dev
);
if
(
parent
)
up
(
&
parent
->
sem
);
}
static
void
ar9170_usb_firmware_finish
(
const
struct
firmware
*
fw
,
void
*
context
)
{
struct
ar9170_usb
*
aru
=
context
;
int
err
;
aru
->
firmware
=
fw
;
if
(
!
fw
)
{
dev_err
(
&
aru
->
udev
->
dev
,
"firmware file not found.
\n
"
);
goto
err_freefw
;
}
err
=
ar9170_usb_init_device
(
aru
);
if
(
err
)
goto
err_freefw
;
err
=
ar9170_usb_open
(
&
aru
->
common
);
if
(
err
)
goto
err_unrx
;
err
=
ar9170_register
(
&
aru
->
common
,
&
aru
->
udev
->
dev
);
ar9170_usb_stop
(
&
aru
->
common
);
if
(
err
)
goto
err_unrx
;
return
;
err_unrx:
ar9170_usb_cancel_urbs
(
aru
);
err_freefw:
ar9170_usb_firmware_failed
(
aru
);
}
static
void
ar9170_usb_firmware_inits
(
const
struct
firmware
*
fw
,
void
*
context
)
{
struct
ar9170_usb
*
aru
=
context
;
int
err
;
if
(
!
fw
)
{
dev_err
(
&
aru
->
udev
->
dev
,
"file with init values not found.
\n
"
);
ar9170_usb_firmware_failed
(
aru
);
return
;
}
aru
->
init_values
=
fw
;
/* ok so we have the init values -- get code for two-stage */
err
=
request_firmware_nowait
(
THIS_MODULE
,
1
,
"ar9170-2.fw"
,
&
aru
->
udev
->
dev
,
GFP_KERNEL
,
aru
,
ar9170_usb_firmware_finish
);
if
(
err
)
ar9170_usb_firmware_failed
(
aru
);
}
static
void
ar9170_usb_firmware_step2
(
const
struct
firmware
*
fw
,
void
*
context
)
{
struct
ar9170_usb
*
aru
=
context
;
int
err
;
if
(
fw
)
{
ar9170_usb_firmware_finish
(
fw
,
context
);
return
;
}
if
(
aru
->
req_one_stage_fw
)
{
dev_err
(
&
aru
->
udev
->
dev
,
"ar9170.fw firmware file "
"not found and is required for this device
\n
"
);
ar9170_usb_firmware_failed
(
aru
);
return
;
}
dev_err
(
&
aru
->
udev
->
dev
,
"ar9170.fw firmware file "
"not found, trying old firmware...
\n
"
);
err
=
request_firmware_nowait
(
THIS_MODULE
,
1
,
"ar9170-1.fw"
,
&
aru
->
udev
->
dev
,
GFP_KERNEL
,
aru
,
ar9170_usb_firmware_inits
);
if
(
err
)
ar9170_usb_firmware_failed
(
aru
);
}
static
bool
ar9170_requires_one_stage
(
const
struct
usb_device_id
*
id
)
static
bool
ar9170_requires_one_stage
(
const
struct
usb_device_id
*
id
)
{
{
if
(
!
id
->
driver_info
)
if
(
!
id
->
driver_info
)
...
@@ -814,33 +874,9 @@ static int ar9170_usb_probe(struct usb_interface *intf,
...
@@ -814,33 +874,9 @@ static int ar9170_usb_probe(struct usb_interface *intf,
if
(
err
)
if
(
err
)
goto
err_freehw
;
goto
err_freehw
;
err
=
ar9170_usb_request_firmware
(
aru
);
return
request_firmware_nowait
(
THIS_MODULE
,
1
,
"ar9170.fw"
,
if
(
err
)
&
aru
->
udev
->
dev
,
GFP_KERNEL
,
aru
,
goto
err_freehw
;
ar9170_usb_firmware_step2
);
err
=
ar9170_usb_init_device
(
aru
);
if
(
err
)
goto
err_freefw
;
err
=
ar9170_usb_open
(
ar
);
if
(
err
)
goto
err_unrx
;
err
=
ar9170_register
(
ar
,
&
udev
->
dev
);
ar9170_usb_stop
(
ar
);
if
(
err
)
goto
err_unrx
;
return
0
;
err_unrx:
ar9170_usb_cancel_urbs
(
aru
);
err_freefw:
release_firmware
(
aru
->
init_values
);
release_firmware
(
aru
->
firmware
);
err_freehw:
err_freehw:
usb_set_intfdata
(
intf
,
NULL
);
usb_set_intfdata
(
intf
,
NULL
);
usb_put_dev
(
udev
);
usb_put_dev
(
udev
);
...
@@ -860,12 +896,12 @@ static void ar9170_usb_disconnect(struct usb_interface *intf)
...
@@ -860,12 +896,12 @@ static void ar9170_usb_disconnect(struct usb_interface *intf)
ar9170_unregister
(
&
aru
->
common
);
ar9170_unregister
(
&
aru
->
common
);
ar9170_usb_cancel_urbs
(
aru
);
ar9170_usb_cancel_urbs
(
aru
);
release_firmware
(
aru
->
init_values
);
release_firmware
(
aru
->
firmware
);
usb_put_dev
(
aru
->
udev
);
usb_put_dev
(
aru
->
udev
);
usb_set_intfdata
(
intf
,
NULL
);
usb_set_intfdata
(
intf
,
NULL
);
ieee80211_free_hw
(
aru
->
common
.
hw
);
ieee80211_free_hw
(
aru
->
common
.
hw
);
release_firmware
(
aru
->
init_values
);
release_firmware
(
aru
->
firmware
);
}
}
#ifdef CONFIG_PM
#ifdef CONFIG_PM
...
...
drivers/net/wireless/ath/ath9k/rc.c
View file @
e5c1a0aa
...
@@ -1323,7 +1323,7 @@ static void ath_rate_init(void *priv, struct ieee80211_supported_band *sband,
...
@@ -1323,7 +1323,7 @@ static void ath_rate_init(void *priv, struct ieee80211_supported_band *sband,
static
void
ath_rate_update
(
void
*
priv
,
struct
ieee80211_supported_band
*
sband
,
static
void
ath_rate_update
(
void
*
priv
,
struct
ieee80211_supported_band
*
sband
,
struct
ieee80211_sta
*
sta
,
void
*
priv_sta
,
struct
ieee80211_sta
*
sta
,
void
*
priv_sta
,
u32
changed
)
u32
changed
,
enum
nl80211_channel_type
oper_chan_type
)
{
{
struct
ath_softc
*
sc
=
priv
;
struct
ath_softc
*
sc
=
priv
;
struct
ath_rate_priv
*
ath_rc_priv
=
priv_sta
;
struct
ath_rate_priv
*
ath_rc_priv
=
priv_sta
;
...
@@ -1340,8 +1340,8 @@ static void ath_rate_update(void *priv, struct ieee80211_supported_band *sband,
...
@@ -1340,8 +1340,8 @@ static void ath_rate_update(void *priv, struct ieee80211_supported_band *sband,
if
(
sc
->
sc_ah
->
opmode
!=
NL80211_IFTYPE_STATION
)
if
(
sc
->
sc_ah
->
opmode
!=
NL80211_IFTYPE_STATION
)
return
;
return
;
if
(
sc
->
hw
->
conf
.
channel
_type
==
NL80211_CHAN_HT40MINUS
||
if
(
oper_chan
_type
==
NL80211_CHAN_HT40MINUS
||
sc
->
hw
->
conf
.
channel
_type
==
NL80211_CHAN_HT40PLUS
)
oper_chan
_type
==
NL80211_CHAN_HT40PLUS
)
oper_cw40
=
true
;
oper_cw40
=
true
;
oper_sgi40
=
(
sta
->
ht_cap
.
cap
&
IEEE80211_HT_CAP_SGI_40
)
?
oper_sgi40
=
(
sta
->
ht_cap
.
cap
&
IEEE80211_HT_CAP_SGI_40
)
?
...
...
drivers/net/wireless/ath/ath9k/xmit.c
View file @
e5c1a0aa
...
@@ -2258,7 +2258,7 @@ void ath_tx_node_cleanup(struct ath_softc *sc, struct ath_node *an)
...
@@ -2258,7 +2258,7 @@ void ath_tx_node_cleanup(struct ath_softc *sc, struct ath_node *an)
if
(
ATH_TXQ_SETUP
(
sc
,
i
))
{
if
(
ATH_TXQ_SETUP
(
sc
,
i
))
{
txq
=
&
sc
->
tx
.
txq
[
i
];
txq
=
&
sc
->
tx
.
txq
[
i
];
spin_lock
(
&
txq
->
axq_lock
);
spin_lock
_bh
(
&
txq
->
axq_lock
);
list_for_each_entry_safe
(
ac
,
list_for_each_entry_safe
(
ac
,
ac_tmp
,
&
txq
->
axq_acq
,
list
)
{
ac_tmp
,
&
txq
->
axq_acq
,
list
)
{
...
@@ -2279,7 +2279,7 @@ void ath_tx_node_cleanup(struct ath_softc *sc, struct ath_node *an)
...
@@ -2279,7 +2279,7 @@ void ath_tx_node_cleanup(struct ath_softc *sc, struct ath_node *an)
}
}
}
}
spin_unlock
(
&
txq
->
axq_lock
);
spin_unlock
_bh
(
&
txq
->
axq_lock
);
}
}
}
}
}
}
drivers/net/wireless/iwlwifi/iwl-agn.c
View file @
e5c1a0aa
...
@@ -1463,59 +1463,66 @@ static void iwl_nic_start(struct iwl_priv *priv)
...
@@ -1463,59 +1463,66 @@ static void iwl_nic_start(struct iwl_priv *priv)
}
}
static
void
iwl_ucode_callback
(
const
struct
firmware
*
ucode_raw
,
void
*
context
);
static
int
iwl_mac_setup_register
(
struct
iwl_priv
*
priv
);
static
int
__must_check
iwl_request_firmware
(
struct
iwl_priv
*
priv
,
bool
first
)
{
const
char
*
name_pre
=
priv
->
cfg
->
fw_name_pre
;
if
(
first
)
priv
->
fw_index
=
priv
->
cfg
->
ucode_api_max
;
else
priv
->
fw_index
--
;
if
(
priv
->
fw_index
<
priv
->
cfg
->
ucode_api_min
)
{
IWL_ERR
(
priv
,
"no suitable firmware found!
\n
"
);
return
-
ENOENT
;
}
sprintf
(
priv
->
firmware_name
,
"%s%d%s"
,
name_pre
,
priv
->
fw_index
,
".ucode"
);
IWL_DEBUG_INFO
(
priv
,
"attempting to load firmware '%s'
\n
"
,
priv
->
firmware_name
);
return
request_firmware_nowait
(
THIS_MODULE
,
1
,
priv
->
firmware_name
,
&
priv
->
pci_dev
->
dev
,
GFP_KERNEL
,
priv
,
iwl_ucode_callback
);
}
/**
/**
* iwl_
read_ucode - Read uCode images from disk file.
* iwl_
ucode_callback - callback when firmware was loaded
*
*
* Copy into buffers for card to fetch via bus-mastering
* If loaded successfully, copies the firmware into buffers
* for the card to fetch (via DMA).
*/
*/
static
int
iwl_read_ucode
(
struct
iwl_priv
*
priv
)
static
void
iwl_ucode_callback
(
const
struct
firmware
*
ucode_raw
,
void
*
context
)
{
{
struct
iwl_priv
*
priv
=
context
;
struct
iwl_ucode_header
*
ucode
;
struct
iwl_ucode_header
*
ucode
;
int
ret
=
-
EINVAL
,
index
;
const
struct
firmware
*
ucode_raw
;
const
char
*
name_pre
=
priv
->
cfg
->
fw_name_pre
;
const
unsigned
int
api_max
=
priv
->
cfg
->
ucode_api_max
;
const
unsigned
int
api_max
=
priv
->
cfg
->
ucode_api_max
;
const
unsigned
int
api_min
=
priv
->
cfg
->
ucode_api_min
;
const
unsigned
int
api_min
=
priv
->
cfg
->
ucode_api_min
;
char
buf
[
25
];
u8
*
src
;
u8
*
src
;
size_t
len
;
size_t
len
;
u32
api_ver
,
build
;
u32
api_ver
,
build
;
u32
inst_size
,
data_size
,
init_size
,
init_data_size
,
boot_size
;
u32
inst_size
,
data_size
,
init_size
,
init_data_size
,
boot_size
;
int
err
;
u16
eeprom_ver
;
u16
eeprom_ver
;
/* Ask kernel firmware_class module to get the boot firmware off disk.
if
(
!
ucode_raw
)
{
* request_firmware() is synchronous, file is in memory on return. */
IWL_ERR
(
priv
,
"request for firmware file '%s' failed.
\n
"
,
for
(
index
=
api_max
;
index
>=
api_min
;
index
--
)
{
priv
->
firmware_name
);
sprintf
(
buf
,
"%s%d%s"
,
name_pre
,
index
,
".ucode"
);
goto
try_again
;
ret
=
request_firmware
(
&
ucode_raw
,
buf
,
&
priv
->
pci_dev
->
dev
);
if
(
ret
<
0
)
{
IWL_ERR
(
priv
,
"%s firmware file req failed: %d
\n
"
,
buf
,
ret
);
if
(
ret
==
-
ENOENT
)
continue
;
else
goto
error
;
}
else
{
if
(
index
<
api_max
)
IWL_ERR
(
priv
,
"Loaded firmware %s, "
"which is deprecated. "
"Please use API v%u instead.
\n
"
,
buf
,
api_max
);
IWL_DEBUG_INFO
(
priv
,
"Got firmware '%s' file (%zd bytes) from disk
\n
"
,
buf
,
ucode_raw
->
size
);
break
;
}
}
}
if
(
ret
<
0
)
IWL_DEBUG_INFO
(
priv
,
"Loaded firmware file '%s' (%zd bytes).
\n
"
,
goto
error
;
priv
->
firmware_name
,
ucode_raw
->
size
)
;
/* Make sure that we got at least the v1 header! */
/* Make sure that we got at least the v1 header! */
if
(
ucode_raw
->
size
<
priv
->
cfg
->
ops
->
ucode
->
get_header_size
(
1
))
{
if
(
ucode_raw
->
size
<
priv
->
cfg
->
ops
->
ucode
->
get_header_size
(
1
))
{
IWL_ERR
(
priv
,
"File size way too small!
\n
"
);
IWL_ERR
(
priv
,
"File size way too small!
\n
"
);
ret
=
-
EINVAL
;
goto
try_again
;
goto
err_release
;
}
}
/* Data from ucode file: header followed by uCode images */
/* Data from ucode file: header followed by uCode images */
...
@@ -1540,10 +1547,9 @@ static int iwl_read_ucode(struct iwl_priv *priv)
...
@@ -1540,10 +1547,9 @@ static int iwl_read_ucode(struct iwl_priv *priv)
IWL_ERR
(
priv
,
"Driver unable to support your firmware API. "
IWL_ERR
(
priv
,
"Driver unable to support your firmware API. "
"Driver supports v%u, firmware is v%u.
\n
"
,
"Driver supports v%u, firmware is v%u.
\n
"
,
api_max
,
api_ver
);
api_max
,
api_ver
);
priv
->
ucode_ver
=
0
;
goto
try_again
;
ret
=
-
EINVAL
;
goto
err_release
;
}
}
if
(
api_ver
!=
api_max
)
if
(
api_ver
!=
api_max
)
IWL_ERR
(
priv
,
"Firmware has old API version. Expected v%u, "
IWL_ERR
(
priv
,
"Firmware has old API version. Expected v%u, "
"got v%u. New firmware can be obtained "
"got v%u. New firmware can be obtained "
...
@@ -1585,6 +1591,12 @@ static int iwl_read_ucode(struct iwl_priv *priv)
...
@@ -1585,6 +1591,12 @@ static int iwl_read_ucode(struct iwl_priv *priv)
IWL_DEBUG_INFO
(
priv
,
"f/w package hdr boot inst size = %u
\n
"
,
IWL_DEBUG_INFO
(
priv
,
"f/w package hdr boot inst size = %u
\n
"
,
boot_size
);
boot_size
);
/*
* For any of the failures below (before allocating pci memory)
* we will try to load a version with a smaller API -- maybe the
* user just got a corrupted version of the latest API.
*/
/* Verify size of file vs. image size info in file's header */
/* Verify size of file vs. image size info in file's header */
if
(
ucode_raw
->
size
!=
if
(
ucode_raw
->
size
!=
priv
->
cfg
->
ops
->
ucode
->
get_header_size
(
api_ver
)
+
priv
->
cfg
->
ops
->
ucode
->
get_header_size
(
api_ver
)
+
...
@@ -1594,41 +1606,35 @@ static int iwl_read_ucode(struct iwl_priv *priv)
...
@@ -1594,41 +1606,35 @@ static int iwl_read_ucode(struct iwl_priv *priv)
IWL_DEBUG_INFO
(
priv
,
IWL_DEBUG_INFO
(
priv
,
"uCode file size %d does not match expected size
\n
"
,
"uCode file size %d does not match expected size
\n
"
,
(
int
)
ucode_raw
->
size
);
(
int
)
ucode_raw
->
size
);
ret
=
-
EINVAL
;
goto
try_again
;
goto
err_release
;
}
}
/* Verify that uCode images will fit in card's SRAM */
/* Verify that uCode images will fit in card's SRAM */
if
(
inst_size
>
priv
->
hw_params
.
max_inst_size
)
{
if
(
inst_size
>
priv
->
hw_params
.
max_inst_size
)
{
IWL_DEBUG_INFO
(
priv
,
"uCode instr len %d too large to fit in
\n
"
,
IWL_DEBUG_INFO
(
priv
,
"uCode instr len %d too large to fit in
\n
"
,
inst_size
);
inst_size
);
ret
=
-
EINVAL
;
goto
try_again
;
goto
err_release
;
}
}
if
(
data_size
>
priv
->
hw_params
.
max_data_size
)
{
if
(
data_size
>
priv
->
hw_params
.
max_data_size
)
{
IWL_DEBUG_INFO
(
priv
,
"uCode data len %d too large to fit in
\n
"
,
IWL_DEBUG_INFO
(
priv
,
"uCode data len %d too large to fit in
\n
"
,
data_size
);
data_size
);
ret
=
-
EINVAL
;
goto
try_again
;
goto
err_release
;
}
}
if
(
init_size
>
priv
->
hw_params
.
max_inst_size
)
{
if
(
init_size
>
priv
->
hw_params
.
max_inst_size
)
{
IWL_INFO
(
priv
,
"uCode init instr len %d too large to fit in
\n
"
,
IWL_INFO
(
priv
,
"uCode init instr len %d too large to fit in
\n
"
,
init_size
);
init_size
);
ret
=
-
EINVAL
;
goto
try_again
;
goto
err_release
;
}
}
if
(
init_data_size
>
priv
->
hw_params
.
max_data_size
)
{
if
(
init_data_size
>
priv
->
hw_params
.
max_data_size
)
{
IWL_INFO
(
priv
,
"uCode init data len %d too large to fit in
\n
"
,
IWL_INFO
(
priv
,
"uCode init data len %d too large to fit in
\n
"
,
init_data_size
);
init_data_size
);
ret
=
-
EINVAL
;
goto
try_again
;
goto
err_release
;
}
}
if
(
boot_size
>
priv
->
hw_params
.
max_bsm_size
)
{
if
(
boot_size
>
priv
->
hw_params
.
max_bsm_size
)
{
IWL_INFO
(
priv
,
"uCode boot instr len %d too large to fit in
\n
"
,
IWL_INFO
(
priv
,
"uCode boot instr len %d too large to fit in
\n
"
,
boot_size
);
boot_size
);
ret
=
-
EINVAL
;
goto
try_again
;
goto
err_release
;
}
}
/* Allocate ucode buffers for card's bus-master loading ... */
/* Allocate ucode buffers for card's bus-master loading ... */
...
@@ -1712,20 +1718,36 @@ static int iwl_read_ucode(struct iwl_priv *priv)
...
@@ -1712,20 +1718,36 @@ static int iwl_read_ucode(struct iwl_priv *priv)
IWL_DEBUG_INFO
(
priv
,
"Copying (but not loading) boot instr len %Zd
\n
"
,
len
);
IWL_DEBUG_INFO
(
priv
,
"Copying (but not loading) boot instr len %Zd
\n
"
,
len
);
memcpy
(
priv
->
ucode_boot
.
v_addr
,
src
,
len
);
memcpy
(
priv
->
ucode_boot
.
v_addr
,
src
,
len
);
/**************************************************
* This is still part of probe() in a sense...
*
* 9. Setup and register with mac80211 and debugfs
**************************************************/
err
=
iwl_mac_setup_register
(
priv
);
if
(
err
)
goto
out_unbind
;
err
=
iwl_dbgfs_register
(
priv
,
DRV_NAME
);
if
(
err
)
IWL_ERR
(
priv
,
"failed to create debugfs files. Ignoring error: %d
\n
"
,
err
);
/* We have our copies now, allow OS release its copies */
/* We have our copies now, allow OS release its copies */
release_firmware
(
ucode_raw
);
release_firmware
(
ucode_raw
);
return
0
;
return
;
try_again:
/* try next, if any */
if
(
iwl_request_firmware
(
priv
,
false
))
goto
out_unbind
;
release_firmware
(
ucode_raw
);
return
;
err_pci_alloc:
err_pci_alloc:
IWL_ERR
(
priv
,
"failed to allocate pci memory
\n
"
);
IWL_ERR
(
priv
,
"failed to allocate pci memory
\n
"
);
ret
=
-
ENOMEM
;
iwl_dealloc_ucode_pci
(
priv
);
iwl_dealloc_ucode_pci
(
priv
);
out_unbind:
err_release:
device_release_driver
(
&
priv
->
pci_dev
->
dev
);
release_firmware
(
ucode_raw
);
release_firmware
(
ucode_raw
);
error:
return
ret
;
}
}
static
const
char
*
desc_lookup_text
[]
=
{
static
const
char
*
desc_lookup_text
[]
=
{
...
@@ -2667,21 +2689,7 @@ static int iwl_mac_start(struct ieee80211_hw *hw)
...
@@ -2667,21 +2689,7 @@ static int iwl_mac_start(struct ieee80211_hw *hw)
/* we should be verifying the device is ready to be opened */
/* we should be verifying the device is ready to be opened */
mutex_lock
(
&
priv
->
mutex
);
mutex_lock
(
&
priv
->
mutex
);
/* fetch ucode file from disk, alloc and copy to bus-master buffers ...
* ucode filename and max sizes are card-specific. */
if
(
!
priv
->
ucode_code
.
len
)
{
ret
=
iwl_read_ucode
(
priv
);
if
(
ret
)
{
IWL_ERR
(
priv
,
"Could not read microcode: %d
\n
"
,
ret
);
mutex_unlock
(
&
priv
->
mutex
);
return
ret
;
}
}
ret
=
__iwl_up
(
priv
);
ret
=
__iwl_up
(
priv
);
mutex_unlock
(
&
priv
->
mutex
);
mutex_unlock
(
&
priv
->
mutex
);
if
(
ret
)
if
(
ret
)
...
@@ -3654,17 +3662,10 @@ static int iwl_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
...
@@ -3654,17 +3662,10 @@ static int iwl_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
iwl_power_initialize
(
priv
);
iwl_power_initialize
(
priv
);
iwl_tt_initialize
(
priv
);
iwl_tt_initialize
(
priv
);
/**************************************************
err
=
iwl_request_firmware
(
priv
,
true
);
* 9. Setup and register with mac80211 and debugfs
**************************************************/
err
=
iwl_mac_setup_register
(
priv
);
if
(
err
)
if
(
err
)
goto
out_remove_sysfs
;
goto
out_remove_sysfs
;
err
=
iwl_dbgfs_register
(
priv
,
DRV_NAME
);
if
(
err
)
IWL_ERR
(
priv
,
"failed to create debugfs files. Ignoring error: %d
\n
"
,
err
);
return
0
;
return
0
;
out_remove_sysfs:
out_remove_sysfs:
...
...
drivers/net/wireless/iwlwifi/iwl-dev.h
View file @
e5c1a0aa
...
@@ -1132,6 +1132,7 @@ struct iwl_priv {
...
@@ -1132,6 +1132,7 @@ struct iwl_priv {
u8
rev_id
;
u8
rev_id
;
/* uCode images, save to reload in case of failure */
/* uCode images, save to reload in case of failure */
int
fw_index
;
/* firmware we're trying to load */
u32
ucode_ver
;
/* version of ucode, copy of
u32
ucode_ver
;
/* version of ucode, copy of
iwl_ucode.ver */
iwl_ucode.ver */
struct
fw_desc
ucode_code
;
/* runtime inst */
struct
fw_desc
ucode_code
;
/* runtime inst */
...
@@ -1142,6 +1143,7 @@ struct iwl_priv {
...
@@ -1142,6 +1143,7 @@ struct iwl_priv {
struct
fw_desc
ucode_boot
;
/* bootstrap inst */
struct
fw_desc
ucode_boot
;
/* bootstrap inst */
enum
ucode_type
ucode_type
;
enum
ucode_type
ucode_type
;
u8
ucode_write_complete
;
/* the image write is complete */
u8
ucode_write_complete
;
/* the image write is complete */
char
firmware_name
[
25
];
struct
iwl_rxon_time_cmd
rxon_timing
;
struct
iwl_rxon_time_cmd
rxon_timing
;
...
...
drivers/net/wireless/rt2x00/rt2800pci.c
View file @
e5c1a0aa
...
@@ -1225,7 +1225,7 @@ MODULE_LICENSE("GPL");
...
@@ -1225,7 +1225,7 @@ MODULE_LICENSE("GPL");
#ifdef CONFIG_RT2800PCI_SOC
#ifdef CONFIG_RT2800PCI_SOC
static
int
rt2800soc_probe
(
struct
platform_device
*
pdev
)
static
int
rt2800soc_probe
(
struct
platform_device
*
pdev
)
{
{
return
rt2x00soc_probe
(
pdev
,
rt2800pci_ops
);
return
rt2x00soc_probe
(
pdev
,
&
rt2800pci_ops
);
}
}
static
struct
platform_driver
rt2800soc_driver
=
{
static
struct
platform_driver
rt2800soc_driver
=
{
...
...
drivers/net/wireless/rt2x00/rt2x00soc.c
View file @
e5c1a0aa
...
@@ -112,6 +112,7 @@ int rt2x00soc_probe(struct platform_device *pdev, const struct rt2x00_ops *ops)
...
@@ -112,6 +112,7 @@ int rt2x00soc_probe(struct platform_device *pdev, const struct rt2x00_ops *ops)
return
retval
;
return
retval
;
}
}
EXPORT_SYMBOL_GPL
(
rt2x00soc_probe
);
int
rt2x00soc_remove
(
struct
platform_device
*
pdev
)
int
rt2x00soc_remove
(
struct
platform_device
*
pdev
)
{
{
...
...
drivers/net/wireless/rt2x00/rt73usb.c
View file @
e5c1a0aa
...
@@ -2352,6 +2352,8 @@ static struct usb_device_id rt73usb_device_table[] = {
...
@@ -2352,6 +2352,8 @@ static struct usb_device_id rt73usb_device_table[] = {
{
USB_DEVICE
(
0x0411
,
0x00f4
),
USB_DEVICE_DATA
(
&
rt73usb_ops
)
},
{
USB_DEVICE
(
0x0411
,
0x00f4
),
USB_DEVICE_DATA
(
&
rt73usb_ops
)
},
{
USB_DEVICE
(
0x0411
,
0x0116
),
USB_DEVICE_DATA
(
&
rt73usb_ops
)
},
{
USB_DEVICE
(
0x0411
,
0x0116
),
USB_DEVICE_DATA
(
&
rt73usb_ops
)
},
{
USB_DEVICE
(
0x0411
,
0x0119
),
USB_DEVICE_DATA
(
&
rt73usb_ops
)
},
{
USB_DEVICE
(
0x0411
,
0x0119
),
USB_DEVICE_DATA
(
&
rt73usb_ops
)
},
/* CEIVA */
{
USB_DEVICE
(
0x178d
,
0x02be
),
USB_DEVICE_DATA
(
&
rt73usb_ops
)
},
/* CNet */
/* CNet */
{
USB_DEVICE
(
0x1371
,
0x9022
),
USB_DEVICE_DATA
(
&
rt73usb_ops
)
},
{
USB_DEVICE
(
0x1371
,
0x9022
),
USB_DEVICE_DATA
(
&
rt73usb_ops
)
},
{
USB_DEVICE
(
0x1371
,
0x9032
),
USB_DEVICE_DATA
(
&
rt73usb_ops
)
},
{
USB_DEVICE
(
0x1371
,
0x9032
),
USB_DEVICE_DATA
(
&
rt73usb_ops
)
},
...
...
drivers/net/wireless/zd1211rw/zd_mac.c
View file @
e5c1a0aa
...
@@ -350,7 +350,7 @@ static void zd_mac_tx_status(struct ieee80211_hw *hw, struct sk_buff *skb,
...
@@ -350,7 +350,7 @@ static void zd_mac_tx_status(struct ieee80211_hw *hw, struct sk_buff *skb,
first_idx
=
info
->
status
.
rates
[
0
].
idx
;
first_idx
=
info
->
status
.
rates
[
0
].
idx
;
ZD_ASSERT
(
0
<=
first_idx
&&
first_idx
<
ARRAY_SIZE
(
zd_retry_rates
));
ZD_ASSERT
(
0
<=
first_idx
&&
first_idx
<
ARRAY_SIZE
(
zd_retry_rates
));
retries
=
&
zd_retry_rates
[
first_idx
];
retries
=
&
zd_retry_rates
[
first_idx
];
ZD_ASSERT
(
0
<=
retry
&&
retry
<=
retries
->
count
);
ZD_ASSERT
(
1
<=
retry
&&
retry
<=
retries
->
count
);
info
->
status
.
rates
[
0
].
idx
=
retries
->
rate
[
0
];
info
->
status
.
rates
[
0
].
idx
=
retries
->
rate
[
0
];
info
->
status
.
rates
[
0
].
count
=
1
;
// (retry > 1 ? 2 : 1);
info
->
status
.
rates
[
0
].
count
=
1
;
// (retry > 1 ? 2 : 1);
...
@@ -360,7 +360,7 @@ static void zd_mac_tx_status(struct ieee80211_hw *hw, struct sk_buff *skb,
...
@@ -360,7 +360,7 @@ static void zd_mac_tx_status(struct ieee80211_hw *hw, struct sk_buff *skb,
info
->
status
.
rates
[
i
].
count
=
1
;
// ((i==retry-1) && success ? 1:2);
info
->
status
.
rates
[
i
].
count
=
1
;
// ((i==retry-1) && success ? 1:2);
}
}
for
(;
i
<
IEEE80211_TX_MAX_RATES
&&
i
<
retry
;
i
++
)
{
for
(;
i
<
IEEE80211_TX_MAX_RATES
&&
i
<
retry
;
i
++
)
{
info
->
status
.
rates
[
i
].
idx
=
retries
->
rate
[
retry
-
1
];
info
->
status
.
rates
[
i
].
idx
=
retries
->
rate
[
retry
-
1
];
info
->
status
.
rates
[
i
].
count
=
1
;
// (success ? 1:2);
info
->
status
.
rates
[
i
].
count
=
1
;
// (success ? 1:2);
}
}
if
(
i
<
IEEE80211_TX_MAX_RATES
)
if
(
i
<
IEEE80211_TX_MAX_RATES
)
...
@@ -424,12 +424,10 @@ void zd_mac_tx_failed(struct urb *urb)
...
@@ -424,12 +424,10 @@ void zd_mac_tx_failed(struct urb *urb)
first_idx
=
info
->
status
.
rates
[
0
].
idx
;
first_idx
=
info
->
status
.
rates
[
0
].
idx
;
ZD_ASSERT
(
0
<=
first_idx
&&
first_idx
<
ARRAY_SIZE
(
zd_retry_rates
));
ZD_ASSERT
(
0
<=
first_idx
&&
first_idx
<
ARRAY_SIZE
(
zd_retry_rates
));
retries
=
&
zd_retry_rates
[
first_idx
];
retries
=
&
zd_retry_rates
[
first_idx
];
if
(
retry
<
0
||
retry
>
retries
->
count
)
{
if
(
retry
<
=
0
||
retry
>
retries
->
count
)
continue
;
continue
;
}
ZD_ASSERT
(
0
<=
retry
&&
retry
<=
retries
->
count
);
final_idx
=
retries
->
rate
[
retry
-
1
];
final_idx
=
retries
->
rate
[
retry
-
1
];
final_rate
=
zd_rates
[
final_idx
].
hw_value
;
final_rate
=
zd_rates
[
final_idx
].
hw_value
;
if
(
final_rate
!=
tx_status
->
rate
)
{
if
(
final_rate
!=
tx_status
->
rate
)
{
...
...
include/linux/rfkill.h
View file @
e5c1a0aa
...
@@ -29,7 +29,7 @@
...
@@ -29,7 +29,7 @@
/**
/**
* enum rfkill_type - type of rfkill switch.
* enum rfkill_type - type of rfkill switch.
*
*
* @RFKILL_TYPE_ALL: toggles all switches (
userspace only
)
* @RFKILL_TYPE_ALL: toggles all switches (
requests only - not a switch type
)
* @RFKILL_TYPE_WLAN: switch is on a 802.11 wireless network device.
* @RFKILL_TYPE_WLAN: switch is on a 802.11 wireless network device.
* @RFKILL_TYPE_BLUETOOTH: switch is on a bluetooth device.
* @RFKILL_TYPE_BLUETOOTH: switch is on a bluetooth device.
* @RFKILL_TYPE_UWB: switch is on a ultra wideband device.
* @RFKILL_TYPE_UWB: switch is on a ultra wideband device.
...
...
include/net/mac80211.h
View file @
e5c1a0aa
...
@@ -2426,7 +2426,8 @@ struct rate_control_ops {
...
@@ -2426,7 +2426,8 @@ struct rate_control_ops {
struct
ieee80211_sta
*
sta
,
void
*
priv_sta
);
struct
ieee80211_sta
*
sta
,
void
*
priv_sta
);
void
(
*
rate_update
)(
void
*
priv
,
struct
ieee80211_supported_band
*
sband
,
void
(
*
rate_update
)(
void
*
priv
,
struct
ieee80211_supported_band
*
sband
,
struct
ieee80211_sta
*
sta
,
struct
ieee80211_sta
*
sta
,
void
*
priv_sta
,
u32
changed
);
void
*
priv_sta
,
u32
changed
,
enum
nl80211_channel_type
oper_chan_type
);
void
(
*
free_sta
)(
void
*
priv
,
struct
ieee80211_sta
*
sta
,
void
(
*
free_sta
)(
void
*
priv
,
struct
ieee80211_sta
*
sta
,
void
*
priv_sta
);
void
*
priv_sta
);
...
...
net/mac80211/mlme.c
View file @
e5c1a0aa
...
@@ -177,7 +177,8 @@ static u32 ieee80211_enable_ht(struct ieee80211_sub_if_data *sdata,
...
@@ -177,7 +177,8 @@ static u32 ieee80211_enable_ht(struct ieee80211_sub_if_data *sdata,
sta
=
sta_info_get
(
sdata
,
bssid
);
sta
=
sta_info_get
(
sdata
,
bssid
);
if
(
sta
)
if
(
sta
)
rate_control_rate_update
(
local
,
sband
,
sta
,
rate_control_rate_update
(
local
,
sband
,
sta
,
IEEE80211_RC_HT_CHANGED
);
IEEE80211_RC_HT_CHANGED
,
local
->
oper_channel_type
);
rcu_read_unlock
();
rcu_read_unlock
();
}
}
...
@@ -1893,8 +1894,20 @@ int ieee80211_mgd_assoc(struct ieee80211_sub_if_data *sdata,
...
@@ -1893,8 +1894,20 @@ int ieee80211_mgd_assoc(struct ieee80211_sub_if_data *sdata,
mutex_lock
(
&
ifmgd
->
mtx
);
mutex_lock
(
&
ifmgd
->
mtx
);
if
(
ifmgd
->
associated
)
{
if
(
ifmgd
->
associated
)
{
mutex_unlock
(
&
ifmgd
->
mtx
);
if
(
!
req
->
prev_bssid
||
return
-
EALREADY
;
memcmp
(
req
->
prev_bssid
,
ifmgd
->
associated
->
bssid
,
ETH_ALEN
))
{
/*
* We are already associated and the request was not a
* reassociation request from the current BSS, so
* reject it.
*/
mutex_unlock
(
&
ifmgd
->
mtx
);
return
-
EALREADY
;
}
/* Trying to reassociate - clear previous association state */
ieee80211_set_disassoc
(
sdata
);
}
}
mutex_unlock
(
&
ifmgd
->
mtx
);
mutex_unlock
(
&
ifmgd
->
mtx
);
...
...
net/mac80211/rate.h
View file @
e5c1a0aa
...
@@ -66,7 +66,8 @@ static inline void rate_control_rate_init(struct sta_info *sta)
...
@@ -66,7 +66,8 @@ static inline void rate_control_rate_init(struct sta_info *sta)
static
inline
void
rate_control_rate_update
(
struct
ieee80211_local
*
local
,
static
inline
void
rate_control_rate_update
(
struct
ieee80211_local
*
local
,
struct
ieee80211_supported_band
*
sband
,
struct
ieee80211_supported_band
*
sband
,
struct
sta_info
*
sta
,
u32
changed
)
struct
sta_info
*
sta
,
u32
changed
,
enum
nl80211_channel_type
oper_chan_type
)
{
{
struct
rate_control_ref
*
ref
=
local
->
rate_ctrl
;
struct
rate_control_ref
*
ref
=
local
->
rate_ctrl
;
struct
ieee80211_sta
*
ista
=
&
sta
->
sta
;
struct
ieee80211_sta
*
ista
=
&
sta
->
sta
;
...
@@ -74,7 +75,7 @@ static inline void rate_control_rate_update(struct ieee80211_local *local,
...
@@ -74,7 +75,7 @@ static inline void rate_control_rate_update(struct ieee80211_local *local,
if
(
ref
&&
ref
->
ops
->
rate_update
)
if
(
ref
&&
ref
->
ops
->
rate_update
)
ref
->
ops
->
rate_update
(
ref
->
priv
,
sband
,
ista
,
ref
->
ops
->
rate_update
(
ref
->
priv
,
sband
,
ista
,
priv_sta
,
changed
);
priv_sta
,
changed
,
oper_chan_type
);
}
}
static
inline
void
*
rate_control_alloc_sta
(
struct
rate_control_ref
*
ref
,
static
inline
void
*
rate_control_alloc_sta
(
struct
rate_control_ref
*
ref
,
...
...
net/rfkill/input.c
View file @
e5c1a0aa
...
@@ -212,6 +212,9 @@ static void rfkill_event(struct input_handle *handle, unsigned int type,
...
@@ -212,6 +212,9 @@ static void rfkill_event(struct input_handle *handle, unsigned int type,
case
KEY_WIMAX
:
case
KEY_WIMAX
:
rfkill_schedule_toggle
(
RFKILL_TYPE_WIMAX
);
rfkill_schedule_toggle
(
RFKILL_TYPE_WIMAX
);
break
;
break
;
case
KEY_RFKILL
:
rfkill_schedule_toggle
(
RFKILL_TYPE_ALL
);
break
;
}
}
}
else
if
(
type
==
EV_SW
&&
code
==
SW_RFKILL_ALL
)
}
else
if
(
type
==
EV_SW
&&
code
==
SW_RFKILL_ALL
)
rfkill_schedule_evsw_rfkillall
(
data
);
rfkill_schedule_evsw_rfkillall
(
data
);
...
@@ -294,6 +297,11 @@ static const struct input_device_id rfkill_ids[] = {
...
@@ -294,6 +297,11 @@ static const struct input_device_id rfkill_ids[] = {
.
evbit
=
{
BIT_MASK
(
EV_KEY
)
},
.
evbit
=
{
BIT_MASK
(
EV_KEY
)
},
.
keybit
=
{
[
BIT_WORD
(
KEY_WIMAX
)]
=
BIT_MASK
(
KEY_WIMAX
)
},
.
keybit
=
{
[
BIT_WORD
(
KEY_WIMAX
)]
=
BIT_MASK
(
KEY_WIMAX
)
},
},
},
{
.
flags
=
INPUT_DEVICE_ID_MATCH_EVBIT
|
INPUT_DEVICE_ID_MATCH_KEYBIT
,
.
evbit
=
{
BIT_MASK
(
EV_KEY
)
},
.
keybit
=
{
[
BIT_WORD
(
KEY_RFKILL
)]
=
BIT_MASK
(
KEY_RFKILL
)
},
},
{
{
.
flags
=
INPUT_DEVICE_ID_MATCH_EVBIT
|
INPUT_DEVICE_ID_MATCH_SWBIT
,
.
flags
=
INPUT_DEVICE_ID_MATCH_EVBIT
|
INPUT_DEVICE_ID_MATCH_SWBIT
,
.
evbit
=
{
BIT
(
EV_SW
)
},
.
evbit
=
{
BIT
(
EV_SW
)
},
...
...
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