1fcf3ce44SJohn Forte /* 2fcf3ce44SJohn Forte * CDDL HEADER START 3fcf3ce44SJohn Forte * 4fcf3ce44SJohn Forte * The contents of this file are subject to the terms of the 5fcf3ce44SJohn Forte * Common Development and Distribution License (the "License"). 6fcf3ce44SJohn Forte * You may not use this file except in compliance with the License. 7fcf3ce44SJohn Forte * 8fcf3ce44SJohn Forte * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9fcf3ce44SJohn Forte * or http://www.opensolaris.org/os/licensing. 10fcf3ce44SJohn Forte * See the License for the specific language governing permissions 11fcf3ce44SJohn Forte * and limitations under the License. 12fcf3ce44SJohn Forte * 13fcf3ce44SJohn Forte * When distributing Covered Code, include this CDDL HEADER in each 14fcf3ce44SJohn Forte * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15fcf3ce44SJohn Forte * If applicable, add the following below this CDDL HEADER, with the 16fcf3ce44SJohn Forte * fields enclosed by brackets "[]" replaced with your own identifying 17fcf3ce44SJohn Forte * information: Portions Copyright [yyyy] [name of copyright owner] 18fcf3ce44SJohn Forte * 19fcf3ce44SJohn Forte * CDDL HEADER END 20fcf3ce44SJohn Forte */ 21fcf3ce44SJohn Forte /* 22fcf3ce44SJohn Forte * Copyright 2008 Sun Microsystems, Inc. All rights reserved. 23fcf3ce44SJohn Forte * Use is subject to license terms. 24fcf3ce44SJohn Forte */ 25fcf3ce44SJohn Forte 26fcf3ce44SJohn Forte 27fcf3ce44SJohn Forte 28fcf3ce44SJohn Forte #include "HBAList.h" 29fcf3ce44SJohn Forte #include "Trace.h" 30fcf3ce44SJohn Forte #include "Exceptions.h" 31*f3aaec0aSRichard Lowe #include <cstring> 32*f3aaec0aSRichard Lowe 33fcf3ce44SJohn Forte #ifdef __cplusplus 34fcf3ce44SJohn Forte extern "C" { 35fcf3ce44SJohn Forte #endif 36fcf3ce44SJohn Forte 37fcf3ce44SJohn Forte /** 38fcf3ce44SJohn Forte * @memo Get the adapters name 39fcf3ce44SJohn Forte * @precondition name parameter must be sufficient length to fit the name 40fcf3ce44SJohn Forte * @postcondition name contains the name of the given adapter 41fcf3ce44SJohn Forte * @return HBA_STATUS_OK on success, or other error code 42fcf3ce44SJohn Forte * @param index the index to which adapter to retrieve the name 43fcf3ce44SJohn Forte * @param name buffer to which the adapter name will be placed 44fcf3ce44SJohn Forte * 45fcf3ce44SJohn Forte * @doc 46fcf3ce44SJohn Forte * Returns the text string which describes this adapter and which is used to 47fcf3ce44SJohn Forte * open the adapter with the library. 48fcf3ce44SJohn Forte */ Sun_fcGetTgtAdapterName(HBA_UINT32 index,char * name)49fcf3ce44SJohn ForteHBA_STATUS Sun_fcGetTgtAdapterName(HBA_UINT32 index, char *name) { 50fcf3ce44SJohn Forte Trace log("Sun_fcGetTgtAdapterName"); 51fcf3ce44SJohn Forte if (name == NULL) { 52fcf3ce44SJohn Forte log.userError( 53fcf3ce44SJohn Forte "NULL name pointer"); 54fcf3ce44SJohn Forte return (HBA_STATUS_ERROR_ARG); 55fcf3ce44SJohn Forte } 56fcf3ce44SJohn Forte try { 57fcf3ce44SJohn Forte HBAList* list = HBAList::instance(); 58fcf3ce44SJohn Forte std::string sname = list->getTgtHBAName(index); 59fcf3ce44SJohn Forte strcpy(name, sname.c_str()); 60fcf3ce44SJohn Forte return (HBA_STATUS_OK); 61fcf3ce44SJohn Forte } catch (HBAException &e) { 62fcf3ce44SJohn Forte return (e.getErrorCode()); 63fcf3ce44SJohn Forte } catch (...) { 64fcf3ce44SJohn Forte log.internalError( 65fcf3ce44SJohn Forte "Uncaught exception"); 66fcf3ce44SJohn Forte return (HBA_STATUS_ERROR); 67fcf3ce44SJohn Forte } 68fcf3ce44SJohn Forte } 69fcf3ce44SJohn Forte 70fcf3ce44SJohn Forte #ifdef __cplusplus 71fcf3ce44SJohn Forte } 72fcf3ce44SJohn Forte #endif 73