diff options
author | Marco Peereboom <marco@cvs.openbsd.org> | 2007-05-29 08:15:33 +0000 |
---|---|---|
committer | Marco Peereboom <marco@cvs.openbsd.org> | 2007-05-29 08:15:33 +0000 |
commit | 6df66a597f04276a6a007b62ecffc2b3dd50af29 (patch) | |
tree | dcf2fbcfd1a39f0b753992d421f49cfaee7a39b0 | |
parent | 9d9e2540ed1f7952497ac7242f99c2c794870188 (diff) |
Re-add sync.
ok tedu
-rw-r--r-- | sys/dev/softraid.c | 31 | ||||
-rw-r--r-- | sys/dev/softraidvar.h | 3 |
2 files changed, 21 insertions, 13 deletions
diff --git a/sys/dev/softraid.c b/sys/dev/softraid.c index 637fd708ae4..8cc6439e4d5 100644 --- a/sys/dev/softraid.c +++ b/sys/dev/softraid.c @@ -1,4 +1,4 @@ -/* $OpenBSD: softraid.c,v 1.51 2007/05/29 02:09:45 marco Exp $ */ +/* $OpenBSD: softraid.c,v 1.52 2007/05/29 08:15:32 marco Exp $ */ /* * Copyright (c) 2007 Marco Peereboom <marco@peereboom.us> * @@ -45,6 +45,7 @@ #include <dev/rndvar.h> /* #define SR_FANCY_STATS */ +#define SR_FANCY_STATS #ifdef SR_DEBUG uint32_t sr_debug = 0 @@ -319,6 +320,8 @@ sr_alloc_wu(struct sr_discipline *sd) return (1); no_wu = sd->sd_max_wu; + sd->sd_wu_pending = no_wu; + sd->sd_wu = malloc(sizeof(struct sr_workunit) * no_wu, M_DEVBUF, M_WAITOK); memset(sd->sd_wu, 0, sizeof(struct sr_workunit) * no_wu); @@ -1453,21 +1456,22 @@ int sr_raid1_sync(struct sr_workunit *wu) { struct sr_discipline *sd = wu->swu_dis; - struct sr_chunk *ch_entry; + int rv = 0; DNPRINTF(SR_D_DIS, "%s: sr_raid1_sync\n", DEVNAME(sd->sd_sc)); - /* drain all io */ - SLIST_FOREACH(ch_entry, &sd->sd_vol.sv_chunk_list, src_link) { - DNPRINTF(SR_D_DIS, "%s: %s: %s: sync\n", DEVNAME(sd->sd_sc), - sd->sd_vol.sv_meta.svm_devname, - ch_entry->src_meta.scm_devname); + atomic_setbits_int(&sd->sd_sync, 1); - /* quiesce io? or assume that there isn't any comming in*/ + /* assume that there isn't any more io comming in, count sync wu */ + while (sd->sd_wu_pending > 1) + if (tsleep(sd, PWAIT, "sr_sync", 60 * hz) == EWOULDBLOCK) { + rv = 0; + break; + } - } + atomic_clearbits_int(&sd->sd_sync, 1); - return (0); + return (rv); } int @@ -1748,6 +1752,9 @@ sr_raid1_intr(struct buf *bp) /* do not change the order of these 2 functions */ sr_put_wu(wu); scsi_done(xs); + + if (sd->sd_sync && sd->sd_wu_pending == 0) + wakeup(sd); } splx(s); @@ -2585,9 +2592,9 @@ sr_print_stats(void) continue; sd = sc->sc_dis[i]; - printf("%s: ios in flight: %d collisions %llu\n", + printf("%s: ios pending: %d collisions %llu\n", sd->sd_vol.sv_meta.svm_devname, - sd->sd_wu_pending + sd->sd_max_wu, + sd->sd_wu_pending, sd->sd_wu_collisions); } } diff --git a/sys/dev/softraidvar.h b/sys/dev/softraidvar.h index 94852056be2..9d37da22d6d 100644 --- a/sys/dev/softraidvar.h +++ b/sys/dev/softraidvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: softraidvar.h,v 1.21 2007/05/28 21:54:26 marco Exp $ */ +/* $OpenBSD: softraidvar.h,v 1.22 2007/05/29 08:15:32 marco Exp $ */ /* * Copyright (c) 2006 Marco Peereboom <sro@peereboom.us> * @@ -236,6 +236,7 @@ struct sr_discipline { /* discipline metadata */ struct sr_metadata *sd_meta; /* in memory copy of metadata */ u_int32_t sd_meta_flags; + int sd_sync; /* discipline volume */ struct sr_volume sd_vol; /* volume associated */ |