1ef270ab1SKenneth D. Merry /*- 2ef270ab1SKenneth D. Merry * Copyright (c) 2017 Broadcom. All rights reserved. 3ef270ab1SKenneth D. Merry * The term "Broadcom" refers to Broadcom Limited and/or its subsidiaries. 4ef270ab1SKenneth D. Merry * 5ef270ab1SKenneth D. Merry * Redistribution and use in source and binary forms, with or without 6ef270ab1SKenneth D. Merry * modification, are permitted provided that the following conditions are met: 7ef270ab1SKenneth D. Merry * 8ef270ab1SKenneth D. Merry * 1. Redistributions of source code must retain the above copyright notice, 9ef270ab1SKenneth D. Merry * this list of conditions and the following disclaimer. 10ef270ab1SKenneth D. Merry * 11ef270ab1SKenneth D. Merry * 2. Redistributions in binary form must reproduce the above copyright notice, 12ef270ab1SKenneth D. Merry * this list of conditions and the following disclaimer in the documentation 13ef270ab1SKenneth D. Merry * and/or other materials provided with the distribution. 14ef270ab1SKenneth D. Merry * 15ef270ab1SKenneth D. Merry * 3. Neither the name of the copyright holder nor the names of its contributors 16ef270ab1SKenneth D. Merry * may be used to endorse or promote products derived from this software 17ef270ab1SKenneth D. Merry * without specific prior written permission. 18ef270ab1SKenneth D. Merry * 19ef270ab1SKenneth D. Merry * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 20ef270ab1SKenneth D. Merry * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21ef270ab1SKenneth D. Merry * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22ef270ab1SKenneth D. Merry * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 23ef270ab1SKenneth D. Merry * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24ef270ab1SKenneth D. Merry * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25ef270ab1SKenneth D. Merry * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26ef270ab1SKenneth D. Merry * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27ef270ab1SKenneth D. Merry * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28ef270ab1SKenneth D. Merry * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29ef270ab1SKenneth D. Merry * POSSIBILITY OF SUCH DAMAGE. 30ef270ab1SKenneth D. Merry * 31ef270ab1SKenneth D. Merry * $FreeBSD$ 32ef270ab1SKenneth D. Merry */ 33ef270ab1SKenneth D. Merry 34ef270ab1SKenneth D. Merry /** 35ef270ab1SKenneth D. Merry * @file 36ef270ab1SKenneth D. Merry * OCS bsd driver common include file 37ef270ab1SKenneth D. Merry */ 38ef270ab1SKenneth D. Merry 39ef270ab1SKenneth D. Merry 40ef270ab1SKenneth D. Merry #if !defined(__OCS_H__) 41ef270ab1SKenneth D. Merry #define __OCS_H__ 42ef270ab1SKenneth D. Merry 43ef270ab1SKenneth D. Merry #include "ocs_os.h" 44ef270ab1SKenneth D. Merry #include "ocs_utils.h" 45ef270ab1SKenneth D. Merry 46ef270ab1SKenneth D. Merry #include "ocs_hw.h" 47ef270ab1SKenneth D. Merry #include "ocs_scsi.h" 48ef270ab1SKenneth D. Merry #include "ocs_io.h" 49ef270ab1SKenneth D. Merry 50ef270ab1SKenneth D. Merry #include "version.h" 51ef270ab1SKenneth D. Merry 52ef270ab1SKenneth D. Merry #define DRV_NAME "ocs_fc" 53ef270ab1SKenneth D. Merry #define DRV_VERSION \ 54ef270ab1SKenneth D. Merry STR_BE_MAJOR "." STR_BE_MINOR "." STR_BE_BUILD "." STR_BE_BRANCH 55ef270ab1SKenneth D. Merry 56ef270ab1SKenneth D. Merry /** 57ef270ab1SKenneth D. Merry * @brief Interrupt context 58ef270ab1SKenneth D. Merry */ 59ef270ab1SKenneth D. Merry typedef struct ocs_intr_ctx_s { 60ef270ab1SKenneth D. Merry uint32_t vec; /** Zero based interrupt vector */ 61ef270ab1SKenneth D. Merry void *softc; /** software context for interrupt */ 62ef270ab1SKenneth D. Merry char name[64]; /** label for this context */ 63ef270ab1SKenneth D. Merry } ocs_intr_ctx_t; 64ef270ab1SKenneth D. Merry 65*6affb8ebSRam Kishore Vegesna typedef struct ocs_fc_rport_db_s { 66*6affb8ebSRam Kishore Vegesna uint32_t node_id; 67*6affb8ebSRam Kishore Vegesna uint32_t state; 68*6affb8ebSRam Kishore Vegesna uint8_t is_target; 69*6affb8ebSRam Kishore Vegesna uint8_t is_initiator; 70*6affb8ebSRam Kishore Vegesna 71*6affb8ebSRam Kishore Vegesna uint32_t port_id; 72*6affb8ebSRam Kishore Vegesna uint64_t wwnn; 73*6affb8ebSRam Kishore Vegesna uint64_t wwpn; 74*6affb8ebSRam Kishore Vegesna uint32_t gone_timer; 75*6affb8ebSRam Kishore Vegesna 76*6affb8ebSRam Kishore Vegesna } ocs_fc_target_t; 77*6affb8ebSRam Kishore Vegesna 78*6affb8ebSRam Kishore Vegesna #define OCS_TGT_STATE_NONE 0 /* Empty DB slot */ 79*6affb8ebSRam Kishore Vegesna #define OCS_TGT_STATE_VALID 1 /* Valid*/ 80*6affb8ebSRam Kishore Vegesna #define OCS_TGT_STATE_LOST 2 /* LOST*/ 81*6affb8ebSRam Kishore Vegesna 82ef270ab1SKenneth D. Merry typedef struct ocs_fcport_s { 83*6affb8ebSRam Kishore Vegesna ocs_t *ocs; 84ef270ab1SKenneth D. Merry struct cam_sim *sim; 85ef270ab1SKenneth D. Merry struct cam_path *path; 86ef270ab1SKenneth D. Merry uint32_t role; 87ef270ab1SKenneth D. Merry 88*6affb8ebSRam Kishore Vegesna ocs_fc_target_t tgt[OCS_MAX_TARGETS]; 89*6affb8ebSRam Kishore Vegesna int lost_device_time; 90*6affb8ebSRam Kishore Vegesna struct callout ldt; /* device lost timer */ 91*6affb8ebSRam Kishore Vegesna struct task ltask; 92*6affb8ebSRam Kishore Vegesna 93ef270ab1SKenneth D. Merry ocs_tgt_resource_t targ_rsrc_wildcard; 94ef270ab1SKenneth D. Merry ocs_tgt_resource_t targ_rsrc[OCS_MAX_LUN]; 95ef270ab1SKenneth D. Merry ocs_vport_spec_t *vport; 96ef270ab1SKenneth D. Merry } ocs_fcport; 97ef270ab1SKenneth D. Merry 98ef270ab1SKenneth D. Merry #define FCPORT(ocs, chan) (&((ocs_fcport *)(ocs)->fcports)[(chan)]) 99ef270ab1SKenneth D. Merry 100ef270ab1SKenneth D. Merry /** 101ef270ab1SKenneth D. Merry * @brief Driver's context 102ef270ab1SKenneth D. Merry */ 103ef270ab1SKenneth D. Merry 104ef270ab1SKenneth D. Merry struct ocs_softc { 105ef270ab1SKenneth D. Merry 106ef270ab1SKenneth D. Merry device_t dev; 107ef270ab1SKenneth D. Merry struct cdev *cdev; 108ef270ab1SKenneth D. Merry 109ef270ab1SKenneth D. Merry ocs_pci_reg_t reg[PCI_MAX_BAR]; 110ef270ab1SKenneth D. Merry 111ef270ab1SKenneth D. Merry uint32_t instance_index; 112ef270ab1SKenneth D. Merry const char *desc; 113ef270ab1SKenneth D. Merry 114ef270ab1SKenneth D. Merry uint32_t irqid; 115ef270ab1SKenneth D. Merry struct resource *irq; 116ef270ab1SKenneth D. Merry void *tag; 117ef270ab1SKenneth D. Merry 118ef270ab1SKenneth D. Merry ocs_intr_ctx_t intr_ctx; 119ef270ab1SKenneth D. Merry uint32_t n_vec; 120ef270ab1SKenneth D. Merry 121ef270ab1SKenneth D. Merry bus_dma_tag_t dmat; /** Parent DMA tag */ 122ef270ab1SKenneth D. Merry bus_dma_tag_t buf_dmat;/** IO buffer DMA tag */ 123ef270ab1SKenneth D. Merry char display_name[OCS_DISPLAY_NAME_LENGTH]; 124ef270ab1SKenneth D. Merry uint16_t pci_vendor; 125ef270ab1SKenneth D. Merry uint16_t pci_device; 126ef270ab1SKenneth D. Merry uint16_t pci_subsystem_vendor; 127ef270ab1SKenneth D. Merry uint16_t pci_subsystem_device; 128ef270ab1SKenneth D. Merry char businfo[16]; 129ef270ab1SKenneth D. Merry const char *driver_version; 130ef270ab1SKenneth D. Merry const char *fw_version; 131ef270ab1SKenneth D. Merry const char *model; 132ef270ab1SKenneth D. Merry 133ef270ab1SKenneth D. Merry ocs_hw_t hw; 134ef270ab1SKenneth D. Merry 135ef270ab1SKenneth D. Merry ocs_rlock_t lock; /**< device wide lock */ 136ef270ab1SKenneth D. Merry 137ef270ab1SKenneth D. Merry ocs_xport_e ocs_xport; 138ef270ab1SKenneth D. Merry ocs_xport_t *xport; /**< pointer to transport object */ 139ef270ab1SKenneth D. Merry ocs_domain_t *domain; 140ef270ab1SKenneth D. Merry ocs_list_t domain_list; 141ef270ab1SKenneth D. Merry uint32_t domain_instance_count; 142ef270ab1SKenneth D. Merry void (*domain_list_empty_cb)(ocs_t *ocs, void *arg); 143ef270ab1SKenneth D. Merry void *domain_list_empty_cb_arg; 144ef270ab1SKenneth D. Merry 145ef270ab1SKenneth D. Merry uint8_t enable_ini; 146ef270ab1SKenneth D. Merry uint8_t enable_tgt; 147ef270ab1SKenneth D. Merry uint8_t fc_type; 148ef270ab1SKenneth D. Merry int ctrlmask; 149ef270ab1SKenneth D. Merry uint8_t explicit_buffer_list; 150ef270ab1SKenneth D. Merry uint8_t external_loopback; 151ef270ab1SKenneth D. Merry uint8_t skip_hw_teardown; 152ef270ab1SKenneth D. Merry int speed; 153ef270ab1SKenneth D. Merry int topology; 154ef270ab1SKenneth D. Merry int ethernet_license; 155ef270ab1SKenneth D. Merry int num_scsi_ios; 156ef270ab1SKenneth D. Merry uint8_t enable_hlm; 157ef270ab1SKenneth D. Merry uint32_t hlm_group_size; 158ef270ab1SKenneth D. Merry uint32_t max_isr_time_msec; /*>> Maximum ISR time */ 159ef270ab1SKenneth D. Merry uint32_t auto_xfer_rdy_size; /*>> Max sized write to use auto xfer rdy*/ 160ef270ab1SKenneth D. Merry uint8_t esoc; 161ef270ab1SKenneth D. Merry int logmask; 162ef270ab1SKenneth D. Merry char *hw_war_version; 163ef270ab1SKenneth D. Merry uint32_t num_vports; 164ef270ab1SKenneth D. Merry uint32_t target_io_timer_sec; 165ef270ab1SKenneth D. Merry uint32_t hw_bounce; 166ef270ab1SKenneth D. Merry uint8_t rq_threads; 167ef270ab1SKenneth D. Merry uint8_t rq_selection_policy; 168ef270ab1SKenneth D. Merry uint8_t rr_quanta; 169ef270ab1SKenneth D. Merry char *filter_def; 170ef270ab1SKenneth D. Merry uint32_t max_remote_nodes; 171ef270ab1SKenneth D. Merry 172ef270ab1SKenneth D. Merry /* 173ef270ab1SKenneth D. Merry * tgt_rscn_delay - delay in kicking off RSCN processing 174ef270ab1SKenneth D. Merry * (nameserver queries) after receiving an RSCN on the target. 175ef270ab1SKenneth D. Merry * This prevents thrashing of nameserver requests due to a huge burst of 176ef270ab1SKenneth D. Merry * RSCNs received in a short period of time. 177ef270ab1SKenneth D. Merry * Note: this is only valid when target RSCN handling is enabled -- see 178ef270ab1SKenneth D. Merry * ctrlmask. 179ef270ab1SKenneth D. Merry */ 180ef270ab1SKenneth D. Merry time_t tgt_rscn_delay_msec; /*>> minimum target RSCN delay */ 181ef270ab1SKenneth D. Merry 182ef270ab1SKenneth D. Merry /* 183ef270ab1SKenneth D. Merry * tgt_rscn_period - determines maximum frequency when processing 184ef270ab1SKenneth D. Merry * back-to-back RSCNs; e.g. if this value is 30, there will never be 185ef270ab1SKenneth D. Merry * any more than 1 RSCN handling per 30s window. This prevents 186ef270ab1SKenneth D. Merry * initiators on a faulty link generating many RSCN from causing the 187ef270ab1SKenneth D. Merry * target to continually query the nameserver. 188ef270ab1SKenneth D. Merry * Note: This is only valid when target RSCN handling is enabled 189ef270ab1SKenneth D. Merry */ 190ef270ab1SKenneth D. Merry time_t tgt_rscn_period_msec; /*>> minimum target RSCN period */ 191ef270ab1SKenneth D. Merry 192ef270ab1SKenneth D. Merry uint32_t enable_task_set_full; 193ef270ab1SKenneth D. Merry uint32_t io_in_use; 194ef270ab1SKenneth D. Merry uint32_t io_high_watermark; /**< used to send task set full */ 195ef270ab1SKenneth D. Merry struct mtx sim_lock; 196ef270ab1SKenneth D. Merry uint32_t config_tgt:1, /**< Configured to support target mode */ 197ef270ab1SKenneth D. Merry config_ini:1; /**< Configured to support initiator mode */ 198ef270ab1SKenneth D. Merry 199ef270ab1SKenneth D. Merry 200ef270ab1SKenneth D. Merry uint32_t nodedb_mask; /**< Node debugging mask */ 201ef270ab1SKenneth D. Merry 202ef270ab1SKenneth D. Merry char modeldesc[64]; 203ef270ab1SKenneth D. Merry char serialnum[64]; 204ef270ab1SKenneth D. Merry char fwrev[64]; 205ef270ab1SKenneth D. Merry char sli_intf[9]; 206ef270ab1SKenneth D. Merry 207ef270ab1SKenneth D. Merry ocs_ramlog_t *ramlog; 208ef270ab1SKenneth D. Merry ocs_textbuf_t ddump_saved; 209ef270ab1SKenneth D. Merry 210ef270ab1SKenneth D. Merry ocs_mgmt_functions_t *mgmt_functions; 211ef270ab1SKenneth D. Merry ocs_mgmt_functions_t *tgt_mgmt_functions; 212ef270ab1SKenneth D. Merry ocs_mgmt_functions_t *ini_mgmt_functions; 213ef270ab1SKenneth D. Merry 214ef270ab1SKenneth D. Merry ocs_err_injection_e err_injection; 215ef270ab1SKenneth D. Merry uint32_t cmd_err_inject; 216ef270ab1SKenneth D. Merry time_t delay_value_msec; 217ef270ab1SKenneth D. Merry 218ef270ab1SKenneth D. Merry bool attached; 219ef270ab1SKenneth D. Merry struct mtx dbg_lock; 220ef270ab1SKenneth D. Merry 221ef270ab1SKenneth D. Merry struct cam_devq *devq; 222ef270ab1SKenneth D. Merry ocs_fcport *fcports; 223ef270ab1SKenneth D. Merry 224ef270ab1SKenneth D. Merry void* tgt_ocs; 225ef270ab1SKenneth D. Merry }; 226ef270ab1SKenneth D. Merry 227ef270ab1SKenneth D. Merry static inline void 228ef270ab1SKenneth D. Merry ocs_device_lock_init(ocs_t *ocs) 229ef270ab1SKenneth D. Merry { 230ef270ab1SKenneth D. Merry ocs_rlock_init(ocs, &ocs->lock, "ocsdevicelock"); 231ef270ab1SKenneth D. Merry } 232ef270ab1SKenneth D. Merry 233ef270ab1SKenneth D. Merry static inline int32_t 234ef270ab1SKenneth D. Merry ocs_device_lock_try(ocs_t *ocs) 235ef270ab1SKenneth D. Merry { 236ef270ab1SKenneth D. Merry return ocs_rlock_try(&ocs->lock); 237ef270ab1SKenneth D. Merry } 238ef270ab1SKenneth D. Merry 239ef270ab1SKenneth D. Merry static inline void 240ef270ab1SKenneth D. Merry ocs_device_lock(ocs_t *ocs) 241ef270ab1SKenneth D. Merry { 242ef270ab1SKenneth D. Merry ocs_rlock_acquire(&ocs->lock); 243ef270ab1SKenneth D. Merry } 244ef270ab1SKenneth D. Merry 245ef270ab1SKenneth D. Merry static inline void 246ef270ab1SKenneth D. Merry ocs_device_unlock(ocs_t *ocs) 247ef270ab1SKenneth D. Merry { 248ef270ab1SKenneth D. Merry ocs_rlock_release(&ocs->lock); 249ef270ab1SKenneth D. Merry } 250ef270ab1SKenneth D. Merry 251ef270ab1SKenneth D. Merry static inline void 252ef270ab1SKenneth D. Merry ocs_device_lock_free(ocs_t *ocs) 253ef270ab1SKenneth D. Merry { 254ef270ab1SKenneth D. Merry ocs_rlock_free(&ocs->lock); 255ef270ab1SKenneth D. Merry } 256ef270ab1SKenneth D. Merry 257ef270ab1SKenneth D. Merry extern int32_t ocs_device_detach(ocs_t *ocs); 258ef270ab1SKenneth D. Merry 259ef270ab1SKenneth D. Merry extern int32_t ocs_device_attach(ocs_t *ocs); 260ef270ab1SKenneth D. Merry 261ef270ab1SKenneth D. Merry #define ocs_is_initiator_enabled() (ocs->enable_ini) 262ef270ab1SKenneth D. Merry #define ocs_is_target_enabled() (ocs->enable_tgt) 263ef270ab1SKenneth D. Merry 264ef270ab1SKenneth D. Merry #include "ocs_xport.h" 265ef270ab1SKenneth D. Merry #include "ocs_domain.h" 266ef270ab1SKenneth D. Merry #include "ocs_sport.h" 267ef270ab1SKenneth D. Merry #include "ocs_node.h" 268ef270ab1SKenneth D. Merry #include "ocs_unsol.h" 269ef270ab1SKenneth D. Merry #include "ocs_scsi.h" 270ef270ab1SKenneth D. Merry #include "ocs_ioctl.h" 271ef270ab1SKenneth D. Merry 272ef270ab1SKenneth D. Merry static inline ocs_io_t * 273ef270ab1SKenneth D. Merry ocs_io_alloc(ocs_t *ocs) 274ef270ab1SKenneth D. Merry { 275ef270ab1SKenneth D. Merry return ocs_io_pool_io_alloc(ocs->xport->io_pool); 276ef270ab1SKenneth D. Merry } 277ef270ab1SKenneth D. Merry 278ef270ab1SKenneth D. Merry static inline void 279ef270ab1SKenneth D. Merry ocs_io_free(ocs_t *ocs, ocs_io_t *io) 280ef270ab1SKenneth D. Merry { 281ef270ab1SKenneth D. Merry ocs_io_pool_io_free(ocs->xport->io_pool, io); 282ef270ab1SKenneth D. Merry } 283ef270ab1SKenneth D. Merry 284ef270ab1SKenneth D. Merry #endif /* __OCS_H__ */ 285