[SCSI] bfa: Serialize the IOC hw semaphore unlock logic.
[GitHub/mt8127/android_kernel_alcatel_ttab.git] / drivers / scsi / bfa / bfad_bsg.h
CommitLineData
b85daafe
KG
1/*
2 * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
3 * All rights reserved
4 * www.brocade.com
5 *
6 * Linux driver for Brocade Fibre Channel Host Bus Adapter.
7 *
8 * This program is free software; you can redistribute it and/or modify it
9 * under the terms of the GNU General Public License (GPL) Version 2 as
10 * published by the Free Software Foundation
11 *
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * General Public License for more details.
16 */
17#ifndef BFAD_BSG_H
18#define BFAD_BSG_H
19
20#include "bfa_defs.h"
21#include "bfa_defs_fcs.h"
22
23/* Definitions of vendor unique structures and command codes passed in
24 * using FC_BSG_HST_VENDOR message code.
25 */
26enum {
60138066
KG
27 IOCMD_IOC_ENABLE = 0x1,
28 IOCMD_IOC_DISABLE,
29 IOCMD_IOC_GET_ATTR,
b85daafe 30 IOCMD_IOC_GET_INFO,
60138066
KG
31 IOCMD_IOC_GET_STATS,
32 IOCMD_IOC_GET_FWSTATS,
f2ee7601
KG
33 IOCMD_IOC_RESET_STATS,
34 IOCMD_IOC_RESET_FWSTATS,
35 IOCMD_IOC_SET_ADAPTER_NAME,
36 IOCMD_IOC_SET_PORT_NAME,
60138066
KG
37 IOCMD_IOCFC_GET_ATTR,
38 IOCMD_IOCFC_SET_INTR,
39 IOCMD_PORT_ENABLE,
40 IOCMD_PORT_DISABLE,
b85daafe 41 IOCMD_PORT_GET_ATTR,
60138066 42 IOCMD_PORT_GET_STATS,
f2ee7601
KG
43 IOCMD_PORT_RESET_STATS,
44 IOCMD_PORT_CFG_TOPO,
45 IOCMD_PORT_CFG_SPEED,
46 IOCMD_PORT_CFG_ALPA,
47 IOCMD_PORT_CFG_MAXFRSZ,
48 IOCMD_PORT_CLR_ALPA,
49 IOCMD_PORT_BBSC_ENABLE,
50 IOCMD_PORT_BBSC_DISABLE,
b85daafe 51 IOCMD_LPORT_GET_ATTR,
60138066
KG
52 IOCMD_LPORT_GET_RPORTS,
53 IOCMD_LPORT_GET_STATS,
f2ee7601 54 IOCMD_LPORT_RESET_STATS,
60138066
KG
55 IOCMD_LPORT_GET_IOSTATS,
56 IOCMD_RPORT_GET_ATTR,
b85daafe 57 IOCMD_RPORT_GET_ADDR,
60138066 58 IOCMD_RPORT_GET_STATS,
f2ee7601
KG
59 IOCMD_RPORT_RESET_STATS,
60 IOCMD_RPORT_SET_SPEED,
61 IOCMD_VPORT_GET_ATTR,
62 IOCMD_VPORT_GET_STATS,
63 IOCMD_VPORT_RESET_STATS,
b85daafe 64 IOCMD_FABRIC_GET_LPORTS,
f2ee7601
KG
65 IOCMD_RATELIM_ENABLE,
66 IOCMD_RATELIM_DISABLE,
67 IOCMD_RATELIM_DEF_SPEED,
68 IOCMD_FCPIM_FAILOVER,
60138066 69 IOCMD_FCPIM_MODSTATS,
f2ee7601 70 IOCMD_FCPIM_MODSTATSCLR,
60138066 71 IOCMD_FCPIM_DEL_ITN_STATS,
b85daafe 72 IOCMD_ITNIM_GET_ATTR,
60138066 73 IOCMD_ITNIM_GET_IOSTATS,
f2ee7601 74 IOCMD_ITNIM_RESET_STATS,
60138066 75 IOCMD_ITNIM_GET_ITNSTATS,
1a4d8e1b 76 IOCMD_IOC_PCIFN_CFG,
60138066
KG
77 IOCMD_FCPORT_ENABLE,
78 IOCMD_FCPORT_DISABLE,
1a4d8e1b
KG
79 IOCMD_PCIFN_CREATE,
80 IOCMD_PCIFN_DELETE,
81 IOCMD_PCIFN_BW,
82 IOCMD_ADAPTER_CFG_MODE,
83 IOCMD_PORT_CFG_MODE,
84 IOCMD_FLASH_ENABLE_OPTROM,
85 IOCMD_FLASH_DISABLE_OPTROM,
a714134a
KG
86 IOCMD_FAA_ENABLE,
87 IOCMD_FAA_DISABLE,
88 IOCMD_FAA_QUERY,
148d6103
KG
89 IOCMD_CEE_GET_ATTR,
90 IOCMD_CEE_GET_STATS,
91 IOCMD_CEE_RESET_STATS,
51e569aa
KG
92 IOCMD_SFP_MEDIA,
93 IOCMD_SFP_SPEED,
5a54b1d5
KG
94 IOCMD_FLASH_GET_ATTR,
95 IOCMD_FLASH_ERASE_PART,
96 IOCMD_FLASH_UPDATE_PART,
97 IOCMD_FLASH_READ_PART,
3d7fc66d
KG
98 IOCMD_DIAG_TEMP,
99 IOCMD_DIAG_MEMTEST,
100 IOCMD_DIAG_LOOPBACK,
101 IOCMD_DIAG_FWPING,
102 IOCMD_DIAG_QUEUETEST,
103 IOCMD_DIAG_SFP,
104 IOCMD_DIAG_LED,
105 IOCMD_DIAG_BEACON_LPORT,
106 IOCMD_DIAG_LB_STAT,
3350d98d
KG
107 IOCMD_PHY_GET_ATTR,
108 IOCMD_PHY_GET_STATS,
109 IOCMD_PHY_UPDATE_FW,
110 IOCMD_PHY_READ_FW,
61e62e21
KG
111 IOCMD_VHBA_QUERY,
112 IOCMD_DEBUG_PORTLOG,
f2ee7601
KG
113 IOCMD_DEBUG_FW_CORE,
114 IOCMD_DEBUG_FW_STATE_CLR,
115 IOCMD_DEBUG_PORTLOG_CLR,
116 IOCMD_DEBUG_START_DTRC,
117 IOCMD_DEBUG_STOP_DTRC,
118 IOCMD_DEBUG_PORTLOG_CTL,
42a8e6e2
KG
119 IOCMD_FCPIM_PROFILE_ON,
120 IOCMD_FCPIM_PROFILE_OFF,
121 IOCMD_ITNIM_GET_IOPROFILE,
37ea0558
KG
122 IOCMD_FCPORT_GET_STATS,
123 IOCMD_FCPORT_RESET_STATS,
a46bd300
KG
124 IOCMD_BOOT_CFG,
125 IOCMD_BOOT_QUERY,
126 IOCMD_PREBOOT_QUERY,
127 IOCMD_ETHBOOT_CFG,
128 IOCMD_ETHBOOT_QUERY,
45191236
KG
129 IOCMD_TRUNK_ENABLE,
130 IOCMD_TRUNK_DISABLE,
131 IOCMD_TRUNK_GET_ATTR,
3ec4f2c8
KG
132 IOCMD_QOS_ENABLE,
133 IOCMD_QOS_DISABLE,
134 IOCMD_QOS_GET_ATTR,
135 IOCMD_QOS_GET_VC_ATTR,
136 IOCMD_QOS_GET_STATS,
137 IOCMD_QOS_RESET_STATS,
c0350bf5
KG
138 IOCMD_VF_GET_STATS,
139 IOCMD_VF_RESET_STATS,
4c5d22bf
KG
140 IOCMD_FCPIM_LUNMASK_ENABLE,
141 IOCMD_FCPIM_LUNMASK_DISABLE,
142 IOCMD_FCPIM_LUNMASK_CLEAR,
143 IOCMD_FCPIM_LUNMASK_QUERY,
144 IOCMD_FCPIM_LUNMASK_ADD,
145 IOCMD_FCPIM_LUNMASK_DELETE,
1a4d8e1b
KG
146};
147
148struct bfa_bsg_gen_s {
149 bfa_status_t status;
150 u16 bfad_num;
151 u16 rsvd;
b85daafe
KG
152};
153
f2ee7601
KG
154struct bfa_bsg_portlogctl_s {
155 bfa_status_t status;
156 u16 bfad_num;
157 u16 rsvd;
158 bfa_boolean_t ctl;
159 int inst_no;
160};
161
42a8e6e2
KG
162struct bfa_bsg_fcpim_profile_s {
163 bfa_status_t status;
164 u16 bfad_num;
165 u16 rsvd;
166};
167
168struct bfa_bsg_itnim_ioprofile_s {
169 bfa_status_t status;
170 u16 bfad_num;
171 u16 vf_id;
172 wwn_t lpwwn;
173 wwn_t rpwwn;
174 struct bfa_itnim_ioprofile_s ioprofile;
175};
176
37ea0558
KG
177struct bfa_bsg_fcport_stats_s {
178 bfa_status_t status;
179 u16 bfad_num;
180 u16 rsvd;
181 union bfa_fcport_stats_u stats;
182};
183
f2ee7601
KG
184struct bfa_bsg_ioc_name_s {
185 bfa_status_t status;
186 u16 bfad_num;
187 u16 rsvd;
188 char name[BFA_ADAPTER_SYM_NAME_LEN];
189};
190
b85daafe
KG
191struct bfa_bsg_ioc_info_s {
192 bfa_status_t status;
193 u16 bfad_num;
194 u16 rsvd;
195 char serialnum[64];
196 char hwpath[BFA_STRING_32];
197 char adapter_hwpath[BFA_STRING_32];
198 char guid[BFA_ADAPTER_SYM_NAME_LEN*2];
199 char name[BFA_ADAPTER_SYM_NAME_LEN];
200 char port_name[BFA_ADAPTER_SYM_NAME_LEN];
201 char eth_name[BFA_ADAPTER_SYM_NAME_LEN];
202 wwn_t pwwn;
203 wwn_t nwwn;
204 wwn_t factorypwwn;
205 wwn_t factorynwwn;
206 mac_t mac;
207 mac_t factory_mac; /* Factory mac address */
208 mac_t current_mac; /* Currently assigned mac address */
209 enum bfa_ioc_type_e ioc_type;
210 u16 pvid; /* Port vlan id */
211 u16 rsvd1;
212 u32 host;
213 u32 bandwidth; /* For PF support */
214 u32 rsvd2;
215};
216
217struct bfa_bsg_ioc_attr_s {
218 bfa_status_t status;
219 u16 bfad_num;
220 u16 rsvd;
221 struct bfa_ioc_attr_s ioc_attr;
222};
223
60138066
KG
224struct bfa_bsg_ioc_stats_s {
225 bfa_status_t status;
226 u16 bfad_num;
227 u16 rsvd;
228 struct bfa_ioc_stats_s ioc_stats;
229};
230
231struct bfa_bsg_ioc_fwstats_s {
232 bfa_status_t status;
233 u16 bfad_num;
234 u16 rsvd;
235 u32 buf_size;
236 u32 rsvd1;
237 u64 buf_ptr;
238};
239
240struct bfa_bsg_iocfc_attr_s {
241 bfa_status_t status;
242 u16 bfad_num;
243 u16 rsvd;
244 struct bfa_iocfc_attr_s iocfc_attr;
245};
246
247struct bfa_bsg_iocfc_intr_s {
248 bfa_status_t status;
249 u16 bfad_num;
250 u16 rsvd;
251 struct bfa_iocfc_intr_attr_s attr;
252};
253
b85daafe
KG
254struct bfa_bsg_port_attr_s {
255 bfa_status_t status;
256 u16 bfad_num;
257 u16 rsvd;
258 struct bfa_port_attr_s attr;
259};
260
f2ee7601
KG
261struct bfa_bsg_port_cfg_s {
262 bfa_status_t status;
263 u16 bfad_num;
264 u16 rsvd;
265 u32 param;
266 u32 rsvd1;
267};
268
269struct bfa_bsg_port_cfg_maxfrsize_s {
270 bfa_status_t status;
271 u16 bfad_num;
272 u16 maxfrsize;
273};
274
60138066
KG
275struct bfa_bsg_port_stats_s {
276 bfa_status_t status;
277 u16 bfad_num;
278 u16 rsvd;
279 u32 buf_size;
280 u32 rsvd1;
281 u64 buf_ptr;
282};
283
b85daafe
KG
284struct bfa_bsg_lport_attr_s {
285 bfa_status_t status;
286 u16 bfad_num;
287 u16 vf_id;
288 wwn_t pwwn;
289 struct bfa_lport_attr_s port_attr;
290};
291
60138066
KG
292struct bfa_bsg_lport_stats_s {
293 bfa_status_t status;
294 u16 bfad_num;
295 u16 vf_id;
296 wwn_t pwwn;
297 struct bfa_lport_stats_s port_stats;
298};
299
300struct bfa_bsg_lport_iostats_s {
301 bfa_status_t status;
302 u16 bfad_num;
303 u16 vf_id;
304 wwn_t pwwn;
305 struct bfa_itnim_iostats_s iostats;
306};
307
308struct bfa_bsg_lport_get_rports_s {
309 bfa_status_t status;
310 u16 bfad_num;
311 u16 vf_id;
312 wwn_t pwwn;
313 u64 rbuf_ptr;
314 u32 nrports;
315 u32 rsvd;
316};
317
318struct bfa_bsg_rport_attr_s {
319 bfa_status_t status;
320 u16 bfad_num;
321 u16 vf_id;
322 wwn_t pwwn;
323 wwn_t rpwwn;
324 struct bfa_rport_attr_s attr;
325};
326
327struct bfa_bsg_rport_stats_s {
328 bfa_status_t status;
329 u16 bfad_num;
330 u16 vf_id;
331 wwn_t pwwn;
332 wwn_t rpwwn;
333 struct bfa_rport_stats_s stats;
334};
335
b85daafe
KG
336struct bfa_bsg_rport_scsi_addr_s {
337 bfa_status_t status;
338 u16 bfad_num;
339 u16 vf_id;
340 wwn_t pwwn;
341 wwn_t rpwwn;
342 u32 host;
343 u32 bus;
344 u32 target;
345 u32 lun;
346};
347
f2ee7601
KG
348struct bfa_bsg_rport_reset_stats_s {
349 bfa_status_t status;
350 u16 bfad_num;
351 u16 vf_id;
352 wwn_t pwwn;
353 wwn_t rpwwn;
354};
355
356struct bfa_bsg_rport_set_speed_s {
357 bfa_status_t status;
358 u16 bfad_num;
359 u16 vf_id;
360 enum bfa_port_speed speed;
361 u32 rsvd;
362 wwn_t pwwn;
363 wwn_t rpwwn;
364};
365
366struct bfa_bsg_vport_attr_s {
367 bfa_status_t status;
368 u16 bfad_num;
369 u16 vf_id;
370 wwn_t vpwwn;
371 struct bfa_vport_attr_s vport_attr;
372};
373
374struct bfa_bsg_vport_stats_s {
375 bfa_status_t status;
376 u16 bfad_num;
377 u16 vf_id;
378 wwn_t vpwwn;
379 struct bfa_vport_stats_s vport_stats;
380};
381
382struct bfa_bsg_reset_stats_s {
383 bfa_status_t status;
384 u16 bfad_num;
385 u16 vf_id;
386 wwn_t vpwwn;
387};
388
b85daafe
KG
389struct bfa_bsg_fabric_get_lports_s {
390 bfa_status_t status;
391 u16 bfad_num;
392 u16 vf_id;
393 u64 buf_ptr;
394 u32 nports;
395 u32 rsvd;
396};
397
f2ee7601
KG
398struct bfa_bsg_trl_speed_s {
399 bfa_status_t status;
400 u16 bfad_num;
401 u16 rsvd;
402 enum bfa_port_speed speed;
403};
404
405struct bfa_bsg_fcpim_s {
406 bfa_status_t status;
407 u16 bfad_num;
408 u16 param;
409};
410
60138066
KG
411struct bfa_bsg_fcpim_modstats_s {
412 bfa_status_t status;
413 u16 bfad_num;
414 struct bfa_itnim_iostats_s modstats;
415};
416
417struct bfa_bsg_fcpim_del_itn_stats_s {
418 bfa_status_t status;
419 u16 bfad_num;
420 struct bfa_fcpim_del_itn_stats_s modstats;
421};
422
f2ee7601
KG
423struct bfa_bsg_fcpim_modstatsclr_s {
424 bfa_status_t status;
425 u16 bfad_num;
426};
427
b85daafe
KG
428struct bfa_bsg_itnim_attr_s {
429 bfa_status_t status;
430 u16 bfad_num;
431 u16 vf_id;
432 wwn_t lpwwn;
433 wwn_t rpwwn;
434 struct bfa_itnim_attr_s attr;
435};
436
60138066
KG
437struct bfa_bsg_itnim_iostats_s {
438 bfa_status_t status;
439 u16 bfad_num;
440 u16 vf_id;
441 wwn_t lpwwn;
442 wwn_t rpwwn;
443 struct bfa_itnim_iostats_s iostats;
444};
445
446struct bfa_bsg_itnim_itnstats_s {
447 bfa_status_t status;
448 u16 bfad_num;
449 u16 vf_id;
450 wwn_t lpwwn;
451 wwn_t rpwwn;
452 struct bfa_itnim_stats_s itnstats;
453};
454
1a4d8e1b
KG
455struct bfa_bsg_pcifn_cfg_s {
456 bfa_status_t status;
457 u16 bfad_num;
458 u16 rsvd;
459 struct bfa_ablk_cfg_s pcifn_cfg;
460};
461
462struct bfa_bsg_pcifn_s {
463 bfa_status_t status;
464 u16 bfad_num;
465 u16 pcifn_id;
466 u32 bandwidth;
467 u8 port;
468 enum bfi_pcifn_class pcifn_class;
469 u8 rsvd[1];
470};
471
472struct bfa_bsg_adapter_cfg_mode_s {
473 bfa_status_t status;
474 u16 bfad_num;
475 u16 rsvd;
476 struct bfa_adapter_cfg_mode_s cfg;
477};
478
479struct bfa_bsg_port_cfg_mode_s {
480 bfa_status_t status;
481 u16 bfad_num;
482 u16 instance;
483 struct bfa_port_cfg_mode_s cfg;
484};
485
a714134a
KG
486struct bfa_bsg_faa_attr_s {
487 bfa_status_t status;
488 u16 bfad_num;
489 u16 rsvd;
490 struct bfa_faa_attr_s faa_attr;
491};
492
148d6103
KG
493struct bfa_bsg_cee_attr_s {
494 bfa_status_t status;
495 u16 bfad_num;
496 u16 rsvd;
497 u32 buf_size;
498 u32 rsvd1;
499 u64 buf_ptr;
500};
501
502struct bfa_bsg_cee_stats_s {
503 bfa_status_t status;
504 u16 bfad_num;
505 u16 rsvd;
506 u32 buf_size;
507 u32 rsvd1;
508 u64 buf_ptr;
509};
510
51e569aa
KG
511struct bfa_bsg_sfp_media_s {
512 bfa_status_t status;
513 u16 bfad_num;
514 u16 rsvd;
515 enum bfa_defs_sfp_media_e media;
516};
517
518struct bfa_bsg_sfp_speed_s {
519 bfa_status_t status;
520 u16 bfad_num;
521 u16 rsvd;
522 enum bfa_port_speed speed;
523};
524
5a54b1d5
KG
525struct bfa_bsg_flash_attr_s {
526 bfa_status_t status;
527 u16 bfad_num;
528 u16 rsvd;
529 struct bfa_flash_attr_s attr;
530};
531
532struct bfa_bsg_flash_s {
533 bfa_status_t status;
534 u16 bfad_num;
535 u8 instance;
536 u8 rsvd;
537 enum bfa_flash_part_type type;
538 int bufsz;
539 u64 buf_ptr;
540};
541
3d7fc66d
KG
542struct bfa_bsg_diag_get_temp_s {
543 bfa_status_t status;
544 u16 bfad_num;
545 u16 rsvd;
546 struct bfa_diag_results_tempsensor_s result;
547};
548
549struct bfa_bsg_diag_memtest_s {
550 bfa_status_t status;
551 u16 bfad_num;
552 u16 rsvd[3];
553 u32 pat;
554 struct bfa_diag_memtest_result result;
555 struct bfa_diag_memtest_s memtest;
556};
557
558struct bfa_bsg_diag_loopback_s {
559 bfa_status_t status;
560 u16 bfad_num;
561 u16 rsvd;
562 enum bfa_port_opmode opmode;
563 enum bfa_port_speed speed;
564 u32 lpcnt;
565 u32 pat;
566 struct bfa_diag_loopback_result_s result;
567};
568
569struct bfa_bsg_diag_fwping_s {
570 bfa_status_t status;
571 u16 bfad_num;
572 u16 rsvd;
573 u32 cnt;
574 u32 pattern;
575 struct bfa_diag_results_fwping result;
576};
577
578struct bfa_bsg_diag_qtest_s {
579 bfa_status_t status;
580 u16 bfad_num;
581 u16 rsvd;
582 u32 force;
583 u32 queue;
584 struct bfa_diag_qtest_result_s result;
585};
586
587struct bfa_bsg_sfp_show_s {
588 bfa_status_t status;
589 u16 bfad_num;
590 u16 rsvd;
591 struct sfp_mem_s sfp;
592};
593
594struct bfa_bsg_diag_led_s {
595 bfa_status_t status;
596 u16 bfad_num;
597 u16 rsvd;
598 struct bfa_diag_ledtest_s ledtest;
599};
600
601struct bfa_bsg_diag_beacon_s {
602 bfa_status_t status;
603 u16 bfad_num;
604 u16 rsvd;
605 bfa_boolean_t beacon;
606 bfa_boolean_t link_e2e_beacon;
607 u32 second;
608};
609
610struct bfa_bsg_diag_lb_stat_s {
611 bfa_status_t status;
612 u16 bfad_num;
613 u16 rsvd;
614};
615
3350d98d
KG
616struct bfa_bsg_phy_attr_s {
617 bfa_status_t status;
618 u16 bfad_num;
619 u16 instance;
620 struct bfa_phy_attr_s attr;
621};
622
623struct bfa_bsg_phy_s {
624 bfa_status_t status;
625 u16 bfad_num;
626 u16 instance;
627 u64 bufsz;
628 u64 buf_ptr;
629};
630
61e62e21
KG
631struct bfa_bsg_debug_s {
632 bfa_status_t status;
633 u16 bfad_num;
634 u16 rsvd;
635 u32 bufsz;
636 int inst_no;
637 u64 buf_ptr;
638 u64 offset;
639};
640
3350d98d
KG
641struct bfa_bsg_phy_stats_s {
642 bfa_status_t status;
643 u16 bfad_num;
644 u16 instance;
645 struct bfa_phy_stats_s stats;
646};
647
61e62e21
KG
648struct bfa_bsg_vhba_attr_s {
649 bfa_status_t status;
650 u16 bfad_num;
651 u16 pcifn_id;
652 struct bfa_vhba_attr_s attr;
653};
654
a46bd300
KG
655struct bfa_bsg_boot_s {
656 bfa_status_t status;
657 u16 bfad_num;
658 u16 rsvd;
659 struct bfa_boot_cfg_s cfg;
660};
661
662struct bfa_bsg_preboot_s {
663 bfa_status_t status;
664 u16 bfad_num;
665 u16 rsvd;
666 struct bfa_boot_pbc_s cfg;
667};
668
669struct bfa_bsg_ethboot_s {
670 bfa_status_t status;
671 u16 bfad_num;
672 u16 rsvd;
673 struct bfa_ethboot_cfg_s cfg;
674};
675
45191236
KG
676struct bfa_bsg_trunk_attr_s {
677 bfa_status_t status;
678 u16 bfad_num;
679 u16 rsvd;
680 struct bfa_trunk_attr_s attr;
681};
682
3ec4f2c8
KG
683struct bfa_bsg_qos_attr_s {
684 bfa_status_t status;
685 u16 bfad_num;
686 u16 rsvd;
687 struct bfa_qos_attr_s attr;
688};
689
690struct bfa_bsg_qos_vc_attr_s {
691 bfa_status_t status;
692 u16 bfad_num;
693 u16 rsvd;
694 struct bfa_qos_vc_attr_s attr;
695};
696
c0350bf5
KG
697struct bfa_bsg_vf_stats_s {
698 bfa_status_t status;
699 u16 bfad_num;
700 u16 vf_id;
701 struct bfa_vf_stats_s stats;
702};
703
704struct bfa_bsg_vf_reset_stats_s {
705 bfa_status_t status;
706 u16 bfad_num;
707 u16 vf_id;
708};
709
4c5d22bf
KG
710struct bfa_bsg_fcpim_lunmask_query_s {
711 bfa_status_t status;
712 u16 bfad_num;
713 struct bfa_lunmask_cfg_s lun_mask;
714};
715
716struct bfa_bsg_fcpim_lunmask_s {
717 bfa_status_t status;
718 u16 bfad_num;
719 u16 vf_id;
720 wwn_t pwwn;
721 wwn_t rpwwn;
722 struct scsi_lun lun;
723};
724
b85daafe
KG
725struct bfa_bsg_fcpt_s {
726 bfa_status_t status;
727 u16 vf_id;
728 wwn_t lpwwn;
729 wwn_t dpwwn;
730 u32 tsecs;
731 int cts;
732 enum fc_cos cos;
733 struct fchs_s fchs;
734};
735#define bfa_bsg_fcpt_t struct bfa_bsg_fcpt_s
736
737struct bfa_bsg_data {
738 int payload_len;
739 void *payload;
740};
741
742#define bfad_chk_iocmd_sz(__payload_len, __hdrsz, __bufsz) \
743 (((__payload_len) != ((__hdrsz) + (__bufsz))) ? \
744 BFA_STATUS_FAILED : BFA_STATUS_OK)
745
746#endif /* BFAD_BSG_H */