1*9e86db79SHyon Kim /* 2*9e86db79SHyon Kim * CDDL HEADER START 3*9e86db79SHyon Kim * 4*9e86db79SHyon Kim * The contents of this file are subject to the terms of the 5*9e86db79SHyon Kim * Common Development and Distribution License (the "License"). 6*9e86db79SHyon Kim * You may not use this file except in compliance with the License. 7*9e86db79SHyon Kim * 8*9e86db79SHyon Kim * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*9e86db79SHyon Kim * or http://www.opensolaris.org/os/licensing. 10*9e86db79SHyon Kim * See the License for the specific language governing permissions 11*9e86db79SHyon Kim * and limitations under the License. 12*9e86db79SHyon Kim * 13*9e86db79SHyon Kim * When distributing Covered Code, include this CDDL HEADER in each 14*9e86db79SHyon Kim * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*9e86db79SHyon Kim * If applicable, add the following below this CDDL HEADER, with the 16*9e86db79SHyon Kim * fields enclosed by brackets "[]" replaced with your own identifying 17*9e86db79SHyon Kim * information: Portions Copyright [yyyy] [name of copyright owner] 18*9e86db79SHyon Kim * 19*9e86db79SHyon Kim * CDDL HEADER END 20*9e86db79SHyon Kim */ 21*9e86db79SHyon Kim 22*9e86db79SHyon Kim /* 23*9e86db79SHyon Kim * Copyright 2009 Sun Microsystems, Inc. All rights reserved. 24*9e86db79SHyon Kim * Use is subject to license terms. 25*9e86db79SHyon Kim */ 26*9e86db79SHyon Kim 27*9e86db79SHyon Kim #include <sun_sas.h> 28*9e86db79SHyon Kim 29*9e86db79SHyon Kim /* 30*9e86db79SHyon Kim * Retrieves the attributes for a specified port of an adapter 31*9e86db79SHyon Kim */ 32*9e86db79SHyon Kim HBA_STATUS 33*9e86db79SHyon Kim Sun_sasGetAdapterPortAttributes(HBA_HANDLE handle, 34*9e86db79SHyon Kim HBA_UINT32 port, PSMHBA_PORTATTRIBUTES attributes) { 35*9e86db79SHyon Kim const char ROUTINE[] = "Sun_sasGetAdapterPortAttributes"; 36*9e86db79SHyon Kim HBA_STATUS status; 37*9e86db79SHyon Kim struct sun_sas_hba *hba_ptr; 38*9e86db79SHyon Kim struct sun_sas_port *hba_port_ptr; 39*9e86db79SHyon Kim int index; 40*9e86db79SHyon Kim 41*9e86db79SHyon Kim /* Validate the arguments */ 42*9e86db79SHyon Kim if ((attributes == NULL) || 43*9e86db79SHyon Kim (attributes->PortSpecificAttribute.SASPort == NULL)) { 44*9e86db79SHyon Kim log(LOG_DEBUG, ROUTINE, "NULL attributes"); 45*9e86db79SHyon Kim return (HBA_STATUS_ERROR_ARG); 46*9e86db79SHyon Kim } 47*9e86db79SHyon Kim 48*9e86db79SHyon Kim lock(&all_hbas_lock); 49*9e86db79SHyon Kim index = RetrieveIndex(handle); 50*9e86db79SHyon Kim lock(&open_handles_lock); 51*9e86db79SHyon Kim hba_ptr = RetrieveHandle(index); 52*9e86db79SHyon Kim if (hba_ptr == NULL) { 53*9e86db79SHyon Kim log(LOG_DEBUG, ROUTINE, "Invalid handle %08lx", handle); 54*9e86db79SHyon Kim unlock(&open_handles_lock); 55*9e86db79SHyon Kim unlock(&all_hbas_lock); 56*9e86db79SHyon Kim return (HBA_STATUS_ERROR_INVALID_HANDLE); 57*9e86db79SHyon Kim } 58*9e86db79SHyon Kim 59*9e86db79SHyon Kim /* Check for stale data */ 60*9e86db79SHyon Kim status = verifyAdapter(hba_ptr); 61*9e86db79SHyon Kim if (status != HBA_STATUS_OK) { 62*9e86db79SHyon Kim log(LOG_DEBUG, ROUTINE, "Verify Adapter failed"); 63*9e86db79SHyon Kim unlock(&open_handles_lock); 64*9e86db79SHyon Kim unlock(&all_hbas_lock); 65*9e86db79SHyon Kim return (status); 66*9e86db79SHyon Kim } 67*9e86db79SHyon Kim 68*9e86db79SHyon Kim if (hba_ptr->first_port == NULL) { 69*9e86db79SHyon Kim /* This is probably an internal failure of the library */ 70*9e86db79SHyon Kim if (hba_ptr->device_path) { 71*9e86db79SHyon Kim log(LOG_DEBUG, ROUTINE, 72*9e86db79SHyon Kim "Internal failure: Adapter %s contains no port data", 73*9e86db79SHyon Kim hba_ptr->device_path); 74*9e86db79SHyon Kim } else { 75*9e86db79SHyon Kim log(LOG_DEBUG, ROUTINE, 76*9e86db79SHyon Kim "Internal failure: Adapter at index %d contains no port " 77*9e86db79SHyon Kim "data", hba_ptr->index); 78*9e86db79SHyon Kim } 79*9e86db79SHyon Kim unlock(&open_handles_lock); 80*9e86db79SHyon Kim unlock(&all_hbas_lock); 81*9e86db79SHyon Kim return (HBA_STATUS_ERROR); 82*9e86db79SHyon Kim } 83*9e86db79SHyon Kim for (hba_port_ptr = hba_ptr->first_port; 84*9e86db79SHyon Kim hba_port_ptr != NULL; hba_port_ptr = hba_port_ptr->next) { 85*9e86db79SHyon Kim if (hba_port_ptr->index == port) { 86*9e86db79SHyon Kim break; 87*9e86db79SHyon Kim } 88*9e86db79SHyon Kim } 89*9e86db79SHyon Kim if (hba_port_ptr == NULL || hba_port_ptr->index != port) { 90*9e86db79SHyon Kim log(LOG_DEBUG, ROUTINE, 91*9e86db79SHyon Kim "Invalid port index %d for handle %08lx.", 92*9e86db79SHyon Kim port, handle); 93*9e86db79SHyon Kim unlock(&open_handles_lock); 94*9e86db79SHyon Kim unlock(&all_hbas_lock); 95*9e86db79SHyon Kim return (HBA_STATUS_ERROR_ILLEGAL_INDEX); 96*9e86db79SHyon Kim } 97*9e86db79SHyon Kim 98*9e86db79SHyon Kim attributes->PortType = hba_port_ptr->port_attributes.PortType; 99*9e86db79SHyon Kim attributes->PortState = hba_port_ptr->port_attributes.PortState; 100*9e86db79SHyon Kim (void) strlcpy(attributes->OSDeviceName, 101*9e86db79SHyon Kim hba_port_ptr->port_attributes.OSDeviceName, 102*9e86db79SHyon Kim sizeof (attributes->OSDeviceName)); 103*9e86db79SHyon Kim (void) memcpy(attributes->PortSpecificAttribute.SASPort, 104*9e86db79SHyon Kim hba_port_ptr->port_attributes.PortSpecificAttribute.SASPort, 105*9e86db79SHyon Kim sizeof (struct SMHBA_SAS_Port)); 106*9e86db79SHyon Kim 107*9e86db79SHyon Kim unlock(&open_handles_lock); 108*9e86db79SHyon Kim unlock(&all_hbas_lock); 109*9e86db79SHyon Kim 110*9e86db79SHyon Kim return (HBA_STATUS_OK); 111*9e86db79SHyon Kim } 112