[alsa-devel] ALSA: oxygen: set fifo_size
Takashi Iwai
tiwai at suse.de
Mon Sep 22 09:02:12 CEST 2014
At Sun, 21 Sep 2014 22:52:46 +0200,
Clemens Ladisch wrote:
>
> Allow the driver to report the hardware FIFO size.
>
> Signed-off-by: Clemens Ladisch <clemens at ladisch.de>
Applied, thanks.
Takashi
> ---
> sound/pci/oxygen/oxygen_pcm.c | 10 ++++++++++
> 1 file changed, 10 insertions(+)
>
> diff --git a/sound/pci/oxygen/oxygen_pcm.c b/sound/pci/oxygen/oxygen_pcm.c
> index cc0bcd9..0282824 100644
> --- a/sound/pci/oxygen/oxygen_pcm.c
> +++ b/sound/pci/oxygen/oxygen_pcm.c
> @@ -29,6 +29,9 @@
> /* the multichannel DMA channel has a 24-bit counter */
> #define BUFFER_BYTES_MAX_MULTICH ((1 << 24) * 4)
>
> +#define FIFO_BYTES 256
> +#define FIFO_BYTES_MULTICH 1024
> +
> #define PERIOD_BYTES_MIN 64
>
> #define DEFAULT_BUFFER_BYTES (BUFFER_BYTES_MAX / 2)
> @@ -60,6 +63,7 @@ static const struct snd_pcm_hardware oxygen_stereo_hardware = {
> .period_bytes_max = BUFFER_BYTES_MAX,
> .periods_min = 1,
> .periods_max = BUFFER_BYTES_MAX / PERIOD_BYTES_MIN,
> + .fifo_size = FIFO_BYTES,
> };
> static const struct snd_pcm_hardware oxygen_multichannel_hardware = {
> .info = SNDRV_PCM_INFO_MMAP |
> @@ -87,6 +91,7 @@ static const struct snd_pcm_hardware oxygen_multichannel_hardware = {
> .period_bytes_max = BUFFER_BYTES_MAX_MULTICH,
> .periods_min = 1,
> .periods_max = BUFFER_BYTES_MAX_MULTICH / PERIOD_BYTES_MIN,
> + .fifo_size = FIFO_BYTES_MULTICH,
> };
> static const struct snd_pcm_hardware oxygen_ac97_hardware = {
> .info = SNDRV_PCM_INFO_MMAP |
> @@ -106,6 +111,7 @@ static const struct snd_pcm_hardware oxygen_ac97_hardware = {
> .period_bytes_max = BUFFER_BYTES_MAX,
> .periods_min = 1,
> .periods_max = BUFFER_BYTES_MAX / PERIOD_BYTES_MIN,
> + .fifo_size = FIFO_BYTES,
> };
>
> static const struct snd_pcm_hardware *const oxygen_hardware[PCM_COUNT] = {
> @@ -141,6 +147,10 @@ static int oxygen_open(struct snd_pcm_substream *substream,
> runtime->hw.rates &= ~(SNDRV_PCM_RATE_32000 |
> SNDRV_PCM_RATE_64000);
> runtime->hw.rate_min = 44100;
> + /* fall through */
> + case PCM_A:
> + case PCM_B:
> + runtime->hw.fifo_size = 0;
> break;
> case PCM_MULTICH:
> runtime->hw.channels_max = chip->model.dac_channels_pcm;
>
More information about the Alsa-devel
mailing list