-static int mdt_server_data_init(const struct lu_env *env,
- struct mdt_device *mdt,
- struct lustre_sb_info *lsi)
-{
- struct lr_server_data *lsd = &mdt->mdt_lut.lut_lsd;
- struct lsd_client_data *lcd = NULL;
- struct obd_device *obd = mdt2obd_dev(mdt);
- struct mdt_thread_info *mti;
- struct dt_object *obj;
- struct lu_attr *la;
- unsigned long last_rcvd_size;
- __u64 mount_count;
- int rc;
- ENTRY;
-
- /* ensure padding in the struct is the correct size */
- CLASSERT(offsetof(struct lr_server_data, lsd_padding) +
- sizeof(lsd->lsd_padding) == LR_SERVER_SIZE);
- CLASSERT(offsetof(struct lsd_client_data, lcd_padding) +
- sizeof(lcd->lcd_padding) == LR_CLIENT_SIZE);
-
- mti = lu_context_key_get(&env->le_ctx, &mdt_thread_key);
- LASSERT(mti != NULL);
- la = &mti->mti_attr.ma_attr;
-
- obj = mdt->mdt_lut.lut_last_rcvd;
- rc = dt_attr_get(env, obj, la, BYPASS_CAPA);
- if (rc)
- RETURN(rc);
-
- last_rcvd_size = (unsigned long)la->la_size;
-
- if (last_rcvd_size == 0) {
- LCONSOLE_WARN("%s: new disk, initializing\n", obd->obd_name);
-
- memcpy(lsd->lsd_uuid, obd->obd_uuid.uuid,
- sizeof(lsd->lsd_uuid));
- lsd->lsd_last_transno = 0;
- lsd->lsd_mount_count = 0;
- lsd->lsd_server_size = LR_SERVER_SIZE;
- lsd->lsd_client_start = LR_CLIENT_START;
- lsd->lsd_client_size = LR_CLIENT_SIZE;
- lsd->lsd_feature_compat = OBD_COMPAT_MDT;
- lsd->lsd_feature_rocompat = OBD_ROCOMPAT_LOVOBJID;
- lsd->lsd_feature_incompat = OBD_INCOMPAT_MDT |
- OBD_INCOMPAT_COMMON_LR |
- OBD_INCOMPAT_MULTI_OI;
- } else {
- LCONSOLE_WARN("%s: used disk, loading\n", obd->obd_name);
- rc = tgt_server_data_read(env, &mdt->mdt_lut);
- if (rc) {
- CERROR("error reading MDS %s: rc %d\n", LAST_RCVD, rc);
- GOTO(out, rc);
- }
- if (strcmp(lsd->lsd_uuid, obd->obd_uuid.uuid) != 0) {
- LCONSOLE_ERROR_MSG(0x157, "Trying to start OBD %s using"
- "the wrong disk %s. Were the /dev/ "
- "assignments rearranged?\n",
- obd->obd_uuid.uuid, lsd->lsd_uuid);
- GOTO(out, rc = -EINVAL);
- }
- lsd->lsd_feature_compat |= OBD_COMPAT_MDT;
- lsd->lsd_feature_incompat |= OBD_INCOMPAT_MDT |
- OBD_INCOMPAT_COMMON_LR;
- }
- mount_count = lsd->lsd_mount_count;
-
- if (lsd->lsd_feature_incompat & ~MDT_INCOMPAT_SUPP) {
- CERROR("%s: unsupported incompat filesystem feature(s) %x\n",
- obd->obd_name,
- lsd->lsd_feature_incompat & ~MDT_INCOMPAT_SUPP);
- GOTO(out, rc = -EINVAL);
- }
- if (lsd->lsd_feature_rocompat & ~MDT_ROCOMPAT_SUPP) {
- CERROR("%s: unsupported read-only filesystem feature(s) %x\n",
- obd->obd_name,
- lsd->lsd_feature_rocompat & ~MDT_ROCOMPAT_SUPP);
- /* XXX: Do something like remount filesystem read-only */
- GOTO(out, rc = -EINVAL);
- }
- /** Interop: evict all clients at first boot with 1.8 last_rcvd */
- if (!(lsd->lsd_feature_compat & OBD_COMPAT_20)) {
- if (last_rcvd_size > lsd->lsd_client_start) {
- LCONSOLE_WARN("Mounting %s at first time on 1.8 FS, "
- "remove all clients for interop needs\n",
- obd->obd_name);
- rc = tgt_truncate_last_rcvd(env, &mdt->mdt_lut,
- lsd->lsd_client_start);
- if (rc)
- GOTO(out, rc);
- last_rcvd_size = lsd->lsd_client_start;
- }
- /** set 2.0 flag to upgrade/downgrade between 1.8 and 2.0 */
- lsd->lsd_feature_compat |= OBD_COMPAT_20;
- }
-
- lsd->lsd_feature_incompat |= OBD_INCOMPAT_FID;
-
- spin_lock(&mdt->mdt_lut.lut_translock);
- mdt->mdt_lut.lut_last_transno = lsd->lsd_last_transno;
- spin_unlock(&mdt->mdt_lut.lut_translock);
-
- CDEBUG(D_INODE, "========BEGIN DUMPING LAST_RCVD========\n");
- CDEBUG(D_INODE, "%s: server last_transno: "LPU64"\n",
- obd->obd_name, mdt->mdt_lut.lut_last_transno);
- CDEBUG(D_INODE, "%s: server mount_count: "LPU64"\n",
- obd->obd_name, mount_count + 1);
- CDEBUG(D_INODE, "%s: server data size: %u\n",
- obd->obd_name, lsd->lsd_server_size);
- CDEBUG(D_INODE, "%s: per-client data start: %u\n",
- obd->obd_name, lsd->lsd_client_start);
- CDEBUG(D_INODE, "%s: per-client data size: %u\n",
- obd->obd_name, lsd->lsd_client_size);
- CDEBUG(D_INODE, "%s: last_rcvd size: %lu\n",
- obd->obd_name, last_rcvd_size);
- CDEBUG(D_INODE, "%s: last_rcvd clients: %lu\n", obd->obd_name,
- last_rcvd_size <= lsd->lsd_client_start ? 0 :
- (last_rcvd_size - lsd->lsd_client_start) /
- lsd->lsd_client_size);
- CDEBUG(D_INODE, "========END DUMPING LAST_RCVD========\n");
-
- if (!lsd->lsd_server_size || !lsd->lsd_client_start ||
- !lsd->lsd_client_size) {
- CERROR("Bad last_rcvd contents!\n");
- GOTO(out, rc = -EINVAL);
- }
-
- rc = mdt_clients_data_init(env, mdt, last_rcvd_size);
- if (rc)
- GOTO(err_client, rc);
-
- spin_lock(&mdt->mdt_lut.lut_translock);
- /* obd_last_committed is used for compatibility
- * with other lustre recovery code */
- obd->obd_last_committed = mdt->mdt_lut.lut_last_transno;
- spin_unlock(&mdt->mdt_lut.lut_translock);
-
- obd->u.obt.obt_mount_count = mount_count + 1;
- obd->u.obt.obt_instance = (__u32)obd->u.obt.obt_mount_count;
- lsd->lsd_mount_count = obd->u.obt.obt_mount_count;
-
- /* save it, so mount count and last_transno is current */
- rc = tgt_server_data_update(env, &mdt->mdt_lut, 0);
- if (rc)
- GOTO(err_client, rc);
-
- RETURN(0);
-
-err_client:
- class_disconnect_exports(obd);
-out:
- return rc;