<html><head><meta http-equiv="Content-Type" content="text/html charset=windows-1252"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">Good catch, thanks.<div><br></div><div>Committed in r<span style="font-family: Menlo; font-size: 11px;">183544.</span></div><div><font face="Menlo"><span style="font-size: 11px;"><br></span></font><div apple-content-edited="true">
<div style="color: rgb(0, 0, 0); font-family: Helvetica; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">-Quentin</div>
</div>
<br><div><div>On Jun 7, 2013, at 11:00 AM, Jim Grosbach <<a href="mailto:grosbach@apple.com">grosbach@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">There’s some trailing whitespace in the patch, but other than that trivial detail, this LGTM.<div><br></div><div>-Jim</div><div><br></div><div><div>On Jun 7, 2013, at 9:18 AM, Quentin Colombet <<a href="mailto:qcolombet@apple.com">qcolombet@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">Ping?<div><br><div apple-content-edited="true"><div style="font-family: Helvetica; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">-Quentin</div></div><br><div><div>On Jun 4, 2013, at 5:10 PM, Quentin Colombet <<a href="mailto:qcolombet@apple.com">qcolombet@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">Hi,<div><br></div><div>** Context **</div><div>Currently, the compiler asserts if it encounters big constants whose bit width is not a multiple of 64-bits .</div><div>Although clang would never generate something like this, the backend should be able to handle any legal IR.</div><div><br></div><div>** Proposal **</div><div>The proposed patch teaches the AsmPrinter how to emit such constants.</div><div><br></div><div>** Implementation Details **</div><div>It emits the bytes, that will not be part of the 64-bits chunks, in a separate directive after the 64-bits chunks.</div><div>The chosen directive fills the gap in size between the emitted 64-bits chunks and the size expected by the target data layout.</div><div><br></div><div>The little endian case is straightforward as the extra bits are emitted at the end.</div><div>The big endian case requires more work. The left most bit of the first directive is expected to be the most significant one. Since the bit width of the data is not a multiple of 64-bits, the APInt does not expose nice 64-bits chunks.</div><div>The chosen approach is to shift the data so that the chunks are perfectly aligned. Then, the process is similar to little endian case.</div><div>See the comments in the patch for more details.</div><div><br></div><div>** Test Cases **</div><div>The patch includes 3 test cases:</div><div>- X86_64: little endian, last directive is 64 bits.</div><div>- Mips: big endian, last directive is 64 bits.</div><div>- thumbv7: little endian, last directive is 32 bits. </div><div><br></div><div>Thanks for the review,</div><div><br></div><div><div apple-content-edited="true"><div style="font-family: Helvetica; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">-Quentin</div></div></div><span><AsmPrinter-odd-cst.svndiff></span><div></div>_______________________________________________<br>llvm-commits mailing list<br><a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br><a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a></div></blockquote></div></div></div></blockquote></div></div></blockquote></div><br></div></body></html>