[alsa-devel] [PATCH 11/20] OMAP: McBSP: Add link DMA mode selection
Jarkko Nikula
jhnikula at gmail.com
Wed Aug 5 09:39:00 CEST 2009
On Thu, 30 Jul 2009 15:49:34 +0300
Eduardo Valentin <eduardo.valentin at nokia.com> wrote:
> From: Peter Ujfalusi <peter.ujfalusi at nokia.com>
>
> It adds a new sysfs file, where the user can configure the mcbsp mode to use.
> If the mcbsp channel is in use, it does not allow the change.
> Than in omap_pcm_open we can call the omap_mcbsp_get_opmode to get the mode,
> store it, than use it to implement the different modes.
>
...
> +/********************** McBSP DMA operating modes **************************/
> +#define MCBSP_DMA_MODE_ELEMENT 0
> +#define MCBSP_DMA_MODE_THRESHOLD 1
> +#define MCBSP_DMA_MODE_FRAME 2
...
> +static ssize_t dma_op_mode_show(struct device *dev,
> + struct device_attribute *attr, char *buf)
> +{
> + struct omap_mcbsp *mcbsp = dev_get_drvdata(dev);
> + int dma_op_mode;
> +
> + spin_lock_irq(&mcbsp->lock);
> + dma_op_mode = mcbsp->dma_op_mode;
> + spin_unlock_irq(&mcbsp->lock);
> +
> + return sprintf(buf, "%d\n", dma_op_mode);
It would be good to handle this as an ascii like e.g /sys/power/state
does. "element", "threshold" or "frame". A number value doesn't tell
much (for me when testing).
> @@ -1195,12 +1266,14 @@ static int __devinit omap_mcbsp_probe
(struct platform_device *pdev)
> if (cpu_is_omap34xx()) {
> mcbsp->max_tx_thres = max_thres(mcbsp);
> mcbsp->max_rx_thres = max_thres(mcbsp);
> + mcbsp->dma_op_mode = MCBSP_DMA_MODE_THRESHOLD;
> if (omap_additional_add(pdev))
> dev_warn(&pdev->dev,
> "Unable to create threshold controls\n");
> } else {
> mcbsp->max_tx_thres = -EINVAL;
> mcbsp->max_rx_thres = -EINVAL;
> + mcbsp->dma_op_mode = MCBSP_DMA_MODE_ELEMENT;
> }
I would say the default mode for the omap34xx should be also element as
it keeps the omap_pcm_pointer behavior the same than currently and
avoids possible regression.
--
Jarkko
--
To unsubscribe from this list: send the line "unsubscribe alsa-devel" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
More information about the Alsa-devel
mailing list