/*
* 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 <devfsadm.h>
#include <stdio.h>
#include <strings.h>
#include <stdlib.h>
#include <limits.h>
#include <ctype.h>
#include <sys/int_fmtio.h>
#include <sys/libdevid.h>
}
};
/*
* HOT auto cleanup of sgen links not desired.
*/
}
};
static int
{
char *tgt_port;
goto done;
/*
* SCSAv3 attached devices.
*/
SCSI_ADDR_PROP_TARGET_PORT, &tgt_port) > 0) {
int *intp;
/* Get lun property */
SCSI_ADDR_PROP_LUN64, &lun64p) > 0) &&
(*lun64p != SCSI_LUN64_ILLEGAL)) {
SCSI_ADDR_PROP_LUN, &intp) > 0) {
}
if ((addr_method == SCSI_LUN_AM_PDEV) &&
} else if ((addr_method == SCSI_LUN_AM_FLAT) &&
} else {
}
"client-guid", (char **)&wwnstr) > 0) {
/*
* MPXIO-enabled devices; lun is always 0.
*/
sizeof (buf))
goto done;
}
goto done;
/*
* "normal" fibre channel devices
*/
else
lun = 0;
*tstr = '\0';
goto done;
} else {
/*
* Parallel SCSI devices
*/
goto done;
goto done;
goto done;
}
done:
return (DEVFSADM_CONTINUE);
}
/* index of enumeration rule applicable to this module */
static char *
{
char *devfspath;
};
return (NULL);
}
/*
* Use controller (parent) component of device path
*/
/*
* We failed because there are multiple logical controller
* numbers for a single physical controller. If we use node
* name also for DEVICE paths in the match it should fix this
* and only find one logical controller. (See 4045879).
* NOTE: Rules for controllers are not changed, as there is
* no unique controller number for them in this case.
*
* MATCH_UNCACHED flag is private to the "disks" and "sgen"
* modules. NOT to be used by other modules.
*/
return (NULL);
}
}
return (buf);
}