diff options
author | le <le@FreeBSD.org> | 2004-06-16 14:41:04 +0000 |
---|---|---|
committer | le <le@FreeBSD.org> | 2004-06-16 14:41:04 +0000 |
commit | c2c39c895678d3e7ac762a0370704c00a5f851bb (patch) | |
tree | 33a093d93d5d77276951b18f914832f20c2f0c48 /sys/geom/vinum/geom_vinum_drive.c | |
parent | df666606e40b3eceb25bbd6cedf1d5fb125047ca (diff) | |
download | FreeBSD-src-c2c39c895678d3e7ac762a0370704c00a5f851bb.zip FreeBSD-src-c2c39c895678d3e7ac762a0370704c00a5f851bb.tar.gz |
Handle dead disks in a somewhat sane way.
Diffstat (limited to 'sys/geom/vinum/geom_vinum_drive.c')
-rw-r--r-- | sys/geom/vinum/geom_vinum_drive.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/sys/geom/vinum/geom_vinum_drive.c b/sys/geom/vinum/geom_vinum_drive.c index 3673255..5d3a381 100644 --- a/sys/geom/vinum/geom_vinum_drive.c +++ b/sys/geom/vinum/geom_vinum_drive.c @@ -264,6 +264,8 @@ static void gv_drive_orphan(struct g_consumer *cp) { struct g_geom *gp; + struct gv_drive *d; + struct gv_sd *s; int error; g_topology_assert(); @@ -278,6 +280,15 @@ gv_drive_orphan(struct g_consumer *cp) g_destroy_consumer(cp); if (!LIST_EMPTY(&gp->consumer)) return; + d = gp->softc; + printf("gvinum: lost drive '%s'\n", d->name); + d->geom = NULL; + LIST_FOREACH(s, &d->subdisks, from_drive) { + s->provider = NULL; + s->consumer = NULL; + } + gv_set_drive_state(d, GV_DRIVE_DOWN, GV_SETSTATE_FORCE); + gp->softc = NULL; g_wither_geom(gp, error); } |