Lines Matching refs:pdi
621 struct sdw_cdns_pdi *pdi, in intel_pdi_get_ch_update() argument
628 pdi->ch_count = intel_pdi_get_ch_cap(sdw, pdi->num, pcm); in intel_pdi_get_ch_update()
629 ch_count += pdi->ch_count; in intel_pdi_get_ch_update()
630 pdi++; in intel_pdi_get_ch_update()
662 intel_pdi_shim_configure(struct sdw_intel *sdw, struct sdw_cdns_pdi *pdi) in intel_pdi_shim_configure() argument
669 pdi->intel_alh_id = (link_id * 16) + pdi->num + 3; in intel_pdi_shim_configure()
670 if (pdi->num >= 2) in intel_pdi_shim_configure()
671 pdi->intel_alh_id += 2; in intel_pdi_shim_configure()
677 if (pdi->type != SDW_STREAM_PCM) in intel_pdi_shim_configure()
680 if (pdi->dir == SDW_DATA_DIR_RX) in intel_pdi_shim_configure()
685 u32p_replace_bits(&pdi_conf, pdi->intel_alh_id, SDW_SHIM_PCMSYCM_STREAM); in intel_pdi_shim_configure()
686 u32p_replace_bits(&pdi_conf, pdi->l_ch_num, SDW_SHIM_PCMSYCM_LCHN); in intel_pdi_shim_configure()
687 u32p_replace_bits(&pdi_conf, pdi->h_ch_num, SDW_SHIM_PCMSYCM_HCHN); in intel_pdi_shim_configure()
689 intel_writew(shim, SDW_SHIM_PCMSYCHM(link_id, pdi->num), pdi_conf); in intel_pdi_shim_configure()
693 intel_pdi_alh_configure(struct sdw_intel *sdw, struct sdw_cdns_pdi *pdi) in intel_pdi_alh_configure() argument
700 pdi->intel_alh_id = (link_id * 16) + pdi->num + 3; in intel_pdi_alh_configure()
701 if (pdi->num >= 2) in intel_pdi_alh_configure()
702 pdi->intel_alh_id += 2; in intel_pdi_alh_configure()
705 conf = intel_readl(alh, SDW_ALH_STRMZCFG(pdi->intel_alh_id)); in intel_pdi_alh_configure()
708 u32p_replace_bits(&conf, pdi->ch_count - 1, SDW_ALH_STRMZCFG_CHN); in intel_pdi_alh_configure()
710 intel_writel(alh, SDW_ALH_STRMZCFG(pdi->intel_alh_id), conf); in intel_pdi_alh_configure()
838 struct sdw_cdns_pdi *pdi; in intel_hw_params() local
859 pdi = sdw_cdns_alloc_pdi(cdns, &cdns->pcm, ch, dir, dai->id); in intel_hw_params()
861 pdi = sdw_cdns_alloc_pdi(cdns, &cdns->pdm, ch, dir, dai->id); in intel_hw_params()
863 if (!pdi) { in intel_hw_params()
869 intel_pdi_shim_configure(sdw, pdi); in intel_hw_params()
870 intel_pdi_alh_configure(sdw, pdi); in intel_hw_params()
871 sdw_cdns_config_stream(cdns, ch, dir, pdi); in intel_hw_params()
875 dma->pdi = pdi; in intel_hw_params()
881 pdi->intel_alh_id); in intel_hw_params()
904 pconfig->num = pdi->num; in intel_hw_params()
951 intel_pdi_shim_configure(sdw, dma->pdi); in intel_prepare()
952 intel_pdi_alh_configure(sdw, dma->pdi); in intel_prepare()
953 sdw_cdns_config_stream(cdns, ch, dir, dma->pdi); in intel_prepare()
959 dma->pdi->intel_alh_id); in intel_prepare()
997 dma->pdi = NULL; in intel_hw_free()