[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / CodeGen / Hexagon / autohvx / vector-align-order.ll
blobf8bf0e9957ab4767219325347e10b22d81f774c1
1 ; RUN: llc -march=hexagon < %s | FileCheck %s
3 ; Check that this doesn't crash.
4 ; CHECK: vmem
6 target datalayout = "e-m:e-p:32:32:32-a:0-n16:32-i64:64:64-i32:32:32-i16:16:16-i1:8:8-f32:32:32-f64:64:64-v32:32:32-v64:64:64-v512:512:512-v1024:1024:1024-v2048:2048:2048"
7 target triple = "hexagon"
9 @g0 = external dllexport local_unnamed_addr global ptr, align 4
10 @g1 = external dllexport local_unnamed_addr global ptr, align 4
12 define dso_local fastcc void @f0(ptr %a0, i32 %a1) unnamed_addr #0 {
13 b0:
14   %v0 = load ptr, ptr @g1, align 4
15   %v1 = tail call ptr %v0(i32 16, i32 %a1, i64 2400, i32 0, i32 32)
16   br i1 poison, label %b2, label %b1
18 b1:                                               ; preds = %b0
19   %v2 = load <64 x i8>, ptr poison, align 64
20   %v3 = zext <64 x i8> %v2 to <64 x i32>
21   %v4 = load <128 x i8>, ptr poison, align 64
22   %v5 = zext <128 x i8> %v4 to <128 x i32>
23   %v6 = load <128 x i8>, ptr poison, align 64
24   %v7 = zext <128 x i8> %v6 to <128 x i32>
25   %v8 = getelementptr i8, ptr %a0, i32 576
26   %v9 = getelementptr i8, ptr %v8, i32 -64
27   %v10 = load <64 x i8>, ptr %v9, align 64
28   %v11 = sext <64 x i8> %v10 to <64 x i32>
29   %v12 = add nsw <64 x i32> %v11, <i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128>
30   %v13 = mul nuw nsw <64 x i32> %v12, %v3
31   %v14 = extractelement <64 x i32> %v13, i32 0
32   store i32 %v14, ptr %v1, align 8, !tbaa !0
33   %v15 = getelementptr i8, ptr %v8, i32 384
34   %v16 = load <128 x i8>, ptr %v15, align 64, !tbaa !3
35   %v17 = sext <128 x i8> %v16 to <128 x i32>
36   %v18 = add nsw <128 x i32> %v17, <i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128>
37   %v19 = mul nuw nsw <128 x i32> %v18, %v5
38   %v20 = getelementptr i8, ptr %v8, i32 256
39   %v21 = load <128 x i8>, ptr %v20, align 64, !tbaa !3
40   %v22 = sext <128 x i8> %v21 to <128 x i32>
41   %v23 = add nsw <128 x i32> %v22, <i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128, i32 128>
42   %v24 = mul nuw nsw <128 x i32> %v23, %v7
43   %v25 = add nsw <128 x i32> %v19, %v24
44   %v26 = extractelement <128 x i32> %v25, i32 0
45   %v27 = insertelement <64 x i32> <i32 poison, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0>, i32 %v26, i64 0
46   %v28 = extractelement <64 x i32> %v27, i32 0
47   %v29 = getelementptr i8, ptr %v1, i32 4
48   store i32 %v28, ptr %v29, align 4
49   %v30 = load ptr, ptr @g0, align 4
50   %v31 = call i32 %v30(ptr nonnull @f1, ptr nonnull poison, i32 0)
51   unreachable
53 b2:                                               ; preds = %b0
54   ret void
57 declare dso_local i32 @f1(i32, ptr, ptr) #0
59 attributes #0 = { "target-features"="+hvxv68,+hvx-length128b,+hvx-qfloat,-hvx-ieee-fp" }
61 !0 = !{!1, !1, i64 0}
62 !1 = !{!"0x555e886c7bc0", !2, i64 0}
63 !2 = !{!"tvm-tbaa"}
64 !3 = !{!4, !4, i64 0}
65 !4 = !{!"0x555e88cb2ce0", !2, i64 0}