drive_descriptors.c revision da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0
/*
* 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 2007 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
#pragma ident "%Z%%M% %I% %E% SMI"
#include <stdio.h>
#include <unistd.h>
#include <strings.h>
#include <stdlib.h>
#include <errno.h>
#include <netdb.h>
#include <cimapi.h>
#include <libnvpair.h>
#include <md5.h>
#include "libdiskmgt.h"
#include "providerNames.h"
#include "messageStrings.h"
#include "cimKeys.h"
#include "util.h"
/*
* Convert a single descriptor in to a Solaris_DiskDrive instance
*/
{
char *alias;
char buf[100];
int error = 0;
int fdisk = 0;
*errp = 0;
return ((CCIMInstance *)NULL);
}
/* Create instance of disk drive. */
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
/*
* Get the common name from the alias descriptor associated with
* this drive. This is used for the 'name' attribute as well as the
* deviceid if the standard deviceid is not found.
*/
&error);
if (error != 0) {
return ((CCIMInstance *)NULL);
}
if (error != 0) {
return ((CCIMInstance *)NULL);
}
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
/* Now, assign the deviceID */
if (error != 0) {
return ((CCIMInstance *)NULL);
}
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
} else {
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
}
/* add keys */
if (*errp == 0) {
}
if (*errp == 0) {
}
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
if (error != 0) {
return ((CCIMInstance *)NULL);
}
return (inst);
}
char *attrname;
char *status;
continue;
}
/*
* loop through the nvpair list and assign attributes to the
* CIMInstace.
*/
char *type = "Unknown";
if (error != 0) {
return ((CCIMInstance *)NULL);
}
switch (ui32) {
case DM_DT_FIXED:
type = "Fixed";
break;
case DM_DT_ZIP:
type = "Zip";
break;
case DM_DT_JAZ:
type = "Jaz";
break;
default:
type = "Removable";
}
break;
}
errp);
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
if (error != 0) {
return ((CCIMInstance *)NULL);
}
if (ui32 == 0) {
status = "Error";
} else {
status = "OK";
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (*errp == 0) {
}
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
}
}
/*
* Now get the associated media, and get some of the other attributes.
*/
return (inst);
}
return (inst);
}
if (*errp != 0) {
return ((CCIMInstance *)NULL);
}
/*
* It is possible that we cannot read the media for this drive.
* So, do not error out, but return what we have so far for the
* drive instance.
*/
*errp = 0;
return (inst);
}
if (*errp != 0) {
return ((CCIMInstance *)NULL);
}
char *attrname;
continue;
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
fdisk = 1;
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
if (error != 0) {
return ((CCIMInstance *)NULL);
}
errp);
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
}
} /* end for */
/*
* Now fill in the geometry data
*/
if (error < 0) {
return ((CCIMInstance *)NULL);
}
errp);
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
errp);
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
errp);
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
if (error < 0) {
return ((CCIMInstance *)NULL);
}
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
/*
* Now check to see if there is an fdisk or not.
*/
if (fdisk != 1) {
if (*errp != 0) {
ex = cim_getLastError();
return ((CCIMInstance *)NULL);
}
}
return (inst);
}
/* Convert the descriptor list to a CIMInstance List */
int *errp)
{
int i;
int error = 0;
*errp = 0;
/* If not descriptor list, return an empty instance list. */
return ((CCIMInstanceList *)NULL);
}
/* Create the instance list which will store the instances */
ex = cim_getLastError();
return ((CCIMInstanceList *)NULL);
}
providerName, &error);
if (error != 0) {
/* Error handling is done in the subfunction. */
return ((CCIMInstanceList *)NULL);
}
continue;
}
/* add the instance to the instance list */
ex = cim_getLastError();
return ((CCIMInstanceList *)NULL);
}
}
return (instList);
}
/*
* Convert the descriptor list to a CIMInstance List that will be used
* only for object paths and thus does not need to be fully populated.
* We do the filtering in this function to be sure that we are only
* returning drives that are modeled with this class in CIM.
*/
int *errp)
{
int i;
int error = 0;
int have_instances = 0;
*errp = 0;
return ((CCIMInstanceList *)NULL);
}
/* Create the instance list which will store the instances */
return ((CCIMInstanceList *)NULL);
}
char *str;
continue;
}
switch (drvtype) {
case DM_DT_UNKNOWN:
break;
case DM_DT_FIXED:
break;
case DM_DT_ZIP:
break;
case DM_DT_JAZ:
break;
default:
/*
* This is not one of the drives that are modeled as a
* Solaris_DiskDrive, so we should skip over it.
*/
continue;
}
if (error != 0) {
return ((CCIMInstanceList *)NULL);
}
if (error != 0) {
return ((CCIMInstanceList *)NULL);
}
if (error != 0) {
return ((CCIMInstanceList *)NULL);
}
}
/* Create instance of disk drive. */
return ((CCIMInstanceList *)NULL);
}
/* add keys */
if (*errp == 0) {
}
if (*errp == 0) {
}
if (*errp == 0) {
}
if (*errp != 0) {
return ((CCIMInstanceList *)NULL);
}
/* add the instance to the instance list */
return ((CCIMInstanceList *)NULL);
}
have_instances = 1;
}
if (!have_instances) {
}
return (instList);
}