Module Name:    src
Committed By:   pooka
Date:           Mon Aug  3 16:22:00 UTC 2009

Modified Files:
        src/sys/rump/librump/rumpvfs: Makefile.rumpvfs rumpblk.c

Log Message:
Support read/write in rumpblk via physio()


To generate a diff of this commit:
cvs rdiff -u -r1.9 -r1.10 src/sys/rump/librump/rumpvfs/Makefile.rumpvfs
cvs rdiff -u -r1.24 -r1.25 src/sys/rump/librump/rumpvfs/rumpblk.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/rump/librump/rumpvfs/Makefile.rumpvfs
diff -u src/sys/rump/librump/rumpvfs/Makefile.rumpvfs:1.9 src/sys/rump/librump/rumpvfs/Makefile.rumpvfs:1.10
--- src/sys/rump/librump/rumpvfs/Makefile.rumpvfs:1.9	Wed Jun 10 20:50:51 2009
+++ src/sys/rump/librump/rumpvfs/Makefile.rumpvfs	Mon Aug  3 16:22:00 2009
@@ -1,4 +1,4 @@
-#	$NetBSD: Makefile.rumpvfs,v 1.9 2009/06/10 20:50:51 pooka Exp $
+#	$NetBSD: Makefile.rumpvfs,v 1.10 2009/08/03 16:22:00 pooka Exp $
 #
 
 .include "${RUMPTOP}/Makefile.rump"
@@ -18,6 +18,9 @@
 
 SRCS+=	fstrans_stub.c vfsops_stub.c
 
+# sys/kern I/O
+SRCS+=	kern_physio.c
+
 # sys/kern vfs
 SRCS+=	vfs_bio.c vfs_cache.c vfs_cwd.c vfs_dirhash.c vfs_getcwd.c	\
 	vfs_hooks.c vfs_init.c vfs_lockf.c vfs_lookup.c vfs_subr.c	\

Index: src/sys/rump/librump/rumpvfs/rumpblk.c
diff -u src/sys/rump/librump/rumpvfs/rumpblk.c:1.24 src/sys/rump/librump/rumpvfs/rumpblk.c:1.25
--- src/sys/rump/librump/rumpvfs/rumpblk.c:1.24	Mon Aug  3 14:23:30 2009
+++ src/sys/rump/librump/rumpvfs/rumpblk.c	Mon Aug  3 16:22:00 2009
@@ -1,4 +1,4 @@
-/*	$NetBSD: rumpblk.c,v 1.24 2009/08/03 14:23:30 pooka Exp $	*/
+/*	$NetBSD: rumpblk.c,v 1.25 2009/08/03 16:22:00 pooka Exp $	*/
 
 /*
  * Copyright (c) 2009 Antti Kantee.  All Rights Reserved.
@@ -43,7 +43,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rumpblk.c,v 1.24 2009/08/03 14:23:30 pooka Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rumpblk.c,v 1.25 2009/08/03 16:22:00 pooka Exp $");
 
 #include <sys/param.h>
 #include <sys/buf.h>
@@ -89,7 +89,7 @@
 static struct rblkdev {
 	char *rblk_path;
 	int rblk_fd;
-	int rblk_refcnt;
+	int rblk_opencnt;
 #ifdef HAS_ODIRECT
 	int rblk_dfd;
 #endif
@@ -376,7 +376,8 @@
 	int ft, dummy;
 	int error, fd;
 
-	KASSERT(rblk->rblk_fd == -1); /* XXX */
+	if (rblk->rblk_fd != -1)
+		return 0; /* XXX: refcount, open mode */
 	fd = rumpuser_open(rblk->rblk_path, OFLAGS(flag), &error);
 	if (error)
 		return error;
@@ -492,18 +493,31 @@
 	return 0;
 }
 
+static int
+do_physio(dev_t dev, struct uio *uio, int which)
+{
+	void (*strat)(struct buf *);
+
+	if (blkfail)
+		strat = rumpblk_strategy_fail;
+	else
+		strat = rumpblk_strategy;
+
+	return physio(strat, NULL, dev, which, minphys, uio);
+}
+
 int
 rumpblk_read(dev_t dev, struct uio *uio, int flags)
 {
 
-	panic("%s: unimplemented", __func__);
+	return do_physio(dev, uio, B_READ);
 }
 
 int
 rumpblk_write(dev_t dev, struct uio *uio, int flags)
 {
 
-	panic("%s: unimplemented", __func__);
+	return do_physio(dev, uio, B_WRITE);
 }
 
 static void

Reply via email to