summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarco Peereboom <marco@cvs.openbsd.org>2007-05-29 08:15:33 +0000
committerMarco Peereboom <marco@cvs.openbsd.org>2007-05-29 08:15:33 +0000
commit6df66a597f04276a6a007b62ecffc2b3dd50af29 (patch)
treedcf2fbcfd1a39f0b753992d421f49cfaee7a39b0
parent9d9e2540ed1f7952497ac7242f99c2c794870188 (diff)
Re-add sync.
ok tedu
-rw-r--r--sys/dev/softraid.c31
-rw-r--r--sys/dev/softraidvar.h3
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 */