Hi,
Le 30/10/2015 02:29, Nicolin Chen a écrit :
On Thu, Oct 29, 2015 at 04:33:26PM -0700, Caleb Crome wrote:
A little difference between your point and mine is that you think
DMA request only starts when SSIE and TDMAE both get set while I
only think about TDMAE. It's hard to say which one is correct as
it depends on the design of IP wrapper but you can fairly test it
with your change below: Mask both TE with SSIE and set them after
the delay. If it doesn't work, yours is the correct one.
Ah, that's one thing that's very clear in the FSL datasheet: the
FIFOs are ZEROED if SSIE is 0. This means that even if the DMA were
trying to dump data in before SSIE is enabled, the data would go to
bit heaven.
The docs for TE say, "The normal transmit enable sequence is to write
data to the STX register(s) and then set the TE bit." (page 5145 of
IMX6SDLRM.pdf)
So in the DMA + fifo case the words, "write data to the STX
register(s)" imply that it's actually DMA writing to FIFOs, which then
write the STX register. So, the sequence must be: enable SSIE &
TDMAE to allow DMA to write to the fifo, then later enable TE, right?
You have the point. If SSIEN is being treated as the reset signal
internally, any write enable signal could be ignored.
I encourage you to try to follow one of patches I gave you that
sets TDMAE/RDMAE at the beginning of the trigger(). Surely you may
change it to TDMAE | SSIE after you find out that SSIE is indeed
required. If you are still having trouble, adding a delay would
be nice for you but it may be hard for me to ack it if you want
to merge it in the driver.
I now I see your patch! Okay, I'll give that a go, but it's still
just a race condition between the regmap_update_bits with TDMAE (your
patch) verses the regmap_update_bits from fsl_ssi_config. You're just
hoping that a DMA write happens between TDMAE and the end of
fsl_ssi_config where TE is enabled.
DMA transaction will be issued once BD is ready (in SDMA driver)
and SSI sends a DMA request. So I'm hoping that the context
latency between the regmap_update_bits() and TE setting should be
enough for DMA to fill the FIFO.
Now I think I get it though. We do TMDAE + SSIEN like your patch,
then a short while loop on SFCSR.TFCNT0. After the first word gets
written to the fifo, TFCNT0 should go > 0, and then we can release TE.
There may be a better status register to wait on but TFCNT0 seems like
it will do the trick.
Waiting for TFCNT0 sounds reasonable to me as long as the code is
well commented.
At imx50 age, I remember one workaround was to fill the fifo manually,
writing directly a number of samples (equal to the number of slots for
one frame to keep the synchronization), and then, enable the TMDAE.
This just allow to not have to wait an undefined period of time for the
DMA to be ready.
But, on the other hand, if the time to wait the DMA is short enough, it
should not be an issue.
Regards,
Arnaud
_______________________________________________
Alsa-devel mailing list
Alsa-devel@xxxxxxxxxxxxxxxx
http://mailman.alsa-project.org/mailman/listinfo/alsa-devel