[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [V9 PATCH 08/13] virtio-9p: Add support for removing file o
From: |
M. Mohan Kumar |
Subject: |
[Qemu-devel] [V9 PATCH 08/13] virtio-9p: Add support for removing file or directory |
Date: |
Fri, 18 Mar 2011 08:57:56 +0530 |
Support for removing file or directory in chroot environment. Add
interfaces to remove file/directory in chroot worker and qemu side.
Signed-off-by: M. Mohan Kumar <address@hidden>
---
hw/9pfs/virtio-9p-chroot-worker.c | 34 ++++++++++++++++++++++++++--------
hw/9pfs/virtio-9p-chroot.h | 1 +
hw/9pfs/virtio-9p-local.c | 6 +++++-
3 files changed, 32 insertions(+), 9 deletions(-)
diff --git a/hw/9pfs/virtio-9p-chroot-worker.c
b/hw/9pfs/virtio-9p-chroot-worker.c
index fcc0be1..40e572c 100644
--- a/hw/9pfs/virtio-9p-chroot-worker.c
+++ b/hw/9pfs/virtio-9p-chroot-worker.c
@@ -161,6 +161,21 @@ unset_uid:
return retval;
}
+/*
+ * Remove a file object
+ * Returns 0 on success and -errno on failure
+ */
+static int chroot_do_remove(V9fsFileObjectRequest *request)
+{
+ int retval;
+
+ retval = remove(request->path.path);
+ if (retval < 0) {
+ return -errno;
+ }
+ return 0;
+}
+
static void chroot_daemonize(int chroot_sock)
{
sigset_t sigset;
@@ -199,7 +214,7 @@ int v9fs_chroot(FsContext *fs_ctx)
V9fsFileObjectRequest request;
pid_t pid;
uint32_t code;
- int fd, valid_fd;
+ int retval, valid_fd;
if (socketpair(PF_UNIX, SOCK_STREAM, 0, fd_pair) < 0) {
error_report("socketpair %s", strerror(errno));
@@ -245,14 +260,14 @@ int v9fs_chroot(FsContext *fs_ctx)
}
switch (request.data.type) {
case T_OPEN:
- fd = chroot_do_open(&request);
- if (fd >= 0) {
+ retval = chroot_do_open(&request);
+ if (retval >= 0) {
valid_fd = 1;
}
break;
case T_CREATE:
- fd = chroot_do_create(&request);
- if (fd >= 0) {
+ retval = chroot_do_create(&request);
+ if (retval >= 0) {
valid_fd = 1;
}
break;
@@ -260,12 +275,15 @@ int v9fs_chroot(FsContext *fs_ctx)
case T_SYMLINK:
case T_LINK:
case T_MKNOD:
- fd = chroot_do_create_special(&request);
+ retval = chroot_do_create_special(&request);
+ break;
+ case T_REMOVE:
+ retval = chroot_do_remove(&request);
break;
default:
- fd = -1;
+ retval = -1;
break;
}
- chroot_sendfd(chroot_sock, fd, valid_fd);
+ chroot_sendfd(chroot_sock, retval, valid_fd);
}
}
diff --git a/hw/9pfs/virtio-9p-chroot.h b/hw/9pfs/virtio-9p-chroot.h
index b2db276..2d7984a 100644
--- a/hw/9pfs/virtio-9p-chroot.h
+++ b/hw/9pfs/virtio-9p-chroot.h
@@ -8,6 +8,7 @@
#define T_MKNOD 4
#define T_SYMLINK 5
#define T_LINK 6
+#define T_REMOVE 7
union MsgControl {
struct cmsghdr cmsg;
diff --git a/hw/9pfs/virtio-9p-local.c b/hw/9pfs/virtio-9p-local.c
index 66ba53b..c255cbd 100644
--- a/hw/9pfs/virtio-9p-local.c
+++ b/hw/9pfs/virtio-9p-local.c
@@ -566,7 +566,11 @@ static int local_utimensat(FsContext *s, const char *path,
static int local_remove(FsContext *ctx, const char *path)
{
- return remove(rpath(ctx, path));
+ if (ctx->fs_sm == SM_PASSTHROUGH) {
+ return passthrough_request(ctx, NULL, path, 0, NULL, T_REMOVE);
+ } else {
+ return remove(rpath(ctx, path));
+ }
}
static int local_fsync(FsContext *ctx, int fd, int datasync)
--
1.7.3.4
- [Qemu-devel] [V9 PATCH 00/13] virtio-9p: Use chroot to safely access files in passthrough security model, M. Mohan Kumar, 2011/03/17
- [Qemu-devel] [V9 PATCH 10/13] virtio-9p: Move file post creation changes to none security model, M. Mohan Kumar, 2011/03/17
- [Qemu-devel] [V9 PATCH 08/13] virtio-9p: Add support for removing file or directory,
M. Mohan Kumar <=
- [Qemu-devel] [V9 PATCH 11/13] virtio-9p: Add support for chmod, M. Mohan Kumar, 2011/03/17
- [Qemu-devel] [V9 PATCH 03/13] virtio-9p: Provide chroot worker side interfaces, M. Mohan Kumar, 2011/03/17
- [Qemu-devel] [V9 PATCH 13/13] virtio-9p: Chroot environment for other functions, M. Mohan Kumar, 2011/03/17
- [Qemu-devel] [V9 PATCH 12/13] virtio-9p: Add support for chown, M. Mohan Kumar, 2011/03/17
- [Qemu-devel] [V9 PATCH 05/13] virtio-9p: Add support to open a file in chroot environment, M. Mohan Kumar, 2011/03/17
- [Qemu-devel] [V9 PATCH 04/13] virtio-9p: Add qemu side interfaces for chroot environment, M. Mohan Kumar, 2011/03/17
- [Qemu-devel] [V9 PATCH 01/13] Implement qemu_read_full, M. Mohan Kumar, 2011/03/17
- [Qemu-devel] [V9 PATCH 09/13] virtio-9p: Add support to rename, M. Mohan Kumar, 2011/03/17