Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
2b22b1b1
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 3 年多
通知
13
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
2b22b1b1
编写于
6月 06, 2011
作者:
D
David S. Miller
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'for-davem' of
git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6
上级
85fadea9
c1111471
变更
14
隐藏空白更改
内联
并排
Showing
14 changed file
with
68 addition
and
130 deletion
+68
-130
drivers/net/wireless/ath/ath5k/base.c
drivers/net/wireless/ath/ath5k/base.c
+10
-1
drivers/net/wireless/ath/ath5k/reset.c
drivers/net/wireless/ath/ath5k/reset.c
+4
-1
drivers/net/wireless/iwlwifi/iwl-2000.c
drivers/net/wireless/iwlwifi/iwl-2000.c
+0
-74
drivers/net/wireless/iwlwifi/iwl-5000.c
drivers/net/wireless/iwlwifi/iwl-5000.c
+0
-2
drivers/net/wireless/iwlwifi/iwl-6000.c
drivers/net/wireless/iwlwifi/iwl-6000.c
+0
-2
drivers/net/wireless/iwlwifi/iwl-agn-rxon.c
drivers/net/wireless/iwlwifi/iwl-agn-rxon.c
+3
-3
drivers/net/wireless/iwlwifi/iwl-agn.c
drivers/net/wireless/iwlwifi/iwl-agn.c
+10
-9
drivers/net/wireless/iwlwifi/iwl-core.c
drivers/net/wireless/iwlwifi/iwl-core.c
+1
-5
drivers/net/wireless/iwlwifi/iwl-core.h
drivers/net/wireless/iwlwifi/iwl-core.h
+1
-0
drivers/net/wireless/iwlwifi/iwl-dev.h
drivers/net/wireless/iwlwifi/iwl-dev.h
+1
-12
drivers/net/wireless/iwlwifi/iwl-rx.c
drivers/net/wireless/iwlwifi/iwl-rx.c
+12
-12
drivers/net/wireless/libertas/if_sdio.c
drivers/net/wireless/libertas/if_sdio.c
+16
-5
drivers/ssb/driver_pcicore.c
drivers/ssb/driver_pcicore.c
+6
-4
net/mac80211/iface.c
net/mac80211/iface.c
+4
-0
未找到文件。
drivers/net/wireless/ath/ath5k/base.c
浏览文件 @
2b22b1b1
...
@@ -72,6 +72,11 @@ static int modparam_all_channels;
...
@@ -72,6 +72,11 @@ static int modparam_all_channels;
module_param_named
(
all_channels
,
modparam_all_channels
,
bool
,
S_IRUGO
);
module_param_named
(
all_channels
,
modparam_all_channels
,
bool
,
S_IRUGO
);
MODULE_PARM_DESC
(
all_channels
,
"Expose all channels the device can use."
);
MODULE_PARM_DESC
(
all_channels
,
"Expose all channels the device can use."
);
static
int
modparam_fastchanswitch
;
module_param_named
(
fastchanswitch
,
modparam_fastchanswitch
,
bool
,
S_IRUGO
);
MODULE_PARM_DESC
(
fastchanswitch
,
"Enable fast channel switching for AR2413/AR5413 radios."
);
/* Module info */
/* Module info */
MODULE_AUTHOR
(
"Jiri Slaby"
);
MODULE_AUTHOR
(
"Jiri Slaby"
);
MODULE_AUTHOR
(
"Nick Kossifidis"
);
MODULE_AUTHOR
(
"Nick Kossifidis"
);
...
@@ -2686,6 +2691,7 @@ ath5k_reset(struct ath5k_softc *sc, struct ieee80211_channel *chan,
...
@@ -2686,6 +2691,7 @@ ath5k_reset(struct ath5k_softc *sc, struct ieee80211_channel *chan,
struct
ath5k_hw
*
ah
=
sc
->
ah
;
struct
ath5k_hw
*
ah
=
sc
->
ah
;
struct
ath_common
*
common
=
ath5k_hw_common
(
ah
);
struct
ath_common
*
common
=
ath5k_hw_common
(
ah
);
int
ret
,
ani_mode
;
int
ret
,
ani_mode
;
bool
fast
;
ATH5K_DBG
(
sc
,
ATH5K_DEBUG_RESET
,
"resetting
\n
"
);
ATH5K_DBG
(
sc
,
ATH5K_DEBUG_RESET
,
"resetting
\n
"
);
...
@@ -2705,7 +2711,10 @@ ath5k_reset(struct ath5k_softc *sc, struct ieee80211_channel *chan,
...
@@ -2705,7 +2711,10 @@ ath5k_reset(struct ath5k_softc *sc, struct ieee80211_channel *chan,
ath5k_drain_tx_buffs
(
sc
);
ath5k_drain_tx_buffs
(
sc
);
if
(
chan
)
if
(
chan
)
sc
->
curchan
=
chan
;
sc
->
curchan
=
chan
;
ret
=
ath5k_hw_reset
(
ah
,
sc
->
opmode
,
sc
->
curchan
,
chan
!=
NULL
,
fast
=
((
chan
!=
NULL
)
&&
modparam_fastchanswitch
)
?
1
:
0
;
ret
=
ath5k_hw_reset
(
ah
,
sc
->
opmode
,
sc
->
curchan
,
fast
,
skip_pcu
);
skip_pcu
);
if
(
ret
)
{
if
(
ret
)
{
ATH5K_ERR
(
sc
,
"can't reset hardware (%d)
\n
"
,
ret
);
ATH5K_ERR
(
sc
,
"can't reset hardware (%d)
\n
"
,
ret
);
...
...
drivers/net/wireless/ath/ath5k/reset.c
浏览文件 @
2b22b1b1
...
@@ -1124,8 +1124,11 @@ int ath5k_hw_reset(struct ath5k_hw *ah, enum nl80211_iftype op_mode,
...
@@ -1124,8 +1124,11 @@ int ath5k_hw_reset(struct ath5k_hw *ah, enum nl80211_iftype op_mode,
/* Non fatal, can happen eg.
/* Non fatal, can happen eg.
* on mode change */
* on mode change */
ret
=
0
;
ret
=
0
;
}
else
}
else
{
ATH5K_DBG
(
ah
->
ah_sc
,
ATH5K_DEBUG_RESET
,
"fast chan change successful
\n
"
);
return
0
;
return
0
;
}
}
}
/*
/*
...
...
drivers/net/wireless/iwlwifi/iwl-2000.c
浏览文件 @
2b22b1b1
...
@@ -177,79 +177,6 @@ static int iwl2000_hw_set_hw_params(struct iwl_priv *priv)
...
@@ -177,79 +177,6 @@ static int iwl2000_hw_set_hw_params(struct iwl_priv *priv)
return
0
;
return
0
;
}
}
static
int
iwl2030_hw_channel_switch
(
struct
iwl_priv
*
priv
,
struct
ieee80211_channel_switch
*
ch_switch
)
{
/*
* MULTI-FIXME
* See iwl_mac_channel_switch.
*/
struct
iwl_rxon_context
*
ctx
=
&
priv
->
contexts
[
IWL_RXON_CTX_BSS
];
struct
iwl6000_channel_switch_cmd
cmd
;
const
struct
iwl_channel_info
*
ch_info
;
u32
switch_time_in_usec
,
ucode_switch_time
;
u16
ch
;
u32
tsf_low
;
u8
switch_count
;
u16
beacon_interval
=
le16_to_cpu
(
ctx
->
timing
.
beacon_interval
);
struct
ieee80211_vif
*
vif
=
ctx
->
vif
;
struct
iwl_host_cmd
hcmd
=
{
.
id
=
REPLY_CHANNEL_SWITCH
,
.
len
=
{
sizeof
(
cmd
),
},
.
flags
=
CMD_SYNC
,
.
data
=
{
&
cmd
,
},
};
cmd
.
band
=
priv
->
band
==
IEEE80211_BAND_2GHZ
;
ch
=
ch_switch
->
channel
->
hw_value
;
IWL_DEBUG_11H
(
priv
,
"channel switch from %u to %u
\n
"
,
ctx
->
active
.
channel
,
ch
);
cmd
.
channel
=
cpu_to_le16
(
ch
);
cmd
.
rxon_flags
=
ctx
->
staging
.
flags
;
cmd
.
rxon_filter_flags
=
ctx
->
staging
.
filter_flags
;
switch_count
=
ch_switch
->
count
;
tsf_low
=
ch_switch
->
timestamp
&
0x0ffffffff
;
/*
* calculate the ucode channel switch time
* adding TSF as one of the factor for when to switch
*/
if
((
priv
->
ucode_beacon_time
>
tsf_low
)
&&
beacon_interval
)
{
if
(
switch_count
>
((
priv
->
ucode_beacon_time
-
tsf_low
)
/
beacon_interval
))
{
switch_count
-=
(
priv
->
ucode_beacon_time
-
tsf_low
)
/
beacon_interval
;
}
else
switch_count
=
0
;
}
if
(
switch_count
<=
1
)
cmd
.
switch_time
=
cpu_to_le32
(
priv
->
ucode_beacon_time
);
else
{
switch_time_in_usec
=
vif
->
bss_conf
.
beacon_int
*
switch_count
*
TIME_UNIT
;
ucode_switch_time
=
iwl_usecs_to_beacons
(
priv
,
switch_time_in_usec
,
beacon_interval
);
cmd
.
switch_time
=
iwl_add_beacon_time
(
priv
,
priv
->
ucode_beacon_time
,
ucode_switch_time
,
beacon_interval
);
}
IWL_DEBUG_11H
(
priv
,
"uCode time for the switch is 0x%x
\n
"
,
cmd
.
switch_time
);
ch_info
=
iwl_get_channel_info
(
priv
,
priv
->
band
,
ch
);
if
(
ch_info
)
cmd
.
expect_beacon
=
is_channel_radar
(
ch_info
);
else
{
IWL_ERR
(
priv
,
"invalid channel switch from %u to %u
\n
"
,
ctx
->
active
.
channel
,
ch
);
return
-
EFAULT
;
}
priv
->
switch_rxon
.
channel
=
cmd
.
channel
;
priv
->
switch_rxon
.
switch_in_progress
=
true
;
return
iwl_send_cmd_sync
(
priv
,
&
hcmd
);
}
static
struct
iwl_lib_ops
iwl2000_lib
=
{
static
struct
iwl_lib_ops
iwl2000_lib
=
{
.
set_hw_params
=
iwl2000_hw_set_hw_params
,
.
set_hw_params
=
iwl2000_hw_set_hw_params
,
.
rx_handler_setup
=
iwlagn_rx_handler_setup
,
.
rx_handler_setup
=
iwlagn_rx_handler_setup
,
...
@@ -258,7 +185,6 @@ static struct iwl_lib_ops iwl2000_lib = {
...
@@ -258,7 +185,6 @@ static struct iwl_lib_ops iwl2000_lib = {
.
is_valid_rtc_data_addr
=
iwlagn_hw_valid_rtc_data_addr
,
.
is_valid_rtc_data_addr
=
iwlagn_hw_valid_rtc_data_addr
,
.
send_tx_power
=
iwlagn_send_tx_power
,
.
send_tx_power
=
iwlagn_send_tx_power
,
.
update_chain_flags
=
iwl_update_chain_flags
,
.
update_chain_flags
=
iwl_update_chain_flags
,
.
set_channel_switch
=
iwl2030_hw_channel_switch
,
.
apm_ops
=
{
.
apm_ops
=
{
.
init
=
iwl_apm_init
,
.
init
=
iwl_apm_init
,
.
config
=
iwl2000_nic_config
,
.
config
=
iwl2000_nic_config
,
...
...
drivers/net/wireless/iwlwifi/iwl-5000.c
浏览文件 @
2b22b1b1
...
@@ -331,8 +331,6 @@ static int iwl5000_hw_channel_switch(struct iwl_priv *priv,
...
@@ -331,8 +331,6 @@ static int iwl5000_hw_channel_switch(struct iwl_priv *priv,
ctx
->
active
.
channel
,
ch
);
ctx
->
active
.
channel
,
ch
);
return
-
EFAULT
;
return
-
EFAULT
;
}
}
priv
->
switch_rxon
.
channel
=
cmd
.
channel
;
priv
->
switch_rxon
.
switch_in_progress
=
true
;
return
iwl_send_cmd_sync
(
priv
,
&
hcmd
);
return
iwl_send_cmd_sync
(
priv
,
&
hcmd
);
}
}
...
...
drivers/net/wireless/iwlwifi/iwl-6000.c
浏览文件 @
2b22b1b1
...
@@ -270,8 +270,6 @@ static int iwl6000_hw_channel_switch(struct iwl_priv *priv,
...
@@ -270,8 +270,6 @@ static int iwl6000_hw_channel_switch(struct iwl_priv *priv,
ctx
->
active
.
channel
,
ch
);
ctx
->
active
.
channel
,
ch
);
return
-
EFAULT
;
return
-
EFAULT
;
}
}
priv
->
switch_rxon
.
channel
=
cmd
.
channel
;
priv
->
switch_rxon
.
switch_in_progress
=
true
;
return
iwl_send_cmd_sync
(
priv
,
&
hcmd
);
return
iwl_send_cmd_sync
(
priv
,
&
hcmd
);
}
}
...
...
drivers/net/wireless/iwlwifi/iwl-agn-rxon.c
浏览文件 @
2b22b1b1
...
@@ -342,10 +342,10 @@ int iwlagn_commit_rxon(struct iwl_priv *priv, struct iwl_rxon_context *ctx)
...
@@ -342,10 +342,10 @@ int iwlagn_commit_rxon(struct iwl_priv *priv, struct iwl_rxon_context *ctx)
* receive commit_rxon request
* receive commit_rxon request
* abort any previous channel switch if still in process
* abort any previous channel switch if still in process
*/
*/
if
(
priv
->
switch_rxon
.
switch_in_progress
&&
if
(
test_bit
(
STATUS_CHANNEL_SWITCH_PENDING
,
&
priv
->
status
)
&&
(
priv
->
switch_
rxon
.
channel
!=
ctx
->
staging
.
channel
))
{
(
priv
->
switch_channel
!=
ctx
->
staging
.
channel
))
{
IWL_DEBUG_11H
(
priv
,
"abort channel switch on %d
\n
"
,
IWL_DEBUG_11H
(
priv
,
"abort channel switch on %d
\n
"
,
le16_to_cpu
(
priv
->
switch_rxon
.
channel
));
le16_to_cpu
(
priv
->
switch_
channel
));
iwl_chswitch_done
(
priv
,
false
);
iwl_chswitch_done
(
priv
,
false
);
}
}
...
...
drivers/net/wireless/iwlwifi/iwl-agn.c
浏览文件 @
2b22b1b1
...
@@ -2843,16 +2843,13 @@ static void iwlagn_mac_channel_switch(struct ieee80211_hw *hw,
...
@@ -2843,16 +2843,13 @@ static void iwlagn_mac_channel_switch(struct ieee80211_hw *hw,
goto
out
;
goto
out
;
if
(
test_bit
(
STATUS_EXIT_PENDING
,
&
priv
->
status
)
||
if
(
test_bit
(
STATUS_EXIT_PENDING
,
&
priv
->
status
)
||
test_bit
(
STATUS_SCANNING
,
&
priv
->
status
))
test_bit
(
STATUS_SCANNING
,
&
priv
->
status
)
||
test_bit
(
STATUS_CHANNEL_SWITCH_PENDING
,
&
priv
->
status
))
goto
out
;
goto
out
;
if
(
!
iwl_is_associated_ctx
(
ctx
))
if
(
!
iwl_is_associated_ctx
(
ctx
))
goto
out
;
goto
out
;
/* channel switch in progress */
if
(
priv
->
switch_rxon
.
switch_in_progress
==
true
)
goto
out
;
if
(
priv
->
cfg
->
ops
->
lib
->
set_channel_switch
)
{
if
(
priv
->
cfg
->
ops
->
lib
->
set_channel_switch
)
{
ch
=
channel
->
hw_value
;
ch
=
channel
->
hw_value
;
...
@@ -2901,15 +2898,19 @@ static void iwlagn_mac_channel_switch(struct ieee80211_hw *hw,
...
@@ -2901,15 +2898,19 @@ static void iwlagn_mac_channel_switch(struct ieee80211_hw *hw,
* at this point, staging_rxon has the
* at this point, staging_rxon has the
* configuration for channel switch
* configuration for channel switch
*/
*/
set_bit
(
STATUS_CHANNEL_SWITCH_PENDING
,
&
priv
->
status
);
priv
->
switch_channel
=
cpu_to_le16
(
ch
);
if
(
priv
->
cfg
->
ops
->
lib
->
set_channel_switch
(
priv
,
if
(
priv
->
cfg
->
ops
->
lib
->
set_channel_switch
(
priv
,
ch_switch
))
ch_switch
))
{
priv
->
switch_rxon
.
switch_in_progress
=
false
;
clear_bit
(
STATUS_CHANNEL_SWITCH_PENDING
,
&
priv
->
status
);
priv
->
switch_channel
=
0
;
ieee80211_chswitch_done
(
ctx
->
vif
,
false
);
}
}
}
}
}
out:
out:
mutex_unlock
(
&
priv
->
mutex
);
mutex_unlock
(
&
priv
->
mutex
);
if
(
!
priv
->
switch_rxon
.
switch_in_progress
)
ieee80211_chswitch_done
(
ctx
->
vif
,
false
);
IWL_DEBUG_MAC80211
(
priv
,
"leave
\n
"
);
IWL_DEBUG_MAC80211
(
priv
,
"leave
\n
"
);
}
}
...
...
drivers/net/wireless/iwlwifi/iwl-core.c
浏览文件 @
2b22b1b1
...
@@ -843,12 +843,8 @@ void iwl_chswitch_done(struct iwl_priv *priv, bool is_success)
...
@@ -843,12 +843,8 @@ void iwl_chswitch_done(struct iwl_priv *priv, bool is_success)
if
(
test_bit
(
STATUS_EXIT_PENDING
,
&
priv
->
status
))
if
(
test_bit
(
STATUS_EXIT_PENDING
,
&
priv
->
status
))
return
;
return
;
if
(
priv
->
switch_rxon
.
switch_in_progress
)
{
if
(
test_and_clear_bit
(
STATUS_CHANNEL_SWITCH_PENDING
,
&
priv
->
status
))
ieee80211_chswitch_done
(
ctx
->
vif
,
is_success
);
ieee80211_chswitch_done
(
ctx
->
vif
,
is_success
);
mutex_lock
(
&
priv
->
mutex
);
priv
->
switch_rxon
.
switch_in_progress
=
false
;
mutex_unlock
(
&
priv
->
mutex
);
}
}
}
#ifdef CONFIG_IWLWIFI_DEBUG
#ifdef CONFIG_IWLWIFI_DEBUG
...
...
drivers/net/wireless/iwlwifi/iwl-core.h
浏览文件 @
2b22b1b1
...
@@ -560,6 +560,7 @@ void iwlcore_free_geos(struct iwl_priv *priv);
...
@@ -560,6 +560,7 @@ void iwlcore_free_geos(struct iwl_priv *priv);
#define STATUS_POWER_PMI 16
#define STATUS_POWER_PMI 16
#define STATUS_FW_ERROR 17
#define STATUS_FW_ERROR 17
#define STATUS_DEVICE_ENABLED 18
#define STATUS_DEVICE_ENABLED 18
#define STATUS_CHANNEL_SWITCH_PENDING 19
static
inline
int
iwl_is_ready
(
struct
iwl_priv
*
priv
)
static
inline
int
iwl_is_ready
(
struct
iwl_priv
*
priv
)
...
...
drivers/net/wireless/iwlwifi/iwl-dev.h
浏览文件 @
2b22b1b1
...
@@ -981,17 +981,6 @@ struct traffic_stats {
...
@@ -981,17 +981,6 @@ struct traffic_stats {
#endif
#endif
};
};
/*
* iwl_switch_rxon: "channel switch" structure
*
* @ switch_in_progress: channel switch in progress
* @ channel: new channel
*/
struct
iwl_switch_rxon
{
bool
switch_in_progress
;
__le16
channel
;
};
/*
/*
* schedule the timer to wake up every UCODE_TRACE_PERIOD milliseconds
* schedule the timer to wake up every UCODE_TRACE_PERIOD milliseconds
* to perform continuous uCode event logging operation if enabled
* to perform continuous uCode event logging operation if enabled
...
@@ -1287,7 +1276,7 @@ struct iwl_priv {
...
@@ -1287,7 +1276,7 @@ struct iwl_priv {
struct
iwl_rxon_context
contexts
[
NUM_IWL_RXON_CTX
];
struct
iwl_rxon_context
contexts
[
NUM_IWL_RXON_CTX
];
struct
iwl_switch_rxon
switch_rxon
;
__le16
switch_channel
;
struct
{
struct
{
u32
error_event_table
;
u32
error_event_table
;
...
...
drivers/net/wireless/iwlwifi/iwl-rx.c
浏览文件 @
2b22b1b1
...
@@ -250,19 +250,19 @@ static void iwl_rx_csa(struct iwl_priv *priv, struct iwl_rx_mem_buffer *rxb)
...
@@ -250,19 +250,19 @@ static void iwl_rx_csa(struct iwl_priv *priv, struct iwl_rx_mem_buffer *rxb)
struct
iwl_rxon_context
*
ctx
=
&
priv
->
contexts
[
IWL_RXON_CTX_BSS
];
struct
iwl_rxon_context
*
ctx
=
&
priv
->
contexts
[
IWL_RXON_CTX_BSS
];
struct
iwl_rxon_cmd
*
rxon
=
(
void
*
)
&
ctx
->
active
;
struct
iwl_rxon_cmd
*
rxon
=
(
void
*
)
&
ctx
->
active
;
if
(
priv
->
switch_rxon
.
switch_in_progress
)
{
if
(
!
test_bit
(
STATUS_CHANNEL_SWITCH_PENDING
,
&
priv
->
status
))
if
(
!
le32_to_cpu
(
csa
->
status
)
&&
return
;
(
csa
->
channel
==
priv
->
switch_rxon
.
channel
))
{
rxon
->
channel
=
csa
->
channel
;
if
(
!
le32_to_cpu
(
csa
->
status
)
&&
csa
->
channel
==
priv
->
switch_channel
)
{
ctx
->
staging
.
channel
=
csa
->
channel
;
rxon
->
channel
=
csa
->
channel
;
IWL_DEBUG_11H
(
priv
,
"CSA notif: channel %d
\n
"
,
ctx
->
staging
.
channel
=
csa
->
channel
;
le16_to_cpu
(
csa
->
channel
));
IWL_DEBUG_11H
(
priv
,
"CSA notif: channel %d
\n
"
,
iwl_chswitch_done
(
priv
,
true
);
}
else
{
IWL_ERR
(
priv
,
"CSA notif (fail) : channel %d
\n
"
,
le16_to_cpu
(
csa
->
channel
));
le16_to_cpu
(
csa
->
channel
));
iwl_chswitch_done
(
priv
,
false
);
iwl_chswitch_done
(
priv
,
true
);
}
}
else
{
IWL_ERR
(
priv
,
"CSA notif (fail) : channel %d
\n
"
,
le16_to_cpu
(
csa
->
channel
));
iwl_chswitch_done
(
priv
,
false
);
}
}
}
}
...
...
drivers/net/wireless/libertas/if_sdio.c
浏览文件 @
2b22b1b1
...
@@ -907,7 +907,7 @@ static void if_sdio_interrupt(struct sdio_func *func)
...
@@ -907,7 +907,7 @@ static void if_sdio_interrupt(struct sdio_func *func)
card
=
sdio_get_drvdata
(
func
);
card
=
sdio_get_drvdata
(
func
);
cause
=
sdio_readb
(
card
->
func
,
IF_SDIO_H_INT_STATUS
,
&
ret
);
cause
=
sdio_readb
(
card
->
func
,
IF_SDIO_H_INT_STATUS
,
&
ret
);
if
(
ret
)
if
(
ret
||
!
cause
)
goto
out
;
goto
out
;
lbs_deb_sdio
(
"interrupt: 0x%X
\n
"
,
(
unsigned
)
cause
);
lbs_deb_sdio
(
"interrupt: 0x%X
\n
"
,
(
unsigned
)
cause
);
...
@@ -1008,10 +1008,6 @@ static int if_sdio_probe(struct sdio_func *func,
...
@@ -1008,10 +1008,6 @@ static int if_sdio_probe(struct sdio_func *func,
if
(
ret
)
if
(
ret
)
goto
release
;
goto
release
;
ret
=
sdio_claim_irq
(
func
,
if_sdio_interrupt
);
if
(
ret
)
goto
disable
;
/* For 1-bit transfers to the 8686 model, we need to enable the
/* For 1-bit transfers to the 8686 model, we need to enable the
* interrupt flag in the CCCR register. Set the MMC_QUIRK_LENIENT_FN0
* interrupt flag in the CCCR register. Set the MMC_QUIRK_LENIENT_FN0
* bit to allow access to non-vendor registers. */
* bit to allow access to non-vendor registers. */
...
@@ -1082,6 +1078,21 @@ static int if_sdio_probe(struct sdio_func *func,
...
@@ -1082,6 +1078,21 @@ static int if_sdio_probe(struct sdio_func *func,
else
else
card
->
rx_unit
=
0
;
card
->
rx_unit
=
0
;
/*
* Set up the interrupt handler late.
*
* If we set it up earlier, the (buggy) hardware generates a spurious
* interrupt, even before the interrupt has been enabled, with
* CCCR_INTx = 0.
*
* We register the interrupt handler late so that we can handle any
* spurious interrupts, and also to avoid generation of that known
* spurious interrupt in the first place.
*/
ret
=
sdio_claim_irq
(
func
,
if_sdio_interrupt
);
if
(
ret
)
goto
disable
;
/*
/*
* Enable interrupts now that everything is set up
* Enable interrupts now that everything is set up
*/
*/
...
...
drivers/ssb/driver_pcicore.c
浏览文件 @
2b22b1b1
...
@@ -539,10 +539,12 @@ void ssb_pcicore_init(struct ssb_pcicore *pc)
...
@@ -539,10 +539,12 @@ void ssb_pcicore_init(struct ssb_pcicore *pc)
if
(
!
pc
->
hostmode
)
if
(
!
pc
->
hostmode
)
ssb_pcicore_init_clientmode
(
pc
);
ssb_pcicore_init_clientmode
(
pc
);
/* Additional always once-executed workarounds */
/* Additional PCIe always once-executed workarounds */
ssb_pcicore_serdes_workaround
(
pc
);
if
(
dev
->
id
.
coreid
==
SSB_DEV_PCIE
)
{
/* TODO: ASPM */
ssb_pcicore_serdes_workaround
(
pc
);
/* TODO: Clock Request Update */
/* TODO: ASPM */
/* TODO: Clock Request Update */
}
}
}
static
u32
ssb_pcie_read
(
struct
ssb_pcicore
*
pc
,
u32
address
)
static
u32
ssb_pcie_read
(
struct
ssb_pcicore
*
pc
,
u32
address
)
...
...
net/mac80211/iface.c
浏览文件 @
2b22b1b1
...
@@ -1145,6 +1145,10 @@ int ieee80211_if_add(struct ieee80211_local *local, const char *name,
...
@@ -1145,6 +1145,10 @@ int ieee80211_if_add(struct ieee80211_local *local, const char *name,
+
IEEE80211_ENCRYPT_HEADROOM
;
+
IEEE80211_ENCRYPT_HEADROOM
;
ndev
->
needed_tailroom
=
IEEE80211_ENCRYPT_TAILROOM
;
ndev
->
needed_tailroom
=
IEEE80211_ENCRYPT_TAILROOM
;
ret
=
dev_alloc_name
(
ndev
,
ndev
->
name
);
if
(
ret
<
0
)
goto
fail
;
ieee80211_assign_perm_addr
(
local
,
ndev
,
type
);
ieee80211_assign_perm_addr
(
local
,
ndev
,
type
);
memcpy
(
ndev
->
dev_addr
,
ndev
->
perm_addr
,
ETH_ALEN
);
memcpy
(
ndev
->
dev_addr
,
ndev
->
perm_addr
,
ETH_ALEN
);
SET_NETDEV_DEV
(
ndev
,
wiphy_dev
(
local
->
hw
.
wiphy
));
SET_NETDEV_DEV
(
ndev
,
wiphy_dev
(
local
->
hw
.
wiphy
));
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录