[llvm] [SLP]Fix/improve getSpillCost analysis (PR #129258)

Alexander Kornienko via llvm-commits llvm-commits at lists.llvm.org
Fri Mar 14 19:26:16 PDT 2025


alexfh wrote:

We've found a clang crash that seems to be introduced by this commit. The original build is using instrumented FDO + thinlto with a bunch of dependencies. I managed to get a standalone reproducer (hopefully, nothing important was lost during the automated reduction):
```
$ cat reduced.ll
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128-Fn32"
target triple = "aarch64-unknown-linux-gnu"

define void @_f(i64 %0) {
  switch i32 0, label %.lr.ph126 [
    i32 0, label %.loopexit35
    i32 1, label %.loopexit35
  ]

.loopexit46:                                      ; preds = %27
  %2 = load i64, ptr getelementptr inbounds nuw (i8, ptr null, i64 72), align 8
  %3 = or i64 %2, %21
  store i64 %3, ptr getelementptr inbounds nuw (i8, ptr null, i64 72), align 8
  %4 = load i64, ptr getelementptr inbounds nuw (i8, ptr null, i64 48), align 8
  %5 = or i64 %4, %22
  store i64 %5, ptr getelementptr inbounds nuw (i8, ptr null, i64 48), align 8
  %6 = load i64, ptr getelementptr inbounds nuw (i8, ptr null, i64 64), align 8
  %7 = or i64 %6, %23
  store i64 %7, ptr getelementptr inbounds nuw (i8, ptr null, i64 64), align 8
  %8 = load i64, ptr getelementptr inbounds nuw (i8, ptr null, i64 56), align 8
  %9 = or i64 %8, %24
  store i64 %9, ptr getelementptr inbounds nuw (i8, ptr null, i64 56), align 8
  br label %.loopexit35

.lr.ph126:                                        ; preds = %27, %1
  %10 = phi i64 [ %0, %27 ], [ 0, %1 ]
  %11 = phi i64 [ 0, %27 ], [ 0, %1 ]
  %12 = phi i64 [ 0, %27 ], [ 0, %1 ]
  %13 = phi i64 [ 0, %27 ], [ 0, %1 ]
  br i1 false, label %.loopexit39, label %.lr.ph

.lr.ph:                                           ; preds = %16, %.lr.ph126
  %14 = phi i64 [ %17, %16 ], [ 0, %.lr.ph126 ]
  %15 = phi i64 [ 0, %16 ], [ 0, %.lr.ph126 ]
  br i1 false, label %.loopexit39, label %16

16:                                               ; preds = %.lr.ph
  %17 = add i64 0, 0
  br i1 false, label %.lr.ph, label %.loopexit39

.loopexit39:                                      ; preds = %16, %.lr.ph, %.lr.ph126
  %18 = phi i64 [ 0, %.lr.ph126 ], [ %15, %.lr.ph ], [ %14, %16 ]
  %19 = phi i64 [ 0, %.lr.ph126 ], [ %14, %.lr.ph ], [ %17, %16 ]
  %20 = phi i64 [ 0, %.lr.ph126 ], [ %14, %.lr.ph ], [ %14, %16 ]
  %21 = or i64 %19, %13
  %22 = or i64 %20, %12
  %23 = or i64 %18, %11
  %24 = or i64 %18, %10
  br label %27

25:                                               ; No predecessors!
  %26 = call ptr null(i64 0)
  br label %27

27:                                               ; preds = %25, %.loopexit39
  br i1 false, label %.lr.ph126, label %.loopexit46

.loopexit35:                                      ; preds = %.loopexit46, %1, %1
  ret void
}

; uselistorder directives
uselistorder ptr null, { 0, 4, 3, 2, 1 }
$ opt -passes slp-vectorizer reduced.ll -o /dev/null
Instruction does not dominate all uses!
  %11 = insertelement <2 x i64> %10, i64 0, i32 1
  %8 = shufflevector <2 x i64> %11, <2 x i64> poison, <2 x i32> <i32 1, i32 poison>
LLVM ERROR: Broken module found, compilation aborted!
```

https://github.com/llvm/llvm-project/pull/129258


More information about the llvm-commits mailing list