Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
926d152e
Q
qemu
项目概览
openeuler
/
qemu
通知
10
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
Q
qemu
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
926d152e
编写于
7月 27, 2013
作者:
A
Andreas Färber
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
smc91c111: QOM cast cleanup
Signed-off-by:
N
Andreas Färber
<
afaerber@suse.de
>
上级
0e57587f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
19 addition
and
11 deletion
+19
-11
hw/net/smc91c111.c
hw/net/smc91c111.c
+19
-11
未找到文件。
hw/net/smc91c111.c
浏览文件 @
926d152e
...
@@ -16,8 +16,12 @@
...
@@ -16,8 +16,12 @@
/* Number of 2k memory pages available. */
/* Number of 2k memory pages available. */
#define NUM_PACKETS 4
#define NUM_PACKETS 4
#define TYPE_SMC91C111 "smc91c111"
#define SMC91C111(obj) OBJECT_CHECK(smc91c111_state, (obj), TYPE_SMC91C111)
typedef
struct
{
typedef
struct
{
SysBusDevice
busdev
;
SysBusDevice
parent_obj
;
NICState
*
nic
;
NICState
*
nic
;
NICConf
conf
;
NICConf
conf
;
uint16_t
tcr
;
uint16_t
tcr
;
...
@@ -254,7 +258,8 @@ static void smc91c111_queue_tx(smc91c111_state *s, int packet)
...
@@ -254,7 +258,8 @@ static void smc91c111_queue_tx(smc91c111_state *s, int packet)
static
void
smc91c111_reset
(
DeviceState
*
dev
)
static
void
smc91c111_reset
(
DeviceState
*
dev
)
{
{
smc91c111_state
*
s
=
FROM_SYSBUS
(
smc91c111_state
,
SYS_BUS_DEVICE
(
dev
));
smc91c111_state
*
s
=
SMC91C111
(
dev
);
s
->
bank
=
0
;
s
->
bank
=
0
;
s
->
tx_fifo_len
=
0
;
s
->
tx_fifo_len
=
0
;
s
->
tx_fifo_done_len
=
0
;
s
->
tx_fifo_done_len
=
0
;
...
@@ -302,8 +307,9 @@ static void smc91c111_writeb(void *opaque, hwaddr offset,
...
@@ -302,8 +307,9 @@ static void smc91c111_writeb(void *opaque, hwaddr offset,
return
;
return
;
case
5
:
case
5
:
SET_HIGH
(
rcr
,
value
);
SET_HIGH
(
rcr
,
value
);
if
(
s
->
rcr
&
RCR_SOFT_RST
)
if
(
s
->
rcr
&
RCR_SOFT_RST
)
{
smc91c111_reset
(
&
s
->
busdev
.
qdev
);
smc91c111_reset
(
DEVICE
(
s
));
}
return
;
return
;
case
10
:
case
11
:
/* RPCR */
case
10
:
case
11
:
/* RPCR */
/* Ignored */
/* Ignored */
...
@@ -744,16 +750,18 @@ static NetClientInfo net_smc91c111_info = {
...
@@ -744,16 +750,18 @@ static NetClientInfo net_smc91c111_info = {
.
cleanup
=
smc91c111_cleanup
,
.
cleanup
=
smc91c111_cleanup
,
};
};
static
int
smc91c111_init1
(
SysBusDevice
*
dev
)
static
int
smc91c111_init1
(
SysBusDevice
*
sbd
)
{
{
smc91c111_state
*
s
=
FROM_SYSBUS
(
smc91c111_state
,
dev
);
DeviceState
*
dev
=
DEVICE
(
sbd
);
smc91c111_state
*
s
=
SMC91C111
(
dev
);
memory_region_init_io
(
&
s
->
mmio
,
OBJECT
(
s
),
&
smc91c111_mem_ops
,
s
,
memory_region_init_io
(
&
s
->
mmio
,
OBJECT
(
s
),
&
smc91c111_mem_ops
,
s
,
"smc91c111-mmio"
,
16
);
"smc91c111-mmio"
,
16
);
sysbus_init_mmio
(
dev
,
&
s
->
mmio
);
sysbus_init_mmio
(
sbd
,
&
s
->
mmio
);
sysbus_init_irq
(
dev
,
&
s
->
irq
);
sysbus_init_irq
(
sbd
,
&
s
->
irq
);
qemu_macaddr_default_if_unset
(
&
s
->
conf
.
macaddr
);
qemu_macaddr_default_if_unset
(
&
s
->
conf
.
macaddr
);
s
->
nic
=
qemu_new_nic
(
&
net_smc91c111_info
,
&
s
->
conf
,
s
->
nic
=
qemu_new_nic
(
&
net_smc91c111_info
,
&
s
->
conf
,
object_get_typename
(
OBJECT
(
dev
)),
dev
->
qdev
.
id
,
s
);
object_get_typename
(
OBJECT
(
dev
)),
dev
->
id
,
s
);
qemu_format_nic_info_str
(
qemu_get_queue
(
s
->
nic
),
s
->
conf
.
macaddr
.
a
);
qemu_format_nic_info_str
(
qemu_get_queue
(
s
->
nic
),
s
->
conf
.
macaddr
.
a
);
/* ??? Save/restore. */
/* ??? Save/restore. */
return
0
;
return
0
;
...
@@ -776,7 +784,7 @@ static void smc91c111_class_init(ObjectClass *klass, void *data)
...
@@ -776,7 +784,7 @@ static void smc91c111_class_init(ObjectClass *klass, void *data)
}
}
static
const
TypeInfo
smc91c111_info
=
{
static
const
TypeInfo
smc91c111_info
=
{
.
name
=
"smc91c111"
,
.
name
=
TYPE_SMC91C111
,
.
parent
=
TYPE_SYS_BUS_DEVICE
,
.
parent
=
TYPE_SYS_BUS_DEVICE
,
.
instance_size
=
sizeof
(
smc91c111_state
),
.
instance_size
=
sizeof
(
smc91c111_state
),
.
class_init
=
smc91c111_class_init
,
.
class_init
=
smc91c111_class_init
,
...
@@ -795,7 +803,7 @@ void smc91c111_init(NICInfo *nd, uint32_t base, qemu_irq irq)
...
@@ -795,7 +803,7 @@ void smc91c111_init(NICInfo *nd, uint32_t base, qemu_irq irq)
SysBusDevice
*
s
;
SysBusDevice
*
s
;
qemu_check_nic_model
(
nd
,
"smc91c111"
);
qemu_check_nic_model
(
nd
,
"smc91c111"
);
dev
=
qdev_create
(
NULL
,
"smc91c111"
);
dev
=
qdev_create
(
NULL
,
TYPE_SMC91C111
);
qdev_set_nic_properties
(
dev
,
nd
);
qdev_set_nic_properties
(
dev
,
nd
);
qdev_init_nofail
(
dev
);
qdev_init_nofail
(
dev
);
s
=
SYS_BUS_DEVICE
(
dev
);
s
=
SYS_BUS_DEVICE
(
dev
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录