X-Git-Url: https://git.whamcloud.com/?a=blobdiff_plain;f=lnet%2Futils%2Fptlctl.c;h=81e554880ac5af42c6f470489b851ba21e0f6a72;hb=ac7193045474854a1a4136c7d897d8188913b38c;hp=c65ecb2443634f00d93f848570ab46c1d46fb101;hpb=c5050e412572b00cbe93d8517d2d1f767bebfa92;p=fs%2Flustre-release.git diff --git a/lnet/utils/ptlctl.c b/lnet/utils/ptlctl.c index c65ecb2..81e5548 100644 --- a/lnet/utils/ptlctl.c +++ b/lnet/utils/ptlctl.c @@ -1,7 +1,5 @@ -/* -*- mode: c; c-basic-offset: 8; indent-tabs-mode: nil; -*- - * vim:expandtab:shiftwidth=8:tabstop=8: - * - * Copyright (C) 2001, 2002 Cluster File Systems, Inc. +/* + * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved. * * This file is part of Portals, http://www.sf.net/projects/lustre/ * @@ -22,24 +20,26 @@ #include #include -#include -#include - -#include "parser.h" +#include +#include command_t list[] = { - {"network", jt_ptl_network, 0,"setup the NAL (args: nal name)"}, - {"print_autoconns", jt_ptl_print_autoconnects, 0, "print autoconnect entries (no args)"}, - {"add_autoconn", jt_ptl_add_autoconnect, 0, "add autoconnect entry (args: nid host [ise])"}, - {"del_autoconn", jt_ptl_del_autoconnect, 0, "delete autoconnect entry (args: [nid] [host] [ks])"}, + {"network", jt_ptl_network, 0,"select/configure network (args: up|down|LND name)"}, + {"net", jt_ptl_network, 0,"select/configure network (args: up|down|LND name)"}, + {"list_nids", jt_ptl_list_nids, 0,"list local NIDs"}, + {"which_nid", jt_ptl_which_nid, 0,"select the closest NID"}, + {"print_interfaces", jt_ptl_print_interfaces, 0, "print interface entries (no args)"}, + {"add_interface", jt_ptl_add_interface, 0, "add interface entry (args: ip [netmask])"}, + {"del_interface", jt_ptl_del_interface, 0, "delete interface entries (args: [ip])"}, + {"print_peers", jt_ptl_print_peers, 0, "print peer entries (no args)"}, + {"add_peer", jt_ptl_add_peer, 0, "add peer entry (args: nid host port)"}, + {"del_peer", jt_ptl_del_peer, 0, "delete peer entry (args: [nid] [host])"}, {"print_conns", jt_ptl_print_connections, 0, "print connections (no args)"}, - {"connect", jt_ptl_connect, 0, "connect to a remote nid (args: host port [iIOC])"}, {"disconnect", jt_ptl_disconnect, 0, "disconnect from a remote nid (args: [nid] [host]"}, {"push", jt_ptl_push_connection, 0, "flush connection to a remote nid (args: [nid]"}, {"active_tx", jt_ptl_print_active_txs, 0, "print active transmits (no args)"}, - {"ping", jt_ptl_ping, 0, "do a ping test (args: nid [count] [size] [timeout])"}, - {"shownid", jt_ptl_shownid, 0, "print the local NID"}, + {"ping", jt_ptl_ping, 0, "ping (args: nid [timeout] [pid])"}, {"mynid", jt_ptl_mynid, 0, "inform the socknal of the local NID (args: [hostname])"}, {"add_route", jt_ptl_add_route, 0, "add an entry to the routing table (args: gatewayNID targetNID [targetNID])"}, @@ -48,11 +48,9 @@ command_t list[] = { {"set_route", jt_ptl_notify_router, 0, "enable/disable a route in the routing table (args: gatewayNID up/down [time]"}, {"print_routes", jt_ptl_print_routes, 0, "print the routing table (args: none)"}, - {"recv_mem", jt_ptl_rxmem, 0, "Set socket receive buffer size (args: [size])"}, - {"send_mem", jt_ptl_txmem, 0, "Set socket send buffer size (args: [size])"}, - {"nagle", jt_ptl_nagle, 0, "Enable/Disable Nagle (args: [on/off])"}, {"dump", jt_ioc_dump, 0, "usage: dump file, save ioctl buffer to file"}, {"fail", jt_ptl_fail_nid, 0, "usage: fail nid|_all_ [count]"}, + {"testprotocompat", jt_ptl_testprotocompat, 0, "usage: testprotocompat count"}, {"help", Parser_help, 0, "help"}, {"exit", Parser_quit, 0, "quit"}, {"quit", Parser_quit, 0, "quit"}, @@ -61,14 +59,25 @@ command_t list[] = { int main(int argc, char **argv) { - if (ptl_initialize(argc, argv) < 0) - exit(1); + int rc = 0; + + rc = libcfs_arch_init(); + if (rc < 0) + return rc; + + rc = ptl_initialize(argc, argv); + if (rc < 0) + goto errorout; Parser_init("ptlctl > ", list); - if (argc > 1) - return Parser_execarg(argc - 1, &argv[1], list); + if (argc > 1) { + rc = Parser_execarg(argc - 1, &argv[1], list); + goto errorout; + } Parser_commands(); - return 0; +errorout: + libcfs_arch_cleanup(); + return rc; }