X-Git-Url: http://git.ipfire.org/?a=blobdiff_plain;f=mdmon.h;h=aa750c6811e146c9cc9b402783600d47ef75b6cd;hb=50d72ed4298618c679efd43647dd055527e59b10;hp=a965eccacefe6202c82c1bd12226a15adea54e1e;hpb=a88e119f6f483f6bc0fca7ae540881529fe29911;p=thirdparty%2Fmdadm.git diff --git a/mdmon.h b/mdmon.h index a965ecca..aa750c68 100644 --- a/mdmon.h +++ b/mdmon.h @@ -18,15 +18,13 @@ * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA. */ -#undef pr_err -#define pr_err(fmt ...) fprintf(stderr, "mdmon: " fmt) +extern const char Name[]; enum array_state { clear, inactive, suspended, readonly, read_auto, clean, active, write_pending, active_idle, bad_word}; enum sync_action { idle, reshape, resync, recover, check, repair, bad_action }; - struct active_array { struct mdinfo info; struct supertype *container; @@ -73,7 +71,6 @@ extern struct active_array *discard_this; extern struct active_array *pending_discard; extern struct md_generic_cmd *active_cmd; - void remove_pidfile(char *devname); void do_monitor(struct supertype *container); void do_manager(struct supertype *container); @@ -93,8 +90,21 @@ extern int monitor_loop_cnt; */ static inline int is_resync_complete(struct mdinfo *array) { - if (array->resync_start >= array->component_size) - return 1; - return 0; + unsigned long long sync_size = 0; + int ncopies, l; + switch(array->array.level) { + case 1: + case 4: + case 5: + case 6: + sync_size = array->component_size; + break; + case 10: + l = array->array.layout; + ncopies = (l & 0xff) * ((l >> 8) && 0xff); + sync_size = array->component_size * array->array.raid_disks; + sync_size /= ncopies; + break; + } + return array->resync_start >= sync_size; } -