diff options
author | pjd <pjd@FreeBSD.org> | 2004-12-04 21:20:59 +0000 |
---|---|---|
committer | pjd <pjd@FreeBSD.org> | 2004-12-04 21:20:59 +0000 |
commit | ca88614a1e8bc6073f9ffe90fd1618da1d357929 (patch) | |
tree | 209725c4b8d340545674400f26688a6ded462eb6 /sys/geom | |
parent | 174d5d0fa0a547c699cdf560b307dad19aecfe18 (diff) | |
download | FreeBSD-src-ca88614a1e8bc6073f9ffe90fd1618da1d357929.zip FreeBSD-src-ca88614a1e8bc6073f9ffe90fd1618da1d357929.tar.gz |
When initializing device, set d_softc and d_no fields for all components,
because we know it then and we need it when inserting a component which
wasn't destroyed while device was running.
Reported by: Michael Handler <handler@grendel.net>
MFC after: 1 week
Diffstat (limited to 'sys/geom')
-rw-r--r-- | sys/geom/raid3/g_raid3.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/sys/geom/raid3/g_raid3.c b/sys/geom/raid3/g_raid3.c index ca2517f..9d2ce1b 100644 --- a/sys/geom/raid3/g_raid3.c +++ b/sys/geom/raid3/g_raid3.c @@ -466,11 +466,9 @@ g_raid3_init_disk(struct g_raid3_softc *sc, struct g_provider *pp, int error; disk = &sc->sc_disks[md->md_no]; - disk->d_softc = sc; error = g_raid3_connect_disk(disk, pp); if (error != 0) goto fail; - disk->d_no = md->md_no; disk->d_state = G_RAID3_DISK_STATE_NONE; disk->d_flags = md->md_dflags; if (md->md_provider[0] != '\0') @@ -2757,8 +2755,11 @@ g_raid3_create(struct g_class *mp, const struct g_raid3_metadata *md) sc->sc_flags = md->md_mflags; sc->sc_bump_syncid = 0; sc->sc_idle = 0; - for (n = 0; n < sc->sc_ndisks; n++) + for (n = 0; n < sc->sc_ndisks; n++) { + sc->sc_disks[n].d_softc = sc; + sc->sc_disks[n].d_no = n; sc->sc_disks[n].d_state = G_RAID3_DISK_STATE_NODISK; + } bioq_init(&sc->sc_queue); mtx_init(&sc->sc_queue_mtx, "graid3:queue", NULL, MTX_DEF); TAILQ_INIT(&sc->sc_events); |