| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 6 |
| ; RUN: opt -S --passes=slp-vectorizer < %s | FileCheck %s |
| |
| define i16 @test(i40 %0) { |
| ; CHECK-LABEL: define i16 @test( |
| ; CHECK-SAME: i40 [[TMP0:%.*]]) { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[DOTNOT101_I:%.*]] = icmp eq i40 0, 0 |
| ; CHECK-NEXT: [[ADD63_I:%.*]] = select i1 [[DOTNOT101_I]], i32 0, i32 0 |
| ; CHECK-NEXT: [[CONV6:%.*]] = trunc i32 [[ADD63_I]] to i16 |
| ; CHECK-NEXT: tail call void null(i16 0, i16 [[CONV6]], i16 0) |
| ; CHECK-NEXT: [[TMP1:%.*]] = tail call i40 asm "copy $1, $0", "=a,a"(i40 0) |
| ; CHECK-NEXT: [[TMP2:%.*]] = insertelement <8 x i40> <i40 0, i40 0, i40 0, i40 poison, i40 poison, i40 -1, i40 0, i40 0>, i40 [[TMP0]], i32 3 |
| ; CHECK-NEXT: [[TMP3:%.*]] = insertelement <8 x i40> [[TMP2]], i40 [[TMP1]], i32 4 |
| ; CHECK-NEXT: [[TMP4:%.*]] = add <8 x i40> [[TMP3]], zeroinitializer |
| ; CHECK-NEXT: [[TMP5:%.*]] = or <8 x i40> [[TMP4]], zeroinitializer |
| ; CHECK-NEXT: [[TMP6:%.*]] = insertelement <8 x i40> <i40 0, i40 0, i40 0, i40 0, i40 0, i40 0, i40 poison, i40 0>, i40 [[TMP1]], i32 6 |
| ; CHECK-NEXT: [[TMP7:%.*]] = or <8 x i40> zeroinitializer, [[TMP6]] |
| ; CHECK-NEXT: [[TMP8:%.*]] = or <8 x i40> [[TMP5]], [[TMP7]] |
| ; CHECK-NEXT: [[TMP9:%.*]] = or <8 x i40> [[TMP8]], zeroinitializer |
| ; CHECK-NEXT: [[TMP10:%.*]] = and <8 x i40> [[TMP9]], <i40 0, i40 0, i40 0, i40 -1, i40 0, i40 0, i40 0, i40 0> |
| ; CHECK-NEXT: [[TMP11:%.*]] = icmp ne <8 x i40> [[TMP10]], zeroinitializer |
| ; CHECK-NEXT: [[TMP12:%.*]] = bitcast <8 x i1> [[TMP11]] to i8 |
| ; CHECK-NEXT: [[TMP13:%.*]] = call i8 @llvm.ctpop.i8(i8 [[TMP12]]) |
| ; CHECK-NEXT: [[TMP14:%.*]] = zext i8 [[TMP13]] to i16 |
| ; CHECK-NEXT: ret i16 [[TMP14]] |
| ; |
| entry: |
| %1 = add i40 0, 0 |
| %.not101.i = icmp eq i40 %1, 0 |
| %add63.i = select i1 %.not101.i, i32 0, i32 0 |
| %conv6 = trunc i32 %add63.i to i16 |
| tail call void null(i16 0, i16 %conv6, i16 0) |
| %2 = add i40 0, 0 |
| %3 = or i40 %2, 0 |
| %4 = or i40 %3, 0 |
| %5 = or i40 %4, 0 |
| %unsclear9.i68 = and i40 %5, 0 |
| %6 = tail call i40 asm "copy $1, $0", "=a,a"(i40 0) |
| %7 = or i40 0, %6 |
| %8 = or i40 0, %7 |
| %9 = or i40 %8, 0 |
| %unsclear47.i = and i40 %9, 0 |
| %10 = add i40 0, 0 |
| %11 = or i40 %10, %1 |
| %12 = or i40 %11, %7 |
| %13 = or i40 %12, 0 |
| %unsclear89.i79 = and i40 %13, 0 |
| %14 = add i40 0, 0 |
| %15 = or i40 %14, 0 |
| %16 = or i40 %15, 0 |
| %17 = or i40 %16, 0 |
| %unsclear110.i = and i40 %17, 0 |
| %18 = or i40 %14, 0 |
| %19 = or i40 %18, 0 |
| %20 = or i40 %19, 0 |
| %unsclear131.i82 = and i40 %20, 0 |
| %21 = add i40 0, 0 |
| %22 = or i40 0, %21 |
| %23 = or i40 %22, 0 |
| %24 = or i40 %23, 0 |
| %unsclear152.i = and i40 %24, 0 |
| %.not47.i = icmp ne i40 %unsclear152.i, 0 |
| %add156.i = zext i1 %.not47.i to i16 |
| %.not46.i = icmp ne i40 %unsclear131.i82, 0 |
| %add135.i83 = zext i1 %.not46.i to i16 |
| %add31.i75 = add i16 %add156.i, %add135.i83 |
| %.not.i69 = icmp ne i40 %unsclear9.i68, 0 |
| %add10.i71 = zext i1 %.not.i69 to i16 |
| %add52.i = add i16 %add31.i75, %add10.i71 |
| %.not41.i73 = icmp ne i40 %0, 0 |
| %add30.i74 = zext i1 %.not41.i73 to i16 |
| %add73.i78 = add i16 %add52.i, %add30.i74 |
| %.not42.i76 = icmp ne i40 %unsclear47.i, 0 |
| %add51.i = zext i1 %.not42.i76 to i16 |
| %add94.i81 = add i16 %add73.i78, %add51.i |
| %.not43.i77 = icmp ne i40 0, 0 |
| %add72.i = zext i1 %.not43.i77 to i16 |
| %add115.i = add i16 %add94.i81, %add72.i |
| %.not44.i = icmp ne i40 %unsclear89.i79, 0 |
| %add93.i80 = zext i1 %.not44.i to i16 |
| %add136.i84 = add i16 %add115.i, %add93.i80 |
| %.not45.i = icmp ne i40 %unsclear110.i, 0 |
| %add114.i = zext i1 %.not45.i to i16 |
| %add157.i = add i16 %add136.i84, %add114.i |
| ret i16 %add157.i |
| } |
| |