fcinfo.c revision a79493184c9332129c9c91500069322f6f3fafdd
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 2009 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
#include <fcinfo.h>
#define VERSION_STRING_MAX_LEN 10
/*
* Version number:
* MAJOR - This should only change when there is an incompatible change made
* to the interfaces or the output.
*
* MINOR - This should change whenever there is a new command or new feature
* with no incompatible change.
*/
#define VERSION_STRING_MAJOR "1"
#define VERSION_STRING_MINOR "0"
#define OPTIONSTRING1 "HBA Port WWN"
#define OPTIONSTRING2 "HBA Node WWN"
/* forward declarations */
static int listHbaPortFunc(int, char **, cmdOptions_t *, void *);
static int listRemotePortFunc(int, char **, cmdOptions_t *, void *);
static int listLogicalUnitFunc(int, char **, cmdOptions_t *, void *);
static int npivCreatePortFunc(int, char **, cmdOptions_t *, void *);
static int npivDeletePortFunc(int, char **, cmdOptions_t *, void *);
static int npivCreatePortListFunc(int, char **, cmdOptions_t *, void *);
static int npivListHbaPortFunc(int, char **, cmdOptions_t *, void *);
static int npivListRemotePortFunc(int, char **, cmdOptions_t *, void *);
static int fcoeAdmCreatePortFunc(int, char **, cmdOptions_t *, void *);
static int fcoeListPortsFunc(int, char **, cmdOptions_t *, void *);
static int fcoeAdmDeletePortFunc(int, char **, cmdOptions_t *, void *);
static int fcadmForceLipFunc(int, char **, cmdOptions_t *, void *);
static char *getExecBasename(char *);
/*
* Add new options here
*
* Optional option-arguments are not allowed by CLIP
*/
optionTbl_t fcinfolongOptions[] = {
{NULL, 0, 0}
};
optionTbl_t fcadmlongOptions[] = {
{NULL, 0, 0}
};
/*
* Add new subcommands here
*/
OPERAND_OPTIONAL_MULTIPLE, "WWN"},
OPERAND_OPTIONAL_MULTIPLE, "WWN"},
OPERAND_OPTIONAL_MULTIPLE, "OS Device Path"},
OPERAND_OPTIONAL_MULTIPLE, "OS Device Path"},
};
{"create-npiv-port",
OPERAND_MANDATORY_SINGLE, "WWN"},
{"delete-npiv-port",
OPERAND_MANDATORY_SINGLE, "WWN"},
{"hba-port",
OPERAND_OPTIONAL_MULTIPLE, "WWN"},
{"remote-port",
OPERAND_OPTIONAL_MULTIPLE, "WWN"},
{"create-port-list",
OPERAND_NONE, NULL},
{"create-fcoe-port",
OPERAND_MANDATORY_SINGLE, "Network Interface Name"},
{"delete-fcoe-port",
OPERAND_MANDATORY_SINGLE, "Network Interface Name"},
{"list-fcoe-ports",
OPERAND_NONE, NULL},
{"force-lip",
OPERAND_MANDATORY_SINGLE, "WWN"},
};
/*
*/
/*ARGSUSED*/
static int
{
}
/*
*/
/*ARGSUSED*/
static int
void *addArgs)
{
}
/*
*/
/*ARGSUSED*/
static int
void *addArgs)
{
}
/*
*/
/*ARGSUSED*/
static int
}
static int
objects = 1;
}
return (fc_util_create_portlist());
}
/*
*/
/*ARGSUSED*/
static int
}
/*
*/
/*ARGSUSED*/
static int
}
/*
*/
/*ARGSUSED*/
static int
}
/*
*/
/*ARGSUSED*/
static int
void *addArgs)
{
}
/*
*/
/*ARGSUSED*/
static int
void *addArgs)
{
}
/*
*/
/*ARGSUSED*/
static int
void *addArgs)
{
return (fcoe_adm_list_ports(options));
}
/*
*/
/*ARGSUSED*/
static int
void *addArgs)
{
}
/*
* input:
* execFullName - exec name of program (argv[0])
*
* Returns:
* command name portion of execFullName
*/
static char *
getExecBasename(char *execFullname)
{
char *lastSlash, *execBasename;
/* guard against '/' at end of command invocation */
for (;;) {
break;
} else {
if (*execBasename == '\0') {
*lastSlash = '\0';
continue;
}
break;
}
}
return (execBasename);
}
/*
* main calls a parser that checks syntax of the input command against
* various rules tables.
*
* The parser provides usage feedback based upon same tables by calling
* two usage functions, usage and subUsage, handling command and subcommand
* usage respectively.
*
* The parser handles all printing of usage syntactical errors
*
* When syntax is successfully validated, the parser calls the associated
* function using the subcommands table functions.
*
* Syntax is as follows:
* command subcommand [options] resource-type [<object>]
*
* The return value from the function is placed in funcRet
*/
int
{
int ret;
int funcRet;
void *subcommandArgs = NULL;
#if !defined(TEXT_DOMAIN) /* Should be defined by cc -D */
#endif
(void) textdomain(TEXT_DOMAIN);
/* set global command name */
} else {
}
/* call the CLI parser */
if (ret == 1) {
return (1);
} else if (ret == -1) {
return (1);
}
if (funcRet != 0) {
return (1);
}
return (0);
}