| James Smart | c79c129 | 2010-01-26 23:09:22 -0500 | [diff] [blame] | 1 | /******************************************************************* | 
|  | 2 | * This file is part of the Emulex Linux Device Driver for         * | 
|  | 3 | * Fibre Channel Host Bus Adapters.                                * | 
|  | 4 | * Copyright (C) 2010 Emulex.  All rights reserved.                * | 
|  | 5 | * EMULEX and SLI are trademarks of Emulex.                        * | 
|  | 6 | * www.emulex.com                                                  * | 
|  | 7 | *                                                                 * | 
|  | 8 | * This program is free software; you can redistribute it and/or   * | 
|  | 9 | * modify it under the terms of version 2 of the GNU General       * | 
|  | 10 | * Public License as published by the Free Software Foundation.    * | 
|  | 11 | * This program is distributed in the hope that it will be useful. * | 
|  | 12 | * ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND          * | 
|  | 13 | * WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY,  * | 
|  | 14 | * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT, ARE      * | 
|  | 15 | * DISCLAIMED, EXCEPT TO THE EXTENT THAT SUCH DISCLAIMERS ARE HELD * | 
|  | 16 | * TO BE LEGALLY INVALID.  See the GNU General Public License for  * | 
|  | 17 | * more details, a copy of which can be found in the file COPYING  * | 
|  | 18 | * included with this package.                                     * | 
|  | 19 | *******************************************************************/ | 
|  | 20 | /* bsg definitions | 
|  | 21 | * No pointers to user data are allowed, all application buffers and sizes will | 
|  | 22 | * derived through the bsg interface. | 
|  | 23 | * | 
|  | 24 | * These are the vendor unique structures passed in using the bsg | 
|  | 25 | * FC_BSG_HST_VENDOR message code type. | 
|  | 26 | */ | 
|  | 27 | #define LPFC_BSG_VENDOR_SET_CT_EVENT	1 | 
|  | 28 | #define LPFC_BSG_VENDOR_GET_CT_EVENT	2 | 
|  | 29 | #define LPFC_BSG_VENDOR_SEND_MGMT_RESP	3 | 
|  | 30 | #define LPFC_BSG_VENDOR_DIAG_MODE	4 | 
|  | 31 | #define LPFC_BSG_VENDOR_DIAG_TEST	5 | 
|  | 32 | #define LPFC_BSG_VENDOR_GET_MGMT_REV	6 | 
|  | 33 | #define LPFC_BSG_VENDOR_MBOX		7 | 
| James Smart | e2aed29 | 2010-02-26 14:15:00 -0500 | [diff] [blame] | 34 | #define LPFC_BSG_VENDOR_MENLO_CMD	8 | 
|  | 35 | #define LPFC_BSG_VENDOR_MENLO_DATA	9 | 
| James Smart | c79c129 | 2010-01-26 23:09:22 -0500 | [diff] [blame] | 36 |  | 
|  | 37 | struct set_ct_event { | 
|  | 38 | uint32_t command; | 
|  | 39 | uint32_t type_mask; | 
|  | 40 | uint32_t ev_req_id; | 
|  | 41 | uint32_t ev_reg_id; | 
|  | 42 | }; | 
|  | 43 |  | 
|  | 44 | struct get_ct_event { | 
|  | 45 | uint32_t command; | 
|  | 46 | uint32_t ev_reg_id; | 
|  | 47 | uint32_t ev_req_id; | 
|  | 48 | }; | 
|  | 49 |  | 
|  | 50 | struct get_ct_event_reply { | 
|  | 51 | uint32_t immed_data; | 
|  | 52 | uint32_t type; | 
|  | 53 | }; | 
|  | 54 |  | 
|  | 55 | struct send_mgmt_resp { | 
|  | 56 | uint32_t command; | 
|  | 57 | uint32_t tag; | 
|  | 58 | }; | 
|  | 59 |  | 
|  | 60 |  | 
|  | 61 | #define INTERNAL_LOOP_BACK 0x1 /* adapter short cuts the loop internally */ | 
|  | 62 | #define EXTERNAL_LOOP_BACK 0x2 /* requires an external loopback plug */ | 
|  | 63 |  | 
|  | 64 | struct diag_mode_set { | 
|  | 65 | uint32_t command; | 
|  | 66 | uint32_t type; | 
|  | 67 | uint32_t timeout; | 
|  | 68 | }; | 
|  | 69 |  | 
|  | 70 | struct diag_mode_test { | 
|  | 71 | uint32_t command; | 
|  | 72 | }; | 
|  | 73 |  | 
|  | 74 | #define LPFC_WWNN_TYPE		0 | 
|  | 75 | #define LPFC_WWPN_TYPE		1 | 
|  | 76 |  | 
|  | 77 | struct get_mgmt_rev { | 
|  | 78 | uint32_t command; | 
|  | 79 | }; | 
|  | 80 |  | 
|  | 81 | #define MANAGEMENT_MAJOR_REV   1 | 
|  | 82 | #define MANAGEMENT_MINOR_REV   0 | 
|  | 83 |  | 
|  | 84 | /* the MgmtRevInfo structure */ | 
|  | 85 | struct MgmtRevInfo { | 
|  | 86 | uint32_t a_Major; | 
|  | 87 | uint32_t a_Minor; | 
|  | 88 | }; | 
|  | 89 |  | 
|  | 90 | struct get_mgmt_rev_reply { | 
|  | 91 | struct MgmtRevInfo info; | 
|  | 92 | }; | 
|  | 93 |  | 
| James Smart | 49198b3 | 2010-04-06 15:04:33 -0400 | [diff] [blame] | 94 | #define BSG_MBOX_SIZE 4096 /* mailbox command plus extended data */ | 
| James Smart | c79c129 | 2010-01-26 23:09:22 -0500 | [diff] [blame] | 95 | struct dfc_mbox_req { | 
|  | 96 | uint32_t command; | 
| James Smart | 7a47027 | 2010-03-15 11:25:20 -0400 | [diff] [blame] | 97 | uint32_t mbOffset; | 
| James Smart | c79c129 | 2010-01-26 23:09:22 -0500 | [diff] [blame] | 98 | uint32_t inExtWLen; | 
| James Smart | c749593 | 2010-04-06 15:05:28 -0400 | [diff] [blame] | 99 | uint32_t outExtWLen; | 
| James Smart | c79c129 | 2010-01-26 23:09:22 -0500 | [diff] [blame] | 100 | }; | 
|  | 101 |  | 
| James Smart | e2aed29 | 2010-02-26 14:15:00 -0500 | [diff] [blame] | 102 | /* Used for menlo command or menlo data. The xri is only used for menlo data */ | 
|  | 103 | struct menlo_command { | 
|  | 104 | uint32_t cmd; | 
|  | 105 | uint32_t xri; | 
|  | 106 | }; | 
|  | 107 |  | 
|  | 108 | struct menlo_response { | 
|  | 109 | uint32_t xri; /* return the xri of the iocb exchange */ | 
|  | 110 | }; | 
|  | 111 |  |