Whamcloud - gitweb
LU-4808 tests: sanity cleanup to work on Xeon Phi
[fs/lustre-release.git] / lustre / mgs / mgs_fs.c
index e5b1fb6..5d2b99b 100644 (file)
@@ -27,7 +27,7 @@
  * Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
  * Use is subject to license terms.
  *
- * Copyright (c) 2011, 2012, Whamcloud, Inc.
+ * Copyright (c) 2011, 2012, Intel Corporation.
  */
 /*
  * This file is part of Lustre, http://www.lustre.org/
 #include "mgs_internal.h"
 
 int mgs_export_stats_init(struct obd_device *obd, struct obd_export *exp,
-                          void *localdata)
-
+                         void *localdata)
 {
-        lnet_nid_t *client_nid = localdata;
-        int rc, newnid;
-        ENTRY;
-
-        rc = lprocfs_exp_setup(exp, client_nid, &newnid);
-        if (rc) {
-                /* Mask error for already created
-                 * /proc entries */
-                if (rc == -EALREADY)
-                        rc = 0;
-                RETURN(rc);
-        }
-        if (newnid) {
-                struct nid_stat *tmp = exp->exp_nid_stats;
-                int num_stats = 0;
-
-                num_stats = (sizeof(*obd->obd_type->typ_dt_ops) / sizeof(void *)) +
-                            LPROC_MGS_LAST - 1;
-                tmp->nid_stats = lprocfs_alloc_stats(num_stats,
-                                                     LPROCFS_STATS_FLAG_NOPERCPU);
-                if (tmp->nid_stats == NULL)
-                        return -ENOMEM;
-                lprocfs_init_ops_stats(LPROC_MGS_LAST, tmp->nid_stats);
-                mgs_stats_counter_init(tmp->nid_stats);
-                rc = lprocfs_register_stats(tmp->nid_proc, "stats",
-                                            tmp->nid_stats);
-                if (rc)
-                        GOTO(clean, rc);
-
-                rc = lprocfs_nid_ldlm_stats_init(tmp);
-                if (rc)
-                        GOTO(clean, rc);
+       lnet_nid_t *client_nid = localdata;
+       struct nid_stat *tmp;
+       int rc, is_new_nid;
+       ENTRY;
+
+       rc = lprocfs_exp_setup(exp, client_nid, &is_new_nid);
+       if (rc != 0) {
+               /* Mask error for already created /proc entries */
+               if (rc == -EALREADY)
+                       rc = 0;
+               GOTO(out, rc = 0);
         }
-        RETURN(0);
-clean:
-        return rc;
+
+       if (!is_new_nid)
+               GOTO(out, rc = 0);
+
+       tmp = exp->exp_nid_stats;
+       tmp->nid_stats = lprocfs_alloc_stats(NUM_OBD_STATS + LPROC_MGS_LAST,
+                                            LPROCFS_STATS_FLAG_NOPERCPU);
+       if (tmp->nid_stats == NULL)
+               GOTO(out, rc = -ENOMEM);
+
+       lprocfs_init_ops_stats(LPROC_MGS_LAST, tmp->nid_stats);
+       mgs_stats_counter_init(tmp->nid_stats);
+       rc = lprocfs_register_stats(tmp->nid_proc, "stats", tmp->nid_stats);
+       if (rc != 0)
+               GOTO(out, rc);
+
+       rc = lprocfs_nid_ldlm_stats_init(tmp);
+       if (rc != 0)
+               GOTO(out, rc);
+
+       RETURN(0);
+out:
+       return rc;
 }
 
 /**
@@ -141,9 +139,9 @@ int mgs_fs_setup(const struct lu_env *env, struct mgs_device *mgs)
                GOTO(out_los, rc);
 
        root = dt_locate_at(env, mgs->mgs_bottom, &rfid,
-                           &mgs->mgs_dt_dev.dd_lu_dev);
+                           &mgs->mgs_dt_dev.dd_lu_dev, NULL);
        if (unlikely(IS_ERR(root)))
-               GOTO(out_los, PTR_ERR(root));
+               GOTO(out_los, rc = PTR_ERR(root));
 
        o = local_file_find_or_create(env, mgs->mgs_los, root,
                                      MOUNT_CONFIGS_DIR,
@@ -151,6 +149,11 @@ int mgs_fs_setup(const struct lu_env *env, struct mgs_device *mgs)
        if (IS_ERR(o))
                GOTO(out_root, rc = PTR_ERR(o));
 
+       if (!dt_try_as_dir(env, o)) {
+               lu_object_put(env, &o->do_lu);
+               GOTO(out_root, rc = -ENOTDIR);
+       }
+
        mgs->mgs_configs_dir = o;
 
        /* create directory to store nid table versions */