<div dir="ltr">On Tue, Jul 5, 2016 at 10:30 AM, John McCall <span dir="ltr">&lt;<a href="mailto:rjmccall@apple.com" target="_blank">rjmccall@apple.com</a>&gt;</span> wrote:<br><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">&gt; On Jul 3, 2016, at 2:40 PM, Saleem Abdulrasool &lt;<a href="mailto:compnerd@compnerd.org">compnerd@compnerd.org</a>&gt; wrote:<br>
&gt; Hello again,<br>
&gt;<br>
&gt; I come bearing more problems :-).<br>
&gt;<br>
&gt; I seem to have found another point in the ABI which prevents an easy port of swift to Windows without an emulation layer underneath.  This time it deals with the protocol conformance table.  The table is constructed with a direct reference to protocol.  However, because the protocol lies in an external module, this ends up being a problem as it must be indirectly addressed.<br>
&gt;<br>
&gt; There is a workaround in place for generating a GOT equivalent entry, however, that still doesnt indirect through the pointer, which needs to be done to address the executable model on Windows.<br>
<br>
</span>Is it not possible to emit the GOT equivalent entry as a reference to the appropriate entry in the import lookup table?</blockquote><div><br></div><div>I had tried that, but it would still just be a constant reference to the value rather than the synthetic.  Perhaps I am misunderstanding something?</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="HOEnZb"><font color="#888888"><br>
John.</font></span></blockquote></div><br>-- <br><div class="gmail_signature" data-smartmail="gmail_signature">Saleem Abdulrasool<br>compnerd (at) compnerd (dot) org</div>
</div></div>