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_fcGetAdapterName(HBA_UINT32 index,char * name)49fcf3ce44SJohn Forte HBA_STATUS Sun_fcGetAdapterName(HBA_UINT32 index, char *name) {
50fcf3ce44SJohn Forte 	Trace log("Sun_fcGetAdapterName");
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->getHBAName(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