> The udelay just doesn't make sense to what you are talking about. > > Does SAI really need 10us delay between two register-updating? >
No, this is not must be. > We basically use udelay only if the IP hardware actually needs it: some > IP needs time to boot itself up after doing software reset for example. > But it doesn't look reasonable to me by using udelay to make sure "the > last enabled". > > And from the 'Synchronous mode' you just provided, there're another issue: > > + case SNDRV_PCM_TRIGGER_START: > + case SNDRV_PCM_TRIGGER_RESUME: > + case SNDRV_PCM_TRIGGER_PAUSE_RELEASE: > + tcsr |= FSL_SAI_CSR_TERE; > + rcsr |= FSL_SAI_CSR_TERE; > + writel(rcsr, sai->base + FSL_SAI_RCSR); > + udelay(10); > + writel(tcsr, sai->base + FSL_SAI_TCSR); > + break; > + > + case SNDRV_PCM_TRIGGER_STOP: > + case SNDRV_PCM_TRIGGER_SUSPEND: > + case SNDRV_PCM_TRIGGER_PAUSE_PUSH: > + if (!(dai->playback_active || dai->capture_active)) { > + tcsr &= ~FSL_SAI_CSR_TERE; > + rcsr &= ~FSL_SAI_CSR_TERE; > + } > + writel(rcsr, sai->base + FSL_SAI_RCSR); > + udelay(10); > + writel(tcsr, sai->base + FSL_SAI_TCSR); > + break; > > ISSUE 1: You might make sure transmitter is the last enabled. > However, it's not the first disabled. Is this okay? > Yes, this is just programming mistake. I'll revise it. In this case the transmitter should be the last enabled and the first disabled. > ISSUE 2: There are two cases listed in 'Synchronous mode'. > However, your driver doesn't take care of them. > The SAI's synchronous mode looks like more flexible > than SSI's. The driver needs to be more sophisticated > so that it can handle multiple cases when TX/RX clocks > are controlled by either TX or RX, and surely, the > asynchronous mode as well. > Because in Vybrid the transmitter bit clock and frame sync are to be used by both the transmitter and receiver, and only this case can be used here, so now I only handle this case. > > And there's another personal tip: I think you can first try to focus on > this SAI driver and pend the others. There might be two many things you > need to refine if you are doing them at the same time. > I'll implement them later if needed. -- Best Regards, Xiubo _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev