<div dir="ltr">yeah, that makes sense.</div><div class="gmail_extra"><br><br><div class="gmail_quote">On Fri, Aug 22, 2014 at 9:45 AM, Neale Ferguson <span dir="ltr"><<a href="mailto:NealeFerguson@verizon.net" target="_blank">NealeFerguson@verizon.net</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">I am also wondering about the parameters in some of the OCIBindxxxx methods and the OCIDefineByPosPtr that are "ref IntPtr". There's a small window when GC could suspend the thread where the IntPtr object is also moved before the OCI call has completed and set the underlying IntPtr field.<div class="">

<div><br><div><div>On Aug 21, 2014, at 9:48 PM, Miguel de Icaza <<a href="mailto:miguel@xamarin.com" target="_blank">miguel@xamarin.com</a>> wrote:</div><br><blockquote type="cite"><div dir="ltr">Hello,<div><br></div>

<div>Wanted to follow up to Neale's comment, as he clarified an important point that I overlooked.</div><div><br></div><div>There are two ref parameters that are being passed to unmanaged code, both point to fields inside the OciDefineHandle managed type.   </div>



<div><br></div><div>Neale's analysis is correct: the object might move and with it, the two short variables that were passed to OciDefineByPos.   This would explain the crashes that developers are experiencing with the OracleClient provider and Sgen.</div>



<div><br></div><div>The proposed fix is one possible solution: to allocate the values outside of the managed heap for both the short values.</div><div><br></div><div>There is another suspicious use that we should look into.  The OciDefineByPos method is actually a set of overloaded methods, with different types for the "value" parameter.    It is often a handle that is usually allocated via an unmanaged API.   But there are a few troubling uses:</div>



<div><ul><li>ref value: used in DefineTimeStamp</li><li>ref value: when passing the reference to a Handle defined in a separate class, DefineLob, DefineInterval</li></ul><div>The above does not look very easy to fix.</div>



</div><div><br></div><div>Given that these are resources that should be explicitly disposed, perhaps what we should do is allocate a GCHandle for the OciDefineHandle object (from OciStatementHandle, the one place that creates these objects) and also create GCHandles for the objects that we use their Handle fields from (in DefineTimeStamp, DefineLob, DefineInterval) and release the GCHandles in the respective Dispose methods.</div>



<div><br></div><div>Miguel</div></div></blockquote></div></div></div></div></blockquote></div><br></div>