<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;">I think that Tyler addressed all of the comments that the reviewers had, so unless there are any other objections I think this patch should be committed. <div><br><div><div>On May 6, 2014, at 4:22 PM, Arnold Schwaighofer <<a href="mailto:aschwaighofer@apple.com">aschwaighofer@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><meta http-equiv="Content-Type" content="text/html charset=windows-1252"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">It seems to me that the patch is in pretty good shape. Does it make sense do the rest of the review in tree?<div><br></div><div><br><div><div>On May 6, 2014, at 1:19 PM, Tyler Nowicki <<a href="mailto:tnowicki@apple.com">tnowicki@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><meta http-equiv="Content-Type" content="text/html charset=us-ascii"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">Hi Alexey,<div><br></div><div>Thanks for the review. I applied many of your suggestions. Please review my comments below. Here is the updated patch.</div><div><br></div><div>Tyler</div><div><br></div><div></div></div>
<span><pragma_loop-svn.patch></span><meta http-equiv="Content-Type" content="text/html charset=windows-1252"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div></div><div><br></div><div><br></div><div><blockquote type="cite">+ if (Type == LoopHintAttr::Value) {<br>+ llvm::APSInt ValueAPS;<br>+ if(!ValueExpr || !ValueExpr->EvaluateAsInt(ValueAPS, CGM.getContext()) ||<br>+ (ValueInt = ValueAPS.getSExtValue()) < 1) {<br>+ CGM.getDiags().Report(LH->getRange().getEnd(),<br>+ diag::warn_pragma_loop_invalid_value) <<<br>+ LH->getSpelling();<br>+ continue;<br>+ }<br>+ }<br>+<br>+ llvm::Value *Value;<br>+ llvm::MDString *Name;<br>+ LoopHintAttr::Spelling S = LH->getSemanticSpelling();<br>+<br>+ if (S == LoopHintAttr::Keyword_vectorize) {<br>+ // Do not add hint if it is incompatible with prior hints.<br>+ if (!LoopHintAttr::isCompatible(VectorizeState | Type)) {<br>+ CGM.getDiags().Report(LH->getRange().getEnd(),<br>+ diag::warn_pragma_loop_incompatible) <<<br>+ LoopHintAttr::getName(VectorizeState) <<<br>+ LoopHintAttr::getName(Type) <<<br>+ LH->getSpelling();<br>+ continue;<br>+ }<br><br>+ } else if (S == LoopHintAttr::Keyword_interleave) {<br>+ // Do not add hint if it is incompatible with prior hints.<br>+ if (!LoopHintAttr::isCompatible(InterleaveState | Type)) {<br>+ CGM.getDiags().Report(LH->getRange().getEnd(),<br>+ diag::warn_pragma_loop_incompatible) <<<br>+ LoopHintAttr::getName(InterleaveState) <<<br>+ LoopHintAttr::getName(Type) <<<br>+ LH->getSpelling();<br>+ continue;<br>+ }<br><br><br>I think it should be verified in Sema, not in CodeGen<br></blockquote><div><br></div><div>I think it makes sense because c++11 attributes, for example [[loop vectorize(4)]], would be verified at this point too.</div><div><br></div><div><br></div><blockquote type="cite">4. lib/Parse/ParsePragma.cpp<br><br>BalancedDelimiterTracker is not used for parsing.<br></blockquote><div><br></div><div>I looked at using this. BDT requires an instance of Parser which is not given to the pragma handlers (see initializePragmaHandlers). No other pragmas use BDT. If you think pragmas should use BDT then it should be done in another patch.</div><div><br></div><div><br></div><blockquote type="cite">+ case tok::annot_pragma_loop_hint:<br>+ ProhibitAttributes(Attrs);<br>+ return ParsePragmaLoopHint(Stmts, OnlyStatement, TrailingElseLoc, Attrs);<br><br>Why attributes are prohibited?<br></blockquote><div><br></div><div>ProhibitAttributes informs the programmer attributes are not allowed if any are given. I don’t think attributes are allowed on preprocessor directives ([[attribute]] #pragma …?) and none of the existing pragmas allow attributes.</div><div><br></div><div><br></div><blockquote type="cite">+ if (<a href="http://tok.is/">Tok.is</a>(tok::kw___attribute) &&<br>+ (<a href="http://nexttok.is/">NextTok.is</a>(tok::kw_do) ||<br>+ <a href="http://nexttok.is/">NextTok.is</a>(tok::kw_for) ||<br>+ <a href="http://nexttok.is/">NextTok.is</a>(tok::kw_while)) ) {<br>+ // Get the loop's attributes.<br>+ MaybeParseCXX11Attributes(Attrs, 0, /*MightBeObjCMessageSend*/ true);<br>+ }<br><br>I don't think that this correct to handle attributed statements. C++11 does not use __attribute as a key word for attributes, but '[[' sequence. I think it would be better just to call MaybeParseCXX11Attributes(...) without any preconditions. Besides, AttributedStmt will be never created, because you don't call Sema::ProcessStmtAttributes(...) after all.<br></blockquote><div><br></div><div>You are right, I improved this part of the code. But I also think you missed something important about how this works. The pragma for loop hint is turned into an Attrs of an AttributedStmt, but this does not happen right away. The loop hint gets added to a ParsedAttributes list. If the subsequent loop also has attributes those are also added to the ParsedAttributes list. ParsePragmaLoopHint returns a loop stmt and the ParsedAttributes list. Both are turned into an AttributedStmt by the call to ProcessStmtAttributes by ParseStatementOrDeclaration.</div><div><br></div><div><br></div><blockquote type="cite">6. lib/Sema/SemaStmtAttr.cpp<br><br>+ if (St->getStmtClass() != Stmt::DoStmtClass &&<br>+ St->getStmtClass() != Stmt::ForStmtClass &&<br>+ St->getStmtClass() != Stmt::CXXForRangeStmtClass &&<br>+ St->getStmtClass() != Stmt::WhileStmtClass) {<br>+ S.Diag(St->getLocStart(), diag::warn_pragma_loop_precedes_nonloop);<br>+ return 0;<br>+ }<br><br>AttributedStmts are not allowed?<br></blockquote><div><br></div><div>No, this function examines the loop hint ParsedAttribute and returns an Attr. The result of ProcessStmtAttributes is an AttributedStmt.</div></div></div>_______________________________________________<br>cfe-commits mailing list<br><a href="mailto:cfe-commits@cs.uiuc.edu">cfe-commits@cs.uiuc.edu</a><br><a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br></blockquote></div><br></div></div></blockquote></div><br></div></body></html>