9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim/*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * CDDL HEADER START
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim *
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * The contents of this file are subject to the terms of the
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Common Development and Distribution License (the "License").
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * You may not use this file except in compliance with the License.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim *
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * or http://www.opensolaris.org/os/licensing.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * See the License for the specific language governing permissions
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * and limitations under the License.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim *
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * When distributing Covered Code, include this CDDL HEADER in each
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * If applicable, add the following below this CDDL HEADER, with the
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * fields enclosed by brackets "[]" replaced with your own identifying
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * information: Portions Copyright [yyyy] [name of copyright owner]
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim *
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * CDDL HEADER END
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim/*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Use is subject to license terms.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim#include <sun_sas.h>
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim#include <sys/types.h>
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim#include <sys/stat.h>
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim#include <fcntl.h>
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim#include <unistd.h>
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim#include <dirent.h>
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim#include <libdevinfo.h>
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim/*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * structure for di_devlink_walk
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kimtypedef struct walk_devlink {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim char *path;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim size_t len;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim char **linkpp;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim} walk_devlink_t;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim/*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * callback funtion for di_devlink_walk
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Find matching /dev link for the given path argument.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * devlink element and callback function argument.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * The input path is expected to not have "/devices".
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kimstatic int
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kimget_devlink(di_devlink_t devlink, void *arg)
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim{
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim const char ROUTINE[] = "get_devlink";
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim walk_devlink_t *warg = (walk_devlink_t *)arg;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim /*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * When path is specified, it doesn't have minor
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * name. Therefore, the ../.. prefixes needs to be stripped.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (warg->path) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim char *content = (char *)di_devlink_content(devlink);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim char *start = strstr(content, "/devices");
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (start == NULL ||
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim strncmp(start, warg->path, warg->len) != 0 ||
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim /* make it sure the device path has minor name */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim start[warg->len] != ':') {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim return (DI_WALK_CONTINUE);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim *(warg->linkpp) = strdup(di_devlink_path(devlink));
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim log(LOG_DEBUG, ROUTINE, "Walk terminate");
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim return (DI_WALK_TERMINATE);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim}
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim/*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Convert /devices paths to /dev sym-link paths.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * The mapping buffer OSDeviceName paths will be
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * converted to short names.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * mappings The target mappings data to convert to short names
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim *
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * If no link is found, the long path is left as is.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Note: The NumberOfEntries field MUST not be greater than the size
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * of the array passed in.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kimvoid
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon KimconvertDevpathToDevlink(PSMHBA_TARGETMAPPING mappings)
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim{
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim const char ROUTINE[] = "convertDevpathToLink";
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim di_devlink_handle_t hdl;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim walk_devlink_t warg;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim int j;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim char *minor_path, *devlinkp;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if ((hdl = di_devlink_init(NULL, 0)) == NULL) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim log(LOG_DEBUG, ROUTINE, "di_devlink failed: errno:%d",
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim strerror(errno));
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim return;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim for (j = 0; j < mappings->NumberOfEntries; j++) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (strchr(mappings->entry[j].ScsiId.OSDeviceName, ':')) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim /* search link for minor node */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim minor_path = mappings->entry[j].ScsiId.OSDeviceName;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (strstr(minor_path, "/devices") != NULL) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim minor_path = mappings->entry[j].ScsiId.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim OSDeviceName + strlen("/devices");
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim warg.path = NULL;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim } else {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim minor_path = NULL;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (strstr(mappings->entry[j].ScsiId.OSDeviceName,
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim "/devices") != NULL) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim warg.len = strlen(mappings->entry[j].ScsiId.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim OSDeviceName) - strlen("/devices");
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim warg.path = mappings->entry[j].
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim ScsiId.OSDeviceName + strlen("/devices");
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim } else {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim warg.len = strlen(mappings->entry[j].ScsiId.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim OSDeviceName);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim warg.path = mappings->entry[j].ScsiId.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim OSDeviceName;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim devlinkp = NULL;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim warg.linkpp = &devlinkp;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim (void) di_devlink_walk(hdl, NULL, minor_path, DI_PRIMARY_LINK,
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim (void *)&warg, get_devlink);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (devlinkp != NULL) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim (void) snprintf(mappings->entry[j].ScsiId.OSDeviceName,
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim sizeof (mappings->entry[j].ScsiId.OSDeviceName),
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim "%s", devlinkp);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim free(devlinkp);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim (void) di_devlink_fini(&hdl);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim}
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim/*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Finds controller path for a give device path.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim *
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Return value: /dev link for dir and minor name.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kimstatic HBA_STATUS
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon KimlookupLink(char *path, char *link, const char *dir, const char *mname)
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim{
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim const char ROUTINE[] = "lookupLink";
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim DIR *dp;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim char buf[MAXPATHLEN];
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim char node[MAXPATHLEN];
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim char *charptr;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim struct dirent *newdirp, *dirp;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim ssize_t count;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim int dirplen;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim char *subpath;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim char tmpPath[MAXPATHLEN];
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if ((dp = opendir(dir)) == NULL) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim log(LOG_DEBUG, ROUTINE,
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim "Unable to open %s to find controller number.", dir);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim return (HBA_STATUS_ERROR);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (link == NULL) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim log(LOG_DEBUG, ROUTINE,
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim "Invalid argument for storing the link.");
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim return (HBA_STATUS_ERROR);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim /*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * dirplen is large enough to fit the largest path-
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * struct dirent includes one byte (the terminator)
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * so we don't add 1 to the calculation here.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim dirplen = pathconf(dir, _PC_NAME_MAX);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim dirplen = ((dirplen <= 0) ? MAXNAMELEN : dirplen) +
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim sizeof (struct dirent);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim dirp = (struct dirent *)malloc(dirplen);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (dirp == NULL) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim OUT_OF_MEMORY(ROUTINE);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim return (HBA_STATUS_ERROR);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim while ((readdir_r(dp, dirp, &newdirp)) == 0 && newdirp != NULL) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (strcmp(dirp->d_name, ".") == 0 ||
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim strcmp(dirp->d_name, "..") == 0) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim continue;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim /*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * set to another pointer since dirp->d_name length is 1
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * that will store only the first char 'c' from the name.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim charptr = dirp->d_name;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim (void) snprintf(node, strlen(charptr) + strlen(dir) + 2,
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim "%s/%s", dir, charptr);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (count = readlink(node, buf, sizeof (buf))) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim subpath = NULL;
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim subpath = strstr(buf, path);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim buf[count] = '\0';
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (subpath != NULL) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim (void) strlcpy(tmpPath, path, MAXPATHLEN);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim (void) strlcat(tmpPath, mname, MAXPATHLEN);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim /*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * if device path has substring of path
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * and exactally matching with :scsi suffix
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim if (strcmp(subpath, tmpPath) == 0) {
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim (void) strlcpy(link, node, MAXPATHLEN);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim (void) closedir(dp);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim S_FREE(dirp);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim return (HBA_STATUS_OK);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim }
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim (void) closedir(dp);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim S_FREE(dirp);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim return (HBA_STATUS_ERROR);
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim}
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim/*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Finds controller path for a give device path.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim *
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Return vale:i smp devlink.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon KimHBA_STATUS
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon KimlookupControllerLink(char *path, char *link)
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim{
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim const char dir[] = "/dev/cfg";
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim const char mname[] = ":scsi";
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim return (lookupLink(path, link, dir, mname));
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim}
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim/*
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Finds smp devlink for a give smp path.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim *
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim * Return vale: smp devlink.
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim */
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon KimHBA_STATUS
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon KimlookupSMPLink(char *path, char *link)
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim{
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim const char dir[] = "/dev/smp";
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim const char mname[] = ":smp";
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim return (lookupLink(path, link, dir, mname));
9e86db79b7d1bbc5f2f04e99954cbd5eae0e22bbHyon Kim}