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