Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
90079ce8
cloud-kernel
项目概览
openanolis
/
cloud-kernel
大约 1 年 前同步成功
通知
158
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
90079ce8
编写于
9月 11, 2008
作者:
D
David S. Miller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
tg3: Use SKB DMA helper functions for TX.
Signed-off-by:
N
David S. Miller
<
davem@davemloft.net
>
上级
a40c24a1
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
31 addition
and
58 deletion
+31
-58
drivers/net/tg3.c
drivers/net/tg3.c
+31
-57
drivers/net/tg3.h
drivers/net/tg3.h
+0
-1
未找到文件。
drivers/net/tg3.c
浏览文件 @
90079ce8
...
...
@@ -3861,10 +3861,7 @@ static void tg3_tx(struct tg3 *tp)
return
;
}
pci_unmap_single
(
tp
->
pdev
,
pci_unmap_addr
(
ri
,
mapping
),
skb_headlen
(
skb
),
PCI_DMA_TODEVICE
);
skb_dma_unmap
(
&
tp
->
pdev
->
dev
,
skb
,
DMA_TO_DEVICE
);
ri
->
skb
=
NULL
;
...
...
@@ -3874,12 +3871,6 @@ static void tg3_tx(struct tg3 *tp)
ri
=
&
tp
->
tx_buffers
[
sw_idx
];
if
(
unlikely
(
ri
->
skb
!=
NULL
||
sw_idx
==
hw_idx
))
tx_bug
=
1
;
pci_unmap_page
(
tp
->
pdev
,
pci_unmap_addr
(
ri
,
mapping
),
skb_shinfo
(
skb
)
->
frags
[
i
].
size
,
PCI_DMA_TODEVICE
);
sw_idx
=
NEXT_TX
(
sw_idx
);
}
...
...
@@ -4633,12 +4624,13 @@ static int tigon3_dma_hwbug_workaround(struct tg3 *tp, struct sk_buff *skb,
}
else
{
/* New SKB is guaranteed to be linear. */
entry
=
*
start
;
new_addr
=
pci_map_single
(
tp
->
pdev
,
new_skb
->
data
,
new_skb
->
len
,
PCI_DMA_TODEVICE
);
ret
=
skb_dma_map
(
&
tp
->
pdev
->
dev
,
new_skb
,
DMA_TO_DEVICE
);
new_addr
=
skb_shinfo
(
new_skb
)
->
dma_maps
[
0
];
/* Make sure new skb does not cross any 4G boundaries.
* Drop the packet if it does.
*/
if
(
tg3_4g_overflow_test
(
new_addr
,
new_skb
->
len
))
{
if
(
ret
||
tg3_4g_overflow_test
(
new_addr
,
new_skb
->
len
))
{
ret
=
-
1
;
dev_kfree_skb
(
new_skb
);
new_skb
=
NULL
;
...
...
@@ -4652,18 +4644,8 @@ static int tigon3_dma_hwbug_workaround(struct tg3 *tp, struct sk_buff *skb,
/* Now clean up the sw ring entries. */
i
=
0
;
while
(
entry
!=
last_plus_one
)
{
int
len
;
if
(
i
==
0
)
len
=
skb_headlen
(
skb
);
else
len
=
skb_shinfo
(
skb
)
->
frags
[
i
-
1
].
size
;
pci_unmap_single
(
tp
->
pdev
,
pci_unmap_addr
(
&
tp
->
tx_buffers
[
entry
],
mapping
),
len
,
PCI_DMA_TODEVICE
);
if
(
i
==
0
)
{
tp
->
tx_buffers
[
entry
].
skb
=
new_skb
;
pci_unmap_addr_set
(
&
tp
->
tx_buffers
[
entry
],
mapping
,
new_addr
);
}
else
{
tp
->
tx_buffers
[
entry
].
skb
=
NULL
;
}
...
...
@@ -4671,6 +4653,7 @@ static int tigon3_dma_hwbug_workaround(struct tg3 *tp, struct sk_buff *skb,
i
++
;
}
skb_dma_unmap
(
&
tp
->
pdev
->
dev
,
skb
,
DMA_TO_DEVICE
);
dev_kfree_skb
(
skb
);
return
ret
;
...
...
@@ -4705,8 +4688,9 @@ static void tg3_set_txd(struct tg3 *tp, int entry,
static
int
tg3_start_xmit
(
struct
sk_buff
*
skb
,
struct
net_device
*
dev
)
{
struct
tg3
*
tp
=
netdev_priv
(
dev
);
dma_addr_t
mapping
;
u32
len
,
entry
,
base_flags
,
mss
;
struct
skb_shared_info
*
sp
;
dma_addr_t
mapping
;
len
=
skb_headlen
(
skb
);
...
...
@@ -4765,11 +4749,16 @@ static int tg3_start_xmit(struct sk_buff *skb, struct net_device *dev)
(
vlan_tx_tag_get
(
skb
)
<<
16
));
#endif
/* Queue skb data, a.k.a. the main skb fragment. */
mapping
=
pci_map_single
(
tp
->
pdev
,
skb
->
data
,
len
,
PCI_DMA_TODEVICE
);
if
(
skb_dma_map
(
&
tp
->
pdev
->
dev
,
skb
,
DMA_TO_DEVICE
))
{
dev_kfree_skb
(
skb
);
goto
out_unlock
;
}
sp
=
skb_shinfo
(
skb
);
mapping
=
sp
->
dma_maps
[
0
];
tp
->
tx_buffers
[
entry
].
skb
=
skb
;
pci_unmap_addr_set
(
&
tp
->
tx_buffers
[
entry
],
mapping
,
mapping
);
tg3_set_txd
(
tp
,
entry
,
mapping
,
len
,
base_flags
,
(
skb_shinfo
(
skb
)
->
nr_frags
==
0
)
|
(
mss
<<
1
));
...
...
@@ -4785,13 +4774,8 @@ static int tg3_start_xmit(struct sk_buff *skb, struct net_device *dev)
skb_frag_t
*
frag
=
&
skb_shinfo
(
skb
)
->
frags
[
i
];
len
=
frag
->
size
;
mapping
=
pci_map_page
(
tp
->
pdev
,
frag
->
page
,
frag
->
page_offset
,
len
,
PCI_DMA_TODEVICE
);
mapping
=
sp
->
dma_maps
[
i
+
1
];
tp
->
tx_buffers
[
entry
].
skb
=
NULL
;
pci_unmap_addr_set
(
&
tp
->
tx_buffers
[
entry
],
mapping
,
mapping
);
tg3_set_txd
(
tp
,
entry
,
mapping
,
len
,
base_flags
,
(
i
==
last
)
|
(
mss
<<
1
));
...
...
@@ -4859,9 +4843,10 @@ static int tg3_tso_bug(struct tg3 *tp, struct sk_buff *skb)
static
int
tg3_start_xmit_dma_bug
(
struct
sk_buff
*
skb
,
struct
net_device
*
dev
)
{
struct
tg3
*
tp
=
netdev_priv
(
dev
);
dma_addr_t
mapping
;
u32
len
,
entry
,
base_flags
,
mss
;
struct
skb_shared_info
*
sp
;
int
would_hit_hwbug
;
dma_addr_t
mapping
;
len
=
skb_headlen
(
skb
);
...
...
@@ -4942,11 +4927,16 @@ static int tg3_start_xmit_dma_bug(struct sk_buff *skb, struct net_device *dev)
(
vlan_tx_tag_get
(
skb
)
<<
16
));
#endif
/* Queue skb data, a.k.a. the main skb fragment. */
mapping
=
pci_map_single
(
tp
->
pdev
,
skb
->
data
,
len
,
PCI_DMA_TODEVICE
);
if
(
skb_dma_map
(
&
tp
->
pdev
->
dev
,
skb
,
DMA_TO_DEVICE
))
{
dev_kfree_skb
(
skb
);
goto
out_unlock
;
}
sp
=
skb_shinfo
(
skb
);
mapping
=
sp
->
dma_maps
[
0
];
tp
->
tx_buffers
[
entry
].
skb
=
skb
;
pci_unmap_addr_set
(
&
tp
->
tx_buffers
[
entry
],
mapping
,
mapping
);
would_hit_hwbug
=
0
;
...
...
@@ -4969,13 +4959,9 @@ static int tg3_start_xmit_dma_bug(struct sk_buff *skb, struct net_device *dev)
skb_frag_t
*
frag
=
&
skb_shinfo
(
skb
)
->
frags
[
i
];
len
=
frag
->
size
;
mapping
=
pci_map_page
(
tp
->
pdev
,
frag
->
page
,
frag
->
page_offset
,
len
,
PCI_DMA_TODEVICE
);
mapping
=
sp
->
dma_maps
[
i
+
1
];
tp
->
tx_buffers
[
entry
].
skb
=
NULL
;
pci_unmap_addr_set
(
&
tp
->
tx_buffers
[
entry
],
mapping
,
mapping
);
if
(
tg3_4g_overflow_test
(
mapping
,
len
))
would_hit_hwbug
=
1
;
...
...
@@ -5128,7 +5114,6 @@ static void tg3_free_rings(struct tg3 *tp)
for
(
i
=
0
;
i
<
TG3_TX_RING_SIZE
;
)
{
struct
tx_ring_info
*
txp
;
struct
sk_buff
*
skb
;
int
j
;
txp
=
&
tp
->
tx_buffers
[
i
];
skb
=
txp
->
skb
;
...
...
@@ -5138,22 +5123,11 @@ static void tg3_free_rings(struct tg3 *tp)
continue
;
}
pci_unmap_single
(
tp
->
pdev
,
pci_unmap_addr
(
txp
,
mapping
),
skb_headlen
(
skb
),
PCI_DMA_TODEVICE
);
txp
->
skb
=
NULL
;
skb_dma_unmap
(
&
tp
->
pdev
->
dev
,
skb
,
DMA_TO_DEVICE
);
i
++
;
txp
->
skb
=
NULL
;
for
(
j
=
0
;
j
<
skb_shinfo
(
skb
)
->
nr_frags
;
j
++
)
{
txp
=
&
tp
->
tx_buffers
[
i
&
(
TG3_TX_RING_SIZE
-
1
)];
pci_unmap_page
(
tp
->
pdev
,
pci_unmap_addr
(
txp
,
mapping
),
skb_shinfo
(
skb
)
->
frags
[
j
].
size
,
PCI_DMA_TODEVICE
);
i
++
;
}
i
+=
skb_shinfo
(
skb
)
->
nr_frags
+
1
;
dev_kfree_skb_any
(
skb
);
}
...
...
drivers/net/tg3.h
浏览文件 @
90079ce8
...
...
@@ -2197,7 +2197,6 @@ struct ring_info {
struct
tx_ring_info
{
struct
sk_buff
*
skb
;
DECLARE_PCI_UNMAP_ADDR
(
mapping
)
u32
prev_vlan_tag
;
};
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录