/*
* Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
*
- * Copyright (c) 2011, 2015, Intel Corporation.
+ * Copyright (c) 2011, 2017, Intel Corporation.
*
- * This file is part of Lustre, https://wiki.hpdd.intel.com/
+ * This file is part of Lustre, https://wiki.whamcloud.com/
*
* Portals is free software; you can redistribute it and/or
* modify it under the terms of version 2 of the GNU General Public
*/
#define DEBUG_SUBSYSTEM S_LNET
+
+#include <linux/uaccess.h>
+
#include <libcfs/libcfs.h>
#include <lnet/lib-lnet.h>
/* This is really lnet_proc.c. You might need to update sanity test 215
* if any file format is changed. */
-static struct ctl_table_header *lnet_table_header = NULL;
-
#define LNET_LOFFT_BITS (sizeof(loff_t) * 8)
/*
* NB: max allowed LNET_CPT_BITS is 8 on 64-bit system and 2 on 32-bit system
if (peer != NULL) {
lnet_nid_t nid = peer->lpni_nid;
- cfs_time_t now = cfs_time_current();
- cfs_time_t deadline = peer->lpni_ping_deadline;
+ time64_t now = ktime_get_seconds();
+ time64_t deadline = peer->lpni_ping_deadline;
int nrefs = atomic_read(&peer->lpni_refcount);
int nrtrrefs = peer->lpni_rtr_refcount;
int alive_cnt = peer->lpni_alive_count;
int alive = peer->lpni_alive;
int pingsent = !peer->lpni_ping_notsent;
- int last_ping = cfs_duration_sec(cfs_time_sub(now,
- peer->lpni_ping_timestamp));
+ time64_t last_ping = now - peer->lpni_ping_timestamp;
int down_ni = 0;
struct lnet_route *rtr;
if (deadline == 0)
s += snprintf(s, tmpstr + tmpsiz - s,
- "%-4d %7d %9d %6s %12d %9d %8s %7d %s\n",
+ "%-4d %7d %9d %6s %12llu %9d %8s %7d %s\n",
nrefs, nrtrrefs, alive_cnt,
alive ? "up" : "down", last_ping,
pingsent, "NA", down_ni,
libcfs_nid2str(nid));
else
s += snprintf(s, tmpstr + tmpsiz - s,
- "%-4d %7d %9d %6s %12d %9d %8lu %7d %s\n",
+ "%-4d %7d %9d %6s %12llu %9d %8llu %7d %s\n",
nrefs, nrtrrefs, alive_cnt,
alive ? "up" : "down", last_ping,
pingsent,
- cfs_duration_sec(cfs_time_sub(deadline, now)),
+ deadline - now,
down_ni, libcfs_nid2str(nid));
LASSERT(tmpstr + tmpsiz - s > 0);
}
if (peer != NULL) {
lnet_nid_t nid = peer->lpni_nid;
int nrefs = atomic_read(&peer->lpni_refcount);
- int lastalive = -1;
+ time64_t lastalive = -1;
char *aliveness = "NA";
int maxcr = (peer->lpni_net) ?
peer->lpni_net->net_tunables.lct_peer_tx_credits : 0;
aliveness = peer->lpni_alive ? "up" : "down";
if (lnet_peer_aliveness_enabled(peer)) {
- cfs_time_t now = cfs_time_current();
- cfs_duration_t delta;
+ time64_t now = ktime_get_seconds();
- delta = cfs_time_sub(now, peer->lpni_last_alive);
- lastalive = cfs_duration_sec(delta);
+ lastalive = now - peer->lpni_last_alive;
/* No need to mess up peers contents with
* arbitrarily long integers - it suffices to
lnet_net_unlock(cpt);
s += snprintf(s, tmpstr + tmpsiz - s,
- "%-24s %4d %5s %5d %5d %5d %5d %5d %5d %d\n",
+ "%-24s %4d %5s %5lld %5d %5d %5d %5d %5d %d\n",
libcfs_nid2str(nid), nrefs, aliveness,
lastalive, maxcr, rtrcr, minrtrcr, txcr,
mintxcr, txqnob);
ni = lnet_get_ni_idx_locked(skip);
if (ni != NULL) {
- struct lnet_tx_queue *tq;
- char *stat;
+ struct lnet_tx_queue *tq;
+ char *stat;
time64_t now = ktime_get_real_seconds();
- int last_alive = -1;
- int i;
- int j;
+ time64_t last_alive = -1;
+ int i;
+ int j;
if (the_lnet.ln_routing)
last_alive = now - ni->ni_last_alive;
lnet_net_lock(i);
s += snprintf(s, tmpstr + tmpsiz - s,
- "%-24s %6s %5d %4d %4d %4d %5d %5d %5d\n",
+ "%-24s %6s %5lld %4d %4d %4d %5d %5d %5d\n",
libcfs_nid2str(ni->ni_nid), stat,
last_alive, *ni->ni_refs[i],
ni->ni_net->net_tunables.lct_peer_tx_credits,
.mode = 0644,
.proc_handler = &proc_lnet_portal_rotor,
},
- { 0 }
-};
-
-static struct ctl_table top_table[] = {
- {
- INIT_CTL_NAME
- .procname = "lnet",
- .mode = 0555,
- .data = NULL,
- .maxlen = 0,
- .child = lnet_table,
- },
- { 0 }
+ { .procname = NULL }
};
-void
-lnet_proc_init(void)
-{
-#ifdef CONFIG_SYSCTL
- if (lnet_table_header == NULL)
- lnet_table_header = register_sysctl_table(top_table);
-#endif
-}
-
-void
-lnet_proc_fini(void)
+void lnet_router_debugfs_init(void)
{
-#ifdef CONFIG_SYSCTL
- if (lnet_table_header != NULL)
- unregister_sysctl_table(lnet_table_header);
-
- lnet_table_header = NULL;
-#endif
+ lnet_insert_debugfs(lnet_table, NULL);
}