<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css" style="display:none;"><!-- P {margin-top:0;margin-bottom:0;} --></style>
</head>
<body dir="ltr">
<div id="divtagdefaultwrapper" style="font-size: 12pt; color: rgb(0, 0, 0); font-family: Calibri,Helvetica,sans-serif,"EmojiFont","Apple Color Emoji","Segoe UI Emoji",NotoColorEmoji,"Segoe UI Symbol","Android Emoji",EmojiSymbols;" dir="ltr">
<font face="Calibri, sans-serif">Hi,</font><br>
<div style="color: rgb(0, 0, 0);">
<div id="divRplyFwdMsg" dir="ltr">
<div> </div>
</div>
<div class="BodyFragment"><font size="2"><span style="font-size:11pt;">
<div class="PlainText">On Sat, 2 Mar 2019 at 06:58, carl-llvm-dev@petosoft.com via llvm-dev<br>
<llvm-dev@lists.llvm.org> wrote:<br>
> AVRTargetLowering::LowerFormalArguments, we already have a problem because the 32 bit return value has been turned into two 16 bit values by the legaliser and the information has been lost that it was one 32 bit value.<br>
<br>
> Isn't it kept (rather awkwardly) by the fact that the first half of<br>
> this value has the "IsSplit" flag set? The ARM backends use this to<br>
> handle i64 and i128 specially; they need extra alignment rather than<br>
> byte-swapping, but the principle ought to be similar.<br>
<br>
Just my two cents; I believe that 'IsSplit' is not actually set on return values in certain cases. Found this out when I was looking into a similar calling convention detail in our downstream target.<br>
<br>
Also, this might not be relevant to this particular case, but IsSplit is a bit of a kludge and generally useless if you're splitting something into more than two parts, since it cannot tell you which sub-value you're actually looking at. It only tells you that
it _is_ a sub-value (and if it's the last one), which makes picking registers in some particular order quite difficult. This means you need to keep state in your CC analyzer, or preanalyze the arguments.<br>
<br>
/ Bevin<br>
_______________________________________________<br>
LLVM Developers mailing list<br>
llvm-dev@lists.llvm.org<br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" id="LPlnk375322" class="OWAAutoLink" previewremoved="true">https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
</div>
</span></font></div>
</div>
</div>
</body>
</html>