Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
1da9b6b4
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
1da9b6b4
编写于
7月 30, 2012
作者:
R
Roland Dreier
浏览文件
操作
浏览文件
下载
差异文件
Merge branches 'cma', 'ipoib', 'ocrdma' and 'qib' into for-next
上级
0764c76e
b63b70d8
9e8fa040
5d7fe4ef
变更
6
展开全部
隐藏空白更改
内联
并排
Showing
6 changed file
with
547 addition
and
242 deletion
+547
-242
drivers/infiniband/hw/ocrdma/ocrdma_verbs.c
drivers/infiniband/hw/ocrdma/ocrdma_verbs.c
+3
-1
drivers/infiniband/hw/qib/qib.h
drivers/infiniband/hw/qib/qib.h
+5
-5
drivers/infiniband/ulp/ipoib/ipoib.h
drivers/infiniband/ulp/ipoib/ipoib.h
+36
-20
drivers/infiniband/ulp/ipoib/ipoib_cm.c
drivers/infiniband/ulp/ipoib/ipoib_cm.c
+5
-11
drivers/infiniband/ulp/ipoib/ipoib_main.c
drivers/infiniband/ulp/ipoib/ipoib_main.c
+479
-167
drivers/infiniband/ulp/ipoib/ipoib_multicast.c
drivers/infiniband/ulp/ipoib/ipoib_multicast.c
+19
-38
未找到文件。
drivers/infiniband/hw/ocrdma/ocrdma_verbs.c
浏览文件 @
1da9b6b4
...
@@ -893,7 +893,9 @@ static int ocrdma_check_qp_params(struct ib_pd *ibpd, struct ocrdma_dev *dev,
...
@@ -893,7 +893,9 @@ static int ocrdma_check_qp_params(struct ib_pd *ibpd, struct ocrdma_dev *dev,
/* verify consumer QPs are not trying to use GSI QP's CQ */
/* verify consumer QPs are not trying to use GSI QP's CQ */
if
((
attrs
->
qp_type
!=
IB_QPT_GSI
)
&&
(
dev
->
gsi_qp_created
))
{
if
((
attrs
->
qp_type
!=
IB_QPT_GSI
)
&&
(
dev
->
gsi_qp_created
))
{
if
((
dev
->
gsi_sqcq
==
get_ocrdma_cq
(
attrs
->
send_cq
))
||
if
((
dev
->
gsi_sqcq
==
get_ocrdma_cq
(
attrs
->
send_cq
))
||
(
dev
->
gsi_sqcq
==
get_ocrdma_cq
(
attrs
->
send_cq
)))
{
(
dev
->
gsi_sqcq
==
get_ocrdma_cq
(
attrs
->
recv_cq
))
||
(
dev
->
gsi_rqcq
==
get_ocrdma_cq
(
attrs
->
send_cq
))
||
(
dev
->
gsi_rqcq
==
get_ocrdma_cq
(
attrs
->
recv_cq
)))
{
ocrdma_err
(
"%s(%d) Consumer QP cannot use GSI CQs.
\n
"
,
ocrdma_err
(
"%s(%d) Consumer QP cannot use GSI CQs.
\n
"
,
__func__
,
dev
->
id
);
__func__
,
dev
->
id
);
return
-
EINVAL
;
return
-
EINVAL
;
...
...
drivers/infiniband/hw/qib/qib.h
浏览文件 @
1da9b6b4
...
@@ -656,6 +656,11 @@ struct qib_pportdata {
...
@@ -656,6 +656,11 @@ struct qib_pportdata {
/* 16 congestion entries with each entry corresponding to a SL */
/* 16 congestion entries with each entry corresponding to a SL */
struct
ib_cc_congestion_entry_shadow
*
congestion_entries
;
struct
ib_cc_congestion_entry_shadow
*
congestion_entries
;
/* Maximum number of congestion control entries that the agent expects
* the manager to send.
*/
u16
cc_supported_table_entries
;
/* Total number of congestion control table entries */
/* Total number of congestion control table entries */
u16
total_cct_entry
;
u16
total_cct_entry
;
...
@@ -667,11 +672,6 @@ struct qib_pportdata {
...
@@ -667,11 +672,6 @@ struct qib_pportdata {
/* CA's max number of 64 entry units in the congestion control table */
/* CA's max number of 64 entry units in the congestion control table */
u8
cc_max_table_entries
;
u8
cc_max_table_entries
;
/* Maximum number of congestion control entries that the agent expects
* the manager to send.
*/
u8
cc_supported_table_entries
;
};
};
/* Observers. Not to be taken lightly, possibly not to ship. */
/* Observers. Not to be taken lightly, possibly not to ship. */
...
...
drivers/infiniband/ulp/ipoib/ipoib.h
浏览文件 @
1da9b6b4
...
@@ -92,6 +92,8 @@ enum {
...
@@ -92,6 +92,8 @@ enum {
IPOIB_STOP_REAPER
=
7
,
IPOIB_STOP_REAPER
=
7
,
IPOIB_FLAG_ADMIN_CM
=
9
,
IPOIB_FLAG_ADMIN_CM
=
9
,
IPOIB_FLAG_UMCAST
=
10
,
IPOIB_FLAG_UMCAST
=
10
,
IPOIB_STOP_NEIGH_GC
=
11
,
IPOIB_NEIGH_TBL_FLUSH
=
12
,
IPOIB_MAX_BACKOFF_SECONDS
=
16
,
IPOIB_MAX_BACKOFF_SECONDS
=
16
,
...
@@ -260,6 +262,20 @@ struct ipoib_ethtool_st {
...
@@ -260,6 +262,20 @@ struct ipoib_ethtool_st {
u16
max_coalesced_frames
;
u16
max_coalesced_frames
;
};
};
struct
ipoib_neigh_hash
{
struct
ipoib_neigh
__rcu
**
buckets
;
struct
rcu_head
rcu
;
u32
mask
;
u32
size
;
};
struct
ipoib_neigh_table
{
struct
ipoib_neigh_hash
__rcu
*
htbl
;
rwlock_t
rwlock
;
atomic_t
entries
;
struct
completion
flushed
;
};
/*
/*
* Device private locking: network stack tx_lock protects members used
* Device private locking: network stack tx_lock protects members used
* in TX fast path, lock protects everything else. lock nests inside
* in TX fast path, lock protects everything else. lock nests inside
...
@@ -279,6 +295,8 @@ struct ipoib_dev_priv {
...
@@ -279,6 +295,8 @@ struct ipoib_dev_priv {
struct
rb_root
path_tree
;
struct
rb_root
path_tree
;
struct
list_head
path_list
;
struct
list_head
path_list
;
struct
ipoib_neigh_table
ntbl
;
struct
ipoib_mcast
*
broadcast
;
struct
ipoib_mcast
*
broadcast
;
struct
list_head
multicast_list
;
struct
list_head
multicast_list
;
struct
rb_root
multicast_tree
;
struct
rb_root
multicast_tree
;
...
@@ -291,7 +309,7 @@ struct ipoib_dev_priv {
...
@@ -291,7 +309,7 @@ struct ipoib_dev_priv {
struct
work_struct
flush_heavy
;
struct
work_struct
flush_heavy
;
struct
work_struct
restart_task
;
struct
work_struct
restart_task
;
struct
delayed_work
ah_reap_task
;
struct
delayed_work
ah_reap_task
;
struct
delayed_work
neigh_reap_task
;
struct
ib_device
*
ca
;
struct
ib_device
*
ca
;
u8
port
;
u8
port
;
u16
pkey
;
u16
pkey
;
...
@@ -377,13 +395,16 @@ struct ipoib_neigh {
...
@@ -377,13 +395,16 @@ struct ipoib_neigh {
#ifdef CONFIG_INFINIBAND_IPOIB_CM
#ifdef CONFIG_INFINIBAND_IPOIB_CM
struct
ipoib_cm_tx
*
cm
;
struct
ipoib_cm_tx
*
cm
;
#endif
#endif
u
nion
ib_gid
dgid
;
u
8
daddr
[
INFINIBAND_ALEN
]
;
struct
sk_buff_head
queue
;
struct
sk_buff_head
queue
;
struct
neighbour
*
neighbour
;
struct
net_device
*
dev
;
struct
net_device
*
dev
;
struct
list_head
list
;
struct
list_head
list
;
struct
ipoib_neigh
__rcu
*
hnext
;
struct
rcu_head
rcu
;
atomic_t
refcnt
;
unsigned
long
alive
;
};
};
#define IPOIB_UD_MTU(ib_mtu) (ib_mtu - IPOIB_ENCAP_LEN)
#define IPOIB_UD_MTU(ib_mtu) (ib_mtu - IPOIB_ENCAP_LEN)
...
@@ -394,21 +415,17 @@ static inline int ipoib_ud_need_sg(unsigned int ib_mtu)
...
@@ -394,21 +415,17 @@ static inline int ipoib_ud_need_sg(unsigned int ib_mtu)
return
IPOIB_UD_BUF_SIZE
(
ib_mtu
)
>
PAGE_SIZE
;
return
IPOIB_UD_BUF_SIZE
(
ib_mtu
)
>
PAGE_SIZE
;
}
}
/*
void
ipoib_neigh_dtor
(
struct
ipoib_neigh
*
neigh
);
* We stash a pointer to our private neighbour information after our
static
inline
void
ipoib_neigh_put
(
struct
ipoib_neigh
*
neigh
)
* hardware address in neigh->ha. The ALIGN() expression here makes
* sure that this pointer is stored aligned so that an unaligned
* load is not needed to dereference it.
*/
static
inline
struct
ipoib_neigh
**
to_ipoib_neigh
(
struct
neighbour
*
neigh
)
{
{
return
(
void
*
)
neigh
+
ALIGN
(
offsetof
(
struct
neighbour
,
ha
)
+
if
(
atomic_dec_and_test
(
&
neigh
->
refcnt
))
INFINIBAND_ALEN
,
sizeof
(
void
*
)
);
ipoib_neigh_dtor
(
neigh
);
}
}
struct
ipoib_neigh
*
ipoib_neigh_get
(
struct
net_device
*
dev
,
u8
*
daddr
);
struct
ipoib_neigh
*
ipoib_neigh_alloc
(
struct
neighbour
*
neigh
,
struct
ipoib_neigh
*
ipoib_neigh_alloc
(
u8
*
daddr
,
struct
net_device
*
dev
);
struct
net_device
*
dev
);
void
ipoib_neigh_free
(
struct
net_device
*
dev
,
struct
ipoib_neigh
*
neigh
);
void
ipoib_neigh_free
(
struct
ipoib_neigh
*
neigh
);
void
ipoib_del_neighs_by_gid
(
struct
net_device
*
dev
,
u8
*
gid
);
extern
struct
workqueue_struct
*
ipoib_workqueue
;
extern
struct
workqueue_struct
*
ipoib_workqueue
;
...
@@ -425,7 +442,6 @@ static inline void ipoib_put_ah(struct ipoib_ah *ah)
...
@@ -425,7 +442,6 @@ static inline void ipoib_put_ah(struct ipoib_ah *ah)
{
{
kref_put
(
&
ah
->
ref
,
ipoib_free_ah
);
kref_put
(
&
ah
->
ref
,
ipoib_free_ah
);
}
}
int
ipoib_open
(
struct
net_device
*
dev
);
int
ipoib_open
(
struct
net_device
*
dev
);
int
ipoib_add_pkey_attr
(
struct
net_device
*
dev
);
int
ipoib_add_pkey_attr
(
struct
net_device
*
dev
);
int
ipoib_add_umcast_attr
(
struct
net_device
*
dev
);
int
ipoib_add_umcast_attr
(
struct
net_device
*
dev
);
...
@@ -455,7 +471,7 @@ void ipoib_dev_cleanup(struct net_device *dev);
...
@@ -455,7 +471,7 @@ void ipoib_dev_cleanup(struct net_device *dev);
void
ipoib_mcast_join_task
(
struct
work_struct
*
work
);
void
ipoib_mcast_join_task
(
struct
work_struct
*
work
);
void
ipoib_mcast_carrier_on_task
(
struct
work_struct
*
work
);
void
ipoib_mcast_carrier_on_task
(
struct
work_struct
*
work
);
void
ipoib_mcast_send
(
struct
net_device
*
dev
,
void
*
mgid
,
struct
sk_buff
*
skb
);
void
ipoib_mcast_send
(
struct
net_device
*
dev
,
u8
*
daddr
,
struct
sk_buff
*
skb
);
void
ipoib_mcast_restart_task
(
struct
work_struct
*
work
);
void
ipoib_mcast_restart_task
(
struct
work_struct
*
work
);
int
ipoib_mcast_start_thread
(
struct
net_device
*
dev
);
int
ipoib_mcast_start_thread
(
struct
net_device
*
dev
);
...
@@ -517,10 +533,10 @@ static inline int ipoib_cm_admin_enabled(struct net_device *dev)
...
@@ -517,10 +533,10 @@ static inline int ipoib_cm_admin_enabled(struct net_device *dev)
test_bit
(
IPOIB_FLAG_ADMIN_CM
,
&
priv
->
flags
);
test_bit
(
IPOIB_FLAG_ADMIN_CM
,
&
priv
->
flags
);
}
}
static
inline
int
ipoib_cm_enabled
(
struct
net_device
*
dev
,
struct
neighbour
*
n
)
static
inline
int
ipoib_cm_enabled
(
struct
net_device
*
dev
,
u8
*
hwaddr
)
{
{
struct
ipoib_dev_priv
*
priv
=
netdev_priv
(
dev
);
struct
ipoib_dev_priv
*
priv
=
netdev_priv
(
dev
);
return
IPOIB_CM_SUPPORTED
(
n
->
ha
)
&&
return
IPOIB_CM_SUPPORTED
(
hwaddr
)
&&
test_bit
(
IPOIB_FLAG_ADMIN_CM
,
&
priv
->
flags
);
test_bit
(
IPOIB_FLAG_ADMIN_CM
,
&
priv
->
flags
);
}
}
...
@@ -575,7 +591,7 @@ static inline int ipoib_cm_admin_enabled(struct net_device *dev)
...
@@ -575,7 +591,7 @@ static inline int ipoib_cm_admin_enabled(struct net_device *dev)
{
{
return
0
;
return
0
;
}
}
static
inline
int
ipoib_cm_enabled
(
struct
net_device
*
dev
,
struct
neighbour
*
n
)
static
inline
int
ipoib_cm_enabled
(
struct
net_device
*
dev
,
u8
*
hwaddr
)
{
{
return
0
;
return
0
;
...
...
drivers/infiniband/ulp/ipoib/ipoib_cm.c
浏览文件 @
1da9b6b4
...
@@ -811,9 +811,7 @@ void ipoib_cm_handle_tx_wc(struct net_device *dev, struct ib_wc *wc)
...
@@ -811,9 +811,7 @@ void ipoib_cm_handle_tx_wc(struct net_device *dev, struct ib_wc *wc)
if
(
neigh
)
{
if
(
neigh
)
{
neigh
->
cm
=
NULL
;
neigh
->
cm
=
NULL
;
list_del
(
&
neigh
->
list
);
list_del
(
&
neigh
->
list
);
if
(
neigh
->
ah
)
ipoib_neigh_free
(
neigh
);
ipoib_put_ah
(
neigh
->
ah
);
ipoib_neigh_free
(
dev
,
neigh
);
tx
->
neigh
=
NULL
;
tx
->
neigh
=
NULL
;
}
}
...
@@ -1230,9 +1228,7 @@ static int ipoib_cm_tx_handler(struct ib_cm_id *cm_id,
...
@@ -1230,9 +1228,7 @@ static int ipoib_cm_tx_handler(struct ib_cm_id *cm_id,
if
(
neigh
)
{
if
(
neigh
)
{
neigh
->
cm
=
NULL
;
neigh
->
cm
=
NULL
;
list_del
(
&
neigh
->
list
);
list_del
(
&
neigh
->
list
);
if
(
neigh
->
ah
)
ipoib_neigh_free
(
neigh
);
ipoib_put_ah
(
neigh
->
ah
);
ipoib_neigh_free
(
dev
,
neigh
);
tx
->
neigh
=
NULL
;
tx
->
neigh
=
NULL
;
}
}
...
@@ -1279,7 +1275,7 @@ void ipoib_cm_destroy_tx(struct ipoib_cm_tx *tx)
...
@@ -1279,7 +1275,7 @@ void ipoib_cm_destroy_tx(struct ipoib_cm_tx *tx)
list_move
(
&
tx
->
list
,
&
priv
->
cm
.
reap_list
);
list_move
(
&
tx
->
list
,
&
priv
->
cm
.
reap_list
);
queue_work
(
ipoib_workqueue
,
&
priv
->
cm
.
reap_task
);
queue_work
(
ipoib_workqueue
,
&
priv
->
cm
.
reap_task
);
ipoib_dbg
(
priv
,
"Reap connection for gid %pI6
\n
"
,
ipoib_dbg
(
priv
,
"Reap connection for gid %pI6
\n
"
,
tx
->
neigh
->
d
gid
.
raw
);
tx
->
neigh
->
d
addr
+
4
);
tx
->
neigh
=
NULL
;
tx
->
neigh
=
NULL
;
}
}
}
}
...
@@ -1304,7 +1300,7 @@ static void ipoib_cm_tx_start(struct work_struct *work)
...
@@ -1304,7 +1300,7 @@ static void ipoib_cm_tx_start(struct work_struct *work)
p
=
list_entry
(
priv
->
cm
.
start_list
.
next
,
typeof
(
*
p
),
list
);
p
=
list_entry
(
priv
->
cm
.
start_list
.
next
,
typeof
(
*
p
),
list
);
list_del_init
(
&
p
->
list
);
list_del_init
(
&
p
->
list
);
neigh
=
p
->
neigh
;
neigh
=
p
->
neigh
;
qpn
=
IPOIB_QPN
(
neigh
->
neighbour
->
ha
);
qpn
=
IPOIB_QPN
(
neigh
->
daddr
);
memcpy
(
&
pathrec
,
&
p
->
path
->
pathrec
,
sizeof
pathrec
);
memcpy
(
&
pathrec
,
&
p
->
path
->
pathrec
,
sizeof
pathrec
);
spin_unlock_irqrestore
(
&
priv
->
lock
,
flags
);
spin_unlock_irqrestore
(
&
priv
->
lock
,
flags
);
...
@@ -1320,9 +1316,7 @@ static void ipoib_cm_tx_start(struct work_struct *work)
...
@@ -1320,9 +1316,7 @@ static void ipoib_cm_tx_start(struct work_struct *work)
if
(
neigh
)
{
if
(
neigh
)
{
neigh
->
cm
=
NULL
;
neigh
->
cm
=
NULL
;
list_del
(
&
neigh
->
list
);
list_del
(
&
neigh
->
list
);
if
(
neigh
->
ah
)
ipoib_neigh_free
(
neigh
);
ipoib_put_ah
(
neigh
->
ah
);
ipoib_neigh_free
(
dev
,
neigh
);
}
}
list_del
(
&
p
->
list
);
list_del
(
&
p
->
list
);
kfree
(
p
);
kfree
(
p
);
...
...
drivers/infiniband/ulp/ipoib/ipoib_main.c
浏览文件 @
1da9b6b4
此差异已折叠。
点击以展开。
drivers/infiniband/ulp/ipoib/ipoib_multicast.c
浏览文件 @
1da9b6b4
...
@@ -69,28 +69,13 @@ struct ipoib_mcast_iter {
...
@@ -69,28 +69,13 @@ struct ipoib_mcast_iter {
static
void
ipoib_mcast_free
(
struct
ipoib_mcast
*
mcast
)
static
void
ipoib_mcast_free
(
struct
ipoib_mcast
*
mcast
)
{
{
struct
net_device
*
dev
=
mcast
->
dev
;
struct
net_device
*
dev
=
mcast
->
dev
;
struct
ipoib_dev_priv
*
priv
=
netdev_priv
(
dev
);
struct
ipoib_neigh
*
neigh
,
*
tmp
;
int
tx_dropped
=
0
;
int
tx_dropped
=
0
;
ipoib_dbg_mcast
(
netdev_priv
(
dev
),
"deleting multicast group %pI6
\n
"
,
ipoib_dbg_mcast
(
netdev_priv
(
dev
),
"deleting multicast group %pI6
\n
"
,
mcast
->
mcmember
.
mgid
.
raw
);
mcast
->
mcmember
.
mgid
.
raw
);
spin_lock_irq
(
&
priv
->
lock
);
/* remove all neigh connected to this mcast */
ipoib_del_neighs_by_gid
(
dev
,
mcast
->
mcmember
.
mgid
.
raw
);
list_for_each_entry_safe
(
neigh
,
tmp
,
&
mcast
->
neigh_list
,
list
)
{
/*
* It's safe to call ipoib_put_ah() inside priv->lock
* here, because we know that mcast->ah will always
* hold one more reference, so ipoib_put_ah() will
* never do more than decrement the ref count.
*/
if
(
neigh
->
ah
)
ipoib_put_ah
(
neigh
->
ah
);
ipoib_neigh_free
(
dev
,
neigh
);
}
spin_unlock_irq
(
&
priv
->
lock
);
if
(
mcast
->
ah
)
if
(
mcast
->
ah
)
ipoib_put_ah
(
mcast
->
ah
);
ipoib_put_ah
(
mcast
->
ah
);
...
@@ -655,17 +640,12 @@ static int ipoib_mcast_leave(struct net_device *dev, struct ipoib_mcast *mcast)
...
@@ -655,17 +640,12 @@ static int ipoib_mcast_leave(struct net_device *dev, struct ipoib_mcast *mcast)
return
0
;
return
0
;
}
}
void
ipoib_mcast_send
(
struct
net_device
*
dev
,
void
*
mgid
,
struct
sk_buff
*
skb
)
void
ipoib_mcast_send
(
struct
net_device
*
dev
,
u8
*
daddr
,
struct
sk_buff
*
skb
)
{
{
struct
ipoib_dev_priv
*
priv
=
netdev_priv
(
dev
);
struct
ipoib_dev_priv
*
priv
=
netdev_priv
(
dev
);
struct
dst_entry
*
dst
=
skb_dst
(
skb
);
struct
ipoib_mcast
*
mcast
;
struct
ipoib_mcast
*
mcast
;
struct
neighbour
*
n
;
unsigned
long
flags
;
unsigned
long
flags
;
void
*
mgid
=
daddr
+
4
;
n
=
NULL
;
if
(
dst
)
n
=
dst_neigh_lookup_skb
(
dst
,
skb
);
spin_lock_irqsave
(
&
priv
->
lock
,
flags
);
spin_lock_irqsave
(
&
priv
->
lock
,
flags
);
...
@@ -721,28 +701,29 @@ void ipoib_mcast_send(struct net_device *dev, void *mgid, struct sk_buff *skb)
...
@@ -721,28 +701,29 @@ void ipoib_mcast_send(struct net_device *dev, void *mgid, struct sk_buff *skb)
out:
out:
if
(
mcast
&&
mcast
->
ah
)
{
if
(
mcast
&&
mcast
->
ah
)
{
if
(
n
)
{
struct
ipoib_neigh
*
neigh
;
if
(
!*
to_ipoib_neigh
(
n
))
{
struct
ipoib_neigh
*
neigh
;
spin_unlock_irqrestore
(
&
priv
->
lock
,
flags
);
neigh
=
ipoib_neigh_get
(
dev
,
daddr
);
neigh
=
ipoib_neigh_alloc
(
n
,
skb
->
dev
);
spin_lock_irqsave
(
&
priv
->
lock
,
flags
);
if
(
neigh
)
{
if
(
!
neigh
)
{
kref_get
(
&
mcast
->
ah
->
ref
);
spin_unlock_irqrestore
(
&
priv
->
lock
,
flags
);
neigh
->
ah
=
mcast
->
ah
;
neigh
=
ipoib_neigh_alloc
(
daddr
,
dev
);
list_add_tail
(
&
neigh
->
list
,
spin_lock_irqsave
(
&
priv
->
lock
,
flags
);
&
mcast
->
neigh_list
);
if
(
neigh
)
{
}
kref_get
(
&
mcast
->
ah
->
ref
);
neigh
->
ah
=
mcast
->
ah
;
list_add_tail
(
&
neigh
->
list
,
&
mcast
->
neigh_list
);
}
}
neigh_release
(
n
);
}
}
spin_unlock_irqrestore
(
&
priv
->
lock
,
flags
);
spin_unlock_irqrestore
(
&
priv
->
lock
,
flags
);
ipoib_send
(
dev
,
skb
,
mcast
->
ah
,
IB_MULTICAST_QPN
);
ipoib_send
(
dev
,
skb
,
mcast
->
ah
,
IB_MULTICAST_QPN
);
if
(
neigh
)
ipoib_neigh_put
(
neigh
);
return
;
return
;
}
}
unlock:
unlock:
if
(
n
)
neigh_release
(
n
);
spin_unlock_irqrestore
(
&
priv
->
lock
,
flags
);
spin_unlock_irqrestore
(
&
priv
->
lock
,
flags
);
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录