Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
b77912a7
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看板
提交
b77912a7
编写于
4月 19, 2012
作者:
P
Paolo Bonzini
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
scsi: move scsi_flush_complete around
Signed-off-by:
N
Paolo Bonzini
<
pbonzini@redhat.com
>
上级
80624c93
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
18 addition
and
18 deletion
+18
-18
hw/scsi-disk.c
hw/scsi-disk.c
+18
-18
未找到文件。
hw/scsi-disk.c
浏览文件 @
b77912a7
...
@@ -153,7 +153,7 @@ static void scsi_disk_load_request(QEMUFile *f, SCSIRequest *req)
...
@@ -153,7 +153,7 @@ static void scsi_disk_load_request(QEMUFile *f, SCSIRequest *req)
qemu_iovec_init_external
(
&
r
->
qiov
,
&
r
->
iov
,
1
);
qemu_iovec_init_external
(
&
r
->
qiov
,
&
r
->
iov
,
1
);
}
}
static
void
scsi_
dma_complete
(
void
*
opaque
,
int
ret
)
static
void
scsi_
flush_complete
(
void
*
opaque
,
int
ret
)
{
{
SCSIDiskReq
*
r
=
(
SCSIDiskReq
*
)
opaque
;
SCSIDiskReq
*
r
=
(
SCSIDiskReq
*
)
opaque
;
SCSIDiskState
*
s
=
DO_UPCAST
(
SCSIDiskState
,
qdev
,
r
->
req
.
dev
);
SCSIDiskState
*
s
=
DO_UPCAST
(
SCSIDiskState
,
qdev
,
r
->
req
.
dev
);
...
@@ -166,8 +166,6 @@ static void scsi_dma_complete(void *opaque, int ret)
...
@@ -166,8 +166,6 @@ static void scsi_dma_complete(void *opaque, int ret)
}
}
}
}
r
->
sector
+=
r
->
sector_count
;
r
->
sector_count
=
0
;
scsi_req_complete
(
&
r
->
req
,
GOOD
);
scsi_req_complete
(
&
r
->
req
,
GOOD
);
done:
done:
...
@@ -176,16 +174,12 @@ done:
...
@@ -176,16 +174,12 @@ done:
}
}
}
}
static
void
scsi_
read_complete
(
void
*
opaque
,
int
ret
)
static
void
scsi_
dma_complete
(
void
*
opaque
,
int
ret
)
{
{
SCSIDiskReq
*
r
=
(
SCSIDiskReq
*
)
opaque
;
SCSIDiskReq
*
r
=
(
SCSIDiskReq
*
)
opaque
;
SCSIDiskState
*
s
=
DO_UPCAST
(
SCSIDiskState
,
qdev
,
r
->
req
.
dev
);
SCSIDiskState
*
s
=
DO_UPCAST
(
SCSIDiskState
,
qdev
,
r
->
req
.
dev
);
int
n
;
if
(
r
->
req
.
aiocb
!=
NULL
)
{
bdrv_acct_done
(
s
->
qdev
.
conf
.
bs
,
&
r
->
acct
);
r
->
req
.
aiocb
=
NULL
;
bdrv_acct_done
(
s
->
qdev
.
conf
.
bs
,
&
r
->
acct
);
}
if
(
ret
<
0
)
{
if
(
ret
<
0
)
{
if
(
scsi_handle_rw_error
(
r
,
-
ret
))
{
if
(
scsi_handle_rw_error
(
r
,
-
ret
))
{
...
@@ -193,12 +187,9 @@ static void scsi_read_complete(void * opaque, int ret)
...
@@ -193,12 +187,9 @@ static void scsi_read_complete(void * opaque, int ret)
}
}
}
}
DPRINTF
(
"Data ready tag=0x%x len=%zd
\n
"
,
r
->
req
.
tag
,
r
->
qiov
.
size
);
r
->
sector
+=
r
->
sector_count
;
r
->
sector_count
=
0
;
n
=
r
->
qiov
.
size
/
512
;
scsi_req_complete
(
&
r
->
req
,
GOOD
);
r
->
sector
+=
n
;
r
->
sector_count
-=
n
;
scsi_req_data
(
&
r
->
req
,
r
->
qiov
.
size
);
done:
done:
if
(
!
r
->
req
.
io_canceled
)
{
if
(
!
r
->
req
.
io_canceled
)
{
...
@@ -206,12 +197,16 @@ done:
...
@@ -206,12 +197,16 @@ done:
}
}
}
}
static
void
scsi_
flush
_complete
(
void
*
opaque
,
int
ret
)
static
void
scsi_
read
_complete
(
void
*
opaque
,
int
ret
)
{
{
SCSIDiskReq
*
r
=
(
SCSIDiskReq
*
)
opaque
;
SCSIDiskReq
*
r
=
(
SCSIDiskReq
*
)
opaque
;
SCSIDiskState
*
s
=
DO_UPCAST
(
SCSIDiskState
,
qdev
,
r
->
req
.
dev
);
SCSIDiskState
*
s
=
DO_UPCAST
(
SCSIDiskState
,
qdev
,
r
->
req
.
dev
);
int
n
;
bdrv_acct_done
(
s
->
qdev
.
conf
.
bs
,
&
r
->
acct
);
if
(
r
->
req
.
aiocb
!=
NULL
)
{
r
->
req
.
aiocb
=
NULL
;
bdrv_acct_done
(
s
->
qdev
.
conf
.
bs
,
&
r
->
acct
);
}
if
(
ret
<
0
)
{
if
(
ret
<
0
)
{
if
(
scsi_handle_rw_error
(
r
,
-
ret
))
{
if
(
scsi_handle_rw_error
(
r
,
-
ret
))
{
...
@@ -219,7 +214,12 @@ static void scsi_flush_complete(void * opaque, int ret)
...
@@ -219,7 +214,12 @@ static void scsi_flush_complete(void * opaque, int ret)
}
}
}
}
scsi_req_complete
(
&
r
->
req
,
GOOD
);
DPRINTF
(
"Data ready tag=0x%x len=%zd
\n
"
,
r
->
req
.
tag
,
r
->
qiov
.
size
);
n
=
r
->
qiov
.
size
/
512
;
r
->
sector
+=
n
;
r
->
sector_count
-=
n
;
scsi_req_data
(
&
r
->
req
,
r
->
qiov
.
size
);
done:
done:
if
(
!
r
->
req
.
io_canceled
)
{
if
(
!
r
->
req
.
io_canceled
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录