<div dir="ltr">Clang on Windows is designed to be compatible with MSVC - which has different layout requirements than the Itanium ABI/GCC on Linux. I don't think there's a way to use the same ABI on both platforms - especially not if you are interacting with any code compiled by another compiler on both platforms (existing/foregin C++ precompiled libraries).</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Jan 28, 2021 at 1:45 PM Vivek Pandey via cfe-users <<a href="mailto:cfe-users@lists.llvm.org">cfe-users@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">





<div lang="EN-US" style="overflow-wrap: break-word;">
<div class="gmail-m_-8432327205818430368WordSection1">
<p class="MsoNormal">Hi Team,<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">We are using Clang 11 for our product that has common C++ code base for Windows, Linux, Macintosh, ….<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">We observed that <span style="background:yellow">
sizeof</span> operator gives different value on Windows and Linux/OSX, when the inheritance is from a common base class:<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">Example Sample:<u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:8pt"><u></u> <u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">#include <cassert><u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New""> <u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">struct Base {}; // empty class<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New""> <u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">struct Derived1 : Base {<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">    int i;<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">};<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New""> <u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">struct Derived2 : Base {<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">    Base c; // Base, occupies 1 byte, followed by padding for i<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">    int i;<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">};<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New""> <u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">struct Derived3 : Base {<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">    Derived1 c; //
<span style="background:yellow">Derived1 is too derived from same Base class</span><u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">    int i;<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">};<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">int main()<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">{<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">   
<a href="http://en.cppreference.com/w/cpp/error/assert" target="_blank"><span style="color:blue">assert</span></a>(sizeof(Derived2) == 2*sizeof(int));<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New""> <u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">   
<a href="http://en.cppreference.com/w/cpp/error/assert" target="_blank"><span style="color:blue">assert</span></a>(<span style="background:yellow">sizeof(Derived3)</span> == 3*sizeof(int));<u></u><u></u></span></p>
<p class="MsoNormal" style="margin-left:45.8pt"><span style="font-size:8pt;font-family:"Courier New"">}<u></u><u></u></span></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">              When we compile above program using Clang 11 and run it on windows and Linux  sizeof(<span style="font-size:10pt;font-family:"Courier New";background:yellow">Derived3</span>) give different value.<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">We don’t want a work-around via making first data member of derived class of type different from class that also is derived from same empty base class.<u></u><u></u></p>
<p class="MsoNormal">Is there any flag that we can use so that it gives same result on all platform (Windows/Linux/OSX/Android/iOS/….)<u></u><u></u></p>
<p class="MsoNormal">Or another way to solve this gracefully. <u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">Thank you!<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">Best Regards,<u></u><u></u></p>
<p class="MsoNormal">Vivek<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
</div>

_______________________________________________<br>
cfe-users mailing list<br>
<a href="mailto:cfe-users@lists.llvm.org" target="_blank">cfe-users@lists.llvm.org</a><br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-users" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-users</a><br>
</blockquote></div>