[ARM] Better OR's for MVE compares
[llvm-core.git] / test / Transforms / InstCombine / vector_gep1.ll
blob8e5bcf963ea1c0df57903c4dcac00bf91e8443ee
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -instcombine -S | FileCheck %s
4 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
5 target triple = "x86_64-unknown-linux-gnu"
7 @G1 = global i8 zeroinitializer
9 define <2 x i1> @test(<2 x i8*> %a, <2 x i8*> %b) {
10 ; CHECK-LABEL: @test(
11 ; CHECK-NEXT:    [[C:%.*]] = icmp eq <2 x i8*> [[A:%.*]], [[B:%.*]]
12 ; CHECK-NEXT:    ret <2 x i1> [[C]]
14   %c = icmp eq <2 x i8*> %a, %b
15   ret <2 x i1> %c
18 define <2 x i1> @test2(<2 x i8*> %a) {
19 ; CHECK-LABEL: @test2(
20 ; CHECK-NEXT:    ret <2 x i1> zeroinitializer
22   %c = inttoptr <2 x i32> <i32 1, i32 2> to <2 x i8*>
23   %d = icmp ult <2 x i8*> %c, zeroinitializer
24   ret <2 x i1> %d
27 define <2 x i1> @test3(<2 x i8*> %a) {
28 ; CHECK-LABEL: @test3(
29 ; CHECK-NEXT:    ret <2 x i1> zeroinitializer
31   %g = getelementptr i8, <2 x i8*> %a, <2 x i32> <i32 1, i32 0>
32   %B = icmp ult <2 x i8*> %g, zeroinitializer
33   ret <2 x i1> %B
36 define <1 x i1> @test4(<1 x i8*> %a) {
37 ; CHECK-LABEL: @test4(
38 ; CHECK-NEXT:    ret <1 x i1> zeroinitializer
40   %g = getelementptr i8, <1 x i8*> %a, <1 x i32> <i32 1>
41   %B = icmp ult <1 x i8*> %g, zeroinitializer
42   ret <1 x i1> %B
45 define <2 x i1> @test5(<2 x i8*> %a) {
46 ; CHECK-LABEL: @test5(
47 ; CHECK-NEXT:    ret <2 x i1> zeroinitializer
49   %w = getelementptr i8, <2 x i8*> %a, <2 x i32> zeroinitializer
50   %e = getelementptr i8, <2 x i8*> %w, <2 x i32> <i32 5, i32 9>
51   %g = getelementptr i8, <2 x i8*> %e, <2 x i32> <i32 1, i32 0>
52   %B = icmp ult <2 x i8*> %g, zeroinitializer
53   ret <2 x i1> %B
56 define <2 x i32*> @test7(<2 x {i32, i32}*> %a) {
57 ; CHECK-LABEL: @test7(
58 ; CHECK-NEXT:    [[W:%.*]] = getelementptr { i32, i32 }, <2 x { i32, i32 }*> [[A:%.*]], <2 x i64> <i64 5, i64 9>, <2 x i32> zeroinitializer
59 ; CHECK-NEXT:    ret <2 x i32*> [[W]]
61   %w = getelementptr {i32, i32}, <2 x {i32, i32}*> %a, <2 x i32> <i32 5, i32 9>, <2 x i32> zeroinitializer
62   ret <2 x i32*> %w