Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
52a34c7f
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
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看板
提交
52a34c7f
编写于
6月 23, 2006
作者:
D
David S. Miller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[NET] sunbmac: Convert over to new SBUS device framework.
Signed-off-by:
N
David S. Miller
<
davem@davemloft.net
>
上级
c2d81e63
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
61 addition
and
67 deletion
+61
-67
drivers/net/sunbmac.c
drivers/net/sunbmac.c
+61
-66
drivers/net/sunbmac.h
drivers/net/sunbmac.h
+0
-1
未找到文件。
drivers/net/sunbmac.c
浏览文件 @
52a34c7f
...
...
@@ -72,8 +72,6 @@ MODULE_LICENSE("GPL");
#define DIRQ(x)
#endif
static
struct
bigmac
*
root_bigmac_dev
;
#define DEFAULT_JAMSIZE 4
/* Toe jam */
#define QEC_RESET_TRIES 200
...
...
@@ -491,7 +489,7 @@ static void bigmac_tcvr_init(struct bigmac *bp)
}
}
static
int
bigmac_init
(
struct
bigmac
*
,
int
);
static
int
bigmac_init
_hw
(
struct
bigmac
*
,
int
);
static
int
try_next_permutation
(
struct
bigmac
*
bp
,
void
__iomem
*
tregs
)
{
...
...
@@ -551,7 +549,7 @@ static void bigmac_timer(unsigned long data)
if
(
ret
==
-
1
)
{
printk
(
KERN_ERR
"%s: Link down, cable problem?
\n
"
,
bp
->
dev
->
name
);
ret
=
bigmac_init
(
bp
,
0
);
ret
=
bigmac_init
_hw
(
bp
,
0
);
if
(
ret
)
{
printk
(
KERN_ERR
"%s: Error, cannot re-init the "
"BigMAC.
\n
"
,
bp
->
dev
->
name
);
...
...
@@ -621,7 +619,7 @@ static void bigmac_begin_auto_negotiation(struct bigmac *bp)
add_timer
(
&
bp
->
bigmac_timer
);
}
static
int
bigmac_init
(
struct
bigmac
*
bp
,
int
from_irq
)
static
int
bigmac_init
_hw
(
struct
bigmac
*
bp
,
int
from_irq
)
{
void
__iomem
*
gregs
=
bp
->
gregs
;
void
__iomem
*
cregs
=
bp
->
creg
;
...
...
@@ -752,7 +750,7 @@ static void bigmac_is_medium_rare(struct bigmac *bp, u32 qec_status, u32 bmac_st
}
printk
(
" RESET
\n
"
);
bigmac_init
(
bp
,
1
);
bigmac_init
_hw
(
bp
,
1
);
}
/* BigMAC transmit complete service routines. */
...
...
@@ -926,7 +924,7 @@ static int bigmac_open(struct net_device *dev)
return
ret
;
}
init_timer
(
&
bp
->
bigmac_timer
);
ret
=
bigmac_init
(
bp
,
0
);
ret
=
bigmac_init
_hw
(
bp
,
0
);
if
(
ret
)
free_irq
(
dev
->
irq
,
bp
);
return
ret
;
...
...
@@ -950,7 +948,7 @@ static void bigmac_tx_timeout(struct net_device *dev)
{
struct
bigmac
*
bp
=
(
struct
bigmac
*
)
dev
->
priv
;
bigmac_init
(
bp
,
0
);
bigmac_init
_hw
(
bp
,
0
);
netif_wake_queue
(
dev
);
}
...
...
@@ -1104,6 +1102,8 @@ static int __init bigmac_ether_init(struct sbus_dev *qec_sdev)
bp
->
qec_sdev
=
qec_sdev
;
bp
->
bigmac_sdev
=
qec_sdev
->
child
;
SET_NETDEV_DEV
(
dev
,
&
bp
->
bigmac_sdev
->
ofdev
.
dev
);
spin_lock_init
(
&
bp
->
lock
);
/* Verify the registers we expect, are actually there. */
...
...
@@ -1226,11 +1226,7 @@ static int __init bigmac_ether_init(struct sbus_dev *qec_sdev)
goto
fail_and_cleanup
;
}
/* Put us into the list of instances attached for later driver
* exit.
*/
bp
->
next_module
=
root_bigmac_dev
;
root_bigmac_dev
=
bp
;
dev_set_drvdata
(
&
bp
->
bigmac_sdev
->
ofdev
.
dev
,
bp
);
printk
(
KERN_INFO
"%s: BigMAC 100baseT Ethernet "
,
dev
->
name
);
for
(
i
=
0
;
i
<
6
;
i
++
)
...
...
@@ -1266,69 +1262,68 @@ static int __init bigmac_ether_init(struct sbus_dev *qec_sdev)
/* QEC can be the parent of either QuadEthernet or
* a BigMAC. We want the latter.
*/
static
int
__
init
bigmac_match
(
struct
sbus_dev
*
sdev
)
static
int
__
devinit
bigmac_sbus_probe
(
struct
of_device
*
dev
,
const
struct
of_device_id
*
match
)
{
struct
sbus_dev
*
child
=
sdev
->
child
;
struct
sbus_dev
*
sdev
=
to_sbus_device
(
&
dev
->
dev
);
struct
device_node
*
dp
=
dev
->
node
;
if
(
strcmp
(
sdev
->
prom_name
,
"qec"
)
!=
0
)
return
0
;
if
(
!
strcmp
(
dp
->
name
,
"be"
)
)
sdev
=
sdev
->
parent
;
if
(
child
==
NULL
)
return
0
;
if
(
strcmp
(
child
->
prom_name
,
"be"
)
!=
0
)
return
0
;
return
1
;
return
bigmac_ether_init
(
sdev
);
}
static
int
__
init
bigmac_probe
(
void
)
static
int
__
devexit
bigmac_sbus_remove
(
struct
of_device
*
dev
)
{
struct
sbus_bus
*
sbus
;
struct
sbus_dev
*
sdev
=
NULL
;
static
int
called
;
int
cards
=
0
,
v
;
root_bigmac_dev
=
NULL
;
if
(
called
)
return
-
ENODEV
;
called
++
;
for_each_sbus
(
sbus
)
{
for_each_sbusdev
(
sdev
,
sbus
)
{
if
(
bigmac_match
(
sdev
))
{
cards
++
;
if
((
v
=
bigmac_ether_init
(
sdev
)))
return
v
;
}
}
}
if
(
!
cards
)
return
-
ENODEV
;
struct
bigmac
*
bp
=
dev_get_drvdata
(
&
dev
->
dev
);
struct
net_device
*
net_dev
=
bp
->
dev
;
unregister_netdevice
(
net_dev
);
sbus_iounmap
(
bp
->
gregs
,
GLOB_REG_SIZE
);
sbus_iounmap
(
bp
->
creg
,
CREG_REG_SIZE
);
sbus_iounmap
(
bp
->
bregs
,
BMAC_REG_SIZE
);
sbus_iounmap
(
bp
->
tregs
,
TCVR_REG_SIZE
);
sbus_free_consistent
(
bp
->
bigmac_sdev
,
PAGE_SIZE
,
bp
->
bmac_block
,
bp
->
bblock_dvma
);
free_netdev
(
net_dev
);
dev_set_drvdata
(
&
dev
->
dev
,
NULL
);
return
0
;
}
static
void
__exit
bigmac_cleanup
(
void
)
{
while
(
root_bigmac_dev
)
{
struct
bigmac
*
bp
=
root_bigmac_dev
;
struct
bigmac
*
bp_nxt
=
root_bigmac_dev
->
next_module
;
static
struct
of_device_id
bigmac_sbus_match
[]
=
{
{
.
name
=
"qec"
,
},
{
.
name
=
"be"
,
},
{},
};
sbus_iounmap
(
bp
->
gregs
,
GLOB_REG_SIZE
);
sbus_iounmap
(
bp
->
creg
,
CREG_REG_SIZE
);
sbus_iounmap
(
bp
->
bregs
,
BMAC_REG_SIZE
);
sbus_iounmap
(
bp
->
tregs
,
TCVR_REG_SIZE
);
sbus_free_consistent
(
bp
->
bigmac_sdev
,
PAGE_SIZE
,
bp
->
bmac_block
,
bp
->
bblock_dvma
);
MODULE_DEVICE_TABLE
(
of
,
bigmac_sbus_match
);
unregister_netdev
(
bp
->
dev
);
free_netdev
(
bp
->
dev
);
root_bigmac_dev
=
bp_nxt
;
}
static
struct
of_platform_driver
bigmac_sbus_driver
=
{
.
name
=
"sunbmac"
,
.
match_table
=
bigmac_sbus_match
,
.
probe
=
bigmac_sbus_probe
,
.
remove
=
__devexit_p
(
bigmac_sbus_remove
),
};
static
int
__init
bigmac_init
(
void
)
{
return
of_register_driver
(
&
bigmac_sbus_driver
,
&
sbus_bus_type
);
}
static
void
__exit
bigmac_exit
(
void
)
{
of_unregister_driver
(
&
bigmac_sbus_driver
);
}
module_init
(
bigmac_
probe
);
module_exit
(
bigmac_
cleanup
);
module_init
(
bigmac_
init
);
module_exit
(
bigmac_
exit
);
drivers/net/sunbmac.h
浏览文件 @
52a34c7f
...
...
@@ -332,7 +332,6 @@ struct bigmac {
struct
sbus_dev
*
qec_sdev
;
struct
sbus_dev
*
bigmac_sdev
;
struct
net_device
*
dev
;
struct
bigmac
*
next_module
;
};
/* We use this to acquire receive skb's that we can DMA directly into. */
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录