if (sscanf(lustre_cfg_buf(lcfg, 3), "%d", &gen) != 1)
GOTO(out, rc = -EINVAL);
- rc = -EINVAL;
+ if (lcfg->lcfg_command == LCFG_LOV_ADD_OBD)
+ rc = lod_add_device(env, lod, arg1, index, gen, 1);
+ else if (lcfg->lcfg_command == LCFG_LOV_ADD_INA)
+ rc = lod_add_device(env, lod, arg1, index, gen, 0);
+ else
+ rc = lod_del_device(env, lod, arg1, index, gen);
+
break;
}
dt_conf_get(env, &lod->lod_dt_dev, &ddp);
lod->lod_osd_max_easize = ddp.ddp_max_ea_size;
+ /* setup obd to be used with old lov code */
+ rc = lod_pools_init(lod, cfg);
+ if (rc)
+ GOTO(out_disconnect, rc);
+
/* for compatibility we link old procfs's OSC entries to osp ones */
lov_proc_dir = lprocfs_srch(proc_lustre_root, "lov");
if (lov_proc_dir) {
RETURN(0);
+out_disconnect:
obd_disconnect(lod->lod_child_exp);
RETURN(rc);
}
if (lod->lod_symlink)
lprocfs_remove(&lod->lod_symlink);
+ lod_pools_fini(lod);
+
RETURN(NULL);
}