Hi Clemens, First of all, thank you for the helpful remarks and suggestions. I have comments inline... At 06:09 AM 10/6/2006, Clemens Ladisch wrote: >Daniel Yek wrote: > > I opened "surround51" PCM device and set the sampling rate to 48000, > S16_LE > > format. > >Better use "plug:surround51". There are chips like ICE1712 that do not >support any format except S32_LE. It would be great if somebody could suggest an easy way for a media application to identify if the system is 5.1-channels capable. After making sure that 5.1-channels playback is preferable over 2-channels playback, I can then use "plug:surround51" PCM device. I assume that Plug will convert all 6 channels without dropping any here. If not, it is not usable. Right now, I'm depending on opening "surround51" PCM device to fail to indicate that the system isn't 5.1-channels capable. "plug:surround51" PCM wouldn't open-fail even if the system isn't 5.1-channels capable, resulting in a poor playback experience. Do you have a suggestion for me? > > I requested 500000 usec (0.5 sec) of buffer time, but I got back only > > 113770 usec. (equals to 65532 bytes.) Is there a way I can get a > > bigger buffer size? > >You can try writing a value larger than 64 to >/proc/asound/card?/pcm?p/sub?/prealloc, but drivers for on-board >controllers typically don't support more than 128 KB. This worked. XRUN is reduced or eliminated in this case. This would be one way to have (root) users fix the systems if other methods don't work. Thanks. <...snip...> > > I used snd_pcm_writei() in blocking mode, transferring 28800 bytes (2400 > > frames) at a time. After two writes (buffer about full), the third write > > blocked for 95 msec. Soon after, the function blocked for 128 msec, caused > > XRUN. Is snd_pcm_writei() in blocking mode suitable for 5.1 channels > > playback without XRUNs? Why snd_pcm_writei() didn't unblock immediately > > when snd_pcm_avail_update() returned 5044 frames (105 msec.) available? > >In theory, playback with a ~100 ms buffer should be possible. > >There are several possibilities why your program wasn't waken up fast >enough: >1) The period size is too high. The period size specifies the interval > after which the hardware issues an interrupt. If the buffer is full, > you have to wait at least until the next period boundary before ALSA > can detect that some part of the buffer is free. > You should try to have at least about five periods per buffer. >2) avail_min and or xfer_align are set too high. avail_min specifies > how much free space must be in the buffer before snd_pcm_writei() > continues writing; xfer_align specifies the minimum size of a block > to write into the buffer. The default value of both parameters is > the period size, but this is not appropriate for your application; > you don't want to wait before writing even the smallest possible > amount. > Set both these software parameters to one frame. Thanks! I'll try it out. >3) Some other process or thread was executed and prevented > snd_pcm_writei() from executing. This shouldn't be too much a > problem because the kernel reschedules every 4 ms. Make sure the > priority of your audio thread is higher than the default. > > > I'm going to try a non-blocking snd_pcm_writei() solution. Do you think it > > is the answer to the XRUN problem? > >No. Using non-blocking writes does not change the wake-up behaviour. > > >HTH >Clemens You are so helpful. Thank you very much. -- Daniel Yek ------------------------------------------------------------------------- Take Surveys. Earn Cash. Influence the Future of IT Join SourceForge.net's Techsay panel and you'll get the chance to share your opinions on IT & business topics through brief surveys -- and earn cash http://www.techsay.com/default.php?page=join.php&p=sourceforge&CID=DEVDEV _______________________________________________ Alsa-devel mailing list Alsa-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.sourceforge.net/lists/listinfo/alsa-devel