diff options
author | Lars Ellenberg <lars.ellenberg@linbit.com> | 2010-11-05 04:52:46 -0400 |
---|---|---|
committer | Philipp Reisner <philipp.reisner@linbit.com> | 2011-03-10 05:18:58 -0500 |
commit | 439d595379f87ec95249da21122eb085866f8ba9 (patch) | |
tree | bcf189586472ec7b64a37a3494b704bedb7c5906 | |
parent | ea5442aff68c559c951373739201721185191748 (diff) |
drbd: show progress bar and ETA for online-verify
Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
-rw-r--r-- | drivers/block/drbd/drbd_int.h | 5 | ||||
-rw-r--r-- | drivers/block/drbd/drbd_proc.c | 52 |
2 files changed, 44 insertions, 13 deletions
diff --git a/drivers/block/drbd/drbd_int.h b/drivers/block/drbd/drbd_int.h index 6cba131011d5..7131bf2af6ae 100644 --- a/drivers/block/drbd/drbd_int.h +++ b/drivers/block/drbd/drbd_int.h | |||
@@ -2157,7 +2157,10 @@ static inline void drbd_get_syncer_progress(struct drbd_conf *mdev, | |||
2157 | * units of BM_BLOCK_SIZE. | 2157 | * units of BM_BLOCK_SIZE. |
2158 | * for the percentage, we don't care. */ | 2158 | * for the percentage, we don't care. */ |
2159 | 2159 | ||
2160 | *bits_left = drbd_bm_total_weight(mdev) - mdev->rs_failed; | 2160 | if (mdev->state.conn == C_VERIFY_S || mdev->state.conn == C_VERIFY_T) |
2161 | *bits_left = mdev->ov_left; | ||
2162 | else | ||
2163 | *bits_left = drbd_bm_total_weight(mdev) - mdev->rs_failed; | ||
2161 | /* >> 10 to prevent overflow, | 2164 | /* >> 10 to prevent overflow, |
2162 | * +1 to prevent division by zero */ | 2165 | * +1 to prevent division by zero */ |
2163 | if (*bits_left > mdev->rs_total) { | 2166 | if (*bits_left > mdev->rs_total) { |
diff --git a/drivers/block/drbd/drbd_proc.c b/drivers/block/drbd/drbd_proc.c index 0b20aa837022..0ec6f4b6a4a8 100644 --- a/drivers/block/drbd/drbd_proc.c +++ b/drivers/block/drbd/drbd_proc.c | |||
@@ -45,6 +45,19 @@ const struct file_operations drbd_proc_fops = { | |||
45 | .release = single_release, | 45 | .release = single_release, |
46 | }; | 46 | }; |
47 | 47 | ||
48 | void seq_printf_with_thousands_grouping(struct seq_file *seq, long v) | ||
49 | { | ||
50 | /* v is in kB/sec. We don't expect TiByte/sec yet. */ | ||
51 | if (unlikely(v >= 1000000)) { | ||
52 | /* cool: > GiByte/s */ | ||
53 | seq_printf(seq, "%ld,", v / 1000000); | ||
54 | v /= 1000000; | ||
55 | seq_printf(seq, "%03ld,%03ld", v/1000, v % 1000); | ||
56 | } else if (likely(v >= 1000)) | ||
57 | seq_printf(seq, "%ld,%03ld", v/1000, v % 1000); | ||
58 | else | ||
59 | seq_printf(seq, "%ld", v); | ||
60 | } | ||
48 | 61 | ||
49 | /*lge | 62 | /*lge |
50 | * progress bars shamelessly adapted from driver/md/md.c | 63 | * progress bars shamelessly adapted from driver/md/md.c |
@@ -94,6 +107,7 @@ static void drbd_syncer_progress(struct drbd_conf *mdev, struct seq_file *seq) | |||
94 | /* Rolling marks. last_mark+1 may just now be modified. last_mark+2 is | 107 | /* Rolling marks. last_mark+1 may just now be modified. last_mark+2 is |
95 | * at least (DRBD_SYNC_MARKS-2)*DRBD_SYNC_MARK_STEP old, and has at | 108 | * at least (DRBD_SYNC_MARKS-2)*DRBD_SYNC_MARK_STEP old, and has at |
96 | * least DRBD_SYNC_MARK_STEP time before it will be modified. */ | 109 | * least DRBD_SYNC_MARK_STEP time before it will be modified. */ |
110 | /* ------------------------ ~18s average ------------------------ */ | ||
97 | i = (mdev->rs_last_mark + 2) % DRBD_SYNC_MARKS; | 111 | i = (mdev->rs_last_mark + 2) % DRBD_SYNC_MARKS; |
98 | dt = (jiffies - mdev->rs_mark_time[i]) / HZ; | 112 | dt = (jiffies - mdev->rs_mark_time[i]) / HZ; |
99 | if (dt > (DRBD_SYNC_MARK_STEP * DRBD_SYNC_MARKS)) | 113 | if (dt > (DRBD_SYNC_MARK_STEP * DRBD_SYNC_MARKS)) |
@@ -107,14 +121,29 @@ static void drbd_syncer_progress(struct drbd_conf *mdev, struct seq_file *seq) | |||
107 | seq_printf(seq, "finish: %lu:%02lu:%02lu", | 121 | seq_printf(seq, "finish: %lu:%02lu:%02lu", |
108 | rt / 3600, (rt % 3600) / 60, rt % 60); | 122 | rt / 3600, (rt % 3600) / 60, rt % 60); |
109 | 123 | ||
110 | /* current speed average over (SYNC_MARKS * SYNC_MARK_STEP) jiffies */ | ||
111 | dbdt = Bit2KB(db/dt); | 124 | dbdt = Bit2KB(db/dt); |
112 | if (dbdt > 1000) | 125 | seq_printf(seq, " speed: "); |
113 | seq_printf(seq, " speed: %ld,%03ld", | 126 | seq_printf_with_thousands_grouping(seq, dbdt); |
114 | dbdt/1000, dbdt % 1000); | 127 | seq_printf(seq, " ("); |
115 | else | 128 | /* ------------------------- ~3s average ------------------------ */ |
116 | seq_printf(seq, " speed: %ld", dbdt); | 129 | if (proc_details >= 1) { |
130 | /* this is what drbd_rs_should_slow_down() uses */ | ||
131 | i = (mdev->rs_last_mark + DRBD_SYNC_MARKS-1) % DRBD_SYNC_MARKS; | ||
132 | dt = (jiffies - mdev->rs_mark_time[i]) / HZ; | ||
133 | if (dt > (DRBD_SYNC_MARK_STEP * DRBD_SYNC_MARKS)) | ||
134 | stalled = 1; | ||
135 | |||
136 | if (!dt) | ||
137 | dt++; | ||
138 | db = mdev->rs_mark_left[i] - rs_left; | ||
139 | rt = (dt * (rs_left / (db/100+1)))/100; /* seconds */ | ||
140 | |||
141 | dbdt = Bit2KB(db/dt); | ||
142 | seq_printf_with_thousands_grouping(seq, dbdt); | ||
143 | seq_printf(seq, " -- "); | ||
144 | } | ||
117 | 145 | ||
146 | /* --------------------- long term average ---------------------- */ | ||
118 | /* mean speed since syncer started | 147 | /* mean speed since syncer started |
119 | * we do account for PausedSync periods */ | 148 | * we do account for PausedSync periods */ |
120 | dt = (jiffies - mdev->rs_start - mdev->rs_paused) / HZ; | 149 | dt = (jiffies - mdev->rs_start - mdev->rs_paused) / HZ; |
@@ -122,11 +151,8 @@ static void drbd_syncer_progress(struct drbd_conf *mdev, struct seq_file *seq) | |||
122 | dt = 1; | 151 | dt = 1; |
123 | db = mdev->rs_total - rs_left; | 152 | db = mdev->rs_total - rs_left; |
124 | dbdt = Bit2KB(db/dt); | 153 | dbdt = Bit2KB(db/dt); |
125 | if (dbdt > 1000) | 154 | seq_printf_with_thousands_grouping(seq, dbdt); |
126 | seq_printf(seq, " (%ld,%03ld)", | 155 | seq_printf(seq, ")"); |
127 | dbdt/1000, dbdt % 1000); | ||
128 | else | ||
129 | seq_printf(seq, " (%ld)", dbdt); | ||
130 | 156 | ||
131 | if (mdev->state.conn == C_SYNC_TARGET) { | 157 | if (mdev->state.conn == C_SYNC_TARGET) { |
132 | if (mdev->c_sync_rate > 1000) | 158 | if (mdev->c_sync_rate > 1000) |
@@ -236,7 +262,9 @@ static int drbd_seq_show(struct seq_file *seq, void *v) | |||
236 | Bit2KB(drbd_bm_total_weight(mdev))); | 262 | Bit2KB(drbd_bm_total_weight(mdev))); |
237 | } | 263 | } |
238 | if (mdev->state.conn == C_SYNC_SOURCE || | 264 | if (mdev->state.conn == C_SYNC_SOURCE || |
239 | mdev->state.conn == C_SYNC_TARGET) | 265 | mdev->state.conn == C_SYNC_TARGET || |
266 | mdev->state.conn == C_VERIFY_S || | ||
267 | mdev->state.conn == C_VERIFY_T) | ||
240 | drbd_syncer_progress(mdev, seq); | 268 | drbd_syncer_progress(mdev, seq); |
241 | 269 | ||
242 | if (mdev->state.conn == C_VERIFY_S || mdev->state.conn == C_VERIFY_T) { | 270 | if (mdev->state.conn == C_VERIFY_S || mdev->state.conn == C_VERIFY_T) { |