Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
b4c7d3b0
K
Kernel
项目概览
openeuler
/
Kernel
接近 2 年 前同步成功
通知
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看板
提交
b4c7d3b0
编写于
12月 20, 2008
作者:
K
Krzysztof Hałasa
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
IXP4xx: Make the Ethernet driver use built-in netdev stats.
Signed-off-by:
N
Krzysztof Hałasa
<
khc@pm.waw.pl
>
上级
3c36a837
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
8 addition
and
16 deletion
+8
-16
drivers/net/arm/ixp4xx_eth.c
drivers/net/arm/ixp4xx_eth.c
+8
-16
未找到文件。
drivers/net/arm/ixp4xx_eth.c
浏览文件 @
b4c7d3b0
...
@@ -164,7 +164,6 @@ struct port {
...
@@ -164,7 +164,6 @@ struct port {
struct
npe
*
npe
;
struct
npe
*
npe
;
struct
net_device
*
netdev
;
struct
net_device
*
netdev
;
struct
napi_struct
napi
;
struct
napi_struct
napi
;
struct
net_device_stats
stat
;
struct
mii_if_info
mii
;
struct
mii_if_info
mii
;
struct
delayed_work
mdio_thread
;
struct
delayed_work
mdio_thread
;
struct
eth_plat_info
*
plat
;
struct
eth_plat_info
*
plat
;
...
@@ -562,7 +561,7 @@ static int eth_poll(struct napi_struct *napi, int budget)
...
@@ -562,7 +561,7 @@ static int eth_poll(struct napi_struct *napi, int budget)
#endif
#endif
if
(
!
skb
)
{
if
(
!
skb
)
{
port
->
stat
.
rx_dropped
++
;
dev
->
stats
.
rx_dropped
++
;
/* put the desc back on RX-ready queue */
/* put the desc back on RX-ready queue */
desc
->
buf_len
=
MAX_MRU
;
desc
->
buf_len
=
MAX_MRU
;
desc
->
pkt_len
=
0
;
desc
->
pkt_len
=
0
;
...
@@ -588,8 +587,8 @@ static int eth_poll(struct napi_struct *napi, int budget)
...
@@ -588,8 +587,8 @@ static int eth_poll(struct napi_struct *napi, int budget)
debug_pkt
(
dev
,
"eth_poll"
,
skb
->
data
,
skb
->
len
);
debug_pkt
(
dev
,
"eth_poll"
,
skb
->
data
,
skb
->
len
);
skb
->
protocol
=
eth_type_trans
(
skb
,
dev
);
skb
->
protocol
=
eth_type_trans
(
skb
,
dev
);
port
->
stat
.
rx_packets
++
;
dev
->
stats
.
rx_packets
++
;
port
->
stat
.
rx_bytes
+=
skb
->
len
;
dev
->
stats
.
rx_bytes
+=
skb
->
len
;
netif_receive_skb
(
skb
);
netif_receive_skb
(
skb
);
/* put the new buffer on RX-free queue */
/* put the new buffer on RX-free queue */
...
@@ -634,8 +633,8 @@ static void eth_txdone_irq(void *unused)
...
@@ -634,8 +633,8 @@ static void eth_txdone_irq(void *unused)
debug_desc
(
phys
,
desc
);
debug_desc
(
phys
,
desc
);
if
(
port
->
tx_buff_tab
[
n_desc
])
{
/* not the draining packet */
if
(
port
->
tx_buff_tab
[
n_desc
])
{
/* not the draining packet */
port
->
stat
.
tx_packets
++
;
port
->
netdev
->
stats
.
tx_packets
++
;
port
->
stat
.
tx_bytes
+=
desc
->
pkt_len
;
port
->
netdev
->
stats
.
tx_bytes
+=
desc
->
pkt_len
;
dma_unmap_tx
(
port
,
desc
);
dma_unmap_tx
(
port
,
desc
);
#if DEBUG_TX
#if DEBUG_TX
...
@@ -673,7 +672,7 @@ static int eth_xmit(struct sk_buff *skb, struct net_device *dev)
...
@@ -673,7 +672,7 @@ static int eth_xmit(struct sk_buff *skb, struct net_device *dev)
if
(
unlikely
(
skb
->
len
>
MAX_MRU
))
{
if
(
unlikely
(
skb
->
len
>
MAX_MRU
))
{
dev_kfree_skb
(
skb
);
dev_kfree_skb
(
skb
);
port
->
stat
.
tx_errors
++
;
dev
->
stats
.
tx_errors
++
;
return
NETDEV_TX_OK
;
return
NETDEV_TX_OK
;
}
}
...
@@ -689,7 +688,7 @@ static int eth_xmit(struct sk_buff *skb, struct net_device *dev)
...
@@ -689,7 +688,7 @@ static int eth_xmit(struct sk_buff *skb, struct net_device *dev)
bytes
=
ALIGN
(
offset
+
len
,
4
);
bytes
=
ALIGN
(
offset
+
len
,
4
);
if
(
!
(
mem
=
kmalloc
(
bytes
,
GFP_ATOMIC
)))
{
if
(
!
(
mem
=
kmalloc
(
bytes
,
GFP_ATOMIC
)))
{
dev_kfree_skb
(
skb
);
dev_kfree_skb
(
skb
);
port
->
stat
.
tx_dropped
++
;
dev
->
stats
.
tx_dropped
++
;
return
NETDEV_TX_OK
;
return
NETDEV_TX_OK
;
}
}
memcpy_swab32
(
mem
,
(
u32
*
)((
int
)
skb
->
data
&
~
3
),
bytes
/
4
);
memcpy_swab32
(
mem
,
(
u32
*
)((
int
)
skb
->
data
&
~
3
),
bytes
/
4
);
...
@@ -703,7 +702,7 @@ static int eth_xmit(struct sk_buff *skb, struct net_device *dev)
...
@@ -703,7 +702,7 @@ static int eth_xmit(struct sk_buff *skb, struct net_device *dev)
#else
#else
kfree
(
mem
);
kfree
(
mem
);
#endif
#endif
port
->
stat
.
tx_dropped
++
;
dev
->
stats
.
tx_dropped
++
;
return
NETDEV_TX_OK
;
return
NETDEV_TX_OK
;
}
}
...
@@ -746,12 +745,6 @@ static int eth_xmit(struct sk_buff *skb, struct net_device *dev)
...
@@ -746,12 +745,6 @@ static int eth_xmit(struct sk_buff *skb, struct net_device *dev)
}
}
static
struct
net_device_stats
*
eth_stats
(
struct
net_device
*
dev
)
{
struct
port
*
port
=
netdev_priv
(
dev
);
return
&
port
->
stat
;
}
static
void
eth_set_mcast_list
(
struct
net_device
*
dev
)
static
void
eth_set_mcast_list
(
struct
net_device
*
dev
)
{
{
struct
port
*
port
=
netdev_priv
(
dev
);
struct
port
*
port
=
netdev_priv
(
dev
);
...
@@ -1155,7 +1148,6 @@ static int __devinit eth_init_one(struct platform_device *pdev)
...
@@ -1155,7 +1148,6 @@ static int __devinit eth_init_one(struct platform_device *pdev)
dev
->
open
=
eth_open
;
dev
->
open
=
eth_open
;
dev
->
hard_start_xmit
=
eth_xmit
;
dev
->
hard_start_xmit
=
eth_xmit
;
dev
->
stop
=
eth_close
;
dev
->
stop
=
eth_close
;
dev
->
get_stats
=
eth_stats
;
dev
->
do_ioctl
=
eth_ioctl
;
dev
->
do_ioctl
=
eth_ioctl
;
dev
->
set_multicast_list
=
eth_set_mcast_list
;
dev
->
set_multicast_list
=
eth_set_mcast_list
;
dev
->
tx_queue_len
=
100
;
dev
->
tx_queue_len
=
100
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录