[Freeswitch-users] mod_portaudio send 3rtppacket/60msinsteadof1packet/20ms

Sluschny, Thomas Thomas.Sluschny at siemens.com
Fri May 9 04:34:56 PDT 2008


ok,
now it looks better, i. e. the switch_core_timer_check() times the
ReadAudioStream function,
but not perfect, now i see packets with differences of 15, 30, 45, 0 ms,

e. g. 15, 15, 30, 15, 15, 15, 31, 16, 15, 31, 15, 16, 16, 29 ms and so
on
 
Looks like we already stuck with time resolution, but the
switch_yield(1000) in ReadAudioStream() seems to work properly, strange
...
I don't have the time to go deeper into and i next read my emails on
tuesday :(
 
I don't want to hijack this thread from Csaba, should we make a jira
entry, Csaba? (for Anthonys clients sake :) )
 
Thomas

________________________________

Von: freeswitch-users-bounces at lists.freeswitch.org
[mailto:freeswitch-users-bounces at lists.freeswitch.org] Im Auftrag von
Anthony Minessale
Gesendet: Donnerstag, 8. Mai 2008 18:22
An: freeswitch-users at lists.freeswitch.org
Betreff: Re: [Freeswitch-users] mod_portaudio send
3rtppacket/60msinsteadof1packet/20ms


r8305 is now exclusively using the timer to clock the audio stream.
This is silly because you would think the darn sound card could at least
provide timing at a lousy 8khz.

please tell me this fixes it..... if the thread gets any bigger my
client will crash.....


On Thu, May 8, 2008 at 3:12 AM, Sluschny, Thomas
<Thomas.Sluschny at siemens.com> wrote:


	i tested with 8296 now in all combinations, but allways the same
as before, 3 RTP packets all 60ms:
	now 2 frames accumulated (1 frame = 320 bytes always readable),
but switch_core_timer_sync() is not waiting 20ms.
	I think its because at the beginning we get late by 2 frames, as
you described (2 timeouts at the beginning), so
	the timer is lag behind the buffer.
	 
	there the log for 20ms in portaudio.xml and vars.xml:
	 
	2008-05-08 10:08:18 [DEBUG] pablio.c:155 ReadAudioStream()
177664138 ms : Beginning (320 Bytes readable) ...
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664138 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664139 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664139 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664141 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664141 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664143 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664143 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664145 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664145 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664147 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664147 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664149 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664149 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664151 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664151 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664153 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664153 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664155 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664155 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664157 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664157 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664159 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664159 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664161 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664161 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664163 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664163 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664165 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664165 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664167 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664167 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664169 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664169 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664171 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664171 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664173 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664173 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664175 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:174 ReadAudioStream()
177664175 ms : timer timed out (320 Bytes readable)!
	2008-05-08 10:08:18 [DEBUG] pablio.c:192 ReadAudioStream()
177664175 ms : Return with 0 Bytes read (320 Bytes readable), exit.
	2008-05-08 10:08:18 [DEBUG] pablio.c:155 ReadAudioStream()
177664176 ms : Beginning (320 Bytes readable) ...
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664177 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664178 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664178 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664180 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664180 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664182 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664182 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664184 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664184 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664186 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664186 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664188 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664188 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664190 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664190 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664192 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664192 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664194 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664194 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664196 ms : after Wait... (1280 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:188 ReadAudioStream()
177664196 ms : after switch_core_timer_sync()... (960 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:192 ReadAudioStream()
177664196 ms : Return with 160 Bytes read (960 Bytes readable), exit.
	2008-05-08 10:08:18 [DEBUG] pablio.c:155 ReadAudioStream()
177664196 ms : Beginning (960 Bytes readable) ...
	2008-05-08 10:08:18 [DEBUG] pablio.c:188 ReadAudioStream()
177664196 ms : after switch_core_timer_sync()... (640 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:192 ReadAudioStream()
177664196 ms : Return with 160 Bytes read (640 Bytes readable), exit.
	2008-05-08 10:08:18 [DEBUG] pablio.c:155 ReadAudioStream()
177664197 ms : Beginning (640 Bytes readable) ...
	2008-05-08 10:08:18 [DEBUG] pablio.c:188 ReadAudioStream()
177664197 ms : after switch_core_timer_sync()... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:192 ReadAudioStream()
177664197 ms : Return with 160 Bytes read (320 Bytes readable), exit.
	2008-05-08 10:08:18 [DEBUG] pablio.c:155 ReadAudioStream()
177664197 ms : Beginning (320 Bytes readable) ...
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664197 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664198 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664198 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664200 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664200 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664202 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664202 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664204 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664204 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664206 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664206 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664208 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664208 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664210 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664210 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664212 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664212 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664214 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664214 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664216 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664216 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664217 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664218 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664219 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664220 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664221 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664221 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664223 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664223 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664225 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664225 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664227 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664227 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664229 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664229 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664231 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664231 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664233 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664233 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664235 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664235 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664237 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:174 ReadAudioStream()
177664237 ms : timer timed out (320 Bytes readable)!
	2008-05-08 10:08:18 [DEBUG] pablio.c:192 ReadAudioStream()
177664237 ms : Return with 0 Bytes read (320 Bytes readable), exit.
	2008-05-08 10:08:18 [DEBUG] pablio.c:155 ReadAudioStream()
177664239 ms : Beginning (320 Bytes readable) ...
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664239 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664241 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664241 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664243 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664243 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664245 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664245 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664247 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664247 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664249 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664249 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664251 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664251 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664253 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664253 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664255 ms : after Wait... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:177 ReadAudioStream()
177664255 ms : before Wait...
	2008-05-08 10:08:18 [DEBUG] pablio.c:180 ReadAudioStream()
177664257 ms : after Wait... (1280 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:188 ReadAudioStream()
177664257 ms : after switch_core_timer_sync()... (960 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:192 ReadAudioStream()
177664257 ms : Return with 160 Bytes read (960 Bytes readable), exit.
	2008-05-08 10:08:18 [DEBUG] pablio.c:155 ReadAudioStream()
177664257 ms : Beginning (960 Bytes readable) ...
	2008-05-08 10:08:18 [DEBUG] pablio.c:188 ReadAudioStream()
177664257 ms : after switch_core_timer_sync()... (640 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:192 ReadAudioStream()
177664257 ms : Return with 160 Bytes read (640 Bytes readable), exit.
	2008-05-08 10:08:18 [DEBUG] pablio.c:155 ReadAudioStream()
177664257 ms : Beginning (640 Bytes readable) ...
	2008-05-08 10:08:18 [DEBUG] pablio.c:188 ReadAudioStream()
177664257 ms : after switch_core_timer_sync()... (320 Bytes readable)
	2008-05-08 10:08:18 [DEBUG] pablio.c:192 ReadAudioStream()
177664257 ms : Return with 160 Bytes read (320 Bytes readable), exit.
	2008-05-08 10:08:18 [DEBUG] pablio.c:155 ReadAudioStream()
177664257 ms : Beginning (320 Bytes readable) ...
	
	Thomas

________________________________

	Von: freeswitch-users-bounces at lists.freeswitch.org
[mailto:freeswitch-users-bounces at lists.freeswitch.org] Im Auftrag von
Anthony Minessale
	Gesendet: Mittwoch, 7. Mai 2008 18:50 

	An: freeswitch-users at lists.freeswitch.org
	Betreff: Re: [Freeswitch-users] mod_portaudio send
3rtppacket/60msinsteadof1 packet/20ms
	

	ok,
	please try 8295 at all combinations of codec-ms etc.
	I changed the code to snoop the ringbuffer and make sure 2
frames worth of audio as accumulated before i read from it.
	
	
	
	On Wed, May 7, 2008 at 10:13 AM, Sluschny, Thomas
<Thomas.Sluschny at siemens.com> wrote:
	

		I get always 3 RTP packets at once with 60ms setting, i
also test with PCMU at 60i in vars.xml but i always get 20ms packets with
160byres packet size.
		 
		Anthony, you are right with you "timeout assumption". To
illustrate, here a log from my patch without waiting, i. e. no
functional difference:
		 
		2008-05-07 16:53:48 [DEBUG] pablio.c:156
ReadAudioStream() 115594577 ms : Beginning (0 Bytes readable) ...
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594577 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594577 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594579 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594579 ms : after Wait... (960 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:184
ReadAudioStream() 115594581 ms : all 320 Bytes read (640 Bytes
readable), exit.
		2008-05-07 16:53:48 [DEBUG] pablio.c:156
ReadAudioStream() 115594582 ms : Beginning (640 Bytes readable) ...
		2008-05-07 16:53:48 [DEBUG] pablio.c:184
ReadAudioStream() 115594582 ms : all 320 Bytes read (320 Bytes
readable), exit.
		2008-05-07 16:53:48 [DEBUG] pablio.c:156
ReadAudioStream() 115594582 ms : Beginning (320 Bytes readable) ...
		2008-05-07 16:53:48 [DEBUG] pablio.c:184
ReadAudioStream() 115594582 ms : all 320 Bytes read (0 Bytes readable),
exit.
		2008-05-07 16:53:48 [DEBUG] pablio.c:156
ReadAudioStream() 115594582 ms : Beginning (0 Bytes readable) ...
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594582 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594582 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594583 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594583 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594585 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594585 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594587 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594587 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594589 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594589 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:167
ReadAudioStream() 115594591 ms : timer timed out (0 Bytes readable)!
		2008-05-07 16:53:48 [DEBUG] pablio.c:156
ReadAudioStream() 115594593 ms : Beginning (0 Bytes readable) ...
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594593 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594593 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594595 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594595 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594597 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594597 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594599 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594599 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594601 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594601 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594603 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594603 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594605 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594605 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:167
ReadAudioStream() 115594607 ms : timer timed out (0 Bytes readable)!
		2008-05-07 16:53:48 [DEBUG] pablio.c:156
ReadAudioStream() 115594609 ms : Beginning (0 Bytes readable) ...
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594609 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594609 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594611 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594611 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594613 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594613 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594615 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594615 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594617 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594617 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594618 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594618 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594620 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594620 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:167
ReadAudioStream() 115594622 ms : timer timed out (0 Bytes readable)!
		2008-05-07 16:53:48 [DEBUG] pablio.c:156
ReadAudioStream() 115594624 ms : Beginning (0 Bytes readable) ...
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594624 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594624 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594626 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594626 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594628 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594628 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594630 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594630 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594632 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594632 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594634 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594634 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594636 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594636 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594638 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594638 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594640 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594640 ms : after Wait... (960 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:184
ReadAudioStream() 115594642 ms : all 320 Bytes read (640 Bytes
readable), exit.
		2008-05-07 16:53:48 [DEBUG] pablio.c:156
ReadAudioStream() 115594642 ms : Beginning (640 Bytes readable) ...
		2008-05-07 16:53:48 [DEBUG] pablio.c:184
ReadAudioStream() 115594642 ms : all 320 Bytes read (320 Bytes
readable), exit.
		2008-05-07 16:53:48 [DEBUG] pablio.c:156
ReadAudioStream() 115594642 ms : Beginning (320 Bytes readable) ...
		2008-05-07 16:53:48 [DEBUG] pablio.c:184
ReadAudioStream() 115594642 ms : all 320 Bytes read (0 Bytes readable),
exit.
		2008-05-07 16:53:48 [DEBUG] pablio.c:156
ReadAudioStream() 115594642 ms : Beginning (0 Bytes readable) ...
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594642 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594642 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594644 ms : before Wait...
		2008-05-07 16:53:48 [DEBUG] pablio.c:172
ReadAudioStream() 115594644 ms : after Wait... (0 Bytes readable)
		2008-05-07 16:53:48 [DEBUG] pablio.c:170
ReadAudioStream() 115594646 ms : before Wait...
		
		So i want use the timer to prevent these buffer read
bursts all 60ms.
		All 3 x 320 bytes are used for RTP packets, so samples
are not lost (only during the first 2 timeouts, but this is irrelevant).
		 
		And if you like logs ;), here are the behavior with 60ms
in portaudio.xml:
		 
		2008-05-07 17:09:04 [DEBUG] pablio.c:156
ReadAudioStream() 116511260 ms : Beginning (0 Bytes readable) ...
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511260 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511260 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511262 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511262 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511264 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511264 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511266 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511266 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511268 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511268 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511270 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511270 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511272 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511272 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511274 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511274 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511276 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511276 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511278 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511278 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511279 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511279 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511281 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511281 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511283 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511283 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511285 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511285 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511287 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511287 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511289 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511289 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511291 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511291 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511293 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511293 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:167
ReadAudioStream() 116511295 ms : timer timed out (0 Bytes readable)!
		2008-05-07 17:09:04 [DEBUG] pablio.c:156
ReadAudioStream() 116511297 ms : Beginning (0 Bytes readable) ...
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511297 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511297 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511299 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511299 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511301 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511301 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511303 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511303 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511305 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511305 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511307 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511307 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511309 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511309 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511311 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511311 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511313 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511313 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511315 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511315 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511317 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511317 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511318 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511318 ms : after Wait... (960 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:184
ReadAudioStream() 116511321 ms : all 960 Bytes read (0 Bytes readable),
exit.
		2008-05-07 17:09:04 [DEBUG] pablio.c:156
ReadAudioStream() 116511321 ms : Beginning (0 Bytes readable) ...
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511321 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511321 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511322 ms : before Wait...
		2008-05-07 17:09:04 [DEBUG] pablio.c:172
ReadAudioStream() 116511322 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:04 [DEBUG] pablio.c:170
ReadAudioStream() 116511324 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511324 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511326 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511326 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511328 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511328 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511330 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511330 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511332 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511332 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511334 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511334 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511336 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511336 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511338 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511338 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511340 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511340 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511342 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511342 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511344 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511344 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511346 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511346 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511348 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511348 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511350 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511350 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511352 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511352 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511354 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511354 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511356 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511356 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:167
ReadAudioStream() 116511358 ms : timer timed out (0 Bytes readable)!
		2008-05-07 17:09:05 [DEBUG] pablio.c:156
ReadAudioStream() 116511359 ms : Beginning (0 Bytes readable) ...
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511360 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511360 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511361 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511361 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511363 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511363 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511365 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511365 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511367 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511367 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511369 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511369 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511371 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511371 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511373 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511373 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511375 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511375 ms : after Wait... (0 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:170
ReadAudioStream() 116511377 ms : before Wait...
		2008-05-07 17:09:05 [DEBUG] pablio.c:172
ReadAudioStream() 116511377 ms : after Wait... (960 Bytes readable)
		2008-05-07 17:09:05 [DEBUG] pablio.c:184
ReadAudioStream() 116511379 ms : all 960 Bytes read (0 Bytes readable),
exit.
		
		Strange timeout after 35...40ms, or should it be?
		 
		Thomas

________________________________

		Von: freeswitch-users-bounces at lists.freeswitch.org
[mailto:freeswitch-users-bounces at lists.freeswitch.org] Im Auftrag von
Csaba Zelei
		Gesendet: Mittwoch, 7. Mai 2008 16:46 

		An: freeswitch-users at lists.freeswitch.org
		Betreff: Re: [Freeswitch-users] mod_portaudio send 3
rtppacket/60msinsteadof1 packet/20ms
		

		I tried it with the latest trunk.
		If I set it to 60ms sometimes I still get <1ms rtp
packet delta, if I set it to 120ms then there is none
		The rtp packet delta is still random within 50-70ms with
sometimes too low 15-30ms, sometimes too high 100-150ms delta (with
codec-ms = 60ms), and with 15-20ms jitter.
		
		
		Anthony Minessale wrote: 

			Have you tried setting the codec-ms in the
portaudio.conf.xml to 60 or 120 ms?
			Maybe the soundcard is not able to do 20ms
intervals and portaudio is doing the least common multiple and chopping
it up for us.
			I think what's happening is the timer in the
module is set to the interval from the config file (20ms) and during
every 60ms period there is no audio until the last ms.  so in each 60
ms:
			
			20ms (timeout..... flush buffer)
			20ms (timeout..... flush buffer)
			20ms (get 60ms worth of audio at once [3 20ms
packets] but we have already read 2 filler frames from the timeouts)
			
			So now we have read 5 packets instead of 3 and
erased some of our buffer because of perceived timeouts.
			The code is using the assumption that if the
device will obey the chosen frame size and sample rate requests down to
the interval.
			
			If you find and edit
conf/autoload_configs/portaudio.conf.xml
			
			look for this:
			
			 <param name="codec-ms" value="20"/>
			
			and change 20 to 60
			
			Setting this to 60 will change the frame size of
all the packets from 320 to 960 and set the timer to clock at an
interval of 60ms
			Since the card seems to be able to reliably
produce 3 20ms packets every 60ms it should also be able to produce 1
60ms packet.
			
			FreeSWITCH should then buffer the audio and
still deliver it over SIP at 20ms if you want but you can opt to set the
codec PCMU at 60i to disable buffering if you are in a reliable network.
			
			The same should be true for setting the codec-ms
to 120
			
			
			
			On Wed, May 7, 2008 at 3:27 AM, Sluschny, Thomas
<Thomas.Sluschny at siemens.com> wrote:
			

				Hi Anthony,
				 
				i also tested your patch with no
success.
				As i already described below, the
problem with all 60ms 3 packets comes from the soundcard.
				The hardware delivers its samples all 60
ms.
				Our problem is (like Csaba said) that we
read out the buffer after 60ms, 3 times, each with samples for 20ms, AND
WITH NO DELAY!
				So we get: 60ms wait and 3 RTP packets
within <1ms to send, and after that we already wait 60 ms for the next
samples.
				 
				In my patch i wait appr.20 ms if last
method call was no longer than 4ms ago,
				but i think we can do better with
switch_core_timer_check() method, but i don't know exactly how.
				 
				You are absolutly right with your demand
for a better timing resolution under Windows,
				but this 60ms mystery is caused by the
soundcard.
				 
				Thomas

________________________________




		_______________________________________________
		Freeswitch-users mailing list
		Freeswitch-users at lists.freeswitch.org
	
http://lists.freeswitch.org/mailman/listinfo/freeswitch-users
	
UNSUBSCRIBE:http://lists.freeswitch.org/mailman/options/freeswitch-users
		http://www.freeswitch.org
		
		




	-- 
	Anthony Minessale II
	
	FreeSWITCH http://www.freeswitch.org/
	ClueCon http://www.cluecon.com/
	
	AIM: anthm
	MSN:anthony_minessale at hotmail.com
<mailto:MSN%3Aanthony_minessale at hotmail.com> 
	GTALK/JABBER/PAYPAL:anthony.minessale at gmail.com
<mailto:PAYPAL%3Aanthony.minessale at gmail.com> 
	IRC: irc.freenode.net #freeswitch
	
	FreeSWITCH Developer Conference
	sip:888 at conference.freeswitch.org
<mailto:sip%3A888 at conference.freeswitch.org> 
	iax:guest at conference.freeswitch.org/888
	googletalk:conf+888 at conference.freeswitch.org
<mailto:googletalk%3Aconf%2B888 at conference.freeswitch.org> 
	pstn:213-799-1400 

	_______________________________________________
	Freeswitch-users mailing list
	Freeswitch-users at lists.freeswitch.org
	http://lists.freeswitch.org/mailman/listinfo/freeswitch-users
	
UNSUBSCRIBE:http://lists.freeswitch.org/mailman/options/freeswitch-users
	http://www.freeswitch.org
	
	




-- 
Anthony Minessale II

FreeSWITCH http://www.freeswitch.org/
ClueCon http://www.cluecon.com/

AIM: anthm
MSN:anthony_minessale at hotmail.com
<mailto:MSN%3Aanthony_minessale at hotmail.com> 
GTALK/JABBER/PAYPAL:anthony.minessale at gmail.com
<mailto:PAYPAL%3Aanthony.minessale at gmail.com> 
IRC: irc.freenode.net #freeswitch

FreeSWITCH Developer Conference
sip:888 at conference.freeswitch.org
<mailto:sip%3A888 at conference.freeswitch.org> 
iax:guest at conference.freeswitch.org/888
googletalk:conf+888 at conference.freeswitch.org
<mailto:googletalk%3Aconf%2B888 at conference.freeswitch.org> 
pstn:213-799-1400 
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.freeswitch.org/pipermail/freeswitch-users/attachments/20080509/515456ee/attachment-0002.html 


More information about the FreeSWITCH-users mailing list