|
@@ -252,10 +252,16 @@ static void mmp_pdma_free_phy(struct mmp_pdma_chan *pchan)
|
|
{
|
|
{
|
|
struct mmp_pdma_device *pdev = to_mmp_pdma_dev(pchan->chan.device);
|
|
struct mmp_pdma_device *pdev = to_mmp_pdma_dev(pchan->chan.device);
|
|
unsigned long flags;
|
|
unsigned long flags;
|
|
|
|
+ u32 reg;
|
|
|
|
|
|
if (!pchan->phy)
|
|
if (!pchan->phy)
|
|
return;
|
|
return;
|
|
|
|
|
|
|
|
+ /* clear the channel mapping in DRCMR */
|
|
|
|
+ reg = pchan->phy->vchan->drcmr;
|
|
|
|
+ reg = ((reg < 64) ? 0x0100 : 0x1100) + ((reg & 0x3f) << 2);
|
|
|
|
+ writel(0, pchan->phy->base + reg);
|
|
|
|
+
|
|
spin_lock_irqsave(&pdev->phy_lock, flags);
|
|
spin_lock_irqsave(&pdev->phy_lock, flags);
|
|
pchan->phy->vchan = NULL;
|
|
pchan->phy->vchan = NULL;
|
|
pchan->phy = NULL;
|
|
pchan->phy = NULL;
|