Lines Matching refs:ascb

67 static void asd_phy_event_tasklet(struct asd_ascb *ascb,  in asd_phy_event_tasklet()  argument
70 struct asd_ha_struct *asd_ha = ascb->ha; in asd_phy_event_tasklet()
216 static void asd_bytes_dmaed_tasklet(struct asd_ascb *ascb, in asd_bytes_dmaed_tasklet() argument
221 int edb_el = edb_id + ascb->edb_index; in asd_bytes_dmaed_tasklet()
222 struct asd_dma_tok *edb = ascb->ha->seq.edb_arr[edb_el]; in asd_bytes_dmaed_tasklet()
223 struct asd_phy *phy = &ascb->ha->phys[phy_id]; in asd_bytes_dmaed_tasklet()
234 asd_form_port(ascb->ha, phy); in asd_bytes_dmaed_tasklet()
238 static void asd_link_reset_err_tasklet(struct asd_ascb *ascb, in asd_link_reset_err_tasklet() argument
242 struct asd_ha_struct *asd_ha = ascb->ha; in asd_link_reset_err_tasklet()
275 struct asd_ascb *cp = asd_ascb_alloc_list(ascb->ha, &num, in asd_link_reset_err_tasklet()
284 if (asd_post_ascb_list(ascb->ha, cp, 1) != 0) in asd_link_reset_err_tasklet()
291 static void asd_primitive_rcvd_tasklet(struct asd_ascb *ascb, in asd_primitive_rcvd_tasklet() argument
296 struct sas_ha_struct *sas_ha = &ascb->ha->sas_ha; in asd_primitive_rcvd_tasklet()
298 struct asd_ha_struct *asd_ha = ascb->ha; in asd_primitive_rcvd_tasklet()
362 void asd_invalidate_edb(struct asd_ascb *ascb, int edb_id) in asd_invalidate_edb() argument
364 struct asd_seq_data *seq = &ascb->ha->seq; in asd_invalidate_edb()
365 struct empty_scb *escb = &ascb->scb->escb; in asd_invalidate_edb()
367 struct asd_dma_tok *edb = seq->edb_arr[ascb->edb_index + edb_id]; in asd_invalidate_edb()
387 if (!list_empty(&ascb->list)) in asd_invalidate_edb()
388 list_del_init(&ascb->list); in asd_invalidate_edb()
389 i = asd_post_escb_list(ascb->ha, ascb, 1); in asd_invalidate_edb()
395 static void escb_tasklet_complete(struct asd_ascb *ascb, in escb_tasklet_complete() argument
398 struct asd_ha_struct *asd_ha = ascb->ha; in escb_tasklet_complete()
414 ascb->dma_scb.vaddr, in escb_tasklet_complete()
415 (unsigned long long)ascb->dma_scb.dma_handle, in escb_tasklet_complete()
417 le64_to_cpu(ascb->scb->header.next_scb), in escb_tasklet_complete()
418 le16_to_cpu(ascb->scb->header.index), in escb_tasklet_complete()
419 ascb->scb->header.opcode); in escb_tasklet_complete()
545 asd_bytes_dmaed_tasklet(ascb, dl, edb, phy_id); in escb_tasklet_complete()
550 asd_primitive_rcvd_tasklet(ascb, dl, phy_id); in escb_tasklet_complete()
554 asd_phy_event_tasklet(ascb, dl); in escb_tasklet_complete()
559 asd_link_reset_err_tasklet(ascb, dl, phy_id); in escb_tasklet_complete()
580 ascb->dma_scb.vaddr, in escb_tasklet_complete()
581 (unsigned long long)ascb->dma_scb.dma_handle, in escb_tasklet_complete()
583 le64_to_cpu(ascb->scb->header.next_scb), in escb_tasklet_complete()
584 le16_to_cpu(ascb->scb->header.index), in escb_tasklet_complete()
585 ascb->scb->header.opcode); in escb_tasklet_complete()
590 asd_invalidate_edb(ascb, edb); in escb_tasklet_complete()
622 static void control_phy_tasklet_complete(struct asd_ascb *ascb, in control_phy_tasklet_complete() argument
625 struct asd_ha_struct *asd_ha = ascb->ha; in control_phy_tasklet_complete()
626 struct scb *scb = ascb->scb; in control_phy_tasklet_complete()
629 struct asd_phy *phy = &ascb->ha->phys[phy_id]; in control_phy_tasklet_complete()
695 asd_ascb_free(ascb); in control_phy_tasklet_complete()
760 void asd_build_control_phy(struct asd_ascb *ascb, int phy_id, u8 subfunc) in asd_build_control_phy() argument
762 struct asd_phy *phy = &ascb->ha->phys[phy_id]; in asd_build_control_phy()
763 struct scb *scb = ascb->scb; in asd_build_control_phy()
803 ascb->tasklet_complete = control_phy_tasklet_complete; in asd_build_control_phy()
810 static void link_adm_tasklet_complete(struct asd_ascb *ascb,
814 struct initiate_link_adm *link_adm = &ascb->scb->link_adm;
824 asd_ascb_free(ascb);
827 void asd_build_initiate_link_adm_task(struct asd_ascb *ascb, int phy_id,
830 struct scb *scb = ascb->scb;
839 ascb->tasklet_complete = link_adm_tasklet_complete;
859 struct asd_ascb *ascb = from_timer(ascb, t, timer); in asd_ascb_timedout() local
860 struct asd_seq_data *seq = &ascb->ha->seq; in asd_ascb_timedout()
863 ASD_DPRINTK("scb:0x%x timed out\n", ascb->scb->header.opcode); in asd_ascb_timedout()
867 list_del_init(&ascb->list); in asd_ascb_timedout()
870 asd_ascb_free(ascb); in asd_ascb_timedout()
888 struct asd_ascb *ascb; in asd_control_phy() local
912 ascb = asd_ascb_alloc_list(asd_ha, &res, GFP_KERNEL); in asd_control_phy()
913 if (!ascb) in asd_control_phy()
916 asd_build_control_phy(ascb, phy->id, phy_func_table[func]); in asd_control_phy()
917 res = asd_post_ascb_list(asd_ha, ascb , 1); in asd_control_phy()
919 asd_ascb_free(ascb); in asd_control_phy()