Lines Matching refs:scsiq
6117 ADV_SCSI_REQ_Q *scsiq; in AdvISR() local
6175 scsiq = &reqp->scsi_req_q; in AdvISR()
6183 scsiq->done_status = QD_NO_ERROR; in AdvISR()
6184 scsiq->host_status = scsiq->scsi_status = 0; in AdvISR()
6185 scsiq->data_cnt = 0L; in AdvISR()
6201 target_bit = ADV_TID_TO_TIDMASK(scsiq->target_id); in AdvISR()
6206 scsiq->cntl = 0; in AdvISR()
6212 adv_isr_callback(asc_dvc, scsiq); in AdvISR()
6691 ASC_QDONE_INFO *scsiq, unsigned int max_dma_count) in _AscCopyLramScsiDoneQ() argument
6698 (uchar *)scsiq, in _AscCopyLramScsiDoneQ()
6703 scsiq->q_status = (uchar)_val; in _AscCopyLramScsiDoneQ()
6704 scsiq->q_no = (uchar)(_val >> 8); in _AscCopyLramScsiDoneQ()
6707 scsiq->cntl = (uchar)_val; in _AscCopyLramScsiDoneQ()
6712 scsiq->sense_len = (uchar)_val; in _AscCopyLramScsiDoneQ()
6713 scsiq->extra_bytes = (uchar)(_val >> 8); in _AscCopyLramScsiDoneQ()
6718 scsiq->remain_bytes = (((u32)AscReadLramWord(iop_base, in _AscCopyLramScsiDoneQ()
6726 scsiq->remain_bytes += AscReadLramWord(iop_base, in _AscCopyLramScsiDoneQ()
6730 scsiq->remain_bytes &= max_dma_count; in _AscCopyLramScsiDoneQ()
6866 ASC_QDONE_INFO *scsiq; in AscIsrQDone() local
6871 scsiq = (ASC_QDONE_INFO *)&scsiq_buf; in AscIsrQDone()
6879 sg_queue_cnt = _AscCopyLramScsiDoneQ(iop_base, q_addr, scsiq, in AscIsrQDone()
6884 (uchar)(scsiq-> in AscIsrQDone()
6887 tid_no = ASC_TIX_TO_TID(scsiq->d2.target_ix); in AscIsrQDone()
6888 target_id = ASC_TIX_TO_TARGET_ID(scsiq->d2.target_ix); in AscIsrQDone()
6889 if ((scsiq->cntl & QC_SG_HEAD) != 0) { in AscIsrQDone()
6901 scsiq->d3.done_stat = QD_WITH_ERROR; in AscIsrQDone()
6902 scsiq->d3.host_stat = in AscIsrQDone()
6919 scsiq->d2. in AscIsrQDone()
6938 scsiq->d3.done_stat = QD_WITH_ERROR; in AscIsrQDone()
6941 if ((scsiq->d2.srb_tag == 0UL) || in AscIsrQDone()
6942 ((scsiq->q_status & QS_ABORTED) != 0)) { in AscIsrQDone()
6944 } else if (scsiq->q_status == QS_DONE) { in AscIsrQDone()
6950 if (scsiq->extra_bytes != 0) { in AscIsrQDone()
6951 scsiq->remain_bytes += scsiq->extra_bytes; in AscIsrQDone()
6953 if (scsiq->d3.done_stat == QD_WITH_ERROR) { in AscIsrQDone()
6954 if (scsiq->d3.host_stat == in AscIsrQDone()
6956 if ((scsiq-> in AscIsrQDone()
6959 scsiq->d3.done_stat = in AscIsrQDone()
6961 scsiq->d3.host_stat = in AscIsrQDone()
6964 scsiq->d3.done_stat = in AscIsrQDone()
6966 scsiq->d3.host_stat = in AscIsrQDone()
6969 } else if (scsiq->d3.host_stat == in AscIsrQDone()
6983 if ((scsiq->cntl & QC_NO_CALLBACK) == 0) { in AscIsrQDone()
6984 asc_isr_callback(asc_dvc, scsiq); in AscIsrQDone()
6991 if (scsiq->d3.done_stat != QD_NO_ERROR) { in AscIsrQDone()
7001 if ((scsiq->cntl & QC_NO_CALLBACK) == 0) { in AscIsrQDone()
7002 asc_isr_callback(asc_dvc, scsiq); in AscIsrQDone()
7957 static int AscPutReadyQueue(ASC_DVC_VAR *asc_dvc, ASC_SCSI_Q *scsiq, uchar q_no) in AscPutReadyQueue() argument
7967 if (((asc_dvc->init_sdtr & scsiq->q1.target_id) != 0) && in AscPutReadyQueue()
7968 ((asc_dvc->sdtr_done & scsiq->q1.target_id) == 0)) { in AscPutReadyQueue()
7969 tid_no = ASC_TIX_TO_TID(scsiq->q2.target_ix); in AscPutReadyQueue()
7977 scsiq->q1.cntl |= QC_MSG_OUT; in AscPutReadyQueue()
7980 if ((scsiq->q1.target_id & asc_dvc->use_tagged_qng) == 0) { in AscPutReadyQueue()
7981 scsiq->q2.tag_code &= ~SIMPLE_QUEUE_TAG; in AscPutReadyQueue()
7983 scsiq->q1.status = QS_FREE; in AscPutReadyQueue()
7986 (uchar *)scsiq->cdbptr, scsiq->q2.cdb_len >> 1); in AscPutReadyQueue()
7990 (uchar *)&scsiq->q1.cntl, in AscPutReadyQueue()
7994 (ushort)(((ushort)scsiq->q1. in AscPutReadyQueue()
8000 AscPutReadySgListQueue(ASC_DVC_VAR *asc_dvc, ASC_SCSI_Q *scsiq, uchar q_no) in AscPutReadySgListQueue() argument
8016 sg_head = scsiq->sg_head; in AscPutReadySgListQueue()
8017 saved_data_addr = scsiq->q1.data_addr; in AscPutReadySgListQueue()
8018 saved_data_cnt = scsiq->q1.data_cnt; in AscPutReadySgListQueue()
8019 scsiq->q1.data_addr = cpu_to_le32(sg_head->sg_list[0].addr); in AscPutReadySgListQueue()
8020 scsiq->q1.data_cnt = cpu_to_le32(sg_head->sg_list[0].bytes); in AscPutReadySgListQueue()
8029 scsiq->q1.cntl |= QC_SG_HEAD; in AscPutReadySgListQueue()
8032 scsiq->q1.sg_queue_cnt = sg_head->queue_cnt; in AscPutReadySgListQueue()
8081 scsiq->next_sg_index = sg_index; in AscPutReadySgListQueue()
8084 scsiq->q1.cntl &= ~QC_SG_HEAD; in AscPutReadySgListQueue()
8086 sta = AscPutReadyQueue(asc_dvc, scsiq, q_no); in AscPutReadySgListQueue()
8087 scsiq->q1.data_addr = saved_data_addr; in AscPutReadySgListQueue()
8088 scsiq->q1.data_cnt = saved_data_cnt; in AscPutReadySgListQueue()
8093 AscSendScsiQueue(ASC_DVC_VAR *asc_dvc, ASC_SCSI_Q *scsiq, uchar n_q_required) in AscSendScsiQueue() argument
8103 target_ix = scsiq->q2.target_ix; in AscSendScsiQueue()
8112 scsiq->sg_head->queue_cnt = n_q_required - 1; in AscSendScsiQueue()
8113 scsiq->q1.q_no = free_q_head; in AscSendScsiQueue()
8114 sta = AscPutReadySgListQueue(asc_dvc, scsiq, in AscSendScsiQueue()
8120 scsiq->q1.q_no = free_q_head; in AscSendScsiQueue()
8121 sta = AscPutReadyQueue(asc_dvc, scsiq, free_q_head); in AscSendScsiQueue()
8152 static int AscExeScsiQueue(ASC_DVC_VAR *asc_dvc, ASC_SCSI_Q *scsiq) in AscExeScsiQueue() argument
8172 sg_head = scsiq->sg_head; in AscExeScsiQueue()
8175 scsiq->q1.q_no = 0; in AscExeScsiQueue()
8176 if ((scsiq->q2.tag_code & ASC_TAG_FLAG_EXTRA_BYTES) == 0) { in AscExeScsiQueue()
8177 scsiq->q1.extra_bytes = 0; in AscExeScsiQueue()
8180 target_ix = scsiq->q2.target_ix; in AscExeScsiQueue()
8183 if (scsiq->cdbptr[0] == REQUEST_SENSE) { in AscExeScsiQueue()
8184 if ((asc_dvc->init_sdtr & scsiq->q1.target_id) != 0) { in AscExeScsiQueue()
8185 asc_dvc->sdtr_done &= ~scsiq->q1.target_id; in AscExeScsiQueue()
8195 scsiq->q1.cntl |= (QC_MSG_OUT | QC_URGENT); in AscExeScsiQueue()
8203 if ((scsiq->q1.cntl & QC_SG_HEAD) != 0) { in AscExeScsiQueue()
8213 scsiq->q1.data_addr = cpu_to_le32(sg_head->sg_list[0].addr); in AscExeScsiQueue()
8214 scsiq->q1.data_cnt = cpu_to_le32(sg_head->sg_list[0].bytes); in AscExeScsiQueue()
8215 scsiq->q1.cntl &= ~(QC_SG_HEAD | QC_SG_SWAP_QUEUE); in AscExeScsiQueue()
8219 scsi_cmd = scsiq->cdbptr[0]; in AscExeScsiQueue()
8221 if ((asc_dvc->pci_fix_asyn_xfer & scsiq->q1.target_id) && in AscExeScsiQueue()
8222 !(asc_dvc->pci_fix_asyn_xfer_always & scsiq->q1.target_id)) { in AscExeScsiQueue()
8223 if (scsiq->q1.cntl & QC_SG_HEAD) { in AscExeScsiQueue()
8230 data_cnt = le32_to_cpu(scsiq->q1.data_cnt); in AscExeScsiQueue()
8253 scsiq->q2.tag_code &= ~SIMPLE_QUEUE_TAG; in AscExeScsiQueue()
8254 scsiq->q2.tag_code |= (ASC_TAG_FLAG_DISABLE_ASYN_USE_SYN_FIX | in AscExeScsiQueue()
8257 scsiq->q2.tag_code &= 0x27; in AscExeScsiQueue()
8259 if ((scsiq->q1.cntl & QC_SG_HEAD) != 0) { in AscExeScsiQueue()
8276 ((scsiq->q2. in AscExeScsiQueue()
8280 scsiq->q2.tag_code |= in AscExeScsiQueue()
8282 scsiq->q1.extra_bytes = in AscExeScsiQueue()
8303 || ((scsiq->q1.cntl & QC_URGENT) != 0)) { in AscExeScsiQueue()
8305 AscSendScsiQueue(asc_dvc, scsiq, in AscExeScsiQueue()
8317 le32_to_cpu(scsiq->q1.data_addr) + in AscExeScsiQueue()
8318 le32_to_cpu(scsiq->q1.data_cnt); in AscExeScsiQueue()
8323 ((scsiq->q2. in AscExeScsiQueue()
8328 le32_to_cpu(scsiq->q1. in AscExeScsiQueue()
8332 scsiq->q2.tag_code |= in AscExeScsiQueue()
8335 scsiq->q1.data_cnt = in AscExeScsiQueue()
8338 scsiq->q1.extra_bytes = in AscExeScsiQueue()
8347 ((scsiq->q1.cntl & QC_URGENT) != 0)) { in AscExeScsiQueue()
8348 if ((sta = AscSendScsiQueue(asc_dvc, scsiq, in AscExeScsiQueue()
8384 ADV_SCSI_REQ_Q *scsiq = &reqp->scsi_req_q; in AdvExeScsiQueue() local
8389 if (scsiq->target_id > ADV_MAX_TID) { in AdvExeScsiQueue()
8390 scsiq->host_status = QHSTA_M_INVALID_DEVICE; in AdvExeScsiQueue()
8391 scsiq->done_status = QD_WITH_ERROR; in AdvExeScsiQueue()
8410 scsiq->scsiq_ptr = cpu_to_le32(scsiq->srb_tag); in AdvExeScsiQueue()
8411 scsiq->scsiq_rptr = cpu_to_le32(reqp->req_addr); in AdvExeScsiQueue()
8413 scsiq->carr_va = asc_dvc->icq_sp->carr_va; in AdvExeScsiQueue()
8414 scsiq->carr_pa = asc_dvc->icq_sp->carr_pa; in AdvExeScsiQueue()
8421 asc_dvc->icq_sp->areq_vpa = scsiq->scsiq_rptr; in AdvExeScsiQueue()