• Home
  • History
  • Annotate
  • Line#
  • Navigate
  • Raw
  • Download
  • only in /asuswrt-rt-n18u-9.0.0.4.380.2695/release/src-rt-6.x.4708/linux/linux-2.6.36/drivers/scsi/lpfc/
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
34#define LPFC_BSG_VENDOR_MENLO_CMD	8
35#define LPFC_BSG_VENDOR_MENLO_DATA	9
36
37struct 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
44struct get_ct_event {
45	uint32_t command;
46	uint32_t ev_reg_id;
47	uint32_t ev_req_id;
48};
49
50struct get_ct_event_reply {
51	uint32_t immed_data;
52	uint32_t type;
53};
54
55struct 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
64struct diag_mode_set {
65	uint32_t command;
66	uint32_t type;
67	uint32_t timeout;
68};
69
70struct diag_mode_test {
71	uint32_t command;
72};
73
74#define LPFC_WWNN_TYPE		0
75#define LPFC_WWPN_TYPE		1
76
77struct 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 */
85struct MgmtRevInfo {
86	uint32_t a_Major;
87	uint32_t a_Minor;
88};
89
90struct get_mgmt_rev_reply {
91	struct MgmtRevInfo info;
92};
93
94#define BSG_MBOX_SIZE 4096 /* mailbox command plus extended data */
95struct dfc_mbox_req {
96	uint32_t command;
97	uint32_t mbOffset;
98	uint32_t inExtWLen;
99	uint32_t outExtWLen;
100};
101
102/* Used for menlo command or menlo data. The xri is only used for menlo data */
103struct menlo_command {
104	uint32_t cmd;
105	uint32_t xri;
106};
107
108struct menlo_response {
109	uint32_t xri; /* return the xri of the iocb exchange */
110};
111