Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
db59203d
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看板
提交
db59203d
编写于
5月 21, 2006
作者:
P
pbrook
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ESP DMA fix.
git-svn-id:
svn://svn.savannah.nongnu.org/qemu/trunk@1926
c046a42c-6fe2-441c-8c8c-71466251a162
上级
1c46d713
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
50 addition
and
20 deletion
+50
-20
hw/esp.c
hw/esp.c
+50
-20
未找到文件。
hw/esp.c
浏览文件 @
db59203d
...
...
@@ -229,12 +229,17 @@ static int esp_write_dma_cb(ESPState *s,
target_phys_addr_t
phys_addr
,
int
transfer_size1
)
{
int
len
;
if
(
bdrv_get_type_hint
(
s
->
bd
[
s
->
target
])
==
BDRV_TYPE_CDROM
)
{
len
=
transfer_size1
/
2048
;
}
else
{
len
=
transfer_size1
/
512
;
}
DPRINTF
(
"Write callback (offset %lld len %lld size %d trans_size %d)
\n
"
,
s
->
offset
,
s
->
len
,
s
->
ti_size
,
transfer_size1
);
bdrv_write
(
s
->
bd
[
s
->
target
],
s
->
offset
,
s
->
ti_buf
,
s
->
len
);
s
->
offset
=
0
;
s
->
len
=
0
;
s
->
target
=
0
;
bdrv_write
(
s
->
bd
[
s
->
target
],
s
->
offset
,
s
->
ti_buf
+
s
->
ti_rptr
,
len
);
s
->
offset
+=
len
;
return
0
;
}
...
...
@@ -336,6 +341,7 @@ static void handle_satn(ESPState *s)
bdrv_read
(
s
->
bd
[
target
],
offset
,
s
->
ti_buf
,
len
);
// XXX error handling
s
->
ti_dir
=
1
;
s
->
ti_rptr
=
0
;
break
;
}
case
0x2a
:
...
...
@@ -359,6 +365,7 @@ static void handle_satn(ESPState *s)
s
->
offset
=
offset
;
s
->
len
=
len
;
s
->
target
=
target
;
s
->
ti_rptr
=
0
;
// XXX error handling
s
->
ti_dir
=
0
;
break
;
...
...
@@ -415,10 +422,9 @@ static void handle_satn(ESPState *s)
static
void
dma_write
(
ESPState
*
s
,
const
uint8_t
*
buf
,
uint32_t
len
)
{
uint32_t
dmaptr
,
dmalen
;
uint32_t
dmaptr
;
dmalen
=
s
->
wregs
[
0
]
|
(
s
->
wregs
[
1
]
<<
8
);
DPRINTF
(
"Transfer status len %d
\n
"
,
dmalen
);
DPRINTF
(
"Transfer status len %d
\n
"
,
len
);
if
(
s
->
dma
)
{
dmaptr
=
iommu_translate
(
s
->
espdmaregs
[
1
]);
DPRINTF
(
"DMA Direction: %c
\n
"
,
s
->
espdmaregs
[
0
]
&
0x100
?
'w'
:
'r'
);
...
...
@@ -428,10 +434,10 @@ static void dma_write(ESPState *s, const uint8_t *buf, uint32_t len)
s
->
rregs
[
6
]
=
SEQ_CD
;
}
else
{
memcpy
(
s
->
ti_buf
,
buf
,
len
);
s
->
ti_size
=
dma
len
;
s
->
ti_size
=
len
;
s
->
ti_rptr
=
0
;
s
->
ti_wptr
=
0
;
s
->
rregs
[
7
]
=
dma
len
;
s
->
rregs
[
7
]
=
len
;
}
s
->
espdmaregs
[
0
]
|=
DMA_INTR
;
pic_set_irq
(
s
->
irq
,
1
);
...
...
@@ -442,34 +448,58 @@ static const uint8_t okbuf[] = {0, 0};
static
void
handle_ti
(
ESPState
*
s
)
{
uint32_t
dmaptr
,
dmalen
;
uint32_t
dmaptr
,
dmalen
,
minlen
,
len
,
from
,
to
;
unsigned
int
i
;
dmalen
=
s
->
wregs
[
0
]
|
(
s
->
wregs
[
1
]
<<
8
);
DPRINTF
(
"Transfer Information len %d
\n
"
,
dmalen
);
if
(
dmalen
==
0
)
{
dmalen
=
0x10000
;
}
minlen
=
(
dmalen
<
s
->
ti_size
)
?
dmalen
:
s
->
ti_size
;
DPRINTF
(
"Transfer Information len %d
\n
"
,
minlen
);
if
(
s
->
dma
)
{
dmaptr
=
iommu_translate
(
s
->
espdmaregs
[
1
]);
DPRINTF
(
"DMA Direction: %c, addr 0x%8.8x
\n
"
,
s
->
espdmaregs
[
0
]
&
0x100
?
'w'
:
'r'
,
dmaptr
);
for
(
i
=
0
;
i
<
s
->
ti_size
;
i
++
)
{
DPRINTF
(
"DMA Direction: %c, addr 0x%8.8x %08x %d %d
\n
"
,
s
->
espdmaregs
[
0
]
&
0x100
?
'w'
:
'r'
,
dmaptr
,
s
->
ti_size
,
s
->
ti_rptr
,
s
->
ti_dir
);
from
=
s
->
espdmaregs
[
1
];
to
=
from
+
minlen
;
for
(
i
=
0
;
i
<
minlen
;
i
+=
len
,
from
+=
len
)
{
dmaptr
=
iommu_translate
(
s
->
espdmaregs
[
1
]
+
i
);
if
((
from
&
TARGET_PAGE_MASK
)
!=
(
to
&
TARGET_PAGE_MASK
))
{
len
=
TARGET_PAGE_SIZE
-
(
from
&
~
TARGET_PAGE_MASK
);
}
else
{
len
=
to
-
from
;
}
DPRINTF
(
"DMA address p %08x v %08x len %08x, from %08x, to %08x
\n
"
,
dmaptr
,
s
->
espdmaregs
[
1
]
+
i
,
len
,
from
,
to
);
if
(
s
->
ti_dir
)
cpu_physical_memory_write
(
dmaptr
,
&
s
->
ti_buf
[
i
],
1
);
cpu_physical_memory_write
(
dmaptr
,
&
s
->
ti_buf
[
s
->
ti_rptr
+
i
],
len
);
else
cpu_physical_memory_read
(
dmaptr
,
&
s
->
ti_buf
[
i
],
1
);
cpu_physical_memory_read
(
dmaptr
,
&
s
->
ti_buf
[
s
->
ti_rptr
+
i
],
len
);
}
if
(
s
->
dma_cb
)
{
s
->
dma_cb
(
s
,
s
->
espdmaregs
[
1
],
dmalen
);
s
->
dma_cb
(
s
,
s
->
espdmaregs
[
1
],
minlen
);
}
if
(
minlen
<
s
->
ti_size
)
{
s
->
rregs
[
4
]
=
STAT_IN
|
STAT_TC
|
(
s
->
ti_dir
?
STAT_DO
:
STAT_DI
);
s
->
ti_size
-=
minlen
;
s
->
ti_rptr
+=
minlen
;
}
else
{
s
->
rregs
[
4
]
=
STAT_IN
|
STAT_TC
|
STAT_ST
;
s
->
dma_cb
=
NULL
;
s
->
offset
=
0
;
s
->
len
=
0
;
s
->
target
=
0
;
s
->
ti_rptr
=
0
;
}
s
->
rregs
[
4
]
=
STAT_IN
|
STAT_TC
|
STAT_ST
;
s
->
rregs
[
5
]
=
INTR_BS
;
s
->
rregs
[
5
]
=
INTR_BS
;
s
->
rregs
[
6
]
=
0
;
s
->
rregs
[
7
]
=
0
;
s
->
espdmaregs
[
0
]
|=
DMA_INTR
;
}
else
{
s
->
ti_size
=
dma
len
;
s
->
ti_size
=
min
len
;
s
->
ti_rptr
=
0
;
s
->
ti_wptr
=
0
;
s
->
rregs
[
7
]
=
dma
len
;
s
->
rregs
[
7
]
=
min
len
;
}
pic_set_irq
(
s
->
irq
,
1
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录