diff --git a/hw/9pfs/cofile.c b/hw/9pfs/cofile.c index 52eec2a662..e0d032dc15 100644 --- a/hw/9pfs/cofile.c +++ b/hw/9pfs/cofile.c @@ -127,3 +127,20 @@ int v9fs_co_link(V9fsState *s, V9fsString *oldpath, V9fsString *newpath) }); return err; } + +int v9fs_co_pwritev(V9fsState *s, V9fsFidState *fidp, + struct iovec *iov, int iovcnt, int64_t offset) +{ + int fd; + int err; + + fd = fidp->fs.fd; + v9fs_co_run_in_worker( + { + err = s->ops->pwritev(&s->ctx, fd, iov, iovcnt, offset); + if (err < 0) { + err = -errno; + } + }); + return err; +} diff --git a/hw/9pfs/virtio-9p-coth.h b/hw/9pfs/virtio-9p-coth.h index 17ffd76f36..fa408f876e 100644 --- a/hw/9pfs/virtio-9p-coth.h +++ b/hw/9pfs/virtio-9p-coth.h @@ -89,4 +89,6 @@ extern int v9fs_co_fsync(V9fsState *, V9fsFidState *, int); extern int v9fs_co_symlink(V9fsState *, V9fsFidState *, const char *, const char *, gid_t); extern int v9fs_co_link(V9fsState *, V9fsString *, V9fsString *); +extern int v9fs_co_pwritev(V9fsState *, V9fsFidState *, + struct iovec *, int, int64_t); #endif