dmake: do not set MAKEFLAGS=k
[unleashed/tickless.git] / usr / src / lib / sun_fc / common / HBANPIVPort.cc
blob42c89ab3fa5174a06929679fe2fe9b0dcc0062e2
1 /*
2 * CDDL HEADER START
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
19 * CDDL HEADER END
22 * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
27 #include "HBANPIVPort.h"
28 #include "Exceptions.h"
29 #include "Trace.h"
30 #include <iostream>
31 #include <iomanip>
32 #include <cerrno>
33 #include <cstring>
34 #include <sys/types.h>
35 #include <sys/mkdev.h>
36 #include <sys/stat.h>
37 #include <fcntl.h>
38 #include <unistd.h>
39 #include <stropts.h>
40 #include <dirent.h>
41 #include <libdevinfo.h>
43 using namespace std;
46 /**
47 * @memo Construct a new deafult HBA Port
48 * @version 1.7
50 HBANPIVPort::HBANPIVPort() {
53 /**
54 * @memo Compare two HBA ports for equality
55 * @return TRUE if both ports are the same
56 * @return FALSE if the ports are different
57 * @version 1.7
59 * @doc Comparison is based on Node WWN, Port WWN and path
61 bool HBANPIVPort::operator==(HBANPIVPort &comp) {
62 return (this->getPortWWN() == comp.getPortWWN() &&
63 this->getNodeWWN() == comp.getNodeWWN());
67 * Finds controller path for a give device path.
69 * Return vale: controller path.
71 string HBANPIVPort::lookupControllerPath(string path) {
72 Trace log("lookupControllerPath");
73 DIR *dp;
74 char buf[MAXPATHLEN];
75 char node[MAXPATHLEN];
76 struct dirent **dirpp, *dirp;
77 const char dir[] = "/dev/cfg";
78 ssize_t count;
79 uchar_t *dir_buf = new uchar_t[sizeof (struct dirent) + MAXPATHLEN];
81 if ((dp = opendir(dir)) == NULL) {
82 string tmp = "Unable to open ";
83 tmp += dir;
84 tmp += "to find controller number.";
85 delete (dir_buf);
86 throw IOError(tmp);
89 dirp = (struct dirent *) dir_buf;
90 dirpp = &dirp;
91 while ((readdir_r(dp, dirp, dirpp)) == 0 && dirp != NULL) {
92 if (strcmp(dirp->d_name, ".") == 0 ||
93 strcmp(dirp->d_name, "..") == 0) {
94 continue;
96 sprintf(node, "%s/%s", dir, dirp->d_name);
97 if ((count = readlink(node,buf,sizeof(buf)))) {
98 buf[count] = '\0';
99 if (strstr(buf, path.c_str())) {
100 string cfg_path = dir;
101 cfg_path += "/";
102 cfg_path += dirp->d_name;
103 closedir(dp);
104 delete (dir_buf);
105 return (cfg_path);
110 closedir(dp);
111 delete (dir_buf);
112 throw InternalError("Unable to find controller path");