/* SPDX-License-Identifier: GPL-2.0 */ /* * Copyright (C) 2021 Broadcom. All Rights Reserved. The term * “Broadcom” refers to Broadcom Inc. and/or its subsidiaries. */ #if !defined(__EFCT_DRIVER_H__) #define __EFCT_DRIVER_H__ /*************************************************************************** * OS specific includes */ #include <linux/module.h> #include <linux/debugfs.h> #include <linux/firmware.h> #include "../include/efc_common.h" #include "../libefc/efclib.h" #include "efct_hw.h" #include "efct_io.h" #include "efct_xport.h" #define EFCT_DRIVER_NAME "efct" #define EFCT_DRIVER_VERSION "1.0.0.0" /* EFCT_DEFAULT_FILTER- * MRQ filter to segregate the IO flow. */ #define EFCT_DEFAULT_FILTER "0x01ff22ff,0,0,0" /* EFCT_OS_MAX_ISR_TIME_MSEC - * maximum time driver code should spend in an interrupt * or kernel thread context without yielding */ #define EFCT_OS_MAX_ISR_TIME_MSEC 1000 #define EFCT_FC_MAX_SGL 64 #define EFCT_FC_DIF_SEED 0 /* Watermark */ #define EFCT_WATERMARK_HIGH_PCT 90 #define EFCT_WATERMARK_LOW_PCT 80 #define EFCT_IO_WATERMARK_PER_INITIATOR 8 #define EFCT_PCI_MAX_REGS 6 #define MAX_PCI_INTERRUPTS 16 struct efct_intr_context { struct efct *efct; u32 index; }; struct efct { struct pci_dev *pci; void __iomem *reg[EFCT_PCI_MAX_REGS]; u32 n_msix_vec; bool attached; bool soft_wwn_enable; u8 efct_req_fw_upgrade; struct efct_intr_context intr_context[MAX_PCI_INTERRUPTS]; u32 numa_node; char name[EFC_NAME_LENGTH]; u32 instance_index; struct list_head list_entry; struct efct_scsi_tgt tgt_efct; struct efct_xport *xport; struct efc *efcport; struct Scsi_Host *shost; int logmask; u32 max_isr_time_msec; const char *desc; const char *model; struct efct_hw hw; u32 rq_selection_policy; char *filter_def; int topology; /* Look up for target node */ struct xarray lookup; /* * Target IO timer value: * Zero: target command timeout disabled. * Non-zero: Timeout value, in seconds, for target commands */ u32 target_io_timer_sec; int speed; struct dentry *sess_debugfs_dir; }; #define FW_WRITE_BUFSIZE (64 * 1024) struct efct_fw_write_result { struct completion done; int status; u32 actual_xfer; u32 change_status; }; extern struct list_head efct_devices; #endif /* __EFCT_DRIVER_H__ */