Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 12 Oct 2013 22:41:28 +0000 (UTC)
From:      Bryan Venteicher <bryanv@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-projects@freebsd.org
Subject:   svn commit: r256397 - projects/virtio/sys/dev/virtio/block
Message-ID:  <201310122241.r9CMfSlF012672@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: bryanv
Date: Sat Oct 12 22:41:28 2013
New Revision: 256397
URL: http://svnweb.freebsd.org/changeset/base/256397

Log:
  Add unmapped IO support to virtio_blk(4)

Modified:
  projects/virtio/sys/dev/virtio/block/virtio_blk.c

Modified: projects/virtio/sys/dev/virtio/block/virtio_blk.c
==============================================================================
--- projects/virtio/sys/dev/virtio/block/virtio_blk.c	Sat Oct 12 22:40:26 2013	(r256396)
+++ projects/virtio/sys/dev/virtio/block/virtio_blk.c	Sat Oct 12 22:41:28 2013	(r256397)
@@ -41,6 +41,9 @@ __FBSDID("$FreeBSD$");
 #include <sys/mutex.h>
 #include <sys/queue.h>
 
+#include <vm/vm.h>
+#include <vm/vm_page.h>
+
 #include <geom/geom_disk.h>
 
 #include <machine/bus.h>
@@ -726,7 +729,7 @@ vtblk_alloc_disk(struct vtblk_softc *sc,
 	dp->d_name = VTBLK_DISK_NAME;
 	dp->d_unit = device_get_unit(dev);
 	dp->d_drv1 = sc;
-	dp->d_flags = DISKFLAG_CANFLUSHCACHE;
+	dp->d_flags = DISKFLAG_CANFLUSHCACHE | DISKFLAG_UNMAPPED_BIO;
 	dp->d_hba_vendor = virtio_get_vendor(dev);
 	dp->d_hba_device = virtio_get_device(dev);
 	dp->d_hba_subvendor = virtio_get_subvendor(dev);
@@ -931,10 +934,11 @@ vtblk_execute_request(struct vtblk_softc
 	sglist_append(sg, &req->vbr_hdr, sizeof(struct virtio_blk_outhdr));
 
 	if (bp->bio_cmd == BIO_READ || bp->bio_cmd == BIO_WRITE) {
-		error = sglist_append(sg, bp->bio_data, bp->bio_bcount);
-		if (error || sg->sg_nseg == sg->sg_maxseg)
+		error = sglist_append_bio(sg, bp);
+		if (error || sg->sg_nseg == sg->sg_maxseg) {
 			panic("%s: data buffer too big bio:%p error:%d",
 			    __func__, bp, error);
+		}
 
 		/* BIO_READ means the host writes into our buffer. */
 		if (bp->bio_cmd == BIO_READ)



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201310122241.r9CMfSlF012672>