]> Git Repo - qemu.git/blame - hw/9pfs/cofile.c
hw/9pfs: Add file descriptor reclaim support
[qemu.git] / hw / 9pfs / cofile.c
CommitLineData
172198d4
AK
1
2/*
3 * Virtio 9p backend
4 *
5 * Copyright IBM, Corp. 2011
6 *
7 * Authors:
8 * Aneesh Kumar K.V <[email protected]>
9 *
10 * This work is licensed under the terms of the GNU GPL, version 2. See
11 * the COPYING file in the top-level directory.
12 *
13 */
14
15#include "fsdev/qemu-fsdev.h"
16#include "qemu-thread.h"
17#include "qemu-coroutine.h"
18#include "virtio-9p-coth.h"
19
20int v9fs_co_lstat(V9fsState *s, V9fsString *path, struct stat *stbuf)
21{
22 int err;
23
24 v9fs_co_run_in_worker(
25 {
26 err = s->ops->lstat(&s->ctx, path->data, stbuf);
27 if (err < 0) {
28 err = -errno;
29 }
30 });
31 return err;
32}
03feb1e1
AK
33
34int v9fs_co_fstat(V9fsState *s, int fd, struct stat *stbuf)
35{
36 int err;
37
38 v9fs_co_run_in_worker(
39 {
40 err = s->ops->fstat(&s->ctx, fd, stbuf);
41 if (err < 0) {
42 err = -errno;
43 }
44 });
45 return err;
46}
f6b7f0ab
AK
47
48int v9fs_co_open(V9fsState *s, V9fsFidState *fidp, int flags)
49{
50 int err;
51
52 v9fs_co_run_in_worker(
53 {
54 fidp->fs.fd = s->ops->open(&s->ctx, fidp->path.data, flags);
55 if (fidp->fs.fd == -1) {
56 err = -errno;
57 } else {
58 err = 0;
59 }
60 });
7a462745
AK
61 if (!err) {
62 total_open_fd++;
63 if (total_open_fd > open_fd_hw) {
64 v9fs_reclaim_fd(s);
65 }
66 }
f6b7f0ab
AK
67 return err;
68}
e4de4232
VJ
69
70int v9fs_co_open2(V9fsState *s, V9fsFidState *fidp, char *fullname, gid_t gid,
71 int flags, int mode)
72{
73 int err;
74 FsCred cred;
75
76 cred_init(&cred);
77 cred.fc_mode = mode & 07777;
78 cred.fc_uid = fidp->uid;
79 cred.fc_gid = gid;
80 v9fs_co_run_in_worker(
81 {
82 fidp->fs.fd = s->ops->open2(&s->ctx, fullname, flags, &cred);
83 err = 0;
84 if (fidp->fs.fd == -1) {
85 err = -errno;
86 }
87 });
7a462745
AK
88 if (!err) {
89 total_open_fd++;
90 if (total_open_fd > open_fd_hw) {
91 v9fs_reclaim_fd(s);
92 }
93 }
e4de4232
VJ
94 return err;
95}
bed4352c 96
7a462745 97int v9fs_co_close(V9fsState *s, int fd)
bed4352c 98{
bed4352c
AK
99 int err;
100
bed4352c
AK
101 v9fs_co_run_in_worker(
102 {
103 err = s->ops->close(&s->ctx, fd);
104 if (err < 0) {
105 err = -errno;
106 }
107 });
7a462745
AK
108 if (!err) {
109 total_open_fd--;
110 }
bed4352c
AK
111 return err;
112}
4743d1f5
AK
113
114int v9fs_co_fsync(V9fsState *s, V9fsFidState *fidp, int datasync)
115{
116 int fd;
117 int err;
118
119 fd = fidp->fs.fd;
120 v9fs_co_run_in_worker(
121 {
122 err = s->ops->fsync(&s->ctx, fd, datasync);
123 if (err < 0) {
124 err = -errno;
125 }
126 });
127 return err;
128}
c6c069b0
VJ
129
130int v9fs_co_link(V9fsState *s, V9fsString *oldpath, V9fsString *newpath)
131{
132 int err;
133
134 v9fs_co_run_in_worker(
135 {
136 err = s->ops->link(&s->ctx, oldpath->data, newpath->data);
137 if (err < 0) {
138 err = -errno;
139 }
140 });
141 return err;
142}
f6b3c976
AK
143
144int v9fs_co_pwritev(V9fsState *s, V9fsFidState *fidp,
145 struct iovec *iov, int iovcnt, int64_t offset)
146{
147 int fd;
148 int err;
149
150 fd = fidp->fs.fd;
151 v9fs_co_run_in_worker(
152 {
153 err = s->ops->pwritev(&s->ctx, fd, iov, iovcnt, offset);
154 if (err < 0) {
155 err = -errno;
156 }
157 });
158 return err;
159}
7eafdcc9
AK
160
161int v9fs_co_preadv(V9fsState *s, V9fsFidState *fidp,
162 struct iovec *iov, int iovcnt, int64_t offset)
163{
164 int fd;
165 int err;
166
167 fd = fidp->fs.fd;
168 v9fs_co_run_in_worker(
169 {
170 err = s->ops->preadv(&s->ctx, fd, iov, iovcnt, offset);
171 if (err < 0) {
172 err = -errno;
173 }
174 });
175 return err;
176}
This page took 0.05001 seconds and 4 git commands to generate.