Lines Matching refs:prm

1685 	struct qla_tgt_sess_work_param *prm;  in qlt_sched_sess_work()  local
1688 prm = kzalloc(sizeof(*prm), GFP_ATOMIC); in qlt_sched_sess_work()
1689 if (!prm) { in qlt_sched_sess_work()
1699 type, prm, param, param_size, tgt); in qlt_sched_sess_work()
1701 prm->type = type; in qlt_sched_sess_work()
1702 memcpy(&prm->tm_iocb, param, param_size); in qlt_sched_sess_work()
1705 list_add_tail(&prm->sess_works_list_entry, &tgt->sess_works_list); in qlt_sched_sess_work()
2452 static int qlt_pci_map_calc_cnt(struct qla_tgt_prm *prm) in qlt_pci_map_calc_cnt() argument
2454 struct qla_tgt_cmd *cmd = prm->cmd; in qlt_pci_map_calc_cnt()
2458 prm->sg = (struct scatterlist *)cmd->sg; in qlt_pci_map_calc_cnt()
2459 prm->seg_cnt = dma_map_sg(&cmd->qpair->pdev->dev, cmd->sg, in qlt_pci_map_calc_cnt()
2461 if (unlikely(prm->seg_cnt == 0)) in qlt_pci_map_calc_cnt()
2464 prm->cmd->sg_mapped = 1; in qlt_pci_map_calc_cnt()
2471 if (prm->seg_cnt > QLA_TGT_DATASEGS_PER_CMD_24XX) in qlt_pci_map_calc_cnt()
2472 prm->req_cnt += DIV_ROUND_UP(prm->seg_cnt - in qlt_pci_map_calc_cnt()
2479 prm->seg_cnt = DIV_ROUND_UP(cmd->bufflen, cmd->blk_sz); in qlt_pci_map_calc_cnt()
2480 prm->tot_dsds = prm->seg_cnt; in qlt_pci_map_calc_cnt()
2482 prm->tot_dsds = prm->seg_cnt; in qlt_pci_map_calc_cnt()
2485 prm->prot_sg = cmd->prot_sg; in qlt_pci_map_calc_cnt()
2486 prm->prot_seg_cnt = dma_map_sg(&cmd->qpair->pdev->dev, in qlt_pci_map_calc_cnt()
2489 if (unlikely(prm->prot_seg_cnt == 0)) in qlt_pci_map_calc_cnt()
2495 prm->prot_seg_cnt = DIV_ROUND_UP(cmd->bufflen, in qlt_pci_map_calc_cnt()
2497 prm->tot_dsds += prm->prot_seg_cnt; in qlt_pci_map_calc_cnt()
2499 prm->tot_dsds += prm->prot_seg_cnt; in qlt_pci_map_calc_cnt()
2506 ql_dbg_qp(ql_dbg_tgt, prm->cmd->qpair, 0xe04d, in qlt_pci_map_calc_cnt()
2508 0, prm->cmd->sg_cnt); in qlt_pci_map_calc_cnt()
2617 struct qla_tgt_prm *prm) in qlt_24xx_build_ctio_pkt() argument
2621 struct atio_from_isp *atio = &prm->cmd->atio; in qlt_24xx_build_ctio_pkt()
2623 struct qla_tgt_cmd *cmd = prm->cmd; in qlt_24xx_build_ctio_pkt()
2626 prm->pkt = pkt; in qlt_24xx_build_ctio_pkt()
2630 pkt->entry_count = (uint8_t)prm->req_cnt; in qlt_24xx_build_ctio_pkt()
2631 pkt->vp_index = prm->cmd->vp_idx; in qlt_24xx_build_ctio_pkt()
2642 qpair->req->outstanding_cmds[h] = (srb_t *)prm->cmd; in qlt_24xx_build_ctio_pkt()
2646 pkt->nport_handle = cpu_to_le16(prm->cmd->loop_id); in qlt_24xx_build_ctio_pkt()
2654 pkt->u.status0.relative_offset = cpu_to_le32(prm->cmd->offset); in qlt_24xx_build_ctio_pkt()
2658 prm->cmd->sess->edif.rx_bytes += cmd->bufflen; in qlt_24xx_build_ctio_pkt()
2660 prm->cmd->sess->edif.tx_bytes += cmd->bufflen; in qlt_24xx_build_ctio_pkt()
2672 static void qlt_load_cont_data_segments(struct qla_tgt_prm *prm) in qlt_load_cont_data_segments() argument
2678 while (prm->seg_cnt > 0) { in qlt_load_cont_data_segments()
2681 prm->cmd->qpair->req); in qlt_load_cont_data_segments()
2700 cnt < QLA_TGT_DATASEGS_PER_CONT_24XX && prm->seg_cnt; in qlt_load_cont_data_segments()
2701 cnt++, prm->seg_cnt--) { in qlt_load_cont_data_segments()
2702 append_dsd64(&cur_dsd, prm->sg); in qlt_load_cont_data_segments()
2703 prm->sg = sg_next(prm->sg); in qlt_load_cont_data_segments()
2712 static void qlt_load_data_segments(struct qla_tgt_prm *prm) in qlt_load_data_segments() argument
2716 struct ctio7_to_24xx *pkt24 = (struct ctio7_to_24xx *)prm->pkt; in qlt_load_data_segments()
2718 pkt24->u.status0.transfer_length = cpu_to_le32(prm->cmd->bufflen); in qlt_load_data_segments()
2724 if (prm->seg_cnt) in qlt_load_data_segments()
2725 pkt24->dseg_count = cpu_to_le16(prm->seg_cnt); in qlt_load_data_segments()
2727 if (prm->seg_cnt == 0) { in qlt_load_data_segments()
2738 (cnt < QLA_TGT_DATASEGS_PER_CMD_24XX) && prm->seg_cnt; in qlt_load_data_segments()
2739 cnt++, prm->seg_cnt--) { in qlt_load_data_segments()
2740 append_dsd64(&cur_dsd, prm->sg); in qlt_load_data_segments()
2741 prm->sg = sg_next(prm->sg); in qlt_load_data_segments()
2744 qlt_load_cont_data_segments(prm); in qlt_load_data_segments()
2752 static void qlt_print_dif_err(struct qla_tgt_prm *prm) in qlt_print_dif_err() argument
2758 if (prm->sense_buffer && (prm->sense_buffer[12] == 0x10)) { in qlt_print_dif_err()
2759 cmd = prm->cmd; in qlt_print_dif_err()
2762 switch (prm->sense_buffer[13]) { in qlt_print_dif_err()
2800 struct qla_tgt_prm *prm, int xmit_type, uint8_t scsi_status, in qlt_pre_xmit_response() argument
2806 prm->cmd = cmd; in qlt_pre_xmit_response()
2807 prm->tgt = cmd->tgt; in qlt_pre_xmit_response()
2808 prm->pkt = NULL; in qlt_pre_xmit_response()
2809 prm->rq_result = scsi_status; in qlt_pre_xmit_response()
2810 prm->sense_buffer = &cmd->sense_buffer[0]; in qlt_pre_xmit_response()
2811 prm->sense_buffer_len = TRANSPORT_SENSE_BUFFER; in qlt_pre_xmit_response()
2812 prm->sg = NULL; in qlt_pre_xmit_response()
2813 prm->seg_cnt = -1; in qlt_pre_xmit_response()
2814 prm->req_cnt = 1; in qlt_pre_xmit_response()
2815 prm->residual = 0; in qlt_pre_xmit_response()
2816 prm->add_status_pkt = 0; in qlt_pre_xmit_response()
2817 prm->prot_sg = NULL; in qlt_pre_xmit_response()
2818 prm->prot_seg_cnt = 0; in qlt_pre_xmit_response()
2819 prm->tot_dsds = 0; in qlt_pre_xmit_response()
2822 if (qlt_pci_map_calc_cnt(prm) != 0) in qlt_pre_xmit_response()
2826 *full_req_cnt = prm->req_cnt; in qlt_pre_xmit_response()
2829 prm->residual = se_cmd->residual_count; in qlt_pre_xmit_response()
2832 prm->residual, se_cmd->tag, in qlt_pre_xmit_response()
2834 cmd->bufflen, prm->rq_result); in qlt_pre_xmit_response()
2835 prm->rq_result |= SS_RESIDUAL_UNDER; in qlt_pre_xmit_response()
2837 prm->residual = se_cmd->residual_count; in qlt_pre_xmit_response()
2840 prm->residual, se_cmd->tag, se_cmd->t_task_cdb ? in qlt_pre_xmit_response()
2841 se_cmd->t_task_cdb[0] : 0, cmd->bufflen, prm->rq_result); in qlt_pre_xmit_response()
2842 prm->rq_result |= SS_RESIDUAL_OVER; in qlt_pre_xmit_response()
2851 if (QLA_TGT_SENSE_VALID(prm->sense_buffer) || in qlt_pre_xmit_response()
2853 (prm->rq_result != 0))) { in qlt_pre_xmit_response()
2854 prm->add_status_pkt = 1; in qlt_pre_xmit_response()
2877 struct qla_tgt_prm *prm) in qlt_24xx_init_ctio_to_isp() argument
2879 prm->sense_buffer_len = min_t(uint32_t, prm->sense_buffer_len, in qlt_24xx_init_ctio_to_isp()
2882 if (qlt_need_explicit_conf(prm->cmd, 0)) { in qlt_24xx_init_ctio_to_isp()
2887 ctio->u.status0.residual = cpu_to_le32(prm->residual); in qlt_24xx_init_ctio_to_isp()
2888 ctio->u.status0.scsi_status = cpu_to_le16(prm->rq_result); in qlt_24xx_init_ctio_to_isp()
2889 if (QLA_TGT_SENSE_VALID(prm->sense_buffer)) { in qlt_24xx_init_ctio_to_isp()
2892 if (qlt_need_explicit_conf(prm->cmd, 1)) { in qlt_24xx_init_ctio_to_isp()
2893 if ((prm->rq_result & SS_SCSI_STATUS_BYTE) != 0) { in qlt_24xx_init_ctio_to_isp()
2894 ql_dbg_qp(ql_dbg_tgt, prm->cmd->qpair, 0xe017, in qlt_24xx_init_ctio_to_isp()
2912 cpu_to_le16(prm->sense_buffer_len); in qlt_24xx_init_ctio_to_isp()
2913 for (i = 0; i < prm->sense_buffer_len/4; i++) { in qlt_24xx_init_ctio_to_isp()
2917 &((uint32_t *)prm->sense_buffer)[i]); in qlt_24xx_init_ctio_to_isp()
2921 qlt_print_dif_err(prm); in qlt_24xx_init_ctio_to_isp()
3066 qlt_build_ctio_crc2_pkt(struct qla_qpair *qpair, struct qla_tgt_prm *prm) in qlt_build_ctio_crc2_pkt() argument
3078 struct qla_tgt_cmd *cmd = prm->cmd; in qlt_build_ctio_crc2_pkt()
3081 struct atio_from_isp *atio = &prm->cmd->atio; in qlt_build_ctio_crc2_pkt()
3089 prm->pkt = pkt; in qlt_build_ctio_crc2_pkt()
3095 prm->prot_sg, prm->prot_seg_cnt, se_cmd->t_task_lba); in qlt_build_ctio_crc2_pkt()
3168 qpair->req->outstanding_cmds[h] = (srb_t *)prm->cmd; in qlt_build_ctio_crc2_pkt()
3172 pkt->nport_handle = cpu_to_le16(prm->cmd->loop_id); in qlt_build_ctio_crc2_pkt()
3183 pkt->relative_offset = cpu_to_le32(prm->cmd->offset); in qlt_build_ctio_crc2_pkt()
3191 pkt->dseg_count = cpu_to_le16(prm->tot_dsds); in qlt_build_ctio_crc2_pkt()
3225 cpu_to_le16(prm->tot_dsds - prm->prot_seg_cnt); in qlt_build_ctio_crc2_pkt()
3247 if (!bundling && prm->prot_seg_cnt) { in qlt_build_ctio_crc2_pkt()
3249 prm->tot_dsds, &tc)) in qlt_build_ctio_crc2_pkt()
3252 (prm->tot_dsds - prm->prot_seg_cnt), &tc)) in qlt_build_ctio_crc2_pkt()
3255 if (bundling && prm->prot_seg_cnt) { in qlt_build_ctio_crc2_pkt()
3261 prm->prot_seg_cnt, cmd)) in qlt_build_ctio_crc2_pkt()
3283 struct qla_tgt_prm prm; in qlt_xmit_response() local
3300 res = qlt_pre_xmit_response(cmd, &prm, xmit_type, scsi_status, in qlt_xmit_response()
3332 res = qlt_build_ctio_crc2_pkt(qpair, &prm); in qlt_xmit_response()
3334 res = qlt_24xx_build_ctio_pkt(qpair, &prm); in qlt_xmit_response()
3340 pkt = (struct ctio7_to_24xx *)prm.pkt; in qlt_xmit_response()
3348 qlt_load_data_segments(&prm); in qlt_xmit_response()
3350 if (prm.add_status_pkt == 0) { in qlt_xmit_response()
3353 cpu_to_le16(prm.rq_result); in qlt_xmit_response()
3356 cpu_to_le32(prm.residual); in qlt_xmit_response()
3404 &prm); in qlt_xmit_response()
3407 qlt_24xx_init_ctio_to_isp(pkt, &prm); in qlt_xmit_response()
3437 struct qla_tgt_prm prm; in qlt_rdy_to_xfer() local
3442 memset(&prm, 0, sizeof(prm)); in qlt_rdy_to_xfer()
3443 prm.cmd = cmd; in qlt_rdy_to_xfer()
3444 prm.tgt = tgt; in qlt_rdy_to_xfer()
3445 prm.sg = NULL; in qlt_rdy_to_xfer()
3446 prm.req_cnt = 1; in qlt_rdy_to_xfer()
3466 if (qlt_pci_map_calc_cnt(&prm) != 0) in qlt_rdy_to_xfer()
3471 res = qlt_check_reserve_free_req(qpair, prm.req_cnt); in qlt_rdy_to_xfer()
3475 res = qlt_build_ctio_crc2_pkt(qpair, &prm); in qlt_rdy_to_xfer()
3477 res = qlt_24xx_build_ctio_pkt(qpair, &prm); in qlt_rdy_to_xfer()
3480 qpair->req->cnt += prm.req_cnt; in qlt_rdy_to_xfer()
3484 pkt = (struct ctio7_to_24xx *)prm.pkt; in qlt_rdy_to_xfer()
3489 qlt_load_data_segments(&prm); in qlt_rdy_to_xfer()
6301 struct qla_tgt_sess_work_param *prm) in qlt_abort_work() argument
6315 s_id = le_id_to_be(prm->abts.fcp_hdr_le.s_id); in qlt_abort_work()
6342 rc = __qlt_24xx_handle_abts(vha, &prm->abts, sess); in qlt_abort_work()
6356 qlt_24xx_send_abts_resp(ha->base_qpair, &prm->abts, in qlt_abort_work()
6362 struct qla_tgt_sess_work_param *prm) in qlt_tmr_work() argument
6364 struct atio_from_isp *a = &prm->tm_iocb2; in qlt_tmr_work()
6380 s_id = prm->tm_iocb2.u.isp24.fcp_hdr.s_id; in qlt_tmr_work()
6421 qlt_send_term_exchange(ha->base_qpair, NULL, &prm->tm_iocb2, 1, 0); in qlt_tmr_work()
6434 struct qla_tgt_sess_work_param *prm = list_entry( in qlt_sess_work_fn() local
6435 tgt->sess_works_list.next, typeof(*prm), in qlt_sess_work_fn()
6442 list_del(&prm->sess_works_list_entry); in qlt_sess_work_fn()
6446 switch (prm->type) { in qlt_sess_work_fn()
6448 qlt_abort_work(tgt, prm); in qlt_sess_work_fn()
6451 qlt_tmr_work(tgt, prm); in qlt_sess_work_fn()
6460 kfree(prm); in qlt_sess_work_fn()