<html><head><meta http-equiv="Content-Type" content="text/html charset=iso-8859-1"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><div>On Nov 27, 2012, at 10:50 AM, Dan Gohman <<a href="mailto:dan433584@gmail.com">dan433584@gmail.com</a>> wrote:</div><blockquote type="cite"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-color: rgb(204, 204, 204); border-left-style: solid; padding-left: 1ex; position: static; z-index: auto; ">In one implementation, the loops had a fixed structure: guard branch, preheader, header and loop body, optional epilog. The structure was clearly identified by various means (flags, bits, etc.). No optimization in the optimizer (roughly a counterpart of the LLVM's bitcode optimizer) was allowed to alter it. For example, CFG simplification could change branches all it wanted, *except* the branches that were a part of the loop structure. A "continue" inside of a loop would not create a nested loop, etc. This worked like a dream (hence my limited appreciation for SimplifyCFG...).<br>
<br>
In that implementation, the metadata was placed in the loop header, or the loop preheader, depending on what information it was. Since any code that would try to move things around in a loop would have to know what it's doing (i.e. would have to be aware of the loop structure and what the rules were), there was no risk that the metadata would become accidentally separated from the loop.<br>
</blockquote><div><br></div><div>Here is an analogy for your consideration. "Where do I put the propeller?"</div></div></blockquote><div><br></div><div>Personally, I find that to be a ridiculous and unhelpful analogy. It is clearly possible and useful to represent loop information in LLVM IR. OpenMP is one particular use of it, but there are plenty of others.</div><div><br></div><div>-Chris</div></div></body></html>