*
* You should have received a copy of the GNU General Public License
* version 2 along with this program; If not, see
- * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
+ * http://www.gnu.org/licenses/gpl-2.0.html
*
* GPL HEADER END
*/
* Copyright (c) 2002, 2010, Oracle and/or its affiliates. All rights reserved.
* Use is subject to license terms.
*
- * Copyright (c) 2014, 2015, Intel Corporation.
+ * Copyright (c) 2014, 2016, Intel Corporation.
*/
/*
* This file is part of Lustre, http://www.lustre.org/
#define DEBUG_SUBSYSTEM S_CLASS
+#include <linux/kobject.h>
+#include <linux/sysfs.h>
#include <obd_class.h>
#include <lprocfs_status.h>
#include <lustre/lustre_idl.h>
#include <lustre_nodemap.h>
+static ssize_t uuid_show(struct kobject *kobj, struct attribute *attr,
+ char *buf)
+{
+ struct obd_device *obd = class_name2obd(kobj->name);
+
+ return sprintf(buf, "%s\n", obd->obd_uuid.uuid);
+}
+LUSTRE_RO_ATTR(uuid);
+
+static struct attribute *server_uuid_attrs[] = {
+ &lustre_attr_uuid.attr,
+ NULL,
+};
+
+static struct attribute_group server_def_attr_group = {
+ .attrs = server_uuid_attrs,
+};
+
+void lprocfs_kset_unregister(struct obd_device *obd, struct kset *kset)
+{
+ if (obd->obd_proc_entry) {
+ lprocfs_remove(&obd->obd_proc_entry);
+ obd->obd_proc_entry = NULL;
+ }
+
+ if (kset)
+ kset_unregister(kset);
+}
+EXPORT_SYMBOL(lprocfs_kset_unregister);
+
+int lprocfs_kset_register(struct obd_device *obd, struct kset **kset)
+{
+ struct kset *obd_kset;
+ int rc = 0;
+
+ obd_kset = kset_create_and_add(obd->obd_name, NULL,
+ obd->obd_type->typ_kobj);
+ if (!obd_kset) {
+ CERROR("%s: cannot add new kset: rc = %d\n", obd->obd_name, rc);
+ rc = -ENOMEM;
+ }
+
+ if (!obd->obd_attrs)
+ obd->obd_attrs = &server_def_attr_group;
+
+ rc = sysfs_create_group(&obd_kset->kobj, obd->obd_attrs);
+ if (rc) {
+ CERROR("%s: cannot create attr group: rc = %d\n", obd->obd_name,
+ rc);
+ kset_unregister(obd_kset);
+ obd_kset = NULL;
+ return rc;
+ }
+
+ obd->obd_proc_entry = lprocfs_register(obd->obd_name,
+ obd->obd_type->typ_procroot,
+ obd->obd_vars, obd);
+ if (IS_ERR(obd->obd_proc_entry)) {
+ rc = PTR_ERR(obd->obd_proc_entry);
+ CERROR("%s: error %d setting up lprocfs\n", obd->obd_name, rc);
+ obd->obd_proc_entry = NULL;
+
+ kset_unregister(obd_kset);
+ obd_kset = NULL;
+ }
+ *kset = obd_kset;
+ return rc;
+}
+EXPORT_SYMBOL(lprocfs_kset_register);
+
#ifdef CONFIG_PROC_FS
int lprocfs_evict_client_open(struct inode *inode, struct file *f)
/* sampled unlocked, but really... */
if (obd->obd_recovering == 0) {
seq_printf(m, "COMPLETE\n");
- seq_printf(m, "recovery_start: %lu\n", obd->obd_recovery_start);
- seq_printf(m, "recovery_duration: %lu\n",
+ seq_printf(m, "recovery_start: %lld\n",
+ (s64)obd->obd_recovery_start);
+ seq_printf(m, "recovery_duration: %lld\n",
obd->obd_recovery_end ?
obd->obd_recovery_end - obd->obd_recovery_start :
- cfs_time_current_sec() - obd->obd_recovery_start);
+ ktime_get_real_seconds() - obd->obd_recovery_start);
/* Number of clients that have completed recovery */
seq_printf(m, "completed_clients: %d/%d\n",
obd->obd_max_recoverable_clients -
seq_printf(m, "WAITING\n");
seq_printf(m, "non-ready MDTs: %s\n",
buf ? buf : "unknown (not enough RAM)");
- seq_printf(m, "recovery_start: %lu\n",
- obd->obd_recovery_start);
- seq_printf(m, "time_waited: %lu\n",
- cfs_time_current_sec() -
- obd->obd_recovery_start);
+ seq_printf(m, "recovery_start: %lld\n",
+ (s64)obd->obd_recovery_start);
+ seq_printf(m, "time_waited: %lld\n",
+ (s64)(ktime_get_real_seconds() -
+ obd->obd_recovery_start));
}
if (buf != NULL)
}
seq_printf(m, "RECOVERING\n");
- seq_printf(m, "recovery_start: %lu\n", obd->obd_recovery_start);
- seq_printf(m, "time_remaining: %lu\n",
- cfs_time_current_sec() >=
+ seq_printf(m, "recovery_start: %lld\n", (s64)obd->obd_recovery_start);
+ seq_printf(m, "time_remaining: %lld\n",
+ ktime_get_real_seconds() >=
obd->obd_recovery_start +
obd->obd_recovery_timeout ? 0 :
- obd->obd_recovery_start +
- obd->obd_recovery_timeout -
- cfs_time_current_sec());
+ (s64)(obd->obd_recovery_start +
+ obd->obd_recovery_timeout -
+ ktime_get_real_seconds()));
seq_printf(m, "connected_clients: %d/%d\n",
atomic_read(&obd->obd_connected_clients),
obd->obd_max_recoverable_clients);
}
EXPORT_SYMBOL(lprocfs_ir_factor_seq_write);
+int lprocfs_checksum_dump_seq_show(struct seq_file *m, void *data)
+{
+ struct obd_device *obd = m->private;
+
+ LASSERT(obd != NULL);
+ seq_printf(m, "%d\n", obd->obd_checksum_dump);
+ return 0;
+}
+EXPORT_SYMBOL(lprocfs_checksum_dump_seq_show);
+
+ssize_t
+lprocfs_checksum_dump_seq_write(struct file *file, const char __user *buffer,
+ size_t count, loff_t *off)
+{
+ struct seq_file *m = file->private_data;
+ struct obd_device *obd = m->private;
+ int rc;
+ __s64 val;
+
+ LASSERT(obd != NULL);
+ rc = lprocfs_str_to_s64(buffer, count, &val);
+ if (rc)
+ return rc;
+
+ obd->obd_checksum_dump = !!val;
+ return count;
+}
+EXPORT_SYMBOL(lprocfs_checksum_dump_seq_write);
+
int lprocfs_recovery_time_soft_seq_show(struct seq_file *m, void *data)
{
struct obd_device *obd = m->private;
LASSERT(obd != NULL);
- seq_printf(m, "%d\n", obd->obd_recovery_timeout);
+ seq_printf(m, "%llu\n", obd->obd_recovery_timeout);
return 0;
}
EXPORT_SYMBOL(lprocfs_recovery_time_soft_seq_show);
struct obd_device *obd = m->private;
LASSERT(obd != NULL);
- seq_printf(m, "%u\n", obd->obd_recovery_time_hard);
+ seq_printf(m, "%lld\n", obd->obd_recovery_time_hard);
return 0;
}
EXPORT_SYMBOL(lprocfs_recovery_time_hard_seq_show);