@ -3255,5 +3255,306 @@ SDP
( $ sock_a , $ sock_b ) = new_call ( [ qw( 198.51.100.1 2020 ) ] , [ qw( 198.51.100.1 3020 ) ] ) ;
( $ port_a ) = offer ( 'PCM DTMF block' , { } , << SDP ) ;
v = 0
o = - 1545997027 1 IN IP4 198.51 .100 .1
s = tester
t = 0 0
m = audio 2020 RTP / AVP 0
c = IN IP4 198.51 .100 .1
a = sendrecv
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
v = 0
o = - 1545997027 1 IN IP4 198.51 .100 .1
s = tester
t = 0 0
m = audio PORT RTP / AVP 0
c = IN IP4 203.0 .113 .1
a = rtpmap:0 PCMU / 8000
a = sendrecv
a = rtcp:PORT
SDP
( $ port_b ) = answer ( 'PCM DTMF block' , { } , << SDP ) ;
v = 0
o = - 1545997027 1 IN IP4 198.51 .100 .1
s = tester
t = 0 0
m = audio 3020 RTP / AVP 0
c = IN IP4 198.51 .100 .1
a = sendrecv
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
v = 0
o = - 1545997027 1 IN IP4 198.51 .100 .1
s = tester
t = 0 0
m = audio PORT RTP / AVP 0
c = IN IP4 203.0 .113 .1
a = rtpmap:0 PCMU / 8000
a = sendrecv
a = rtcp:PORT
SDP
$ seq = 0 ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
# control
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\xff\xb0\xac\xbc\x4c\x39\x3f\x63\xee\x55\x4a\xf6\xba\xaf\xbc\x45\x2c\x2d\x4b\xba\xaf\xbb\x6e\x48\x53\xf3\x5f\x3f\x3a\x52\xba\xac\xb3\x5e\x2f\x2d\x3e\xc8\xb8\xc0\xe8\x6b\xd7\xcc\x66\x39\x30\x3f\xbf\xac\xae\xd2\x37\x2f\x3c\xe1\xc6\xd2\x77\xdd\xbf\xbb\xdc\x38\x2c\x35\xd1\xae\xad\xc2\x43\x37\x40\x6e\xe7\x58\x4e\xdd\xb8\xb1\xc3\x3d\x2b\x2f\x5e\xb5\xaf\xbe\x59\x44\x51\xfb\x5b\x3f\x3d\x6b\xb6\xac\xb8\x4a\x2d\x2d\x47\xbf\xb6\xc1\xfa\x63\xda\xd1\x57\x37\x32\x49\xba\xab\xb0\xfe\x33\x2f\x40\xd2\xc2\xd1\x7e\xda\xbf\xbe\x73\x35\x2d\x3a\xc4\xac\xae\xcd\x3d\x36\x43\xf6\xdf\x5c\x55\xd2\xb7\xb4\xce\x37\x2b\x32\xdf\xb1\xaf\xc3\x4d\x41\x50\x7e\x59\x40" ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\xff\xb0\xac\xbc\x4c\x39\x3f\x63\xee\x55\x4a\xf6\xba\xaf\xbc\x45\x2c\x2d\x4b\xba\xaf\xbb\x6e\x48\x53\xf3\x5f\x3f\x3a\x52\xba\xac\xb3\x5e\x2f\x2d\x3e\xc8\xb8\xc0\xe8\x6b\xd7\xcc\x66\x39\x30\x3f\xbf\xac\xae\xd2\x37\x2f\x3c\xe1\xc6\xd2\x77\xdd\xbf\xbb\xdc\x38\x2c\x35\xd1\xae\xad\xc2\x43\x37\x40\x6e\xe7\x58\x4e\xdd\xb8\xb1\xc3\x3d\x2b\x2f\x5e\xb5\xaf\xbe\x59\x44\x51\xfb\x5b\x3f\x3d\x6b\xb6\xac\xb8\x4a\x2d\x2d\x47\xbf\xb6\xc1\xfa\x63\xda\xd1\x57\x37\x32\x49\xba\xab\xb0\xfe\x33\x2f\x40\xd2\xc2\xd1\x7e\xda\xbf\xbe\x73\x35\x2d\x3a\xc4\xac\xae\xcd\x3d\x36\x43\xf6\xdf\x5c\x55\xd2\xb7\xb4\xce\x37\x2b\x32\xdf\xb1\xaf\xc3\x4d\x41\x50\x7e\x59\x40" ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x40\xe0\xb3\xad\xbd\x3f\x2c\x2f\x54\xbb\xb5\xc4\x6b\x5d\xde\xd9\x4e\x37\x35\x58\xb5\xab\xb4\x52\x2f\x2f\x47\xca\xbf\xd0\xfe\xd8\xc1\xc3\x57\x32\x2e\x40\xbc\xab\xb0\xe0\x39\x35\x46\xe3\xdb\x61\x5d\xcc\xb7\xb7\xe8\x33\x2b\x37\xcb\xae\xb0\xcb\x46\x3f\x50\x7e\x58\x41\x46\xcf\xb1\xae\xc6\x39\x2b\x31\x7d\xb7\xb5\xc8\x5d\x58\xe5\xe1\x4a\x37\x38\xf2\xb1\xab\xba\x44\x2e\x30\x4f\xc3\xbe\xd1\x7d\xd8\xc3\xc9\x4b\x30\x2f\x4c\xb6\xab\xb3\x61\x35\x35\x4b\xd8\xd6\x68\x68\xc8\xb7\xba\x5d\x30\x2c\x3c\xbf\xad\xb1\xd8\x40\x3e\x52\xfb\x58\x44\x4c\xc8\xb0\xb0\xd6\x34\x2b\x35\xd5\xb3\xb5\xcd\x54\x54\xec\xef\x47\x37\x3c\xd3\xaf\xac\xc0\x3c\x2d\x33\x63\xbe" ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x40\xe0\xb3\xad\xbd\x3f\x2c\x2f\x54\xbb\xb5\xc4\x6b\x5d\xde\xd9\x4e\x37\x35\x58\xb5\xab\xb4\x52\x2f\x2f\x47\xca\xbf\xd0\xfe\xd8\xc1\xc3\x57\x32\x2e\x40\xbc\xab\xb0\xe0\x39\x35\x46\xe3\xdb\x61\x5d\xcc\xb7\xb7\xe8\x33\x2b\x37\xcb\xae\xb0\xcb\x46\x3f\x50\x7e\x58\x41\x46\xcf\xb1\xae\xc6\x39\x2b\x31\x7d\xb7\xb5\xc8\x5d\x58\xe5\xe1\x4a\x37\x38\xf2\xb1\xab\xba\x44\x2e\x30\x4f\xc3\xbe\xd1\x7d\xd8\xc3\xc9\x4b\x30\x2f\x4c\xb6\xab\xb3\x61\x35\x35\x4b\xd8\xd6\x68\x68\xc8\xb7\xba\x5d\x30\x2c\x3c\xbf\xad\xb1\xd8\x40\x3e\x52\xfb\x58\x44\x4c\xc8\xb0\xb0\xd6\x34\x2b\x35\xd5\xb3\xb5\xcd\x54\x54\xec\xef\x47\x37\x3c\xd3\xaf\xac\xc0\x3c\x2d\x33\x63\xbe" ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\xbd\xd3\x77\xd9\xc5\xd0\x44\x30\x32\x65\xb2\xab\xb8\x4c\x32\x35\x50\xcf\xd2\x70\x7a\xc6\xb8\xbe\x4c\x2e\x2d\x45\xb9\xac\xb4\xfd\x3c\x3d\x55\xf2\x5a\x47\x56\xc1\xb0\xb4\x71\x30\x2b\x3a\xc7\xb0\xb6\xd7\x4d\x50\xf6\x78\x45\x38\x41\xc7\xae\xae\xcc\x37\x2c\x36\xe5\xbb\xbd\xd7\x6d\xdb\xc9\xdd\x3f\x30\x36\xdc\xae\xab\xbd\x41\x2f\x37\x5d\xcb\xcf\x7b\xef\xc4\xb9\xc6\x42\x2d\x2e\x55\xb4\xac\xb8\x58\x39\x3d\x59\xea\x5c\x4a\x66\xbd\xb0\xb8\x50\x2e\x2c\x40\xbd\xaf\xb8\xe8\x48\x4e\x7d\x6b\x43\x3a\x4a\xbf\xad\xaf\xe4\x32\x2c\x3a\xcf\xb8\xbd\xdc\x66\xde\xcc\xf5\x3c\x30\x3b\xca\xad\xac\xc6\x3b\x2e\x39\x7c\xc6\xcd\xfa\xe7\xc3\xbb\xce\x3c\x2d\x31\xf2" ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\xbd\xd3\x77\xd9\xc5\xd0\x44\x30\x32\x65\xb2\xab\xb8\x4c\x32\x35\x50\xcf\xd2\x70\x7a\xc6\xb8\xbe\x4c\x2e\x2d\x45\xb9\xac\xb4\xfd\x3c\x3d\x55\xf2\x5a\x47\x56\xc1\xb0\xb4\x71\x30\x2b\x3a\xc7\xb0\xb6\xd7\x4d\x50\xf6\x78\x45\x38\x41\xc7\xae\xae\xcc\x37\x2c\x36\xe5\xbb\xbd\xd7\x6d\xdb\xc9\xdd\x3f\x30\x36\xdc\xae\xab\xbd\x41\x2f\x37\x5d\xcb\xcf\x7b\xef\xc4\xb9\xc6\x42\x2d\x2e\x55\xb4\xac\xb8\x58\x39\x3d\x59\xea\x5c\x4a\x66\xbd\xb0\xb8\x50\x2e\x2c\x40\xbd\xaf\xb8\xe8\x48\x4e\x7d\x6b\x43\x3a\x4a\xbf\xad\xaf\xe4\x32\x2c\x3a\xcf\xb8\xbd\xdc\x66\xde\xcc\xf5\x3c\x30\x3b\xca\xad\xac\xc6\x3b\x2e\x39\x7c\xc6\xcd\xfa\xe7\xc3\xbb\xce\x3c\x2d\x31\xf2" ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
# gap
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
# enable blocking
rtpe_req ( 'block DTMF' , 'PCM DTMF block' ,
{ 'from-tag' = > ft ( ) , 'DTMF-security' = > 'tone' , 'delay-buffer' = > 1 , frequencies = > [ 250 , 350 , 450 ] } ) ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\xff\xb0\xac\xbc\x4c\x39\x3f\x63\xee\x55\x4a\xf6\xba\xaf\xbc\x45\x2c\x2d\x4b\xba\xaf\xbb\x6e\x48\x53\xf3\x5f\x3f\x3a\x52\xba\xac\xb3\x5e\x2f\x2d\x3e\xc8\xb8\xc0\xe8\x6b\xd7\xcc\x66\x39\x30\x3f\xbf\xac\xae\xd2\x37\x2f\x3c\xe1\xc6\xd2\x77\xdd\xbf\xbb\xdc\x38\x2c\x35\xd1\xae\xad\xc2\x43\x37\x40\x6e\xe7\x58\x4e\xdd\xb8\xb1\xc3\x3d\x2b\x2f\x5e\xb5\xaf\xbe\x59\x44\x51\xfb\x5b\x3f\x3d\x6b\xb6\xac\xb8\x4a\x2d\x2d\x47\xbf\xb6\xc1\xfa\x63\xda\xd1\x57\x37\x32\x49\xba\xab\xb0\xfe\x33\x2f\x40\xd2\xc2\xd1\x7e\xda\xbf\xbe\x73\x35\x2d\x3a\xc4\xac\xae\xcd\x3d\x36\x43\xf6\xdf\x5c\x55\xd2\xb7\xb4\xce\x37\x2b\x32\xdf\xb1\xaf\xc3\x4d\x41\x50\x7e\x59\x40" ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\xff\xb0\xac\xbc\x4c\x39\x3f\x63\xee\x55\x4a\xf6\xba\xaf\xbc\x45\x2c\x2d\x4b\xba\xaf\xbb\x6e\x48\x53\xf3\x5f\x3f\x3a\x52\xba\xac\xb3\x5e\x2f\x2d\x3e\xc8\xb8\xc0\xe8\x6b\xd7\xcc\x66\x39\x30\x3f\xbf\xac\xae\xd2\x37\x2f\x3c\xe1\xc6\xd2\x77\xdd\xbf\xbb\xdc\x38\x2c\x35\xd1\xae\xad\xc2\x43\x37\x40\x6e\xe7\x58\x4e\xdd\xb8\xb1\xc3\x3d\x2b\x2f\x5e\xb5\xaf\xbe\x59\x44\x51\xfb\x5b\x3f\x3d\x6b\xb6\xac\xb8\x4a\x2d\x2d\x47\xbf\xb6\xc1\xfa\x63\xda\xd1\x57\x37\x32\x49\xba\xab\xb0\xfe\x33\x2f\x40\xd2\xc2\xd1\x7e\xda\xbf\xbe\x73\x35\x2d\x3a\xc4\xac\xae\xcd\x3d\x36\x43\xf6\xdf\x5c\x55\xd2\xb7\xb4\xce\x37\x2b\x32\xdf\xb1\xaf\xc3\x4d\x41\x50\x7e\x59\x40" ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x40\xe0\xb3\xad\xbd\x3f\x2c\x2f\x54\xbb\xb5\xc4\x6b\x5d\xde\xd9\x4e\x37\x35\x58\xb5\xab\xb4\x52\x2f\x2f\x47\xca\xbf\xd0\xfe\xd8\xc1\xc3\x57\x32\x2e\x40\xbc\xab\xb0\xe0\x39\x35\x46\xe3\xdb\x61\x5d\xcc\xb7\xb7\xe8\x33\x2b\x37\xcb\xae\xb0\xcb\x46\x3f\x50\x7e\x58\x41\x46\xcf\xb1\xae\xc6\x39\x2b\x31\x7d\xb7\xb5\xc8\x5d\x58\xe5\xe1\x4a\x37\x38\xf2\xb1\xab\xba\x44\x2e\x30\x4f\xc3\xbe\xd1\x7d\xd8\xc3\xc9\x4b\x30\x2f\x4c\xb6\xab\xb3\x61\x35\x35\x4b\xd8\xd6\x68\x68\xc8\xb7\xba\x5d\x30\x2c\x3c\xbf\xad\xb1\xd8\x40\x3e\x52\xfb\x58\x44\x4c\xc8\xb0\xb0\xd6\x34\x2b\x35\xd5\xb3\xb5\xcd\x54\x54\xec\xef\x47\x37\x3c\xd3\xaf\xac\xc0\x3c\x2d\x33\x63\xbe" ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x40\xe0\xb3\xad\xbd\x3f\x2c\x2f\x54\xbb\xb5\xc4\x6b\x5d\xde\xd9\x4e\x37\x35\x58\xb5\xab\xb4\x52\x2f\x2f\x47\xca\xbf\xd0\xfe\xd8\xc1\xc3\x57\x32\x2e\x40\xbc\xab\xb0\xe0\x39\x35\x46\xe3\xdb\x61\x5d\xcc\xb7\xb7\xe8\x33\x2b\x37\xcb\xae\xb0\xcb\x46\x3f\x50\x7e\x58\x41\x46\xcf\xb1\xae\xc6\x39\x2b\x31\x7d\xb7\xb5\xc8\x5d\x58\xe5\xe1\x4a\x37\x38\xf2\xb1\xab\xba\x44\x2e\x30\x4f\xc3\xbe\xd1\x7d\xd8\xc3\xc9\x4b\x30\x2f\x4c\xb6\xab\xb3\x61\x35\x35\x4b\xd8\xd6\x68\x68\xc8\xb7\xba\x5d\x30\x2c\x3c\xbf\xad\xb1\xd8\x40\x3e\x52\xfb\x58\x44\x4c\xc8\xb0\xb0\xd6\x34\x2b\x35\xd5\xb3\xb5\xcd\x54\x54\xec\xef\x47\x37\x3c\xd3\xaf\xac\xc0\x3c\x2d\x33\x63\xbe" ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\xbd\xd3\x77\xd9\xc5\xd0\x44\x30\x32\x65\xb2\xab\xb8\x4c\x32\x35\x50\xcf\xd2\x70\x7a\xc6\xb8\xbe\x4c\x2e\x2d\x45\xb9\xac\xb4\xfd\x3c\x3d\x55\xf2\x5a\x47\x56\xc1\xb0\xb4\x71\x30\x2b\x3a\xc7\xb0\xb6\xd7\x4d\x50\xf6\x78\x45\x38\x41\xc7\xae\xae\xcc\x37\x2c\x36\xe5\xbb\xbd\xd7\x6d\xdb\xc9\xdd\x3f\x30\x36\xdc\xae\xab\xbd\x41\x2f\x37\x5d\xcb\xcf\x7b\xef\xc4\xb9\xc6\x42\x2d\x2e\x55\xb4\xac\xb8\x58\x39\x3d\x59\xea\x5c\x4a\x66\xbd\xb0\xb8\x50\x2e\x2c\x40\xbd\xaf\xb8\xe8\x48\x4e\x7d\x6b\x43\x3a\x4a\xbf\xad\xaf\xe4\x32\x2c\x3a\xcf\xb8\xbd\xdc\x66\xde\xcc\xf5\x3c\x30\x3b\xca\xad\xac\xc6\x3b\x2e\x39\x7c\xc6\xcd\xfa\xe7\xc3\xbb\xce\x3c\x2d\x31\xf2" ) ) ;
# replaced by tone
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x1b\x1b\x1d\x1e\x22\x28\x30\x3f\xff\xbf\xb0\xa8\xa2\x9e\x9d\x9b\x9b\x9b\x9d\x9e\xa2\xa8\xb0\xbf\xff\x3f\x30\x28\x22\x1e\x1d\x1b\x1b\x1b\x1d\x1e\x22\x28\x30\x3f\xff\xbf\xb0\xa8\xa2\x9e\x9d\x9b\x9b\x9b\x9d\x9e\xa2\xa8\xb0\xbf\xff\x3f\x30\x28\x22\x1e\x1d\x1b\x1b\x1b\x1d\x1e\x22\x28\x30\x3f\xff\xbf\xb0\xa8\xa2\x9e\x9d\x9b\x9b\x9b\x9d\x9e\xa2\xa8\xb0\xbf\xff\x3f\x30\x28\x22\x1e\x1d\x1b\x1b\x1b\x1d\x1e\x22\x28\x30\x3f\xff\xbf\xb0\xa8\xa2\x9e\x9d\x9b\x9b\x9b\x9d\x9e\xa2\xa8\xb0\xbf\xff\x3f\x30\x28\x22\x1e\x1d\x1b\x1b\x1b\x1d\x1e\x22\x28\x30\x3f\xff\xbf\xb0\xa8\xa2\x9e\x9d\x9b\x9b\x9b\x9d\x9e\xa2\xa8\xb0\xbf\xff\x3f\x30\x28\x22\x1e\x1d\x1b" ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
# gap
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
# still tone
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x1b\x1b\x1d\x1e\x22\x28\x30\x3f\xff\xbf\xb0\xa8\xa2\x9e\x9d\x9b\x9b\x9b\x9d\x9e\xa2\xa8\xb0\xbf\xff\x3f\x30\x28\x22\x1e\x1d\x1b\x1b\x1b\x1d\x1e\x22\x28\x30\x3f\xff\xbf\xb0\xa8\xa2\x9e\x9d\x9b\x9b\x9b\x9d\x9e\xa2\xa8\xb0\xbf\xff\x3f\x30\x28\x22\x1e\x1d\x1b\x1b\x1b\x1d\x1e\x22\x28\x30\x3f\xff\xbf\xb0\xa8\xa2\x9e\x9d\x9b\x9b\x9b\x9d\x9e\xa2\xa8\xb0\xbf\xff\x3f\x30\x28\x22\x1e\x1d\x1b\x1b\x1b\x1d\x1e\x22\x28\x30\x3f\xff\xbf\xb0\xa8\xa2\x9e\x9d\x9b\x9b\x9b\x9d\x9e\xa2\xa8\xb0\xbf\xff\x3f\x30\x28\x22\x1e\x1d\x1b\x1b\x1b\x1d\x1e\x22\x28\x30\x3f\xff\xbf\xb0\xa8\xa2\x9e\x9d\x9b\x9b\x9b\x9d\x9e\xa2\xa8\xb0\xbf\xff\x3f\x30\x28\x22\x1e\x1d\x1b" ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
# disable blocking
rtpe_req ( 'unblock DTMF' , 'PCM DTMF block' ,
{ 'from-tag' = > ft ( ) } ) ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
# enable blocking
rtpe_req ( 'block DTMF' , 'PCM DTMF block' ,
{ 'from-tag' = > ft ( ) , 'DTMF-security' = > 'tone' , 'delay-buffer' = > 100 , frequencies = > [ 250 , 350 , 450 ] } ) ;
# pre-send 100 ms worth of audio
$ rseq = $ seq ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
# start receiving
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x00" x 160 ) ) ;
$ rseq + + ;
# start DTMF, interleaved with receiving older audio
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\xff\xb0\xac\xbc\x4c\x39\x3f\x63\xee\x55\x4a\xf6\xba\xaf\xbc\x45\x2c\x2d\x4b\xba\xaf\xbb\x6e\x48\x53\xf3\x5f\x3f\x3a\x52\xba\xac\xb3\x5e\x2f\x2d\x3e\xc8\xb8\xc0\xe8\x6b\xd7\xcc\x66\x39\x30\x3f\xbf\xac\xae\xd2\x37\x2f\x3c\xe1\xc6\xd2\x77\xdd\xbf\xbb\xdc\x38\x2c\x35\xd1\xae\xad\xc2\x43\x37\x40\x6e\xe7\x58\x4e\xdd\xb8\xb1\xc3\x3d\x2b\x2f\x5e\xb5\xaf\xbe\x59\x44\x51\xfb\x5b\x3f\x3d\x6b\xb6\xac\xb8\x4a\x2d\x2d\x47\xbf\xb6\xc1\xfa\x63\xda\xd1\x57\x37\x32\x49\xba\xab\xb0\xfe\x33\x2f\x40\xd2\xc2\xd1\x7e\xda\xbf\xbe\x73\x35\x2d\x3a\xc4\xac\xae\xcd\x3d\x36\x43\xf6\xdf\x5c\x55\xd2\xb7\xb4\xce\x37\x2b\x32\xdf\xb1\xaf\xc3\x4d\x41\x50\x7e\x59\x40" ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
# still buffered silence
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x00" x 160 ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x40\xe0\xb3\xad\xbd\x3f\x2c\x2f\x54\xbb\xb5\xc4\x6b\x5d\xde\xd9\x4e\x37\x35\x58\xb5\xab\xb4\x52\x2f\x2f\x47\xca\xbf\xd0\xfe\xd8\xc1\xc3\x57\x32\x2e\x40\xbc\xab\xb0\xe0\x39\x35\x46\xe3\xdb\x61\x5d\xcc\xb7\xb7\xe8\x33\x2b\x37\xcb\xae\xb0\xcb\x46\x3f\x50\x7e\x58\x41\x46\xcf\xb1\xae\xc6\x39\x2b\x31\x7d\xb7\xb5\xc8\x5d\x58\xe5\xe1\x4a\x37\x38\xf2\xb1\xab\xba\x44\x2e\x30\x4f\xc3\xbe\xd1\x7d\xd8\xc3\xc9\x4b\x30\x2f\x4c\xb6\xab\xb3\x61\x35\x35\x4b\xd8\xd6\x68\x68\xc8\xb7\xba\x5d\x30\x2c\x3c\xbf\xad\xb1\xd8\x40\x3e\x52\xfb\x58\x44\x4c\xc8\xb0\xb0\xd6\x34\x2b\x35\xd5\xb3\xb5\xcd\x54\x54\xec\xef\x47\x37\x3c\xd3\xaf\xac\xc0\x3c\x2d\x33\x63\xbe" ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
# now replaced by tone
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\xbd\xd3\x77\xd9\xc5\xd0\x44\x30\x32\x65\xb2\xab\xb8\x4c\x32\x35\x50\xcf\xd2\x70\x7a\xc6\xb8\xbe\x4c\x2e\x2d\x45\xb9\xac\xb4\xfd\x3c\x3d\x55\xf2\x5a\x47\x56\xc1\xb0\xb4\x71\x30\x2b\x3a\xc7\xb0\xb6\xd7\x4d\x50\xf6\x78\x45\x38\x41\xc7\xae\xae\xcc\x37\x2c\x36\xe5\xbb\xbd\xd7\x6d\xdb\xc9\xdd\x3f\x30\x36\xdc\xae\xab\xbd\x41\x2f\x37\x5d\xcb\xcf\x7b\xef\xc4\xb9\xc6\x42\x2d\x2e\x55\xb4\xac\xb8\x58\x39\x3d\x59\xea\x5c\x4a\x66\xbd\xb0\xb8\x50\x2e\x2c\x40\xbd\xaf\xb8\xe8\x48\x4e\x7d\x6b\x43\x3a\x4a\xbf\xad\xaf\xe4\x32\x2c\x3a\xcf\xb8\xbd\xdc\x66\xde\xcc\xf5\x3c\x30\x3b\xca\xad\xac\xc6\x3b\x2e\x39\x7c\xc6\xcd\xfa\xe7\xc3\xbb\xce\x3c\x2d\x31\xf2" ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
# back to silence
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
# still tone
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x9b\x9c\x9e\xa4\xad\xbf\x52\x32\x27\x1f\x1d\x1b\x1b\x1d\x20\x28\x35\x5f\xbc\xab\xa2\x9e\x9c\x9b\x9c\x9e\xa5\xae\xc4\x4a\x30\x26\x1f\x1c\x1b\x1b\x1d\x21\x2a\x38\xff\xb8\xaa\xa1\x9d\x9b\x9b\x9c\x9f\xa6\xb0\xca\x44\x2e\x25\x1e\x1c\x1b\x1c\x1e\x22\x2b\x3c\xdf\xb5\xa8\xa0\x9d\x9b\x9b\x9d\x9f\xa7\xb2\xd2\x3f\x2d\x23\x1e\x1c\x1b\x1c\x1e\x23\x2d\x3f\xd2\xb2\xa7\x9f\x9d\x9b\x9b\x9d\xa0\xa8\xb5\xdf\x3c\x2b\x22\x1e\x1c\x1b\x1c\x1e\x25\x2e\x44\xca\xb0\xa6\x9f\x9c\x9b\x9b\x9d\xa1\xaa\xb8\xff\x38\x2a\x21\x1d\x1b\x1b\x1c\x1f\x26\x30\x4a\xc4\xae\xa5\x9e\x9c\x9b\x9c\x9e\xa2\xab\xbc\x5f\x35\x28\x20\x1d\x1b\x1b\x1d\x1f\x27\x32\x52\xbf\xad\xa4\x9e\x9c" ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
# finally back to silence
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x00" x 160 ) ) ;
$ rseq + + ;
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x00" x 160 ) ) ;
$ rseq + + ;
# disable blocking
rtpe_req ( 'unblock DTMF' , 'PCM DTMF block' ,
{ 'from-tag' = > ft ( ) , 'delay-buffer' = > 0 } ) ;
# buffer flushing
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x00" x 160 ) ) ;
$ rseq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x00" x 160 ) ) ;
$ rseq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x00" x 160 ) ) ;
$ rseq + + ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ rseq , 3000 + 160 * $ rseq , 0x1234 , "\x00" x 160 ) ) ;
$ rseq + + ;
# sync forwarding
snd ( $ sock_a , $ port_b , rtp ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
rcv ( $ sock_b , $ port_a , rtpm ( 0 , 1000 + $ seq , 3000 + 160 * $ seq , 0x1234 , "\x00" x 160 ) ) ;
Time::HiRes:: usleep ( 18000 ) ; $ seq + + ;
done_testing ( ) ;
#done_testing;NGCP::Rtpengine::AutoTest::terminate('f00');exit;