<div dir="ltr">I think for x86_64, everything is supposed to be extended to 32-bits, but it doesn't need to go wider. At least, that was the conclusion that I took away from the last time this came up: <a href="http://lists.llvm.org/pipermail/cfe-commits/Week-of-Mon-20150907/138250.html">http://lists.llvm.org/pipermail/cfe-commits/Week-of-Mon-20150907/138250.html</a><div><br></div><div>In that case, LLVM combined two i32 loads to one i64 load and left the second i32 in the high bits of the register passed into libjpegturbo assembly. It was decided that this was correct, and libjpegturbo needed to zext.</div><div><br></div><div>For i8s and i16s, those have to be extended to i32, but LLVM doesn't know if they are signed or unsigned, so it doesn't guess. Leaving behind garbage is pretty useless and maybe even inefficient (partial register dependency). I'm still inclined to chalk this up to another LLVM usability issue for non-C frontends. There's still a lot of work to be done in that area, and this is just one of many usability problems.</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Jul 11, 2017 at 6:02 AM, Alexander Potapenko via llvm-dev <span dir="ltr"><<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi llvm-dev,<br>
<br>
Yesterday we've noticed (<a href="https://bugs.llvm.org/show_bug.cgi?id=33732" rel="noreferrer" target="_blank">https://bugs.llvm.org/show_<wbr>bug.cgi?id=33732</a>)<br>
that on x86_64 a function declaration created by getOrInsertFunction()<br>
must set the zeroext attribute for each parameter that is smaller than<br>
64 bits.<br>
Failing to do so may result in LLVM passing garbage in the upper bits<br>
of the registers instead of zeroing them out in the caller. In some<br>
cases the garbage may be passed on from the called function.<br>
<br>
I've started going through sanitizer instrumentation passes and<br>
noticed some of them also declare functions with e.g. i32 parameters<br>
lacking the zeroext attribute. There also are other LLVM passes that<br>
don't set the zeroext attribute for function parameters.<br>
<br>
I find this a little counterintuitive that every user of<br>
getOrInsertFunction() should think about whatever possible ABI<br>
conventions and opt-in into the zeroext attribute.<br>
Is it feasible to make getOrInsertFunction() take care of this<br>
automatically depending on the target?<br>
<br>
Thanks,<br>
Alex<br>
<br>
--<br>
Alexander Potapenko<br>
Software Engineer<br>
<br>
Google Germany GmbH<br>
Erika-Mann-Straße, 33<br>
80636 München<br>
<br>
Geschäftsführer: Matthew Scott Sucherman, Paul Terence Manicle<br>
Registergericht und -nummer: Hamburg, HRB 86891<br>
Sitz der Gesellschaft: Hamburg<br>
______________________________<wbr>_________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/<wbr>mailman/listinfo/llvm-dev</a><br>
</blockquote></div><br></div>