Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
9bac7d6c
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看板
提交
9bac7d6c
编写于
11月 27, 2011
作者:
A
Avi Kivity
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
omap2: convert to memory API (part I)
Signed-off-by:
N
Avi Kivity
<
avi@redhat.com
>
上级
750ecd44
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
55 addition
and
48 deletion
+55
-48
hw/omap2.c
hw/omap2.c
+55
-48
未找到文件。
hw/omap2.c
浏览文件 @
9bac7d6c
...
@@ -33,6 +33,7 @@
...
@@ -33,6 +33,7 @@
/* Enhanced Audio Controller (CODEC only) */
/* Enhanced Audio Controller (CODEC only) */
struct
omap_eac_s
{
struct
omap_eac_s
{
qemu_irq
irq
;
qemu_irq
irq
;
MemoryRegion
iomem
;
uint16_t
sysconfig
;
uint16_t
sysconfig
;
uint8_t
config
[
4
];
uint8_t
config
[
4
];
...
@@ -323,11 +324,16 @@ static void omap_eac_reset(struct omap_eac_s *s)
...
@@ -323,11 +324,16 @@ static void omap_eac_reset(struct omap_eac_s *s)
omap_eac_interrupt_update
(
s
);
omap_eac_interrupt_update
(
s
);
}
}
static
uint32_t
omap_eac_read
(
void
*
opaque
,
target_phys_addr_t
addr
)
static
uint64_t
omap_eac_read
(
void
*
opaque
,
target_phys_addr_t
addr
,
unsigned
size
)
{
{
struct
omap_eac_s
*
s
=
(
struct
omap_eac_s
*
)
opaque
;
struct
omap_eac_s
*
s
=
(
struct
omap_eac_s
*
)
opaque
;
uint32_t
ret
;
uint32_t
ret
;
if
(
size
!=
2
)
{
return
omap_badwidth_read16
(
opaque
,
addr
);
}
switch
(
addr
)
{
switch
(
addr
)
{
case
0x000
:
/* CPCFR1 */
case
0x000
:
/* CPCFR1 */
return
s
->
config
[
0
];
return
s
->
config
[
0
];
...
@@ -435,10 +441,14 @@ static uint32_t omap_eac_read(void *opaque, target_phys_addr_t addr)
...
@@ -435,10 +441,14 @@ static uint32_t omap_eac_read(void *opaque, target_phys_addr_t addr)
}
}
static
void
omap_eac_write
(
void
*
opaque
,
target_phys_addr_t
addr
,
static
void
omap_eac_write
(
void
*
opaque
,
target_phys_addr_t
addr
,
uint32_t
valu
e
)
uint64_t
value
,
unsigned
siz
e
)
{
{
struct
omap_eac_s
*
s
=
(
struct
omap_eac_s
*
)
opaque
;
struct
omap_eac_s
*
s
=
(
struct
omap_eac_s
*
)
opaque
;
if
(
size
!=
2
)
{
return
omap_badwidth_write16
(
opaque
,
addr
,
value
);
}
switch
(
addr
)
{
switch
(
addr
)
{
case
0x098
:
/* APD1LCR */
case
0x098
:
/* APD1LCR */
case
0x09c
:
/* APD1RCR */
case
0x09c
:
/* APD1RCR */
...
@@ -574,22 +584,15 @@ static void omap_eac_write(void *opaque, target_phys_addr_t addr,
...
@@ -574,22 +584,15 @@ static void omap_eac_write(void *opaque, target_phys_addr_t addr,
}
}
}
}
static
CPUReadMemoryFunc
*
const
omap_eac_readfn
[]
=
{
static
const
MemoryRegionOps
omap_eac_ops
=
{
omap_badwidth_read16
,
.
read
=
omap_eac_read
,
omap_eac_read
,
.
write
=
omap_eac_write
,
omap_badwidth_read16
,
.
endianness
=
DEVICE_NATIVE_ENDIAN
,
};
static
CPUWriteMemoryFunc
*
const
omap_eac_writefn
[]
=
{
omap_badwidth_write16
,
omap_eac_write
,
omap_badwidth_write16
,
};
};
static
struct
omap_eac_s
*
omap_eac_init
(
struct
omap_target_agent_s
*
ta
,
static
struct
omap_eac_s
*
omap_eac_init
(
struct
omap_target_agent_s
*
ta
,
qemu_irq
irq
,
qemu_irq
*
drq
,
omap_clk
fclk
,
omap_clk
iclk
)
qemu_irq
irq
,
qemu_irq
*
drq
,
omap_clk
fclk
,
omap_clk
iclk
)
{
{
int
iomemtype
;
struct
omap_eac_s
*
s
=
(
struct
omap_eac_s
*
)
struct
omap_eac_s
*
s
=
(
struct
omap_eac_s
*
)
g_malloc0
(
sizeof
(
struct
omap_eac_s
));
g_malloc0
(
sizeof
(
struct
omap_eac_s
));
...
@@ -600,9 +603,9 @@ static struct omap_eac_s *omap_eac_init(struct omap_target_agent_s *ta,
...
@@ -600,9 +603,9 @@ static struct omap_eac_s *omap_eac_init(struct omap_target_agent_s *ta,
AUD_register_card
(
"OMAP EAC"
,
&
s
->
codec
.
card
);
AUD_register_card
(
"OMAP EAC"
,
&
s
->
codec
.
card
);
iomemtype
=
cpu_register_io_memory
(
omap_eac_readfn
,
memory_region_init_io
(
&
s
->
iomem
,
&
omap_eac_ops
,
s
,
"omap.eac"
,
omap_eac_writefn
,
s
,
DEVICE_NATIVE_ENDIAN
);
omap_l4_region_size
(
ta
,
0
)
);
omap_l4_attach
(
ta
,
0
,
iomemtype
);
omap_l4_attach
_region
(
ta
,
0
,
&
s
->
iomem
);
return
s
;
return
s
;
}
}
...
@@ -610,6 +613,8 @@ static struct omap_eac_s *omap_eac_init(struct omap_target_agent_s *ta,
...
@@ -610,6 +613,8 @@ static struct omap_eac_s *omap_eac_init(struct omap_target_agent_s *ta,
/* STI/XTI (emulation interface) console - reverse engineered only */
/* STI/XTI (emulation interface) console - reverse engineered only */
struct
omap_sti_s
{
struct
omap_sti_s
{
qemu_irq
irq
;
qemu_irq
irq
;
MemoryRegion
iomem
;
MemoryRegion
iomem_fifo
;
CharDriverState
*
chr
;
CharDriverState
*
chr
;
uint32_t
sysconfig
;
uint32_t
sysconfig
;
...
@@ -639,10 +644,15 @@ static void omap_sti_reset(struct omap_sti_s *s)
...
@@ -639,10 +644,15 @@ static void omap_sti_reset(struct omap_sti_s *s)
omap_sti_interrupt_update
(
s
);
omap_sti_interrupt_update
(
s
);
}
}
static
uint32_t
omap_sti_read
(
void
*
opaque
,
target_phys_addr_t
addr
)
static
uint64_t
omap_sti_read
(
void
*
opaque
,
target_phys_addr_t
addr
,
unsigned
size
)
{
{
struct
omap_sti_s
*
s
=
(
struct
omap_sti_s
*
)
opaque
;
struct
omap_sti_s
*
s
=
(
struct
omap_sti_s
*
)
opaque
;
if
(
size
!=
4
)
{
return
omap_badwidth_read32
(
opaque
,
addr
);
}
switch
(
addr
)
{
switch
(
addr
)
{
case
0x00
:
/* STI_REVISION */
case
0x00
:
/* STI_REVISION */
return
0x10
;
return
0x10
;
...
@@ -676,10 +686,14 @@ static uint32_t omap_sti_read(void *opaque, target_phys_addr_t addr)
...
@@ -676,10 +686,14 @@ static uint32_t omap_sti_read(void *opaque, target_phys_addr_t addr)
}
}
static
void
omap_sti_write
(
void
*
opaque
,
target_phys_addr_t
addr
,
static
void
omap_sti_write
(
void
*
opaque
,
target_phys_addr_t
addr
,
uint32_t
valu
e
)
uint64_t
value
,
unsigned
siz
e
)
{
{
struct
omap_sti_s
*
s
=
(
struct
omap_sti_s
*
)
opaque
;
struct
omap_sti_s
*
s
=
(
struct
omap_sti_s
*
)
opaque
;
if
(
size
!=
4
)
{
return
omap_badwidth_write32
(
opaque
,
addr
,
value
);
}
switch
(
addr
)
{
switch
(
addr
)
{
case
0x00
:
/* STI_REVISION */
case
0x00
:
/* STI_REVISION */
case
0x14
:
/* STI_SYSSTATUS / STI_RX_STATUS / XTI_SYSSTATUS */
case
0x14
:
/* STI_SYSSTATUS / STI_RX_STATUS / XTI_SYSSTATUS */
...
@@ -721,31 +735,30 @@ static void omap_sti_write(void *opaque, target_phys_addr_t addr,
...
@@ -721,31 +735,30 @@ static void omap_sti_write(void *opaque, target_phys_addr_t addr,
}
}
}
}
static
CPUReadMemoryFunc
*
const
omap_sti_readfn
[]
=
{
static
const
MemoryRegionOps
omap_sti_ops
=
{
omap_badwidth_read32
,
.
read
=
omap_sti_read
,
omap_badwidth_read32
,
.
write
=
omap_sti_write
,
omap_sti_read
,
.
endianness
=
DEVICE_NATIVE_ENDIAN
,
};
};
static
CPUWriteMemoryFunc
*
const
omap_sti_writefn
[]
=
{
static
uint64_t
omap_sti_fifo_read
(
void
*
opaque
,
target_phys_addr_t
addr
,
omap_badwidth_write32
,
unsigned
size
)
omap_badwidth_write32
,
omap_sti_write
,
};
static
uint32_t
omap_sti_fifo_read
(
void
*
opaque
,
target_phys_addr_t
addr
)
{
{
OMAP_BAD_REG
(
addr
);
OMAP_BAD_REG
(
addr
);
return
0
;
return
0
;
}
}
static
void
omap_sti_fifo_write
(
void
*
opaque
,
target_phys_addr_t
addr
,
static
void
omap_sti_fifo_write
(
void
*
opaque
,
target_phys_addr_t
addr
,
uint32_t
valu
e
)
uint64_t
value
,
unsigned
siz
e
)
{
{
struct
omap_sti_s
*
s
=
(
struct
omap_sti_s
*
)
opaque
;
struct
omap_sti_s
*
s
=
(
struct
omap_sti_s
*
)
opaque
;
int
ch
=
addr
>>
6
;
int
ch
=
addr
>>
6
;
uint8_t
byte
=
value
;
uint8_t
byte
=
value
;
if
(
size
!=
1
)
{
return
omap_badwidth_write8
(
opaque
,
addr
,
size
);
}
if
(
ch
==
STI_TRACE_CONTROL_CHANNEL
)
{
if
(
ch
==
STI_TRACE_CONTROL_CHANNEL
)
{
/* Flush channel <i>value</i>. */
/* Flush channel <i>value</i>. */
qemu_chr_fe_write
(
s
->
chr
,
(
const
uint8_t
*
)
"
\r
"
,
1
);
qemu_chr_fe_write
(
s
->
chr
,
(
const
uint8_t
*
)
"
\r
"
,
1
);
...
@@ -759,23 +772,17 @@ static void omap_sti_fifo_write(void *opaque, target_phys_addr_t addr,
...
@@ -759,23 +772,17 @@ static void omap_sti_fifo_write(void *opaque, target_phys_addr_t addr,
}
}
}
}
static
CPUReadMemoryFunc
*
const
omap_sti_fifo_readfn
[]
=
{
static
const
MemoryRegionOps
omap_sti_fifo_ops
=
{
omap_sti_fifo_read
,
.
read
=
omap_sti_fifo_read
,
omap_badwidth_read8
,
.
write
=
omap_sti_fifo_write
,
omap_badwidth_read8
,
.
endianness
=
DEVICE_NATIVE_ENDIAN
,
};
static
CPUWriteMemoryFunc
*
const
omap_sti_fifo_writefn
[]
=
{
omap_sti_fifo_write
,
omap_badwidth_write8
,
omap_badwidth_write8
,
};
};
static
struct
omap_sti_s
*
omap_sti_init
(
struct
omap_target_agent_s
*
ta
,
static
struct
omap_sti_s
*
omap_sti_init
(
struct
omap_target_agent_s
*
ta
,
MemoryRegion
*
sysmem
,
target_phys_addr_t
channel_base
,
qemu_irq
irq
,
omap_clk
clk
,
target_phys_addr_t
channel_base
,
qemu_irq
irq
,
omap_clk
clk
,
CharDriverState
*
chr
)
CharDriverState
*
chr
)
{
{
int
iomemtype
;
struct
omap_sti_s
*
s
=
(
struct
omap_sti_s
*
)
struct
omap_sti_s
*
s
=
(
struct
omap_sti_s
*
)
g_malloc0
(
sizeof
(
struct
omap_sti_s
));
g_malloc0
(
sizeof
(
struct
omap_sti_s
));
...
@@ -784,13 +791,13 @@ static struct omap_sti_s *omap_sti_init(struct omap_target_agent_s *ta,
...
@@ -784,13 +791,13 @@ static struct omap_sti_s *omap_sti_init(struct omap_target_agent_s *ta,
s
->
chr
=
chr
?:
qemu_chr_new
(
"null"
,
"null"
,
NULL
);
s
->
chr
=
chr
?:
qemu_chr_new
(
"null"
,
"null"
,
NULL
);
iomemtype
=
cpu_register_io_memory
(
omap_sti_readfn
,
memory_region_init_io
(
&
s
->
iomem
,
&
omap_sti_ops
,
s
,
"omap.sti"
,
omap_sti_writefn
,
s
,
DEVICE_NATIVE_ENDIAN
);
omap_l4_region_size
(
ta
,
0
)
);
omap_l4_attach
(
ta
,
0
,
iomemtype
);
omap_l4_attach
_region
(
ta
,
0
,
&
s
->
iomem
);
iomemtype
=
cpu_register_io_memory
(
omap_sti_fifo_readfn
,
memory_region_init_io
(
&
s
->
iomem_fifo
,
&
omap_sti_fifo_ops
,
s
,
omap_sti_fifo_writefn
,
s
,
DEVICE_NATIVE_ENDIAN
);
"omap.sti.fifo"
,
0x10000
);
cpu_register_physical_memory
(
channel_base
,
0x10000
,
iomemtype
);
memory_region_add_subregion
(
sysmem
,
channel_base
,
&
s
->
iomem_fifo
);
return
s
;
return
s
;
}
}
...
@@ -2457,7 +2464,7 @@ struct omap_mpu_state_s *omap2420_mpu_init(MemoryRegion *sysmem,
...
@@ -2457,7 +2464,7 @@ struct omap_mpu_state_s *omap2420_mpu_init(MemoryRegion *sysmem,
omap_findclk
(
s
,
"dss_l3_iclk"
),
omap_findclk
(
s
,
"dss_l3_iclk"
),
omap_findclk
(
s
,
"dss_l4_iclk"
));
omap_findclk
(
s
,
"dss_l4_iclk"
));
omap_sti_init
(
omap_l4ta
(
s
->
l4
,
18
),
0x54000000
,
omap_sti_init
(
omap_l4ta
(
s
->
l4
,
18
),
sysmem
,
0x54000000
,
qdev_get_gpio_in
(
s
->
ih
[
0
],
OMAP_INT_24XX_STI
),
qdev_get_gpio_in
(
s
->
ih
[
0
],
OMAP_INT_24XX_STI
),
omap_findclk
(
s
,
"emul_ck"
),
omap_findclk
(
s
,
"emul_ck"
),
serial_hds
[
0
]
&&
serial_hds
[
1
]
&&
serial_hds
[
2
]
?
serial_hds
[
0
]
&&
serial_hds
[
1
]
&&
serial_hds
[
2
]
?
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录