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

Sluschny, Thomas Thomas.Sluschny at siemens.com
Wed May 7 08:13:58 PDT 2008


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

________________________________



-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.freeswitch.org/pipermail/freeswitch-users/attachments/20080507/e59761bb/attachment-0002.html 


More information about the FreeSWITCH-users mailing list