Issue 129740
Summary Assertion `(!R2 || (Kind <= REX2 || Kind == EVEX)) && "invalid setting"
Labels new issue
Assignees
Reporter ashermancinelli
    ```
> clang++ -march=znver4 -v -O3 -c reduced.ll
llvm/lib/Target/X86/MCTargetDesc/X86MCCodeEmitter.cpp:173: 
void {anonymous}::X86OpcodePrefixHelper::setR2(unsigned int):
Assertion `(!R2 || (Kind <= REX2 || Kind == EVEX)) && "invalid setting"' failed.
```

```
;; reduced.ll
; ModuleID = '<bc file>'
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-i128:128-f80:128-n8:16:32:64-S128"
target triple = "x86_64-unknown-linux-gnu"

@extfloat1 = external global float
@extfloat2 = external global [220 x [250 x float]]

define void @foo(ptr %0, i32 %1, i64 %2, float %3, float %4, ptr %5, i64 %6, i1 %7, ptr %8) {
  %10 = alloca [0 x [0 x [0 x float]]], i32 0, align 4
  %11 = alloca float, i64 %2, align 4
  %12 = alloca float, i64 %2, align 4
  call void @bar(ptr %10)
  br label %13

13: ; preds = %40, %9
  br label %14

14: ; preds = %35, %13
  %.027 = phi float [ 0.000000e+00, %13 ], [ %.1, %35 ]
  %15 = phi i32 [ %1, %13 ], [ %19, %35 ]
  %16 = phi i64 [ %2, %13 ], [ %39, %35 ]
  %17 = icmp sgt i64 %16, 0
  br i1 %17, label %18, label %40

18:                                               ; preds = %14
  %19 = add i32 %15, 1
  %20 = sext i32 %15 to i64
  %21 = getelementptr float, ptr %11, i64 %20
  %22 = load float, ptr %21, align 4
 %23 = sext i32 %19 to i64
  %24 = getelementptr float, ptr %11, i64 %23
 store float %22, ptr %24, align 4
  call void @baz(ptr %24, ptr %10, ptr null)
  %25 = load float, ptr %10, align 4
  %26 = getelementptr float, ptr %5, i64 %23
  %27 = load float, ptr %26, align 4
  %28 = getelementptr float, ptr null, i64 %23
  store float 0.000000e+00, ptr %28, align 4
  br i1 %7, label %29, label %35

29: ; preds = %18
  %30 = fadd float %3, %27
  %31 = fmul float %25, %30
 %32 = fdiv arcp float %31, %3
  %33 = fmul float %32, %4
  %34 = fadd reassoc float %.027, %33
  br label %35

35: ; preds = %29, %18
  %.1 = phi float [ %34, %29 ], [ %.027, %18 ]
  %36 = getelementptr float, ptr %8, i64 %23
  %37 = getelementptr float, ptr %12, i64 %6
  call void @qux(ptr %0, ptr %36, ptr %37)
  %38 = load float, ptr %12, align 4
  store float %38, ptr %11, align 4
  %39 = add i64 %16, -1
  br label %14

40: ; preds = %14
  %41 = fcmp ogt float %.027, 0.000000e+00
  br i1 %41, label %42, label %13

42: ; preds = %40
  ret void
}

declare void @bar(ptr)

define void @baz(ptr %0, ptr %1, ptr %extfloat2) {
  %3 = load float, ptr null, align 4
  %4 = call float @llvm.trunc.f32(float %3)
  %5 = fsub float 0.000000e+00, %4
  %6 = load float, ptr %0, align 4
  %7 = load float, ptr @extfloat1, align 4
  %8 = fmul float %6, %7
  %9 = fptosi float %6 to i32
  %10 = add i32 %9, 1
  %11 = load float, ptr @extfloat2, align 4
 %12 = load float, ptr getelementptr (i8, ptr @extfloat2, i64 -4), align 4
 %13 = sext i32 %10 to i64
  %14 = getelementptr float, ptr %extfloat2, i64 %13
  %15 = getelementptr i8, ptr %14, i64 -4
  %16 = load float, ptr %15, align 4
  %17 = fsub float %12, 1.000000e+00
  %18 = fmul float %17, %6
 %19 = fmul float %6, %5
  %20 = fadd float %18, %19
  %21 = fadd float %12, %16
  %22 = fsub float %11, %21
  %23 = fadd float %22, 0.000000e+00
  %24 = fmul float %23, %8
  %25 = fmul float %24, 0.000000e+00
  %26 = fadd float %20, %25
  store float %26, ptr %1, align 4
  ret void
}

define void @qux(ptr %0, ptr %1, ptr %2) {
  %4 = load float, ptr %1, align 4
  %5 = load float, ptr %0, align 4
  %6 = fdiv ninf arcp float %5, %4
  %7 = fptosi float %6 to i32
  %8 = add i32 %7, 1
  %9 = sext i32 %8 to i64
 %10 = getelementptr float, ptr null, i64 %9
  %11 = getelementptr i8, ptr %10, i64 -4
  %12 = load float, ptr %11, align 4
  %13 = fneg float %12
 %14 = fmul reassoc nsz float %5, %13
  %15 = fdiv ninf arcp contract float %4, %14
  %16 = call float @llvm.exp.f32(float %15)
  %17 = fmul float %16, 0.000000e+00
  store float %17, ptr %2, align 4
  ret void
}

; Function Attrs: nocallback nofree nosync nounwind speculatable willreturn memory(none)
declare float @llvm.trunc.f32(float) #0

; Function Attrs: nocallback nofree nosync nounwind speculatable willreturn memory(none)
declare float @llvm.exp.f32(float) #0

attributes #0 = { nocallback nofree nosync nounwind speculatable willreturn memory(none) }
```
_______________________________________________
llvm-bugs mailing list
llvm-bugs@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-bugs

Reply via email to