Matt Arsenault 1bc9b67bd8
Scalarizer: Replace cl::opts with pass parameters (#110645)
Preserve the existing defaults (although load-store defaulting
to false is a really bad one). Also migrate DirectX tests to new PM.
2024-10-02 14:45:26 +04:00

28 lines
1.1 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt %s -passes='scalarizer<load-store>,dce' -S -o - | FileCheck %s
; This used to crash because the same (pointer) value was scattered by
; different amounts.
define void @test1(ptr %p) {
; CHECK-LABEL: @test1(
; CHECK-NEXT: [[P_I11:%.*]] = getelementptr i16, ptr [[P:%.*]], i32 1
; CHECK-NEXT: [[P_I2:%.*]] = getelementptr i32, ptr [[P]], i32 2
; CHECK-NEXT: [[P_I3:%.*]] = getelementptr i32, ptr [[P]], i32 3
; CHECK-NEXT: store i32 0, ptr [[P]], align 8
; CHECK-NEXT: [[P_I1:%.*]] = getelementptr i32, ptr [[P]], i32 1
; CHECK-NEXT: store i32 0, ptr [[P_I1]], align 4
; CHECK-NEXT: store i32 0, ptr [[P]], align 16
; CHECK-NEXT: store i32 0, ptr [[P_I1]], align 4
; CHECK-NEXT: store i32 0, ptr [[P_I2]], align 8
; CHECK-NEXT: store i32 0, ptr [[P_I3]], align 4
; CHECK-NEXT: store i16 0, ptr [[P]], align 4
; CHECK-NEXT: store i16 0, ptr [[P_I11]], align 2
; CHECK-NEXT: ret void
;
store <2 x i32> zeroinitializer, ptr %p
store <4 x i32> zeroinitializer, ptr %p
store <2 x i16> zeroinitializer, ptr %p
ret void
}