<html>
    <head>
      <base href="https://bugs.llvm.org/">
    </head>
    <body><table border="1" cellspacing="0" cellpadding="8">
        <tr>
          <th>Bug ID</th>
          <td><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - [AArch64] Assertion `i != e && "VECTOR_SHUFFLE node with all undef indices!"'"
   href="https://bugs.llvm.org/show_bug.cgi?id=41535">41535</a>
          </td>
        </tr>

        <tr>
          <th>Summary</th>
          <td>[AArch64] Assertion `i != e && "VECTOR_SHUFFLE node with all undef indices!"'
          </td>
        </tr>

        <tr>
          <th>Product</th>
          <td>libraries
          </td>
        </tr>

        <tr>
          <th>Version</th>
          <td>trunk
          </td>
        </tr>

        <tr>
          <th>Hardware</th>
          <td>PC
          </td>
        </tr>

        <tr>
          <th>OS</th>
          <td>All
          </td>
        </tr>

        <tr>
          <th>Status</th>
          <td>NEW
          </td>
        </tr>

        <tr>
          <th>Severity</th>
          <td>enhancement
          </td>
        </tr>

        <tr>
          <th>Priority</th>
          <td>P
          </td>
        </tr>

        <tr>
          <th>Component</th>
          <td>Backend: AArch64
          </td>
        </tr>

        <tr>
          <th>Assignee</th>
          <td>unassignedbugs@nondot.org
          </td>
        </tr>

        <tr>
          <th>Reporter</th>
          <td>efriedma@quicinc.com
          </td>
        </tr>

        <tr>
          <th>CC</th>
          <td>arnaud.degrandmaison@arm.com, llvm-bugs@lists.llvm.org, peter.smith@linaro.org, spatel+llvm@rotateright.com, Ties.Stuij@arm.com
          </td>
        </tr></table>
      <p>
        <div>
        <pre>llc: [...]/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp:9353: static bool
llvm::ShuffleVectorSDNode::isSplatMask(const int *, llvm::EVT): Assertion `i !=
e && "VECTOR_SHUFFLE node with all undef indices!"' failed.

Started showing up this week on
<a href="http://lab.llvm.org:8011/builders/aosp-O3-polly-before-vectorizer-unprofitable">http://lab.llvm.org:8011/builders/aosp-O3-polly-before-vectorizer-unprofitable</a>
.  I'm pretty sure this is a regression from <a href="https://reviews.llvm.org/D60545">https://reviews.llvm.org/D60545</a>
("[DAGCombiner] narrow shuffle of concatenated vectors").  I didn't properly
bisect, but it's the only relevant commit in the failure range.

Reduced testcase (crashes with "llc"):

target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
target triple = "aarch64-unknown-linux-android"

define void @f(i32 %src2, <16 x i8>* %tmp27) {
entry:
  %tmp1 = insertelement <2 x i32> undef, i32 %src2, i32 0
  %tmp6 = mul <2 x i32> %tmp1, <i32 2, i32 3>
  %tmp7 = shufflevector <2 x i32> %tmp6, <2 x i32> undef, <4 x i32> <i32 0, i32
1, i32 undef, i32 undef>
  %tmp9 = mul nsw <2 x i32> %tmp1, <i32 3, i32 3>
  %tmp10 = shufflevector <2 x i32> %tmp9, <2 x i32> undef, <4 x i32> <i32 0,
i32 undef, i32 undef, i32 undef>
  %tmp11 = insertelement <4 x i32> undef, i32 2, i32 2
  %tmp12 = shufflevector <4 x i32> %tmp11, <4 x i32> undef, <4 x i32> <i32 0,
i32 1, i32 2, i32 4>
  %tmp13 = shufflevector <4 x i32> undef, <4 x i32> %tmp7, <4 x i32> <i32 0,
i32 4, i32 5, i32 undef>
  %tmp14 = shufflevector <4 x i32> %tmp13, <4 x i32> %tmp10, <4 x i32> <i32 0,
i32 1, i32 2, i32 4>
  %tmp15 = add nsw <4 x i32> %tmp12, %tmp14
  %tmp16 = extractelement <4 x i32> %tmp15, i32 2
  %tmp17 = insertelement <16 x i32> undef, i32 %tmp16, i32 13
  %tmp18 = extractelement <4 x i32> %tmp15, i32 3
  %tmp19 = insertelement <16 x i32> %tmp17, i32 %tmp18, i32 14
  %tmp26 = trunc <16 x i32> %tmp19 to <16 x i8>
  store <16 x i8> %tmp26, <16 x i8>* %tmp27, align 1
  ret void
}</pre>
        </div>
      </p>


      <hr>
      <span>You are receiving this mail because:</span>

      <ul>
          <li>You are on the CC list for the bug.</li>
      </ul>
    </body>
</html>