Re: a11y: howto reduce latency with alsa's dmix plugin?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Di, Sep 01 2009, Takashi Iwai wrote:

> At best, we need a small C code that reproduces the behavior.
Ok here is a small example.
It's a modified version of pcm_min.c.
Simply press ctrl+c to reproduce the problematic behaviour.
on my machine it takes about an half sek to stop with an usb head which
uses dmix.
Using an sblive card (without dmix) stopps immediately.
/*
 *  This extra small demo sends a random samples to your speakers.
 */

#include <alsa/asoundlib.h>
#include <signal.h>
#include <unistd.h>
static char *device = "default";

snd_output_t *output = NULL;

unsigned char buffer[16 * 1024];        /* some random data */

snd_pcm_t *handle;

void suspend (int signum)
{
  int err;

  printf ("trying to stop\n");
  if ((err = snd_pcm_drop (handle)) < 0)
    printf ("cannot pause\n");

  sleep (1);
  snd_pcm_close (handle);

  exit (1);
}

int main (void)
{
  int err;

  unsigned int i;

  snd_pcm_sframes_t frames;

  signal (SIGINT, suspend);
  for (i = 0; i < sizeof (buffer); i++)
    buffer[i] = random () & 0xff;

  if ((err = snd_pcm_open (&handle, device, SND_PCM_STREAM_PLAYBACK, 0)) < 0)
   {
     printf ("Playback open error: %s\n", snd_strerror (err));
     exit (EXIT_FAILURE);
   }
  if ((err = snd_pcm_set_params (handle,
                                 SND_PCM_FORMAT_U8,
                                 SND_PCM_ACCESS_RW_INTERLEAVED,
                                 1, 48000, 1, 500000)) < 0)
   {                            /* 0.5sec */
     printf ("Playback open error: %s\n", snd_strerror (err));
     exit (EXIT_FAILURE);
   }

  for (i = 0; i < 16; i++)
   {
     frames = snd_pcm_writei (handle, buffer, sizeof (buffer));
     if (frames < 0)
       frames = snd_pcm_recover (handle, frames, 0);
     if (frames < 0)
      {
        printf ("snd_pcm_writei failed: %s\n", snd_strerror (err));
        break;
      }
     if (frames > 0 && frames < (long) sizeof (buffer))
       printf ("Short write (expected %li, wrote %li)\n",
               (long) sizeof (buffer), frames);
   }

  snd_pcm_close (handle);
  return 0;
}
Hope you can help.
Kind regards
Halim
_______________________________________________
Alsa-devel mailing list
Alsa-devel@xxxxxxxxxxxxxxxx
http://mailman.alsa-project.org/mailman/listinfo/alsa-devel

[Index of Archives]     [ALSA User]     [Linux Audio Users]     [Kernel Archive]     [Asterisk PBX]     [Photo Sharing]     [Linux Sound]     [Video 4 Linux]     [Gimp]     [Yosemite News]

  Powered by Linux