Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
199160bb
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
199160bb
编写于
2月 06, 2014
作者:
J
John W. Linville
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'for-john' of
git://git.kernel.org/pub/scm/linux/kernel/git/jberg/mac80211
上级
4cfe9a8d
fab57a6c
变更
11
隐藏空白更改
内联
并排
Showing
11 changed file
with
102 addition
and
83 deletion
+102
-83
net/mac80211/cfg.c
net/mac80211/cfg.c
+23
-21
net/mac80211/ht.c
net/mac80211/ht.c
+3
-1
net/mac80211/ibss.c
net/mac80211/ibss.c
+1
-4
net/mac80211/iface.c
net/mac80211/iface.c
+19
-8
net/mac80211/tx.c
net/mac80211/tx.c
+1
-1
net/wireless/core.c
net/wireless/core.c
+10
-7
net/wireless/core.h
net/wireless/core.h
+3
-1
net/wireless/nl80211.c
net/wireless/nl80211.c
+12
-20
net/wireless/nl80211.h
net/wireless/nl80211.h
+4
-4
net/wireless/scan.c
net/wireless/scan.c
+25
-15
net/wireless/sme.c
net/wireless/sme.c
+1
-1
未找到文件。
net/mac80211/cfg.c
浏览文件 @
199160bb
...
...
@@ -1021,8 +1021,10 @@ static int ieee80211_start_ap(struct wiphy *wiphy, struct net_device *dev,
IEEE80211_P2P_OPPPS_ENABLE_BIT
;
err
=
ieee80211_assign_beacon
(
sdata
,
&
params
->
beacon
);
if
(
err
<
0
)
if
(
err
<
0
)
{
ieee80211_vif_release_channel
(
sdata
);
return
err
;
}
changed
|=
err
;
err
=
drv_start_ap
(
sdata
->
local
,
sdata
);
...
...
@@ -1032,6 +1034,7 @@ static int ieee80211_start_ap(struct wiphy *wiphy, struct net_device *dev,
if
(
old
)
kfree_rcu
(
old
,
rcu_head
);
RCU_INIT_POINTER
(
sdata
->
u
.
ap
.
beacon
,
NULL
);
ieee80211_vif_release_channel
(
sdata
);
return
err
;
}
...
...
@@ -1090,8 +1093,6 @@ static int ieee80211_stop_ap(struct wiphy *wiphy, struct net_device *dev)
kfree
(
sdata
->
u
.
ap
.
next_beacon
);
sdata
->
u
.
ap
.
next_beacon
=
NULL
;
cancel_work_sync
(
&
sdata
->
u
.
ap
.
request_smps_work
);
/* turn off carrier for this interface and dependent VLANs */
list_for_each_entry
(
vlan
,
&
sdata
->
u
.
ap
.
vlans
,
u
.
vlan
.
list
)
netif_carrier_off
(
vlan
->
dev
);
...
...
@@ -1103,6 +1104,7 @@ static int ieee80211_stop_ap(struct wiphy *wiphy, struct net_device *dev)
kfree_rcu
(
old_beacon
,
rcu_head
);
if
(
old_probe_resp
)
kfree_rcu
(
old_probe_resp
,
rcu_head
);
sdata
->
u
.
ap
.
driver_smps_mode
=
IEEE80211_SMPS_OFF
;
__sta_info_flush
(
sdata
,
true
);
ieee80211_free_keys
(
sdata
,
true
);
...
...
@@ -2638,6 +2640,24 @@ static int ieee80211_start_roc_work(struct ieee80211_local *local,
INIT_DELAYED_WORK
(
&
roc
->
work
,
ieee80211_sw_roc_work
);
INIT_LIST_HEAD
(
&
roc
->
dependents
);
/*
* cookie is either the roc cookie (for normal roc)
* or the SKB (for mgmt TX)
*/
if
(
!
txskb
)
{
/* local->mtx protects this */
local
->
roc_cookie_counter
++
;
roc
->
cookie
=
local
->
roc_cookie_counter
;
/* wow, you wrapped 64 bits ... more likely a bug */
if
(
WARN_ON
(
roc
->
cookie
==
0
))
{
roc
->
cookie
=
1
;
local
->
roc_cookie_counter
++
;
}
*
cookie
=
roc
->
cookie
;
}
else
{
*
cookie
=
(
unsigned
long
)
txskb
;
}
/* if there's one pending or we're scanning, queue this one */
if
(
!
list_empty
(
&
local
->
roc_list
)
||
local
->
scanning
||
local
->
radar_detect_enabled
)
...
...
@@ -2772,24 +2792,6 @@ static int ieee80211_start_roc_work(struct ieee80211_local *local,
if
(
!
queued
)
list_add_tail
(
&
roc
->
list
,
&
local
->
roc_list
);
/*
* cookie is either the roc cookie (for normal roc)
* or the SKB (for mgmt TX)
*/
if
(
!
txskb
)
{
/* local->mtx protects this */
local
->
roc_cookie_counter
++
;
roc
->
cookie
=
local
->
roc_cookie_counter
;
/* wow, you wrapped 64 bits ... more likely a bug */
if
(
WARN_ON
(
roc
->
cookie
==
0
))
{
roc
->
cookie
=
1
;
local
->
roc_cookie_counter
++
;
}
*
cookie
=
roc
->
cookie
;
}
else
{
*
cookie
=
(
unsigned
long
)
txskb
;
}
return
0
;
}
...
...
net/mac80211/ht.c
浏览文件 @
199160bb
...
...
@@ -466,7 +466,9 @@ void ieee80211_request_smps_ap_work(struct work_struct *work)
u
.
ap
.
request_smps_work
);
sdata_lock
(
sdata
);
__ieee80211_request_smps_ap
(
sdata
,
sdata
->
u
.
ap
.
driver_smps_mode
);
if
(
sdata_dereference
(
sdata
->
u
.
ap
.
beacon
,
sdata
))
__ieee80211_request_smps_ap
(
sdata
,
sdata
->
u
.
ap
.
driver_smps_mode
);
sdata_unlock
(
sdata
);
}
...
...
net/mac80211/ibss.c
浏览文件 @
199160bb
...
...
@@ -695,12 +695,9 @@ static void ieee80211_ibss_disconnect(struct ieee80211_sub_if_data *sdata)
struct
cfg80211_bss
*
cbss
;
struct
beacon_data
*
presp
;
struct
sta_info
*
sta
;
int
active_ibss
;
u16
capability
;
active_ibss
=
ieee80211_sta_active_ibss
(
sdata
);
if
(
!
active_ibss
&&
!
is_zero_ether_addr
(
ifibss
->
bssid
))
{
if
(
!
is_zero_ether_addr
(
ifibss
->
bssid
))
{
capability
=
WLAN_CAPABILITY_IBSS
;
if
(
ifibss
->
privacy
)
...
...
net/mac80211/iface.c
浏览文件 @
199160bb
...
...
@@ -418,20 +418,24 @@ int ieee80211_add_virtual_monitor(struct ieee80211_local *local)
return
ret
;
}
mutex_lock
(
&
local
->
iflist_mtx
);
rcu_assign_pointer
(
local
->
monitor_sdata
,
sdata
);
mutex_unlock
(
&
local
->
iflist_mtx
);
mutex_lock
(
&
local
->
mtx
);
ret
=
ieee80211_vif_use_channel
(
sdata
,
&
local
->
monitor_chandef
,
IEEE80211_CHANCTX_EXCLUSIVE
);
mutex_unlock
(
&
local
->
mtx
);
if
(
ret
)
{
mutex_lock
(
&
local
->
iflist_mtx
);
rcu_assign_pointer
(
local
->
monitor_sdata
,
NULL
);
mutex_unlock
(
&
local
->
iflist_mtx
);
synchronize_net
();
drv_remove_interface
(
local
,
sdata
);
kfree
(
sdata
);
return
ret
;
}
mutex_lock
(
&
local
->
iflist_mtx
);
rcu_assign_pointer
(
local
->
monitor_sdata
,
sdata
);
mutex_unlock
(
&
local
->
iflist_mtx
);
return
0
;
}
...
...
@@ -770,12 +774,19 @@ static void ieee80211_do_stop(struct ieee80211_sub_if_data *sdata,
ieee80211_roc_purge
(
local
,
sdata
);
if
(
sdata
->
vif
.
type
==
NL80211_IFTYPE_STATION
)
switch
(
sdata
->
vif
.
type
)
{
case
NL80211_IFTYPE_STATION
:
ieee80211_mgd_stop
(
sdata
);
if
(
sdata
->
vif
.
type
==
NL80211_IFTYPE_ADHOC
)
break
;
case
NL80211_IFTYPE_ADHOC
:
ieee80211_ibss_stop
(
sdata
);
break
;
case
NL80211_IFTYPE_AP
:
cancel_work_sync
(
&
sdata
->
u
.
ap
.
request_smps_work
);
break
;
default:
break
;
}
/*
* Remove all stations associated with this interface.
...
...
net/mac80211/tx.c
浏览文件 @
199160bb
...
...
@@ -878,7 +878,7 @@ static int ieee80211_fragment(struct ieee80211_tx_data *tx,
}
/* adjust first fragment's length */
skb
->
len
=
hdrlen
+
per_fragm
;
skb
_trim
(
skb
,
hdrlen
+
per_fragm
)
;
return
0
;
}
...
...
net/wireless/core.c
浏览文件 @
199160bb
...
...
@@ -203,8 +203,11 @@ void cfg80211_stop_p2p_device(struct cfg80211_registered_device *rdev,
rdev
->
opencount
--
;
WARN_ON
(
rdev
->
scan_req
&&
rdev
->
scan_req
->
wdev
==
wdev
&&
!
rdev
->
scan_req
->
notified
);
if
(
rdev
->
scan_req
&&
rdev
->
scan_req
->
wdev
==
wdev
)
{
if
(
WARN_ON
(
!
rdev
->
scan_req
->
notified
))
rdev
->
scan_req
->
aborted
=
true
;
___cfg80211_scan_done
(
rdev
,
false
);
}
}
static
int
cfg80211_rfkill_set_block
(
void
*
data
,
bool
blocked
)
...
...
@@ -440,9 +443,6 @@ int wiphy_register(struct wiphy *wiphy)
int
i
;
u16
ifmodes
=
wiphy
->
interface_modes
;
/* support for 5/10 MHz is broken due to nl80211 API mess - disable */
wiphy
->
flags
&=
~
WIPHY_FLAG_SUPPORTS_5_10_MHZ
;
/*
* There are major locking problems in nl80211/mac80211 for CSA,
* disable for all drivers until this has been reworked.
...
...
@@ -859,8 +859,11 @@ static int cfg80211_netdev_notifier_call(struct notifier_block *nb,
break
;
case
NETDEV_DOWN
:
cfg80211_update_iface_num
(
rdev
,
wdev
->
iftype
,
-
1
);
WARN_ON
(
rdev
->
scan_req
&&
rdev
->
scan_req
->
wdev
==
wdev
&&
!
rdev
->
scan_req
->
notified
);
if
(
rdev
->
scan_req
&&
rdev
->
scan_req
->
wdev
==
wdev
)
{
if
(
WARN_ON
(
!
rdev
->
scan_req
->
notified
))
rdev
->
scan_req
->
aborted
=
true
;
___cfg80211_scan_done
(
rdev
,
false
);
}
if
(
WARN_ON
(
rdev
->
sched_scan_req
&&
rdev
->
sched_scan_req
->
dev
==
wdev
->
netdev
))
{
...
...
net/wireless/core.h
浏览文件 @
199160bb
...
...
@@ -62,6 +62,7 @@ struct cfg80211_registered_device {
struct
rb_root
bss_tree
;
u32
bss_generation
;
struct
cfg80211_scan_request
*
scan_req
;
/* protected by RTNL */
struct
sk_buff
*
scan_msg
;
struct
cfg80211_sched_scan_request
*
sched_scan_req
;
unsigned
long
suspend_at
;
struct
work_struct
scan_done_wk
;
...
...
@@ -361,7 +362,8 @@ int cfg80211_validate_key_settings(struct cfg80211_registered_device *rdev,
struct
key_params
*
params
,
int
key_idx
,
bool
pairwise
,
const
u8
*
mac_addr
);
void
__cfg80211_scan_done
(
struct
work_struct
*
wk
);
void
___cfg80211_scan_done
(
struct
cfg80211_registered_device
*
rdev
);
void
___cfg80211_scan_done
(
struct
cfg80211_registered_device
*
rdev
,
bool
send_message
);
void
__cfg80211_sched_scan_results
(
struct
work_struct
*
wk
);
int
__cfg80211_stop_sched_scan
(
struct
cfg80211_registered_device
*
rdev
,
bool
driver_initiated
);
...
...
net/wireless/nl80211.c
浏览文件 @
199160bb
...
...
@@ -1719,9 +1719,10 @@ static int nl80211_dump_wiphy(struct sk_buff *skb, struct netlink_callback *cb)
* We can then retry with the larger buffer.
*/
if
((
ret
==
-
ENOBUFS
||
ret
==
-
EMSGSIZE
)
&&
!
skb
->
len
&&
!
skb
->
len
&&
!
state
->
split
&&
cb
->
min_dump_alloc
<
4096
)
{
cb
->
min_dump_alloc
=
4096
;
state
->
split_start
=
0
;
rtnl_unlock
();
return
1
;
}
...
...
@@ -5244,7 +5245,7 @@ static int nl80211_trigger_scan(struct sk_buff *skb, struct genl_info *info)
if
(
!
rdev
->
ops
->
scan
)
return
-
EOPNOTSUPP
;
if
(
rdev
->
scan_req
)
{
if
(
rdev
->
scan_req
||
rdev
->
scan_msg
)
{
err
=
-
EBUSY
;
goto
unlock
;
}
...
...
@@ -10011,40 +10012,31 @@ void nl80211_send_scan_start(struct cfg80211_registered_device *rdev,
NL80211_MCGRP_SCAN
,
GFP_KERNEL
);
}
void
nl80211_send_scan_done
(
struct
cfg80211_registered_device
*
rdev
,
struct
wireless_dev
*
wdev
)
struct
sk_buff
*
nl80211_build_scan_msg
(
struct
cfg80211_registered_device
*
rdev
,
struct
wireless_dev
*
wdev
,
bool
aborted
)
{
struct
sk_buff
*
msg
;
msg
=
nlmsg_new
(
NLMSG_DEFAULT_SIZE
,
GFP_KERNEL
);
if
(
!
msg
)
return
;
return
NULL
;
if
(
nl80211_send_scan_msg
(
msg
,
rdev
,
wdev
,
0
,
0
,
0
,
NL80211_CMD_NEW_SCAN_RESULTS
)
<
0
)
{
aborted
?
NL80211_CMD_SCAN_ABORTED
:
NL80211_CMD_NEW_SCAN_RESULTS
)
<
0
)
{
nlmsg_free
(
msg
);
return
;
return
NULL
;
}
genlmsg_multicast_netns
(
&
nl80211_fam
,
wiphy_net
(
&
rdev
->
wiphy
),
msg
,
0
,
NL80211_MCGRP_SCAN
,
GFP_KERNEL
);
return
msg
;
}
void
nl80211_send_scan_
aborted
(
struct
cfg80211_registered_device
*
rdev
,
struct
wireless_dev
*
wdev
)
void
nl80211_send_scan_
result
(
struct
cfg80211_registered_device
*
rdev
,
struct
sk_buff
*
msg
)
{
struct
sk_buff
*
msg
;
msg
=
nlmsg_new
(
NLMSG_DEFAULT_SIZE
,
GFP_KERNEL
);
if
(
!
msg
)
return
;
if
(
nl80211_send_scan_msg
(
msg
,
rdev
,
wdev
,
0
,
0
,
0
,
NL80211_CMD_SCAN_ABORTED
)
<
0
)
{
nlmsg_free
(
msg
);
return
;
}
genlmsg_multicast_netns
(
&
nl80211_fam
,
wiphy_net
(
&
rdev
->
wiphy
),
msg
,
0
,
NL80211_MCGRP_SCAN
,
GFP_KERNEL
);
}
...
...
net/wireless/nl80211.h
浏览文件 @
199160bb
...
...
@@ -8,10 +8,10 @@ void nl80211_exit(void);
void
nl80211_notify_dev_rename
(
struct
cfg80211_registered_device
*
rdev
);
void
nl80211_send_scan_start
(
struct
cfg80211_registered_device
*
rdev
,
struct
wireless_dev
*
wdev
);
void
nl80211_send_scan_done
(
struct
cfg80211_registered_device
*
rdev
,
struct
wireless_dev
*
wdev
);
void
nl80211_send_scan_
aborted
(
struct
cfg80211_registered_device
*
rdev
,
struct
wireless_dev
*
wdev
);
struct
sk_buff
*
nl80211_build_scan_msg
(
struct
cfg80211_registered_device
*
rdev
,
struct
wireless_dev
*
wdev
,
bool
aborted
);
void
nl80211_send_scan_
result
(
struct
cfg80211_registered_device
*
rdev
,
struct
sk_buff
*
msg
);
void
nl80211_send_sched_scan
(
struct
cfg80211_registered_device
*
rdev
,
struct
net_device
*
netdev
,
u32
cmd
);
void
nl80211_send_sched_scan_results
(
struct
cfg80211_registered_device
*
rdev
,
...
...
net/wireless/scan.c
浏览文件 @
199160bb
...
...
@@ -161,18 +161,25 @@ static void __cfg80211_bss_expire(struct cfg80211_registered_device *dev,
dev
->
bss_generation
++
;
}
void
___cfg80211_scan_done
(
struct
cfg80211_registered_device
*
rdev
)
void
___cfg80211_scan_done
(
struct
cfg80211_registered_device
*
rdev
,
bool
send_message
)
{
struct
cfg80211_scan_request
*
request
;
struct
wireless_dev
*
wdev
;
struct
sk_buff
*
msg
;
#ifdef CONFIG_CFG80211_WEXT
union
iwreq_data
wrqu
;
#endif
ASSERT_RTNL
();
request
=
rdev
->
scan_req
;
if
(
rdev
->
scan_msg
)
{
nl80211_send_scan_result
(
rdev
,
rdev
->
scan_msg
);
rdev
->
scan_msg
=
NULL
;
return
;
}
request
=
rdev
->
scan_req
;
if
(
!
request
)
return
;
...
...
@@ -186,18 +193,16 @@ void ___cfg80211_scan_done(struct cfg80211_registered_device *rdev)
if
(
wdev
->
netdev
)
cfg80211_sme_scan_done
(
wdev
->
netdev
);
if
(
request
->
aborted
)
{
nl80211_send_scan_aborted
(
rdev
,
wdev
);
}
else
{
if
(
request
->
flags
&
NL80211_SCAN_FLAG_FLUSH
)
{
/* flush entries from previous scans */
spin_lock_bh
(
&
rdev
->
bss_lock
);
__cfg80211_bss_expire
(
rdev
,
request
->
scan_start
);
spin_unlock_bh
(
&
rdev
->
bss_lock
);
}
nl80211_send_scan_done
(
rdev
,
wdev
);
if
(
!
request
->
aborted
&&
request
->
flags
&
NL80211_SCAN_FLAG_FLUSH
)
{
/* flush entries from previous scans */
spin_lock_bh
(
&
rdev
->
bss_lock
);
__cfg80211_bss_expire
(
rdev
,
request
->
scan_start
);
spin_unlock_bh
(
&
rdev
->
bss_lock
);
}
msg
=
nl80211_build_scan_msg
(
rdev
,
wdev
,
request
->
aborted
);
#ifdef CONFIG_CFG80211_WEXT
if
(
wdev
->
netdev
&&
!
request
->
aborted
)
{
memset
(
&
wrqu
,
0
,
sizeof
(
wrqu
));
...
...
@@ -211,6 +216,11 @@ void ___cfg80211_scan_done(struct cfg80211_registered_device *rdev)
rdev
->
scan_req
=
NULL
;
kfree
(
request
);
if
(
!
send_message
)
rdev
->
scan_msg
=
msg
;
else
nl80211_send_scan_result
(
rdev
,
msg
);
}
void
__cfg80211_scan_done
(
struct
work_struct
*
wk
)
...
...
@@ -221,7 +231,7 @@ void __cfg80211_scan_done(struct work_struct *wk)
scan_done_wk
);
rtnl_lock
();
___cfg80211_scan_done
(
rdev
);
___cfg80211_scan_done
(
rdev
,
true
);
rtnl_unlock
();
}
...
...
@@ -1079,7 +1089,7 @@ int cfg80211_wext_siwscan(struct net_device *dev,
if
(
IS_ERR
(
rdev
))
return
PTR_ERR
(
rdev
);
if
(
rdev
->
scan_req
)
{
if
(
rdev
->
scan_req
||
rdev
->
scan_msg
)
{
err
=
-
EBUSY
;
goto
out
;
}
...
...
@@ -1481,7 +1491,7 @@ int cfg80211_wext_giwscan(struct net_device *dev,
if
(
IS_ERR
(
rdev
))
return
PTR_ERR
(
rdev
);
if
(
rdev
->
scan_req
)
if
(
rdev
->
scan_req
||
rdev
->
scan_msg
)
return
-
EAGAIN
;
res
=
ieee80211_scan_results
(
rdev
,
info
,
extra
,
data
->
length
);
...
...
net/wireless/sme.c
浏览文件 @
199160bb
...
...
@@ -67,7 +67,7 @@ static int cfg80211_conn_scan(struct wireless_dev *wdev)
ASSERT_RDEV_LOCK
(
rdev
);
ASSERT_WDEV_LOCK
(
wdev
);
if
(
rdev
->
scan_req
)
if
(
rdev
->
scan_req
||
rdev
->
scan_msg
)
return
-
EBUSY
;
if
(
wdev
->
conn
->
params
.
channel
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录