<div dir="ltr"><a href="https://reviews.llvm.org/D96290">https://reviews.llvm.org/D96290</a> should take care of this<br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Feb 5, 2021 at 9:09 AM Mircea Trofin <<a href="mailto:mtrofin@google.com">mtrofin@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div dir="ltr"><br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Feb 5, 2021 at 8:50 AM Sanjay Patel <<a href="mailto:spatel@rotateright.com" target="_blank">spatel@rotateright.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div dir="ltr">Yes, warning only if a function has no asserts sounds like it would restore the previous behavior?<br></div></div></blockquote><div>The previous <i>intended (probably)</i> behavior  :). </div><div><br></div><div>The previous behavior would have warned when 1) a function lost an assert due to a conflict, and 2) that prefix was the last one in the RUN list that happened to have caused point 1. So sometimes, depending on how RUN lines were set up, it may have happened to be the behavior we described here. Often it was just a silent failure, and/or it was resulting in an invalid test.</div><div><br></div><div>I'll create a patch with the desired behavior shortly - thanks for clarifying the problem space!</div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div dir="ltr"></div><div dir="ltr"><br></div><div dir="ltr">If I modify the example test file with a common prefix like this, then I agree with Pengfei that there should be no warnings - all functions have the expected (either common or unique) assertions:<br></div><div dir="ltr"><br></div><div dir="ltr">diff --git a/llvm/test/CodeGen/RISCV/alu32.ll b/llvm/test/CodeGen/RISCV/alu32.ll<br>index 975716e53c04..bf74ef5eab6f 100644<br>--- a/llvm/test/CodeGen/RISCV/alu32.ll<br>+++ b/llvm/test/CodeGen/RISCV/alu32.ll<br>@@ -1,292 +1,252 @@<br> ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py<br> ; RUN: llc -mtriple=riscv32 -verify-machineinstrs < %s \<br>-; RUN:   | FileCheck %s -check-prefix=RV32I<br>+; RUN:   | FileCheck %s --check-prefixes=CHECK,RV32I<br> ; RUN: llc -mtriple=riscv64 -verify-machineinstrs < %s \<br>-; RUN:   | FileCheck %s -check-prefix=RV64I<br>+; RUN:   | FileCheck %s --check-prefixes=CHECK,RV64I<br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Feb 5, 2021 at 10:57 AM Mircea Trofin <<a href="mailto:mtrofin@google.com" target="_blank">mtrofin@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr">Thanks - so would it be then desirable to just warn *if* a function ends up stripped of any assertions? I.e. say you have 2 functions, f1 and f2. First RUN line produces an output for both for prefixes "P1 and P2". Second RUN line produces a conflicting output for f1 for P1 (f2 is OK). Third RUN line produces a conflicting output for f1 for P2. Result: f1 has no asserts => we warn. </div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Feb 4, 2021 at 11:22 PM Wang, Pengfei <<a href="mailto:pengfei.wang@intel.com" target="_blank">pengfei.wang@intel.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">It looks to me the "Function ..." warnings are unnecessary. The test has been updated as expected.<br>
I agreed with Craig. I was thinking of this pain point when I removed those used prefixes.<br>
I believe it's of little account for experienced users like Craig, Simon and Sanjay who adding finer grained prefixes for X86.<br>
But I'm worry about junior user or developers form other targets who accidently changes X86 tests.<br>
<br>
Thanks<br>
Pengfei<br>
<br>
-----Original Message-----<br>
From: Fāng-ruì Sòng <<a href="mailto:maskray@google.com" target="_blank">maskray@google.com</a>> <br>
Sent: Friday, February 5, 2021 2:34 PM<br>
To: Craig Topper <<a href="mailto:craig.topper@gmail.com" target="_blank">craig.topper@gmail.com</a>><br>
Cc: Mircea Trofin <<a href="mailto:mtrofin@google.com" target="_blank">mtrofin@google.com</a>>; llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>>; Simon Pilgrim <<a href="mailto:llvm-dev@redking.me.uk" target="_blank">llvm-dev@redking.me.uk</a>>; Sanjay Patel <<a href="mailto:spatel@rotateright.com" target="_blank">spatel@rotateright.com</a>>; Wang, Pengfei <<a href="mailto:pengfei.wang@intel.com" target="_blank">pengfei.wang@intel.com</a>><br>
Subject: Re: [llvm-dev] Conflicting check prefix detection not working in update_llc_test_checks.py?<br>
<br>
Add back dropped CC: Simon and Sanjay.<br>
<br>
They use update_llc_test_checks.py heavily, perhaps, they can help? :)<br>
<br>
On Wed, Feb 3, 2021 at 11:25 AM Craig Topper via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br>
><br>
> Maybe. I'm not quite sure what you mean by "functions with no asm".<br>
><br>
> X86 especially has a lot of tests with a half dozen or more RUN lines. There is a common prefix for all RUN lines or at least all AVX/AVX512 run lines and then successively more precise check prefixes grouping smaller and smaller subsets of RUN lines. The goal is to minimize the number of check lines in the file by grouping as much as possible. But allowing precise checks for individual functions that have different behavior on many targets.<br>
><br>
> Since we can't have unused prefixes in the test files any more we might lose some of the finer grained check prefixes if multiple RUN lines produce the same results for all functions today. A future change may break that and require finer grained prefixes to be added. That's the important case to warn about since it requires the user to change the RUN lines.<br>
><br>
> ~Craig<br>
><br>
><br>
> On Tue, Feb 2, 2021 at 9:39 PM Mircea Trofin <<a href="mailto:mtrofin@google.com" target="_blank">mtrofin@google.com</a>> wrote:<br>
>><br>
>> I see, so maybe there are some levels of warning to observe - "everything", functions with no asm, prefixes with no use. And maybe the default is the second?<br>
>><br>
>> On Tue, Feb 2, 2021, 21:35 Craig Topper <<a href="mailto:craig.topper@gmail.com" target="_blank">craig.topper@gmail.com</a>> wrote:<br>
>>><br>
>>> Hi Mircea,<br>
>>><br>
>>> It looks like the script is now reporting warnings even when there is a set of prefixes to update the test for all functions. For example, if you add -check-prefixes=CHECK,RV32I to the first command in alu32.ll and -check-prefixes=CHECK,RV64I to the second you'll get this, but it looks like there's a valid solution for the test and no user intervention is required.<br>
>>><br>
>>> WARNING: Function slti had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function sltiu had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function srli had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function srai had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function add had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function sub had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function sll had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function slt had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function sltu had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function srl had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function sra had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>><br>
>>> ~Craig<br>
>>><br>
>>><br>
>>> On Mon, Feb 1, 2021 at 3:19 PM Craig Topper <<a href="mailto:craig.topper@gmail.com" target="_blank">craig.topper@gmail.com</a>> wrote:<br>
>>>><br>
>>>> Yes, that matches my expectations. Thanks!<br>
>>>><br>
>>>> ~Craig<br>
>>>><br>
>>>><br>
>>>> On Mon, Feb 1, 2021 at 3:05 PM Mircea Trofin <<a href="mailto:mtrofin@google.com" target="_blank">mtrofin@google.com</a>> wrote:<br>
>>>>><br>
>>>>> Indeed, we're now not output-ing the case where some functions have conflicting asm, just the case when all functions lose their asm.<br>
>>>>><br>
>>>>> I have a fix ready; to confirm, for this example (i.e. taking all (both) the "--check-prefix"-es in alu32.ll), would this output match your expectations?<br>
>>>>><br>
>>>>> WARNING: Function slti had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function sltiu had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function srli had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function srai had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function add had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function sub had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function sll had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function slt had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function sltu had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function srl had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function sra had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>><br>
>>>>> On Mon, Feb 1, 2021 at 2:12 PM Mircea Trofin <<a href="mailto:mtrofin@google.com" target="_blank">mtrofin@google.com</a>> wrote:<br>
>>>>>><br>
>>>>>> looking<br>
>>>>>><br>
>>>>>> On Mon, Feb 1, 2021 at 2:11 PM Craig Topper <<a href="mailto:craig.topper@gmail.com" target="_blank">craig.topper@gmail.com</a>> wrote:<br>
>>>>>>><br>
>>>>>>> update_llc_test_checks.py seems to not be telling me about assembly that differs under the same prefix anymore.<br>
>>>>>>><br>
>>>>>>> An easy way to see this is to just remove the --check-prefix from test/CodeGen/RISCV/alu32.ll and run the script. You'll get no error about conflicts. And if you look at the resulting file only some functions will have been updated to use CHECK as the prefix.<br>
>>>>>>><br>
>>>>>>> Reverting some commits to update_llc_test_checks.py suggest this <br>
>>>>>>> may have been broken by e2dc306b1ac71258e6ce40a66e778527f282c355 <br>
>>>>>>> [utils] Fix UpdateTestChecks case where 2 runs differ for last <br>
>>>>>>> label<br>
>>>>>>><br>
>>>>>>> ~Craig<br>
><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>
<br>
<br>
<br>
--<br>
宋方睿<br>
</blockquote></div>
</blockquote></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Feb 5, 2021 at 10:57 AM Mircea Trofin <<a href="mailto:mtrofin@google.com" target="_blank">mtrofin@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr">Thanks - so would it be then desirable to just warn *if* a function ends up stripped of any assertions? I.e. say you have 2 functions, f1 and f2. First RUN line produces an output for both for prefixes "P1 and P2". Second RUN line produces a conflicting output for f1 for P1 (f2 is OK). Third RUN line produces a conflicting output for f1 for P2. Result: f1 has no asserts => we warn. </div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Feb 4, 2021 at 11:22 PM Wang, Pengfei <<a href="mailto:pengfei.wang@intel.com" target="_blank">pengfei.wang@intel.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">It looks to me the "Function ..." warnings are unnecessary. The test has been updated as expected.<br>
I agreed with Craig. I was thinking of this pain point when I removed those used prefixes.<br>
I believe it's of little account for experienced users like Craig, Simon and Sanjay who adding finer grained prefixes for X86.<br>
But I'm worry about junior user or developers form other targets who accidently changes X86 tests.<br>
<br>
Thanks<br>
Pengfei<br>
<br>
-----Original Message-----<br>
From: Fāng-ruì Sòng <<a href="mailto:maskray@google.com" target="_blank">maskray@google.com</a>> <br>
Sent: Friday, February 5, 2021 2:34 PM<br>
To: Craig Topper <<a href="mailto:craig.topper@gmail.com" target="_blank">craig.topper@gmail.com</a>><br>
Cc: Mircea Trofin <<a href="mailto:mtrofin@google.com" target="_blank">mtrofin@google.com</a>>; llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>>; Simon Pilgrim <<a href="mailto:llvm-dev@redking.me.uk" target="_blank">llvm-dev@redking.me.uk</a>>; Sanjay Patel <<a href="mailto:spatel@rotateright.com" target="_blank">spatel@rotateright.com</a>>; Wang, Pengfei <<a href="mailto:pengfei.wang@intel.com" target="_blank">pengfei.wang@intel.com</a>><br>
Subject: Re: [llvm-dev] Conflicting check prefix detection not working in update_llc_test_checks.py?<br>
<br>
Add back dropped CC: Simon and Sanjay.<br>
<br>
They use update_llc_test_checks.py heavily, perhaps, they can help? :)<br>
<br>
On Wed, Feb 3, 2021 at 11:25 AM Craig Topper via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br>
><br>
> Maybe. I'm not quite sure what you mean by "functions with no asm".<br>
><br>
> X86 especially has a lot of tests with a half dozen or more RUN lines. There is a common prefix for all RUN lines or at least all AVX/AVX512 run lines and then successively more precise check prefixes grouping smaller and smaller subsets of RUN lines. The goal is to minimize the number of check lines in the file by grouping as much as possible. But allowing precise checks for individual functions that have different behavior on many targets.<br>
><br>
> Since we can't have unused prefixes in the test files any more we might lose some of the finer grained check prefixes if multiple RUN lines produce the same results for all functions today. A future change may break that and require finer grained prefixes to be added. That's the important case to warn about since it requires the user to change the RUN lines.<br>
><br>
> ~Craig<br>
><br>
><br>
> On Tue, Feb 2, 2021 at 9:39 PM Mircea Trofin <<a href="mailto:mtrofin@google.com" target="_blank">mtrofin@google.com</a>> wrote:<br>
>><br>
>> I see, so maybe there are some levels of warning to observe - "everything", functions with no asm, prefixes with no use. And maybe the default is the second?<br>
>><br>
>> On Tue, Feb 2, 2021, 21:35 Craig Topper <<a href="mailto:craig.topper@gmail.com" target="_blank">craig.topper@gmail.com</a>> wrote:<br>
>>><br>
>>> Hi Mircea,<br>
>>><br>
>>> It looks like the script is now reporting warnings even when there is a set of prefixes to update the test for all functions. For example, if you add -check-prefixes=CHECK,RV32I to the first command in alu32.ll and -check-prefixes=CHECK,RV64I to the second you'll get this, but it looks like there's a valid solution for the test and no user intervention is required.<br>
>>><br>
>>> WARNING: Function slti had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function sltiu had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function srli had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function srai had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function add had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function sub had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function sll had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function slt had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function sltu had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function srl had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>> WARNING: Function sra had conflicting output from different RUN <br>
>>> lines for prefix CHECK<br>
>>><br>
>>><br>
>>> ~Craig<br>
>>><br>
>>><br>
>>> On Mon, Feb 1, 2021 at 3:19 PM Craig Topper <<a href="mailto:craig.topper@gmail.com" target="_blank">craig.topper@gmail.com</a>> wrote:<br>
>>>><br>
>>>> Yes, that matches my expectations. Thanks!<br>
>>>><br>
>>>> ~Craig<br>
>>>><br>
>>>><br>
>>>> On Mon, Feb 1, 2021 at 3:05 PM Mircea Trofin <<a href="mailto:mtrofin@google.com" target="_blank">mtrofin@google.com</a>> wrote:<br>
>>>>><br>
>>>>> Indeed, we're now not output-ing the case where some functions have conflicting asm, just the case when all functions lose their asm.<br>
>>>>><br>
>>>>> I have a fix ready; to confirm, for this example (i.e. taking all (both) the "--check-prefix"-es in alu32.ll), would this output match your expectations?<br>
>>>>><br>
>>>>> WARNING: Function slti had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function sltiu had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function srli had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function srai had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function add had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function sub had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function sll had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function slt had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function sltu had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function srl had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>> WARNING: Function sra had conflicting output from different RUN <br>
>>>>> lines for prefix CHECK<br>
>>>>><br>
>>>>> On Mon, Feb 1, 2021 at 2:12 PM Mircea Trofin <<a href="mailto:mtrofin@google.com" target="_blank">mtrofin@google.com</a>> wrote:<br>
>>>>>><br>
>>>>>> looking<br>
>>>>>><br>
>>>>>> On Mon, Feb 1, 2021 at 2:11 PM Craig Topper <<a href="mailto:craig.topper@gmail.com" target="_blank">craig.topper@gmail.com</a>> wrote:<br>
>>>>>>><br>
>>>>>>> update_llc_test_checks.py seems to not be telling me about assembly that differs under the same prefix anymore.<br>
>>>>>>><br>
>>>>>>> An easy way to see this is to just remove the --check-prefix from test/CodeGen/RISCV/alu32.ll and run the script. You'll get no error about conflicts. And if you look at the resulting file only some functions will have been updated to use CHECK as the prefix.<br>
>>>>>>><br>
>>>>>>> Reverting some commits to update_llc_test_checks.py suggest this <br>
>>>>>>> may have been broken by e2dc306b1ac71258e6ce40a66e778527f282c355 <br>
>>>>>>> [utils] Fix UpdateTestChecks case where 2 runs differ for last <br>
>>>>>>> label<br>
>>>>>>><br>
>>>>>>> ~Craig<br>
><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>
<br>
<br>
<br>
--<br>
宋方睿<br>
</blockquote></div>
</blockquote></div>
</blockquote></div></div>
</blockquote></div>