Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
c540ee51
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,发现更多精彩内容 >>
提交
c540ee51
编写于
5月 07, 2011
作者:
A
Aneesh Kumar K.V
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
hw/9pfs: Update v9fs_clunk to use coroutines
Signed-off-by:
N
Aneesh Kumar K.V
<
aneesh.kumar@linux.vnet.ibm.com
>
上级
bed4352c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
7 addition
and
37 deletion
+7
-37
hw/9pfs/virtio-9p.c
hw/9pfs/virtio-9p.c
+7
-37
未找到文件。
hw/9pfs/virtio-9p.c
浏览文件 @
c540ee51
...
...
@@ -82,16 +82,6 @@ static int v9fs_do_lstat(V9fsState *s, V9fsString *path, struct stat *stbuf)
return
s
->
ops
->
lstat
(
&
s
->
ctx
,
path
->
data
,
stbuf
);
}
static
int
v9fs_do_close
(
V9fsState
*
s
,
int
fd
)
{
return
s
->
ops
->
close
(
&
s
->
ctx
,
fd
);
}
static
int
v9fs_do_closedir
(
V9fsState
*
s
,
DIR
*
dir
)
{
return
s
->
ops
->
closedir
(
&
s
->
ctx
,
dir
);
}
static
DIR
*
v9fs_do_opendir
(
V9fsState
*
s
,
V9fsString
*
path
)
{
return
s
->
ops
->
opendir
(
&
s
->
ctx
,
path
->
data
);
...
...
@@ -192,22 +182,6 @@ static int v9fs_do_fsync(V9fsState *s, int fd, int datasync)
return
s
->
ops
->
fsync
(
&
s
->
ctx
,
fd
,
datasync
);
}
static
int
v9fs_do_lsetxattr
(
V9fsState
*
s
,
V9fsString
*
path
,
V9fsString
*
xattr_name
,
void
*
value
,
size_t
size
,
int
flags
)
{
return
s
->
ops
->
lsetxattr
(
&
s
->
ctx
,
path
->
data
,
xattr_name
->
data
,
value
,
size
,
flags
);
}
static
int
v9fs_do_lremovexattr
(
V9fsState
*
s
,
V9fsString
*
path
,
V9fsString
*
xattr_name
)
{
return
s
->
ops
->
lremovexattr
(
&
s
->
ctx
,
path
->
data
,
xattr_name
->
data
);
}
static
void
v9fs_string_init
(
V9fsString
*
str
)
{
str
->
data
=
NULL
;
...
...
@@ -414,12 +388,12 @@ static int v9fs_xattr_fid_clunk(V9fsState *s, V9fsFidState *fidp)
goto
free_out
;
}
if
(
fidp
->
fs
.
xattr
.
len
)
{
retval
=
v9fs_
d
o_lsetxattr
(
s
,
&
fidp
->
path
,
&
fidp
->
fs
.
xattr
.
name
,
retval
=
v9fs_
c
o_lsetxattr
(
s
,
&
fidp
->
path
,
&
fidp
->
fs
.
xattr
.
name
,
fidp
->
fs
.
xattr
.
value
,
fidp
->
fs
.
xattr
.
len
,
fidp
->
fs
.
xattr
.
flags
);
}
else
{
retval
=
v9fs_
d
o_lremovexattr
(
s
,
&
fidp
->
path
,
&
fidp
->
fs
.
xattr
.
name
);
retval
=
v9fs_
c
o_lremovexattr
(
s
,
&
fidp
->
path
,
&
fidp
->
fs
.
xattr
.
name
);
}
free_out:
v9fs_string_free
(
&
fidp
->
fs
.
xattr
.
name
);
...
...
@@ -449,15 +423,14 @@ static int free_fid(V9fsState *s, int32_t fid)
*
fidpp
=
fidp
->
next
;
if
(
fidp
->
fid_type
==
P9_FID_FILE
)
{
v9fs_do_close
(
s
,
fidp
->
fs
.
fd
);
retval
=
v9fs_co_close
(
s
,
fidp
);
}
else
if
(
fidp
->
fid_type
==
P9_FID_DIR
)
{
v9fs_do_closedir
(
s
,
fidp
->
fs
.
dir
);
retval
=
v9fs_co_closedir
(
s
,
fidp
);
}
else
if
(
fidp
->
fid_type
==
P9_FID_XATTR
)
{
retval
=
v9fs_xattr_fid_clunk
(
s
,
fidp
);
}
v9fs_string_free
(
&
fidp
->
path
);
g_free
(
fidp
);
return
retval
;
}
...
...
@@ -1588,20 +1561,17 @@ static void v9fs_fsync(void *opaque)
static
void
v9fs_clunk
(
void
*
opaque
)
{
V9fsPDU
*
pdu
=
opaque
;
V9fsState
*
s
=
pdu
->
s
;
int
err
;
int32_t
fid
;
size_t
offset
=
7
;
int
err
;
V9fsPDU
*
pdu
=
opaque
;
V9fsState
*
s
=
pdu
->
s
;
pdu_unmarshal
(
pdu
,
offset
,
"d"
,
&
fid
);
err
=
free_fid
(
s
,
fid
);
if
(
err
<
0
)
{
goto
out
;
}
offset
=
7
;
err
=
offset
;
out:
complete_pdu
(
s
,
pdu
,
err
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录