#define lod_ost_bitmap lod_ost_descs.ltd_tgt_bitmap
#define lod_ost_count lod_ost_descs.ltd_lov_desc.ld_tgt_count
+#define lod_ost_active_count lod_ost_descs.ltd_lov_desc.ld_active_tgt_count
#define lod_remote_mdt_count lod_mdt_descs.ltd_lmv_desc.ld_tgt_count
struct lod_layout_component {
RETURN(-E2BIG);
objs = &v3->lmm_objects[0];
}
+ lod = lu2lod_dev(lo->ldo_obj.do_lu.lo_dev);
stripe_count = lod_comp_entry_stripe_count(lo, comp_idx, is_dir);
if (stripe_count == 0 && !is_dir &&
!(lod_comp->llc_pattern & LOV_PATTERN_F_RELEASED) &&
- !(lod_comp->llc_pattern & LOV_PATTERN_MDT))
+ !(lod_comp->llc_pattern & LOV_PATTERN_MDT)) {
+ /* Try again if all active targets are disconnected.
+ * It is possible when MDS does failover. */
+ if (!lod->lod_ost_active_count &&
+ lod->lod_ost_count)
+ RETURN(-EAGAIN);
RETURN(-E2BIG);
+ }
if (!is_dir && lo->ldo_is_composite)
lod_comp_shrink_stripe_count(lod_comp, &stripe_count);
GOTO(done, rc = 0);
/* generate ost_idx of this component stripe */
- lod = lu2lod_dev(lo->ldo_obj.do_lu.lo_dev);
for (i = 0; i < stripe_count; i++) {
struct dt_object *object;
__u32 ost_idx = (__u32)-1UL;
return lod->lod_ost_count;
else
return lod_get_stripe_count(lod, lo, comp_idx,
- entry->llc_stripe_count, false);
+ entry->llc_stripe_count,
+ entry->llc_pattern &
+ LOV_PATTERN_OVERSTRIPING);
}
static int lod_comp_md_size(struct lod_object *lo, bool is_dir)