<div dir="ltr"><div>Hey guys, I&#39;m working on a simple media bug module using FS 1.6. When a call comes in I&#39;m calling switch_curl doing an http get. </div><div>







<p class=""><span class="">In switch_standard_app I use switch_curl and invoke switch_curl_easy_perform </span>and exit after that.</p>
<p class="">Calling switch_curl seems very unstable. It&#39;s crashing free switch most of the time.  Are there any things I should be looking for related to this? I&#39;m wondering if maybe this is a threading issue? Any ideas?</p></div><div><div>I&#39;ve included some backtraces</div><div><br></div><div><div>Thanks, chris</div></div><div><br></div><div><br></div><div>







<p class=""><span class="">(gdb) bt</span></p>
<p class=""><span class="">#0  0x00007f8f00c59cc9 in __GI_raise (sig=sig@entry=6) at ../nptl/sysdeps/unix/sysv/linux/raise.c:56</span></p>
<p class=""><span class="">#1  0x00007f8f00c5d0d8 in __GI_abort () at abort.c:89</span></p>
<p class=""><span class="">#2  0x00007f8f00c96394 in __libc_message (do_abort=do_abort@entry=1, fmt=fmt@entry=0x7f8f00da4b28 &quot;*** Error in `%s&#39;: %s: 0x%s ***\n&quot;) at ../sysdeps/posix/libc_fatal.c:175</span></p>
<p class=""><span class="">#3  0x00007f8f00ca266e in malloc_printerr (ptr=&lt;optimized out&gt;, str=0x7f8f00da0c19 &quot;free(): invalid pointer&quot;, action=1) at malloc.c:4996</span></p>
<p class=""><span class="">#4  _int_free (av=&lt;optimized out&gt;, p=&lt;optimized out&gt;, have_lock=0) at malloc.c:3840</span></p>
<p class=""><span class="">#5  0x00007f8f01334567 in switch_log_node_free (pnode=pnode@entry=0x7f8eb2b1f158) at src/switch_log.c:136</span></p>
<p class=""><span class="">#6  0x00007f8eeb192a24 in read_packet (listener=listener@entry=0x7f8ebc027898, event=event@entry=0x7f8eb2b1f7f0, timeout=timeout@entry=0) at mod_event_socket.c:1361</span></p>
<p class=""><span class="">#7  0x00007f8eeb1988a0 in listener_run (thread=&lt;optimized out&gt;, obj=0x7f8ebc027898) at mod_event_socket.c:2719</span></p>
<p class=""><span class="">#8  0x00007f8f01544430 in dummy_worker (opaque=0x7f8eb2be4868) at threadproc/unix/thread.c:151</span></p>
<p class=""><span class="">#9  0x00007f8f00ff0182 in start_thread (arg=0x7f8eb2b20700) at pthread_create.c:312</span></p>
<p class=""><span class="">#10 0x00007f8f00d1d47d in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:111</span></p>
<p class=""><span class=""><i></i></span><br></p>
<p class=""><span class=""><a href="https://soniccloud.slack.com/archives/D02UEC39S/p1458078254000027"><i>[</i><span class=""><i></i></span></a></span></p>
<p class=""><span class=""><a href="https://soniccloud.slack.com/archives/D02UEC39S/p1458078254000027">5:44<span class=""></span></a></span></p>
<p class=""><span class=""><a href="https://soniccloud.slack.com/archives/D02UEC39S/p1458078254000027"><i>]</i><span class=""><i></i></span></a></span></p>
<p class=""><span class="">(gdb) bt full</span></p>
<p class=""><span class="">#0  0x00007f8f00c59cc9 in __GI_raise (sig=sig@entry=6) at ../nptl/sysdeps/unix/sysv/linux/raise.c:56</span></p>
<p class=""><span class="">       resultvar = 0</span></p>
<p class=""><span class="">       pid = 18329</span></p>
<p class=""><span class="">       selftid = 18421</span></p>
<p class=""><span class="">#1  0x00007f8f00c5d0d8 in __GI_abort () at abort.c:89</span></p>
<p class=""><span class="">       save_stage = 2</span></p>
<p class=""><span class="">       act = {__sigaction_handler = {sa_handler = 0x0, sa_sigaction = 0x0}, sa_mask = {__val = {0 &lt;repeats 16 times&gt;}}, sa_flags = 0, sa_restorer = 0x0}</span></p>
<p class=""><span class="">       sigs = {__val = {32, 0 &lt;repeats 15 times&gt;}}</span></p>
<p class=""><span class="">#2  0x00007f8f00c96394 in __libc_message (do_abort=do_abort@entry=1, fmt=fmt@entry=0x7f8f00da4b28 &quot;*** Error in `%s&#39;: %s: 0x%s ***\n&quot;) at ../sysdeps/posix/libc_fatal.c:175</span></p>
<p class=""><span class="">       ap = {{gp_offset = 40, fp_offset = 32654, overflow_arg_area = 0x7f8eb2b1f010, reg_save_area = 0x7f8eb2b1efa0}}</span></p>
<p class=""><span class="">       fd = 2</span></p>
<p class=""><span class="">       on_2 = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       list = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       nlist = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       cp = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       written = &lt;optimized out&gt;</span></p>
<p class=""><span class="">#3  0x00007f8f00ca266e in malloc_printerr (ptr=&lt;optimized out&gt;, str=0x7f8f00da0c19 &quot;free(): invalid pointer&quot;, action=1) at malloc.c:4996</span></p>
<p class=""><span class="">       buf = &quot;00007f8ed0036700&quot;</span></p>
<p class=""><span class="">       cp = &lt;optimized out&gt;</span></p>
<p class=""><span class="">#4  _int_free (av=&lt;optimized out&gt;, p=&lt;optimized out&gt;, have_lock=0) at malloc.c:3840</span></p>
<p class=""><span class="">       size = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       fb = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       nextchunk = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       nextsize = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       nextinuse = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       prevsize = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       bck = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       fwd = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       errstr = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       locked = &lt;optimized out&gt;</span></p>
<p class=""><span class="">#5  0x00007f8f01334567 in switch_log_node_free (pnode=pnode@entry=0x7f8eb2b1f158) at src/switch_log.c:136</span></p>
<p class=""><span class="">       node = 0x7f8ed8012ab0</span></p>
<p class=""><span class="">#6  0x00007f8eeb192a24 in read_packet (listener=listener@entry=0x7f8ebc027898, event=event@entry=0x7f8eb2b1f7f0, timeout=timeout@entry=0) at mod_event_socket.c:1361</span></p>
<p class=""><span class="">       dnode = 0x7f8ed8012ab0</span></p>
<p class=""><span class="">       do_sleep = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       mlen = 0</span></p>
<p class=""><span class="">       bytes = 0</span></p>
<p class=""><span class="">       mbuf = 0x7f8ecc1ebfc0 &quot;&quot;</span></p>
<p class=""><span class="">       buf = &quot;Content-Type: log/data\nContent-Length: 88\nLog-Level: 7\nText-Channel: 3\nLog-File: param_hps_strategy.cpp\nLog-Func: retrieve\nLog-Line: 115\nUser-Data: \347@\247\a\n\n\000\n\n\000\065-418f-a6d1-9dc8f48e0cf9\n\n\000\000\071\n\n\000c8f48e0cf9&quot;...</span></p>
<p class=""><span class="">       len = 88</span></p>
<p class=""><span class="">       status = SWITCH_STATUS_BREAK</span></p>
<p class=""><span class="">       count = 0</span></p>
<p class=""><span class="">       elapsed = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       start = 1457966137</span></p>
<p class=""><span class="">       pop = 0x7f8ed8012ab0</span></p>
<p class=""><span class="">       ptr = 0x7f8ecc1ebfc0 &quot;&quot;</span></p>
<p class=""><span class="">       crcount = 0 &#39;\000&#39;</span></p>
<p class=""><span class="">       buf_len = 2048</span></p>
<p class=""><span class="">       channel = 0x0</span></p>
<p class=""><span class="">       clen = 0</span></p>
<p class=""><span class="">       __PRETTY_FUNCTION__ = &quot;read_packet&quot;</span></p>
<p class=""><span class="">       __func__ = &quot;read_packet&quot;</span></p>
<p class=""><span class="">#7  0x00007f8eeb1988a0 in listener_run (thread=&lt;optimized out&gt;, obj=0x7f8ebc027898) at mod_event_socket.c:2719</span></p>
<p class=""><span class="">       listener = 0x7f8ebc027898</span></p>
<p class=""><span class="">       buf = &#39;\000&#39; &lt;repeats 1023 times&gt;</span></p>
<p class=""><span class="">       len = 1024</span></p>
<p class=""><span class="">       status = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       event = 0x0</span></p>
<p class=""><span class="">       reply = &quot;\000OK log level  [7]&quot;, &#39;\000&#39; &lt;repeats 493 times&gt;</span></p>
<p class=""><span class="">       session = 0x0</span></p>
<p class=""><span class="">       channel = 0x0</span></p>
<p class=""><span class="">       revent = 0x0</span></p>
<p class=""><span class="">       var = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       locked = 1</span></p>
<p class=""><span class="">       __PRETTY_FUNCTION__ = &quot;listener_run&quot;</span></p>
<p class=""><span class="">       __func__ = &quot;listener_run&quot;</span></p>
<p class=""><span class="">#8  0x00007f8f01544430 in dummy_worker (opaque=0x7f8eb2be4868) at threadproc/unix/thread.c:151</span></p>
<p class=""><span class="">       thread = 0x7f8eb2be4868</span></p>
<p class=""><span class="">#9  0x00007f8f00ff0182 in start_thread (arg=0x7f8eb2b20700) at pthread_create.c:312</span></p>
<p class=""><span class="">       __res = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       pd = 0x7f8eb2b20700</span></p>
<p class=""><span class="">       now = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       unwind_buf = {cancel_jmp_buf = {{jmp_buf = {140250860095232, -640791540281233069, 0, 0, 140250860095936, 140250860095232, 578173923610734931, 577994035108262227}, mask_was_saved = 0}}, priv = {pad = {0x0, 0x0, 0x0, 0x0}, data = {prev = 0x0, cleanup = 0x0, canceltype = 0}}}</span></p>
<p class=""><span class="">       not_first_call = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       pagesize_m1 = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       sp = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       freesize = &lt;optimized out&gt;</span></p>
<p class=""><span class="">       __PRETTY_FUNCTION__ = &quot;start_thread&quot;</span></p>
<p class=""><span class="">#10 0x00007f8f00d1d47d in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:111</span></p>
<p class=""><span class="">No locals</span></p></div>
</div></div>