summaryrefslogtreecommitdiffstats
path: root/sys/dev/xen/blkfront
diff options
context:
space:
mode:
authorgibbs <gibbs@FreeBSD.org>2013-06-01 04:02:51 +0000
committergibbs <gibbs@FreeBSD.org>2013-06-01 04:02:51 +0000
commit2c1c63836a2573d9a0a8cd50a9aacdebc5a8ce53 (patch)
tree9d2f410ac2e71e98ae5e4122f21a9e42fe64b7f7 /sys/dev/xen/blkfront
parent5b448807562a3fb19c50621d967272ba6de9fc8d (diff)
downloadFreeBSD-src-2c1c63836a2573d9a0a8cd50a9aacdebc5a8ce53.zip
FreeBSD-src-2c1c63836a2573d9a0a8cd50a9aacdebc5a8ce53.tar.gz
sys/dev/xen/blkfront/blkfront.c:
Remove local, and incorrect, definition for the value of an invalid grant reference. Extract ring cleanup code into xbd_free_ring() function for symetry with xbd_alloc_ring(). This process also eliminated an initialized but unused variable. Sponsored by: Spectra Logic Corporation MFC after: 1 week
Diffstat (limited to 'sys/dev/xen/blkfront')
-rw-r--r--sys/dev/xen/blkfront/blkfront.c40
1 files changed, 20 insertions, 20 deletions
diff --git a/sys/dev/xen/blkfront/blkfront.c b/sys/dev/xen/blkfront/blkfront.c
index 9ccf751..9f0ab72 100644
--- a/sys/dev/xen/blkfront/blkfront.c
+++ b/sys/dev/xen/blkfront/blkfront.c
@@ -87,8 +87,6 @@ static void xbd_startio(struct xbd_softc *sc);
#define XBD_SECTOR_SIZE 512 /* XXX: assume for now */
#define XBD_SECTOR_SHFT 9
-#define GRANT_INVALID_REF 0
-
/* Control whether runtime update of vbds is enabled. */
#define ENABLE_VBD_UPDATE 0
@@ -709,6 +707,24 @@ xbd_alloc_ring(struct xbd_softc *sc)
return (0);
}
+static void
+xbd_free_ring(struct xbd_softc *sc)
+{
+ int i;
+
+ if (sc->xbd_ring.sring == NULL)
+ return;
+
+ for (i = 0; i < sc->xbd_ring_pages; i++) {
+ if (sc->xbd_ring_ref[i] != GRANT_REF_INVALID) {
+ gnttab_end_foreign_access_ref(sc->xbd_ring_ref[i]);
+ sc->xbd_ring_ref[i] = GRANT_REF_INVALID;
+ }
+ }
+ free(sc->xbd_ring.sring, M_XENBLOCKFRONT);
+ sc->xbd_ring.sring = NULL;
+}
+
/*-------------------------- Initialization/Teardown -------------------------*/
static void
xbd_setup_sysctl(struct xbd_softc *xbd)
@@ -846,7 +862,6 @@ xbd_instance_create(struct xbd_softc *sc, blkif_sector_t sectors,
static void
xbd_free(struct xbd_softc *sc)
{
- uint8_t *sring_page_ptr;
int i;
/* Prevent new requests being issued until we fix things up. */
@@ -855,22 +870,7 @@ xbd_free(struct xbd_softc *sc)
mtx_unlock(&sc->xbd_io_lock);
/* Free resources associated with old device channel. */
- if (sc->xbd_ring.sring != NULL) {
- sring_page_ptr = (uint8_t *)sc->xbd_ring.sring;
- for (i = 0; i < sc->xbd_ring_pages; i++) {
- grant_ref_t *ref;
-
- ref = &sc->xbd_ring_ref[i];
- if (*ref != GRANT_INVALID_REF) {
- gnttab_end_foreign_access_ref(*ref);
- *ref = GRANT_INVALID_REF;
- }
- sring_page_ptr += PAGE_SIZE;
- }
- free(sc->xbd_ring.sring, M_XENBLOCKFRONT);
- sc->xbd_ring.sring = NULL;
- }
-
+ xbd_free_ring(sc);
if (sc->xbd_shadow) {
for (i = 0; i < sc->xbd_max_requests; i++) {
@@ -1277,7 +1277,7 @@ xbd_attach(device_t dev)
xbd_initq_complete(sc);
xbd_initq_bio(sc);
for (i = 0; i < XBD_MAX_RING_PAGES; i++)
- sc->xbd_ring_ref[i] = GRANT_INVALID_REF;
+ sc->xbd_ring_ref[i] = GRANT_REF_INVALID;
sc->xbd_dev = dev;
sc->xbd_vdevice = vdevice;
OpenPOWER on IntegriCloud