<div dir="ltr">I'm using FreeSWITCH Version 1.5.13b+git~20140515T183425Z~ebc0a99f1c~64bit.<div>Server is on a public IP. What version of CSipSimple did Tony use to test?</div><div><br></div><div>There have been some changes recently to ICE in CSip. I'm using latest nightly release (2414) <a href="http://nightlies.csipsimple.com/trunk/">http://nightlies.csipsimple.com/trunk/</a> with ICE set to aggressive mode.</div>
<div><br></div><div>Also, I have Kamailio in front of FS on the same server, but that shouldn't really be an issue, no?</div><div><br></div><div>Anyway, I have some FS logs posted here if you want to take a closer look <a href="http://pastebin.com/WNGcpTqB">http://pastebin.com/WNGcpTqB</a></div>
<div><br></div><div>But I did just confirm that all works as expected with ICE turned off in CSip.</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Tue, Jun 10, 2014 at 9:13 PM, Michael Jerris <span dir="ltr"><<a href="mailto:mike@jerris.com" target="_blank">mike@jerris.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word">Tony just tested this and it worked with csipsimple.  Can you confirm if you are testing with freeswitch from latest git master?  is the server side on a public ip or behind nat?<div>
<br></div><div>Mike</div><div><div class="h5"><div><br><div><div>On Jun 10, 2014, at 5:43 PM, Peter Villeneuve <<a href="mailto:petervnv1@gmail.com" target="_blank">petervnv1@gmail.com</a>> wrote:</div><br><blockquote type="cite">
<div dir="ltr">I think Michael's insight appears to be correct.<div>I say this because I also can't seem to get ICE to work correctly with FS when using the CSipSimple client with ICE support.</div><div><br></div>
<div>
As you can see in the CSipSimple logs here, it seems that FS fails to correctly respond to the STUN binding request, and thus ICE negotiation fails:</div><div><br></div><div><div>17:17:58.927        icetp00  ..Triggered check for check 1 not performed because it's in progress. Retransmitting</div>
<div>17:17:58.927 utsx0x5dee930c  ...STUN sending message (transmit count=7)</div><div>17:17:59.040 timer_android. !FIRE timer 26 of heap 16</div><div>17:17:59.040 utsx0x5f6e659c  STUN timeout waiting for response</div><div>
17:17:59.040        icetp00  .Check 2: [2] 192.168.1.4:4037-->79.my.serverIP:62203 (nominated): connectivity check FAILED: STUN transaction has timed out (PJNATH_ESTUNTIMEDOUT)</div><div>17:17:59.040        icetp00  ..Check 2: [2] 192.168.1.4:4037-->79.my.serverIP:62203: state changed from In Progress to Failed</div>
<div>17:17:59.040 stun_session.c  .tdata 0x5f6e6484 destroy request, force=1, tsx=0x5f6e659c</div><div>17:17:59.040 timer_android.  .Ask to cancel something already fired or cancelled : -1 @ 0x5f6e65dc</div><div>17:17:59.040 utsx0x5f6e659c  .STUN client transaction 0x5f6e659c stopped, ref_cnt=46</div>
<div>17:17:59.041 timer_android.  FIRE done and released</div><div>17:17:59.238 timer_android.  FIRE timer 27 of heap 16</div><div>17:17:59.238 utsx0x5d9a080c  STUN timeout waiting for response</div><div>17:17:59.238        icetp00  .Check 0: [1] 192.168.1.4:4001-->79.my.serverIP:62202 (nominated): connectivity check FAILED: STUN transaction has timed out (PJNATH_ESTUNTIMEDOUT)</div>
<div>17:17:59.239        icetp00  ..Check 0: [1] 192.168.1.4:4001-->79.my.serverIP:62202: state changed from In Progress to Failed</div><div>17:17:59.239 stun_session.c  .tdata 0x5d9a06f4 destroy request, force=1, tsx=0x5d9a080c</div>
<div>17:17:59.239 timer_android.  .Ask to cancel something already fired or cancelled : -1 @ 0x5d9a084c</div><div>17:17:59.239 utsx0x5d9a080c  .STUN client transaction 0x5d9a080c stopped, ref_cnt=45</div><div>17:17:59.239 timer_android.  FIRE done and released</div>
<div>17:17:59.257 timer_android.  FIRE timer 28 of heap 16</div><div>17:17:59.257 utsx0x5dee930c  STUN timeout waiting for response</div><div>17:17:59.257        icetp00  .Check 1: [1] 79.my.serverIP:56378-->79.my.serverIP:62202 (nominated): connectivity check FAILED: STUN transaction has timed out (PJNATH_ESTUNTIMEDOUT)</div>
<div>17:17:59.257        icetp00  ..Check 1: [1] 79.my.serverIP:56378-->79.my.serverIP:62202: state changed from In Progress to Failed</div><div>17:17:59.258 stun_session.c  .tdata 0x5dee91f4 destroy request, force=1, tsx=0x5dee930c</div>
<div>17:17:59.258 timer_android.  .Ask to cancel something already fired or cancelled : -1 @ 0x5dee934c</div><div>17:17:59.258 utsx0x5dee930c  .STUN client transaction 0x5dee930c stopped, ref_cnt=44</div><div>17:17:59.258 timer_android.  FIRE done and released</div>
<div>17:17:59.273 timer_android.  FIRE timer 34 of heap 16</div><div>17:17:59.274 utsx0x5da8db64  STUN timeout waiting for response</div><div>17:17:59.274        icetp00  .Check 3: [2] 79.my.serverIP2:54506-->79.my.serverIP:62203 (nominated): connectivity check FAILED: STUN transaction has timed out (PJNATH_ESTUNTIMEDOUT)</div>
<div>17:17:59.274        icetp00  ..Check 3: [2] 79.my.serverIP2:54506-->79.my.serverIP:62203: state changed from In Progress to Failed</div><div>17:17:59.274 timer_android.  ..Ask to cancel something already fired or cancelled : -1 @ 0x5dc0b400</div>
<div>17:17:59.274        icetp00  ..ICE process complete, status=All ICE checklists failed (PJNATH_EICEFAILED)</div><div>17:17:59.274        icetp00  ..Valid list</div><div>17:17:59.274 timer_android.  ..Scheduling timer 30 of 16 in 0 ms @ 0x5dc0b400</div>
<div>17:17:59.278 stun_session.c  .tdata 0x5da8da4c destroy request, force=1, tsx=0x5da8db64</div><div>17:17:59.278 timer_android.  .Ask to cancel something already fired or cancelled : -1 @ 0x5da8dba4</div><div>17:17:59.278 utsx0x5da8db64  .STUN client transaction 0x5da8db64 stopped, ref_cnt=45</div>
<div>17:17:59.278 timer_android.  FIRE done and released</div><div>17:17:59.289 timer_android.  FIRE timer 30 of heap 16</div><div>17:17:59.289        icetp00  ICE negotiation failed after 8s:424: All ICE checklists failed (PJNATH_EICEFAILED)</div>
</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Tue, Jun 10, 2014 at 3:27 PM, Michael Jerris <span dir="ltr"><<a href="mailto:mike@jerris.com" target="_blank">mike@jerris.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Its possible that we have some conditions wrong for non-webrtc ice.  You are going to need to trace the switch_core_media code a bit and see how we parse the sdp, what we are expecting, and how we turn on ice.  I suspect we have conditions that tie some of the ice functionality incorrectly to other things required for webrtc.<br>
<div><div><br>
<br>
On Jun 10, 2014, at 2:09 PM, Jayesh Nambiar <<a href="mailto:jayesh1017@gmail.com" target="_blank">jayesh1017@gmail.com</a>> wrote:<br>
<br>
> Hi,<br>
> I am developing an iOS calling App with libnice for ICE capabilities. The calls go through freeswitch and since freeswitch supports ICE, I expected it to work out of the box. But I have a problem. The way libnice works is as follows:<br>
> 1) The client sends INVITE with his candidates.<br>
> 2) Freeswitch parses the candidates.<br>
> 3) Immediately after 200 OK is received, I can see FreeSWITCH choosing an ICE candidate and logging "Activating Audio ICE" indicating the IP and Port and it sends media/RTP to.<br>
> 4) But the libnice agent tries to look at the candidates received in 200 OK and tries to send a STUN binding request to FreeSWITCH IP as that IP is mentioned as ICE candidate in the 200 OK coming from freeswitch.<br>
> 5) The FreeSWITCH doesn't respond to that STUN binding request and libnice agent times out.<br>
> 6) Ideally, if libnice gets back a response from the freeswitch, it should initiate a Re-INVITE with the candidate pair selected.<br>
><br>
> Now here, the freeswitch starts sending RTP to client's candidate, but the client gets stuck because the candidate pair is not formed as the libnice agent keeps waiting for a response for the STUN Binding Request.<br>
> Is there anything that I am missing here. Any help is highly appreciated.<br>
<br>
<br>
</div></div>_________________________________________________________________________<br>
Professional FreeSWITCH Consulting Services:<br>
<a href="mailto:consulting@freeswitch.org" target="_blank">consulting@freeswitch.org</a><br>
<a href="http://www.freeswitchsolutions.com/" target="_blank">http://www.freeswitchsolutions.com</a><br>
<br>
FreeSWITCH-powered IP PBX: The CudaTel Communication Server<br>
<a href="http://www.cudatel.com/" target="_blank">http://www.cudatel.com</a><br>
<br>
Official FreeSWITCH Sites<br>
<a href="http://www.freeswitch.org/" target="_blank">http://www.freeswitch.org</a><br>
<a href="http://wiki.freeswitch.org/" target="_blank">http://wiki.freeswitch.org</a><br>
<a href="http://www.cluecon.com/" target="_blank">http://www.cluecon.com</a><br>
<br>
FreeSWITCH-users mailing list<br>
<a href="mailto:FreeSWITCH-users@lists.freeswitch.org" target="_blank">FreeSWITCH-users@lists.freeswitch.org</a><br>
<a href="http://lists.freeswitch.org/mailman/listinfo/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/listinfo/freeswitch-users</a><br>
UNSUBSCRIBE:<a href="http://lists.freeswitch.org/mailman/options/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/options/freeswitch-users</a><br>
<a href="http://www.freeswitch.org/" target="_blank">http://www.freeswitch.org</a><br>
</blockquote></div><br></div>
_________________________________________________________________________<br>Professional FreeSWITCH Consulting Services:<br><a href="mailto:consulting@freeswitch.org" target="_blank">consulting@freeswitch.org</a><br><a href="http://www.freeswitchsolutions.com" target="_blank">http://www.freeswitchsolutions.com</a><br>
<br>FreeSWITCH-powered IP PBX: The CudaTel Communication Server<br><a href="http://www.cudatel.com" target="_blank">http://www.cudatel.com</a><br><br>Official FreeSWITCH Sites<br><a href="http://www.freeswitch.org" target="_blank">http://www.freeswitch.org</a><br>
<a href="http://wiki.freeswitch.org" target="_blank">http://wiki.freeswitch.org</a><br><a href="http://www.cluecon.com" target="_blank">http://www.cluecon.com</a><br><br>FreeSWITCH-users mailing list<br><a href="mailto:FreeSWITCH-users@lists.freeswitch.org" target="_blank">FreeSWITCH-users@lists.freeswitch.org</a><br>
<a href="http://lists.freeswitch.org/mailman/listinfo/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/listinfo/freeswitch-users</a><br>UNSUBSCRIBE:<a href="http://lists.freeswitch.org/mailman/options/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/options/freeswitch-users</a><br>
<a href="http://www.freeswitch.org" target="_blank">http://www.freeswitch.org</a><br></blockquote></div><br></div></div></div></div><br>_________________________________________________________________________<br>
Professional FreeSWITCH Consulting Services:<br>
<a href="mailto:consulting@freeswitch.org">consulting@freeswitch.org</a><br>
<a href="http://www.freeswitchsolutions.com" target="_blank">http://www.freeswitchsolutions.com</a><br>
<br>
FreeSWITCH-powered IP PBX: The CudaTel Communication Server<br>
<a href="http://www.cudatel.com" target="_blank">http://www.cudatel.com</a><br>
<br>
Official FreeSWITCH Sites<br>
<a href="http://www.freeswitch.org" target="_blank">http://www.freeswitch.org</a><br>
<a href="http://wiki.freeswitch.org" target="_blank">http://wiki.freeswitch.org</a><br>
<a href="http://www.cluecon.com" target="_blank">http://www.cluecon.com</a><br>
<br>
FreeSWITCH-users mailing list<br>
<a href="mailto:FreeSWITCH-users@lists.freeswitch.org">FreeSWITCH-users@lists.freeswitch.org</a><br>
<a href="http://lists.freeswitch.org/mailman/listinfo/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/listinfo/freeswitch-users</a><br>
UNSUBSCRIBE:<a href="http://lists.freeswitch.org/mailman/options/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/options/freeswitch-users</a><br>
<a href="http://www.freeswitch.org" target="_blank">http://www.freeswitch.org</a><br>
<br></blockquote></div><br></div>