|
@@ -1495,10 +1495,12 @@ static void raid10_status(struct seq_file *seq, struct mddev *mddev)
|
|
|
}
|
|
|
seq_printf(seq, " [%d/%d] [", conf->geo.raid_disks,
|
|
|
conf->geo.raid_disks - mddev->degraded);
|
|
|
- for (i = 0; i < conf->geo.raid_disks; i++)
|
|
|
- seq_printf(seq, "%s",
|
|
|
- conf->mirrors[i].rdev &&
|
|
|
- test_bit(In_sync, &conf->mirrors[i].rdev->flags) ? "U" : "_");
|
|
|
+ rcu_read_lock();
|
|
|
+ for (i = 0; i < conf->geo.raid_disks; i++) {
|
|
|
+ struct md_rdev *rdev = rcu_dereference(conf->mirrors[i].rdev);
|
|
|
+ seq_printf(seq, "%s", rdev && test_bit(In_sync, &rdev->flags) ? "U" : "_");
|
|
|
+ }
|
|
|
+ rcu_read_unlock();
|
|
|
seq_printf(seq, "]");
|
|
|
}
|
|
|
|