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 "Trace.h"
29fcf3ce44SJohn Forte #include "Exceptions.h"
30fcf3ce44SJohn Forte #include "sun_fc.h"
31fcf3ce44SJohn Forte #ifdef __cplusplus
32fcf3ce44SJohn Forte extern "C" {
33fcf3ce44SJohn Forte #endif
34fcf3ce44SJohn Forte
35fcf3ce44SJohn Forte /**
36fcf3ce44SJohn Forte * @memo Send ELS LIRR command out on the wire
37fcf3ce44SJohn Forte * @return HBA_STATUS_OK or error code
38fcf3ce44SJohn Forte * @param handle The HBA to operate on
39fcf3ce44SJohn Forte * @param hbaPortWWN Identifies the HBA port to use
40fcf3ce44SJohn Forte * @param destWWN The target to send the command to
41fcf3ce44SJohn Forte * @param function ???
42fcf3ce44SJohn Forte * @param type ???
43fcf3ce44SJohn Forte * @param pRspBuffer The user-allocated response buffer
44fcf3ce44SJohn Forte * @param pRspBufferSize The size of user-allocated response buffer
45fcf3ce44SJohn Forte */
Sun_fcSendLIRR(HBA_HANDLE handle,HBA_WWN hbaPortWWN,HBA_WWN destWWN,HBA_UINT8 function,HBA_UINT8 type,void * pRspBuffer,HBA_UINT32 * pRspBufferSize)46fcf3ce44SJohn Forte HBA_STATUS Sun_fcSendLIRR(HBA_HANDLE handle,
47fcf3ce44SJohn Forte HBA_WWN hbaPortWWN,
48fcf3ce44SJohn Forte HBA_WWN destWWN,
49fcf3ce44SJohn Forte HBA_UINT8 function,
50fcf3ce44SJohn Forte HBA_UINT8 type,
51fcf3ce44SJohn Forte void *pRspBuffer,
52fcf3ce44SJohn Forte HBA_UINT32 *pRspBufferSize) {
53fcf3ce44SJohn Forte Trace log("Sun_fcSendLIRR");
54fcf3ce44SJohn Forte try {
55fcf3ce44SJohn Forte Handle *myHandle = Handle::findHandle(handle);
56fcf3ce44SJohn Forte HBA *hba = myHandle->getHBA();
57fcf3ce44SJohn Forte HBAPort *port = hba->getPort(wwnConversion(hbaPortWWN.wwn));
58*cd6904adSToomas Soome port->sendLIRR(wwnConversion(destWWN.wwn), function, type,
59*cd6904adSToomas Soome pRspBuffer, pRspBufferSize);
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 #ifdef __cplusplus
70fcf3ce44SJohn Forte }
71fcf3ce44SJohn Forte #endif
72