<div dir="ltr"><br><br><div class="gmail_quote">On Tue, Mar 10, 2015 at 9:43 PM Mehdi Amini <<a href="mailto:mehdi.amini@apple.com">mehdi.amini@apple.com</a>> 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"><div><blockquote type="cite"><div>On Mar 10, 2015, at 8:50 PM, Eric Christopher <<a href="mailto:echristo@gmail.com" target="_blank">echristo@gmail.com</a>> wrote:</div><br><div><p dir="ltr"><br>
</p><div><br></div><p dir="ltr">On Tue, Mar 10, 2015, 5:19 PM Mehdi Amini <<a href="mailto:mehdi.amini@apple.com" target="_blank">mehdi.amini@apple.com</a>> wrote:</p>
<blockquote><p dir="ltr">Hi all,<br></p><p dir="ltr">The Language Reference says:<br></p><p dir="ltr">"The function of the data layout string may not be what you expect. Notably, this is not a specification from the frontend of what alignment the code generator should use.</p><p dir="ltr">Instead, if specified, the target data layout is required to match what the ultimate <i>code generator</i> expects. This string is used by the mid-level optimizers to improve code, and this only works if it matches what the ultimate code generator uses. If you would like to generate IR that does not embed this target-specific detail into the IR, then you don’t have to specify the string. This will disable some optimizations that require precise layout information, but this also prevents those optimizations from introducing target specificity into the IR.”</p><p dir="ltr">I understand from this that the DataLayout present in the Module *must* match the DataLayout that the Target will use.</p><p dir="ltr">There is no runtime check to enforce this at that time. </p><p dir="ltr">My impression is that I can set the DataLayout on the Module to be big-endian and run the optimizer and the X86 backend. </p><p dir="ltr">The IR-level passes will use the DataLayout supplied with the Module and the backend code will silently use the TargetMachine one.</p><p dir="ltr">Should we enforce that the DataLayout attached to the Module matches the one expected by the Target?</p>
</blockquote><div><br></div><p dir="ltr">Definitely. That said clang does this in asserts mode. </p></div></blockquote></div></div><div style="word-wrap:break-word"><div><div>Can you be more specific?</div><div>From what I see, clang (for an IR file only of course) will match the triple, but not the DataLayout (or I haven’t found where):</div><div><br></div></div></div></blockquote><div><br></div><div>Sure, sorry, was on my phone earlier:</div><div>







<p class="p1"><span class="s1">    </span><span class="s2">std</span><span class="s1">::</span><span class="s3">string</span><span class="s1"> </span><span class="s4">DLDesc</span><span class="s1"> =</span></p>
<p class="p1"><span class="s1">        AsmHelper.TM->getDataLayout()->getStringRepresentation();</span></p>
<p class="p1"><span class="s1">    </span><span class="s5">if</span><span class="s1"> (DLDesc != TDesc) {</span></p>
<p class="p1"><span class="s1">      </span><span class="s3">unsigned</span><span class="s1"> </span><span class="s4">DiagID</span><span class="s1"> = Diags.getCustomDiagID(</span></p>
<p class="p2"><span class="s6">          </span><span class="s2">DiagnosticsEngine</span><span class="s6">::Error, </span><span class="s1">"backend data layout '%0' does not match "</span></p>
<p class="p1"><span class="s1">                                    </span><span class="s7">"expected target description '%1'"</span><span class="s1">);</span></p>
<p class="p1"><span class="s1">      Diags.Report(DiagID) << DLDesc << TDesc;</span></p></div><div><br></div><div>lib/CodeGen/BackendUtil.cpp:656.</div><div><br></div><div>-eric</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><div><div></div><div><div style="margin:0px;font-size:11px;font-family:Menlo">    <span style="color:#0433ff">if</span> (TheModule->getTargetTriple() != TargetOpts.Triple) {</div><div style="margin:0px;font-size:11px;font-family:Menlo">      CI.getDiagnostics().Report(SourceLocation(),</div><div style="margin:0px;font-size:11px;font-family:Menlo">                                 diag::warn_fe_override_module)</div><div style="margin:0px;font-size:11px;font-family:Menlo">          << TargetOpts.Triple;</div><div style="margin:0px;font-size:11px;font-family:Menlo">      TheModule->setTargetTriple(TargetOpts.Triple);</div><div style="margin:0px;font-size:11px;font-family:Menlo">    }</div></div></div></div><div style="word-wrap:break-word"><div><div><div><br></div><div><br></div><div>Mehdi</div><div><br></div></div></div></div></blockquote></div></div>