<div dir="ltr"><div dir="ltr"><br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Jun 17, 2021 at 10:15 AM David Blaikie via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div dir="ltr">Got links to the reviews? Hard to discuss in the abstract.<br><br>But generally, if it is intended to change observable behavior of the LLVM program (if you have to modify a lit test, that's not NFC, if one could craft a test (that doesn't invoke UB, though that shouldn't be possible through the command line interface, etc) that would need to be modified when the patch is committed - then it's not NFC).<br></div></blockquote><div><br></div><div>That's my litmus test: I see NFC is an indication that no test changes and none are expected to be provided. The functional behavior of the compiler is unchanged.  I use NFC on API changes and refactoring when it fits this description.</div><div><br></div><div>We could improve the doc maybe?<br></div><div><br></div><div>-- </div><div>Mehdi <br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div dir="ltr"><br>But I think it's important that NFC is about intent, not about the reality of what the patch ends up doing - so we can't judge an NFC patch by whether it causes a regression later - the NFC marker is there to say "I don't intend this to cause any observable change, if you observe any change, that's a bug" in the same way any patch description is a statement of intent and can't be more than that.</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Jun 17, 2021 at 10:11 AM Luke Drummond via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">Hi all<br>
<br>
Twice in the last week I've had to bisect crashes in the middle end or failed CI<br>
due to commits marked "[NFC]" that changed something fundamental about a public<br>
API or the format of IR.<br>
<br>
While I understand LLVM's always been pretty fluid with API and ABI stability,<br>
it smacks a little when the offending commit is marked "[NFC]".<br>
<br>
Can some elders / code-owners comment on the expected threshold for what no<br>
longer counts as "NFC"? I'd personally like to limit its usage to things like<br>
changing a local variable name, rewording a comment, or clang-formatting<br>
something - not API, ABI, or IR changes.<br>
<br>
All the Best<br>
<br>
Luke<br>
-- <br>
Codeplay Software Ltd.<br>
Company registered in England and Wales, number: 04567874<br>
Registered office: Regent House, 316 Beulah Hill, London, SE19 3HF<br>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
</blockquote></div>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
</blockquote></div></div>