Lines Matching refs:qtcb
94 mempool_free(req->qtcb, req->adapter->pool.qtcb_pool); in zfcp_fsf_req_free()
100 kmem_cache_free(zfcp_fsf_qtcb_cache, req->qtcb); in zfcp_fsf_req_free()
289 switch (req->qtcb->header.fsf_status_qual.word[0]) { in zfcp_fsf_fsfstatus_qual_eval()
314 switch (req->qtcb->header.fsf_status) { in zfcp_fsf_fsfstatus_eval()
318 req->qtcb->header.fsf_command); in zfcp_fsf_fsfstatus_eval()
331 struct fsf_qtcb *qtcb = req->qtcb; in zfcp_fsf_protstatus_eval() local
332 union fsf_prot_status_qual *psq = &qtcb->prefix.prot_status_qual; in zfcp_fsf_protstatus_eval()
341 switch (qtcb->prefix.prot_status) { in zfcp_fsf_protstatus_eval()
369 (unsigned long long)qtcb->bottom.support.req_handle); in zfcp_fsf_protstatus_eval()
389 qtcb->prefix.prot_status); in zfcp_fsf_protstatus_eval()
489 struct fsf_qtcb_bottom_config *bottom = &req->qtcb->bottom.config; in zfcp_fsf_exchange_config_evaluate()
518 if (req->qtcb->header.fsf_status == FSF_EXCHANGE_CONFIG_DATA_INCOMPLETE) in zfcp_fsf_exchange_config_evaluate()
557 struct fsf_qtcb *qtcb = req->qtcb; in zfcp_fsf_exchange_config_data_handler() local
558 struct fsf_qtcb_bottom_config *bottom = &qtcb->bottom.config; in zfcp_fsf_exchange_config_data_handler()
571 switch (qtcb->header.fsf_status) { in zfcp_fsf_exchange_config_data_handler()
600 &qtcb->header.fsf_status_qual.link_down_info); in zfcp_fsf_exchange_config_data_handler()
635 struct fsf_qtcb_bottom_port *bottom = &req->qtcb->bottom.port; in zfcp_fsf_exchange_port_evaluate()
656 struct fsf_qtcb *qtcb = req->qtcb; in zfcp_fsf_exchange_port_data_handler() local
661 switch (qtcb->header.fsf_status) { in zfcp_fsf_exchange_port_data_handler()
668 &qtcb->header.fsf_status_qual.link_down_info); in zfcp_fsf_exchange_port_data_handler()
692 struct fsf_qtcb *qtcb; in zfcp_fsf_qtcb_alloc() local
695 qtcb = mempool_alloc(pool, GFP_ATOMIC); in zfcp_fsf_qtcb_alloc()
697 qtcb = kmem_cache_alloc(zfcp_fsf_qtcb_cache, GFP_ATOMIC); in zfcp_fsf_qtcb_alloc()
699 if (unlikely(!qtcb)) in zfcp_fsf_qtcb_alloc()
702 memset(qtcb, 0, sizeof(*qtcb)); in zfcp_fsf_qtcb_alloc()
703 return qtcb; in zfcp_fsf_qtcb_alloc()
728 req->qtcb = zfcp_fsf_qtcb_alloc( in zfcp_fsf_req_create()
731 req->qtcb = zfcp_fsf_qtcb_alloc(NULL); in zfcp_fsf_req_create()
733 if (unlikely(!req->qtcb)) { in zfcp_fsf_req_create()
738 req->qtcb->prefix.req_seq_no = adapter->fsf_req_seq_no; in zfcp_fsf_req_create()
739 req->qtcb->prefix.req_id = req->req_id; in zfcp_fsf_req_create()
740 req->qtcb->prefix.ulp_info = 26; in zfcp_fsf_req_create()
741 req->qtcb->prefix.qtcb_type = fsf_qtcb_type[fsf_cmd]; in zfcp_fsf_req_create()
742 req->qtcb->prefix.qtcb_version = FSF_QTCB_CURRENT_VERSION; in zfcp_fsf_req_create()
743 req->qtcb->header.req_handle = req->req_id; in zfcp_fsf_req_create()
744 req->qtcb->header.fsf_command = fsf_cmd; in zfcp_fsf_req_create()
748 req->qtcb, sizeof(struct fsf_qtcb)); in zfcp_fsf_req_create()
851 union fsf_status_qual *fsq = &req->qtcb->header.fsf_status_qual; in zfcp_fsf_abort_fcp_command_handler()
858 switch (req->qtcb->header.fsf_status) { in zfcp_fsf_abort_fcp_command_handler()
937 req->qtcb->header.lun_handle = zfcp_sdev->lun_handle; in zfcp_fsf_abort_fcp_cmnd()
938 req->qtcb->header.port_handle = zfcp_sdev->port->handle; in zfcp_fsf_abort_fcp_cmnd()
939 req->qtcb->bottom.support.req_handle = (u64) old_req_id; in zfcp_fsf_abort_fcp_cmnd()
959 struct fsf_qtcb_header *header = &req->qtcb->header; in zfcp_fsf_send_ct_handler()
1018 struct fsf_qtcb *qtcb = req->qtcb; in zfcp_fsf_setup_ct_els_sbals() local
1024 qtcb->bottom.support.req_buf_length = in zfcp_fsf_setup_ct_els_sbals()
1028 qtcb->bottom.support.resp_buf_length = in zfcp_fsf_setup_ct_els_sbals()
1050 qtcb->bottom.support.req_buf_length = zfcp_qdio_real_bytes(sg_req); in zfcp_fsf_setup_ct_els_sbals()
1058 qtcb->bottom.support.resp_buf_length = zfcp_qdio_real_bytes(sg_resp); in zfcp_fsf_setup_ct_els_sbals()
1079 req->qtcb->bottom.support.service_class = FSF_CLASS_3; in zfcp_fsf_setup_ct_els()
1080 req->qtcb->bottom.support.timeout = timeout; in zfcp_fsf_setup_ct_els()
1119 req->qtcb->header.port_handle = wka_port->handle; in zfcp_fsf_send_ct()
1142 struct fsf_qtcb_header *header = &req->qtcb->header; in zfcp_fsf_send_els_handler()
1219 hton24(req->qtcb->bottom.support.d_id, d_id); in zfcp_fsf_send_els()
1262 req->qtcb->bottom.config.feature_selection = in zfcp_fsf_exchange_config_data()
1302 req->qtcb->bottom.config.feature_selection = in zfcp_fsf_exchange_config_data_sync()
1425 struct fsf_qtcb_header *header = &req->qtcb->header; in zfcp_fsf_open_port_handler()
1475 plogi = (struct fc_els_flogi *) req->qtcb->bottom.support.els; in zfcp_fsf_open_port_handler()
1476 if (req->qtcb->bottom.support.els1_length >= in zfcp_fsf_open_port_handler()
1518 hton24(req->qtcb->bottom.support.d_id, port->d_id); in zfcp_fsf_open_port()
1544 switch (req->qtcb->header.fsf_status) { in zfcp_fsf_close_port_handler()
1587 req->qtcb->header.port_handle = erp_action->port->handle; in zfcp_fsf_close_port()
1605 struct fsf_qtcb_header *header = &req->qtcb->header; in zfcp_fsf_open_wka_port_handler()
1660 hton24(req->qtcb->bottom.support.d_id, wka_port->d_id); in zfcp_fsf_open_wka_port()
1681 if (req->qtcb->header.fsf_status == FSF_PORT_HANDLE_NOT_VALID) { in zfcp_fsf_close_wka_port_handler()
1720 req->qtcb->header.port_handle = wka_port->handle; in zfcp_fsf_close_wka_port()
1739 struct fsf_qtcb_header *header = &req->qtcb->header; in zfcp_fsf_close_physical_port_handler()
1813 req->qtcb->header.port_handle = erp_action->port->handle; in zfcp_fsf_close_physical_port()
1835 struct fsf_qtcb_header *header = &req->qtcb->header; in zfcp_fsf_open_lun_handler()
1932 req->qtcb->header.port_handle = erp_action->port->handle; in zfcp_fsf_open_lun()
1933 req->qtcb->bottom.support.fcp_lun = zfcp_scsi_dev_lun(erp_action->sdev); in zfcp_fsf_open_lun()
1940 req->qtcb->bottom.support.option = FSF_OPEN_LUN_SUPPRESS_BOXING; in zfcp_fsf_open_lun()
1964 switch (req->qtcb->header.fsf_status) { in zfcp_fsf_close_lun_handler()
1981 switch (req->qtcb->header.fsf_status_qual.word[0]) { in zfcp_fsf_close_lun_handler()
2024 req->qtcb->header.port_handle = erp_action->port->handle; in zfcp_fsf_close_lun()
2025 req->qtcb->header.lun_handle = zfcp_sdev->lun_handle; in zfcp_fsf_close_lun()
2058 lat_in = &req->qtcb->prefix.prot_status_qual.latency_info; in zfcp_fsf_req_trace()
2074 switch (req->qtcb->bottom.io.data_direction) { in zfcp_fsf_req_trace()
2112 struct fsf_qtcb_header *header = &req->qtcb->header; in zfcp_fsf_fcp_handler_common()
2137 req->qtcb->bottom.io.data_direction, in zfcp_fsf_fcp_handler_common()
2146 req->qtcb->bottom.io.fcp_cmnd_length); in zfcp_fsf_fcp_handler_common()
2193 switch (req->qtcb->header.fsf_status) { in zfcp_fsf_fcp_cmnd_handler()
2209 fcp_rsp = &req->qtcb->bottom.io.fcp_rsp.iu; in zfcp_fsf_fcp_cmnd_handler()
2305 io = &req->qtcb->bottom.io; in zfcp_fsf_fcp_cmnd()
2309 req->qtcb->header.lun_handle = zfcp_sdev->lun_handle; in zfcp_fsf_fcp_cmnd()
2310 req->qtcb->header.port_handle = zfcp_sdev->port->handle; in zfcp_fsf_fcp_cmnd()
2323 fcp_cmnd = &req->qtcb->bottom.io.fcp_cmnd.iu; in zfcp_fsf_fcp_cmnd()
2370 fcp_rsp = &req->qtcb->bottom.io.fcp_rsp.iu; in zfcp_fsf_fcp_task_mgmt_handler()
2413 req->qtcb->header.lun_handle = zfcp_sdev->lun_handle; in zfcp_fsf_fcp_task_mgmt()
2414 req->qtcb->header.port_handle = zfcp_sdev->port->handle; in zfcp_fsf_fcp_task_mgmt()
2415 req->qtcb->bottom.io.data_direction = FSF_DATADIR_CMND; in zfcp_fsf_fcp_task_mgmt()
2416 req->qtcb->bottom.io.service_class = FSF_CLASS_3; in zfcp_fsf_fcp_task_mgmt()
2417 req->qtcb->bottom.io.fcp_cmnd_length = FCP_CMND_LEN; in zfcp_fsf_fcp_task_mgmt()
2421 fcp_cmnd = &req->qtcb->bottom.io.fcp_cmnd.iu; in zfcp_fsf_fcp_task_mgmt()