1*7836SJohn.Forte@Sun.COM /* 2*7836SJohn.Forte@Sun.COM * CDDL HEADER START 3*7836SJohn.Forte@Sun.COM * 4*7836SJohn.Forte@Sun.COM * The contents of this file are subject to the terms of the 5*7836SJohn.Forte@Sun.COM * Common Development and Distribution License (the "License"). 6*7836SJohn.Forte@Sun.COM * You may not use this file except in compliance with the License. 7*7836SJohn.Forte@Sun.COM * 8*7836SJohn.Forte@Sun.COM * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*7836SJohn.Forte@Sun.COM * or http://www.opensolaris.org/os/licensing. 10*7836SJohn.Forte@Sun.COM * See the License for the specific language governing permissions 11*7836SJohn.Forte@Sun.COM * and limitations under the License. 12*7836SJohn.Forte@Sun.COM * 13*7836SJohn.Forte@Sun.COM * When distributing Covered Code, include this CDDL HEADER in each 14*7836SJohn.Forte@Sun.COM * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*7836SJohn.Forte@Sun.COM * If applicable, add the following below this CDDL HEADER, with the 16*7836SJohn.Forte@Sun.COM * fields enclosed by brackets "[]" replaced with your own identifying 17*7836SJohn.Forte@Sun.COM * information: Portions Copyright [yyyy] [name of copyright owner] 18*7836SJohn.Forte@Sun.COM * 19*7836SJohn.Forte@Sun.COM * CDDL HEADER END 20*7836SJohn.Forte@Sun.COM */ 21*7836SJohn.Forte@Sun.COM /* 22*7836SJohn.Forte@Sun.COM * Copyright 2008 Sun Microsystems, Inc. All rights reserved. 23*7836SJohn.Forte@Sun.COM * Use is subject to license terms. 24*7836SJohn.Forte@Sun.COM */ 25*7836SJohn.Forte@Sun.COM 26*7836SJohn.Forte@Sun.COM 27*7836SJohn.Forte@Sun.COM 28*7836SJohn.Forte@Sun.COM #include "Handle.h" 29*7836SJohn.Forte@Sun.COM #include "HandlePort.h" 30*7836SJohn.Forte@Sun.COM #include "Trace.h" 31*7836SJohn.Forte@Sun.COM #include "Exceptions.h" 32*7836SJohn.Forte@Sun.COM #ifdef __cplusplus 33*7836SJohn.Forte@Sun.COM extern "C" { 34*7836SJohn.Forte@Sun.COM #endif 35*7836SJohn.Forte@Sun.COM 36*7836SJohn.Forte@Sun.COM /** 37*7836SJohn.Forte@Sun.COM * @memo Retrieves the attributes for a specified port of an adapter 38*7836SJohn.Forte@Sun.COM * @precondition Library is loaded 39*7836SJohn.Forte@Sun.COM * @return HBA_STATUS_OK if attributes were filled in 40*7836SJohn.Forte@Sun.COM * @param handle The desired HBA 41*7836SJohn.Forte@Sun.COM * @param port The desired HBA port 42*7836SJohn.Forte@Sun.COM * @param attributes The user-allocated buffer to store results in 43*7836SJohn.Forte@Sun.COM * 44*7836SJohn.Forte@Sun.COM */ Sun_fcGetAdapterPortAttributes(HBA_HANDLE handle,HBA_UINT32 port,PHBA_PORTATTRIBUTES attributes)45*7836SJohn.Forte@Sun.COMHBA_STATUS Sun_fcGetAdapterPortAttributes(HBA_HANDLE handle, 46*7836SJohn.Forte@Sun.COM HBA_UINT32 port, PHBA_PORTATTRIBUTES attributes) { 47*7836SJohn.Forte@Sun.COM Trace log("Sun_fcGetAdapterPortAttributes"); 48*7836SJohn.Forte@Sun.COM 49*7836SJohn.Forte@Sun.COM if (attributes == NULL) { 50*7836SJohn.Forte@Sun.COM log.userError( 51*7836SJohn.Forte@Sun.COM "NULL attributes pointer"); 52*7836SJohn.Forte@Sun.COM return (HBA_STATUS_ERROR_ARG); 53*7836SJohn.Forte@Sun.COM } 54*7836SJohn.Forte@Sun.COM 55*7836SJohn.Forte@Sun.COM try { 56*7836SJohn.Forte@Sun.COM Handle *myHandle = Handle::findHandle(handle); 57*7836SJohn.Forte@Sun.COM HandlePort *myPort = myHandle->getHandlePortByIndex(port); 58*7836SJohn.Forte@Sun.COM *attributes = myPort->getPortAttributes(); 59*7836SJohn.Forte@Sun.COM return (HBA_STATUS_OK); 60*7836SJohn.Forte@Sun.COM } catch (HBAException &e) { 61*7836SJohn.Forte@Sun.COM return (e.getErrorCode()); 62*7836SJohn.Forte@Sun.COM } catch (...) { 63*7836SJohn.Forte@Sun.COM log.internalError( 64*7836SJohn.Forte@Sun.COM "Uncaught exception"); 65*7836SJohn.Forte@Sun.COM return (HBA_STATUS_ERROR); 66*7836SJohn.Forte@Sun.COM } 67*7836SJohn.Forte@Sun.COM } 68*7836SJohn.Forte@Sun.COM #ifdef __cplusplus 69*7836SJohn.Forte@Sun.COM } 70*7836SJohn.Forte@Sun.COM #endif 71