<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Jul 6, 2017, at 2:05 PM, Peter Lawrence via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><meta http-equiv="Content-Type" content="text/html charset=utf-8" class=""><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div class=""><blockquote type="cite" class=""><div class="">On Jul 6, 2017, at 1:00 PM, via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><blockquote type="cite" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px;" class=""> So far, so good. The problem is that while LLVM seems to consider<br class=""> the above IR to be valid, we officially do not allow dereferencing<br class=""> a pointer constructed in this way (if I’m reading the rules<br class=""> correctly). Consequently, if this GEP ever gets close enough to a<br class=""> load using the pointer, InstCombine will eliminate the GEP and the<br class=""> load.</blockquote></div></blockquote></div><br class=""><div class="">This is the part that confuses me, why would such code be eliminated.</div><div class="">If it is illegal then this should be a compilation failure,</div></div></div></blockquote><br class=""></div><div>This is illegal code, and if we only cared about the C spec, we could at least warn about it if not reject it outright.</div><div><br class=""></div><div>That said, the purpose of clang is to build real code, and real code contains some amount of invalid constructs in important code bases. We care about building a pragmatic compiler that gets the job done, so we sometimes “make things work” even though we don’t have to. There are numerous patterns in old-style “offsetof” macros that do similar things. Instead of fighting to make all the world’s code be theoretically ideal, it is better to just eat it and “do what they meant”.</div><div><br class=""></div><div>-Chris</div><div><br class=""></div><br class=""></body></html>