Lines Matching defs:MPT3SAS_ADAPTER
1328 struct MPT3SAS_ADAPTER { struct
1329 struct list_head list;
1330 struct Scsi_Host *shost;
1331 u8 id;
1332 int cpu_count;
1333 char name[MPT_NAME_LENGTH];
1334 char driver_name[MPT_NAME_LENGTH - 8];
1335 char tmp_string[MPT_STRING_LENGTH];
1336 struct pci_dev *pdev;
1337 Mpi2SystemInterfaceRegs_t __iomem *chip;
1338 phys_addr_t chip_phys;
1339 int logging_level;
1340 int fwfault_debug;
1341 u8 ir_firmware;
1342 int bars;
1343 u8 mask_interrupts;
1346 char fault_reset_work_q_name[20];
1347 struct workqueue_struct *fault_reset_work_q;
1348 struct delayed_work fault_reset_work;
1351 char firmware_event_name[20];
1352 struct workqueue_struct *firmware_event_thread;
1353 spinlock_t fw_event_lock;
1354 struct list_head fw_event_list;
1355 struct fw_event_work *current_event;
1356 u8 fw_events_cleanup;
1359 int aen_event_read_flag;
1360 u8 broadcast_aen_busy;
1361 u16 broadcast_aen_pending;
1362 u8 shost_recovery;
1363 u8 got_task_abort_from_ioctl;
1365 struct mutex reset_in_progress_mutex;
1366 spinlock_t ioc_reset_in_progress_lock;
1367 u8 ioc_link_reset_in_progress;
1369 u8 ignore_loginfos;
1370 u8 remove_host;
1371 u8 pci_error_recovery;
1372 u8 wait_for_discovery_to_complete;
1373 u8 is_driver_loading;
1374 u8 port_enable_failed;
1375 u8 start_scan;
1376 u16 start_scan_failed;
1378 u8 msix_enable;
1379 u16 msix_vector_count;
1380 u8 *cpu_msix_table;
1381 u16 cpu_msix_table_sz;
1382 resource_size_t __iomem **reply_post_host_index;
1383 u32 ioc_reset_count;
1384 MPT3SAS_FLUSH_RUNNING_CMDS schedule_dead_ioc_flush_running_cmds;
1385 u32 non_operational_loop;
1386 u8 ioc_coredump_loop;
1387 u32 timestamp_update_count;
1388 u32 time_sync_interval;
1389 atomic64_t total_io_cnt;
1390 atomic64_t high_iops_outstanding;
1391 bool msix_load_balance;
1392 u16 thresh_hold;
1393 u8 high_iops_queues;
1394 u8 iopoll_q_start_index;
1395 u32 drv_internal_flags;
1396 u32 drv_support_bitmap;
1397 u32 dma_mask;
1398 bool enable_sdev_max_qd;
1399 bool use_32bit_dma;
1400 struct io_uring_poll_queue *io_uring_poll_queues;
1403 u8 scsi_io_cb_idx;
1404 u8 tm_cb_idx;
1405 u8 transport_cb_idx;
1406 u8 scsih_cb_idx;
1407 u8 ctl_cb_idx;
1408 u8 base_cb_idx;
1409 u8 port_enable_cb_idx;
1410 u8 config_cb_idx;
1411 u8 tm_tr_cb_idx;
1412 u8 tm_tr_volume_cb_idx;
1413 u8 tm_sas_control_cb_idx;
1414 struct _internal_cmd base_cmds;
1415 struct _internal_cmd port_enable_cmds;
1416 struct _internal_cmd transport_cmds;
1417 struct _internal_cmd scsih_cmds;
1418 struct _internal_cmd tm_cmds;
1419 struct _internal_cmd ctl_cmds;
1420 struct _internal_cmd config_cmds;
1422 MPT_ADD_SGE base_add_sg_single;
1425 MPT_BUILD_SG_SCMD build_sg_scmd;
1426 MPT_BUILD_SG build_sg;
1427 MPT_BUILD_ZERO_LEN_SGE build_zero_len_sge;
1428 u16 sge_size_ieee;
1429 u16 hba_mpi_version_belonged;
1432 MPT_BUILD_SG build_sg_mpi;
1433 MPT_BUILD_ZERO_LEN_SGE build_zero_len_sge_mpi;
1436 NVME_BUILD_PRP build_nvme_prp;
1439 u32 event_type[MPI2_EVENT_NOTIFY_EVENTMASK_WORDS];
1440 u32 event_context;
1441 void *event_log;
1442 u32 event_masks[MPI2_EVENT_NOTIFY_EVENTMASK_WORDS];
1444 u8 tm_custom_handling;
1445 u8 nvme_abort_timeout;
1446 u16 max_shutdown_latency;
1447 u16 max_wideport_qd;
1448 u16 max_narrowport_qd;
1449 u16 max_nvme_qd;
1450 u8 max_sata_qd;
1453 struct mpt3sas_facts facts;
1454 struct mpt3sas_facts prev_fw_facts;
1455 struct mpt3sas_port_facts *pfacts;
1456 Mpi2ManufacturingPage0_t manu_pg0;
1457 struct Mpi2ManufacturingPage10_t manu_pg10;
1458 struct Mpi2ManufacturingPage11_t manu_pg11;
1459 Mpi2BiosPage2_t bios_pg2;
1460 Mpi2BiosPage3_t bios_pg3;
1461 Mpi2IOCPage8_t ioc_pg8;
1462 Mpi2IOUnitPage0_t iounit_pg0;
1463 Mpi2IOUnitPage1_t iounit_pg1;
1464 Mpi2IOUnitPage8_t iounit_pg8;
1465 Mpi2IOCPage1_t ioc_pg1_copy;
1467 struct _boot_device req_boot_device;
1468 struct _boot_device req_alt_boot_device;
1469 struct _boot_device current_boot_device;
1472 struct _sas_node sas_hba;
1473 struct list_head sas_expander_list;
1474 struct list_head enclosure_list;
1475 spinlock_t sas_node_lock;
1476 struct list_head sas_device_list;
1477 struct list_head sas_device_init_list;
1478 spinlock_t sas_device_lock;
1479 struct list_head pcie_device_list;
1480 struct list_head pcie_device_init_list;
1481 spinlock_t pcie_device_lock;
1483 struct list_head raid_device_list;
1484 spinlock_t raid_device_lock;
1485 u8 io_missing_delay;
1486 u16 device_missing_delay;
1487 int sas_id;
1488 int pcie_target_id;
1490 void *blocking_handles;
1491 void *pd_handles;
1492 u16 pd_handles_sz;
1494 void *pend_os_device_add;
1495 u16 pend_os_device_add_sz;
1498 u16 config_page_sz;
1499 void *config_page;
1500 dma_addr_t config_page_dma;
1501 void *config_vaddr;
1504 u16 hba_queue_depth;
1505 u16 sge_size;
1506 u16 scsiio_depth;
1507 u16 request_sz;
1508 u8 *request;
1509 dma_addr_t request_dma;
1510 u32 request_dma_sz;
1511 struct pcie_sg_list *pcie_sg_lookup;
1512 spinlock_t scsi_lookup_lock;
1513 int pending_io_count;
1514 wait_queue_head_t reset_wq;
1515 u16 *io_queue_num;
1518 struct dma_pool *pcie_sgl_dma_pool;
1520 u32 page_size;
1523 struct chain_lookup *chain_lookup;
1524 struct list_head free_chain_list;
1525 struct dma_pool *chain_dma_pool;
1526 ulong chain_pages;
1527 u16 max_sges_in_main_message;
1528 u16 max_sges_in_chain_message;
1529 u16 chains_needed_per_io;
1530 u32 chain_depth;
1531 u16 chain_segment_sz;
1532 u16 chains_per_prp_buffer;
1535 u16 hi_priority_smid;
1536 u8 *hi_priority;
1537 dma_addr_t hi_priority_dma;
1538 u16 hi_priority_depth;
1539 struct request_tracker *hpr_lookup;
1540 struct list_head hpr_free_list;
1543 u16 internal_smid;
1544 u8 *internal;
1545 dma_addr_t internal_dma;
1546 u16 internal_depth;
1547 struct request_tracker *internal_lookup;
1548 struct list_head internal_free_list;
1551 u8 *sense;
1552 dma_addr_t sense_dma;
1553 struct dma_pool *sense_dma_pool;
1556 u16 reply_sz;
1557 u8 *reply;
1558 dma_addr_t reply_dma;
1559 u32 reply_dma_max_address;
1560 u32 reply_dma_min_address;
1561 struct dma_pool *reply_dma_pool;
1564 u16 reply_free_queue_depth;
1565 __le32 *reply_free;
1566 dma_addr_t reply_free_dma;
1567 struct dma_pool *reply_free_dma_pool;
1568 u32 reply_free_host_index;
1571 u16 reply_post_queue_depth;
1572 struct reply_post_struct *reply_post;
1573 u8 rdpq_array_capable;
1574 u8 rdpq_array_enable;
1575 u8 rdpq_array_enable_assigned;
1576 struct dma_pool *reply_post_free_dma_pool;
1577 struct dma_pool *reply_post_free_array_dma_pool;
1578 Mpi2IOCInitRDPQArrayEntry *reply_post_free_array;
1579 dma_addr_t reply_post_free_array_dma;
1580 u8 reply_queue_count;
1581 struct list_head reply_queue_list;
1583 u8 combined_reply_queue;
1584 u8 combined_reply_index_count;
1585 u8 smp_affinity_enable;
1587 resource_size_t **replyPostRegisterIndex;
1589 struct list_head delayed_tr_list;
1590 struct list_head delayed_tr_volume_list;
1591 struct list_head delayed_sc_list;
1592 struct list_head delayed_event_ack_list;
1593 u8 temp_sensors_count;
1594 struct mutex pci_access_mutex;
1597 u8 *diag_buffer[MPI2_DIAG_BUF_TYPE_COUNT];
1598 u32 diag_buffer_sz[MPI2_DIAG_BUF_TYPE_COUNT];
1599 dma_addr_t diag_buffer_dma[MPI2_DIAG_BUF_TYPE_COUNT];
1600 u8 diag_buffer_status[MPI2_DIAG_BUF_TYPE_COUNT];
1601 u32 unique_id[MPI2_DIAG_BUF_TYPE_COUNT];
1602 u32 product_specific[MPI2_DIAG_BUF_TYPE_COUNT][23];
1603 u32 diagnostic_flags[MPI2_DIAG_BUF_TYPE_COUNT];
1604 u32 ring_buffer_offset;
1605 u32 ring_buffer_sz;
1606 struct htb_rel_query htb_rel;
1607 u8 reset_from_user;
1608 u8 is_warpdrive;
1609 u8 is_mcpu_endpoint;
1610 u8 hide_ir_msg;
1611 u8 mfg_pg10_hide_flag;
1612 u8 hide_drives;
1613 spinlock_t diag_trigger_lock;
1614 u8 diag_trigger_active;
1615 u8 atomic_desc_capable;
1616 BASE_READ_REG base_readl;
1617 struct SL_WH_MASTER_TRIGGER_T diag_trigger_master;
1618 struct SL_WH_EVENT_TRIGGERS_T diag_trigger_event;
1619 struct SL_WH_SCSI_TRIGGERS_T diag_trigger_scsi;
1620 struct SL_WH_MPI_TRIGGERS_T diag_trigger_mpi;
1621 u8 supports_trigger_pages;
1622 void *device_remove_in_progress;
1623 u16 device_remove_in_progress_sz;
1624 u8 is_gen35_ioc;
1648 typedef u8 (*MPT_CALLBACK)(struct MPT3SAS_ADAPTER *ioc, u16 smid, u8 msix_index, argument