diff options
author | grehan <grehan@FreeBSD.org> | 2012-12-08 02:37:18 +0000 |
---|---|---|
committer | grehan <grehan@FreeBSD.org> | 2012-12-08 02:37:18 +0000 |
commit | ad362d1440f4ef139f2108cda83df3bded25f5f7 (patch) | |
tree | 30a2b5e6b5c6bfde0e778242966e00cc3c09d07d | |
parent | d8091074f2295a4be6817c9fe8802b9b0db9346d (diff) | |
download | FreeBSD-src-ad362d1440f4ef139f2108cda83df3bded25f5f7.zip FreeBSD-src-ad362d1440f4ef139f2108cda83df3bded25f5f7.tar.gz |
Determine the correct length and sector size for raw devices.
Obtained from: NetApp
Tested by: Michael Dexter with iscsi LUNs
-rw-r--r-- | usr.sbin/bhyve/pci_virtio_block.c | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/usr.sbin/bhyve/pci_virtio_block.c b/usr.sbin/bhyve/pci_virtio_block.c index 916c7c3..8c98615 100644 --- a/usr.sbin/bhyve/pci_virtio_block.c +++ b/usr.sbin/bhyve/pci_virtio_block.c @@ -34,6 +34,7 @@ __FBSDID("$FreeBSD$"); #include <sys/stat.h> #include <sys/uio.h> #include <sys/ioctl.h> +#include <sys/disk.h> #include <errno.h> #include <fcntl.h> @@ -331,7 +332,9 @@ pci_vtblk_init(struct vmctx *ctx, struct pci_devinst *pi, char *opts) { struct stat sbuf; struct pci_vtblk_softc *sc; + off_t size; int fd; + int sectsz; if (opts == NULL) { printf("virtio-block: backing device required\n"); @@ -359,7 +362,23 @@ pci_vtblk_init(struct vmctx *ctx, struct pci_devinst *pi, char *opts) close(fd); return (1); } - + + /* + * Deal with raw devices + */ + size = sbuf.st_size; + sectsz = DEV_BSIZE; + if (S_ISCHR(sbuf.st_mode)) { + if (ioctl(fd, DIOCGMEDIASIZE, &size) < 0 || + ioctl(fd, DIOCGSECTORSIZE, §sz)) { + perror("Could not fetch dev blk/sector size"); + close(fd); + return (1); + } + assert(size != 0); + assert(sectsz != 0); + } + sc = malloc(sizeof(struct pci_vtblk_softc)); memset(sc, 0, sizeof(struct pci_vtblk_softc)); @@ -368,9 +387,9 @@ pci_vtblk_init(struct vmctx *ctx, struct pci_devinst *pi, char *opts) sc->vbsc_fd = fd; /* setup virtio block config space */ - sc->vbsc_cfg.vbc_capacity = sbuf.st_size / DEV_BSIZE; + sc->vbsc_cfg.vbc_capacity = size / sectsz; sc->vbsc_cfg.vbc_seg_max = VTBLK_MAXSEGS; - sc->vbsc_cfg.vbc_blk_size = DEV_BSIZE; + sc->vbsc_cfg.vbc_blk_size = sectsz; sc->vbsc_cfg.vbc_size_max = 0; /* not negotiated */ sc->vbsc_cfg.vbc_geom_c = 0; /* no geometry */ sc->vbsc_cfg.vbc_geom_h = 0; |