1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py 2 ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-gnu-linux < %s | FileCheck %s -check-prefix=CHECK 3 4 @var_char = external thread_local local_unnamed_addr global i8, align 1 5 @var_short = external thread_local local_unnamed_addr global i16, align 2 6 @var_int = external thread_local local_unnamed_addr global i32, align 4 7 @var_long_long = external thread_local local_unnamed_addr global i64, align 8 8 9 define dso_local zeroext i8 @test_char_one() { 10 ; CHECK-LABEL: test_char_one: 11 ; CHECK: # %bb.0: # %entry 12 ; CHECK: addis 3, 2, var_char@got@tprel@ha 13 ; CHECK-NEXT: ld 3, var_char@got@tprel@l(3) 14 ; CHECK-NEXT: lbzx 3, 3, var_char@tls 15 entry: 16 %0 = load i8, i8* @var_char, align 1, !tbaa !4 17 ret i8 %0 18 } 19 20 define dso_local void @test_char_two(i32 signext %a) { 21 ; CHECK-LABEL: test_char_two: 22 ; CHECK: # %bb.0: # %entry 23 ; CHECK: addis 4, 2, var_char@got@tprel@ha 24 ; CHECK-NEXT: ld 4, var_char@got@tprel@l(4) 25 ; CHECK-NEXT: stbx 3, 4, var_char@tls 26 entry: 27 %conv = trunc i32 %a to i8 28 store i8 %conv, i8* @var_char, align 1, !tbaa !4 29 ret void 30 } 31 32 define dso_local zeroext i8 @test_char_three(i8 zeroext %a) { 33 ; CHECK-LABEL: test_char_three: 34 ; CHECK: # %bb.0: # %entry 35 ; CHECK: addis 4, 2, var_char@got@tprel@ha 36 ; CHECK-NEXT: ld 4, var_char@got@tprel@l(4) 37 ; CHECK-NEXT: lbzx 5, 4, var_char@tls 38 ; CHECK: stbx {{[0-9]+}}, 4, var_char@tls 39 entry: 40 %0 = load i8, i8* @var_char, align 1, !tbaa !4 41 %add = add i8 %0, %a 42 store i8 %add, i8* @var_char, align 1, !tbaa !4 43 ret i8 %add 44 } 45 46 define dso_local signext i16 @test_short_one() { 47 ; CHECK-LABEL: test_short_one: 48 ; CHECK: # %bb.0: # %entry 49 ; CHECK: addis 3, 2, var_short@got@tprel@ha 50 ; CHECK-NEXT: ld 3, var_short@got@tprel@l(3) 51 ; CHECK-NEXT: lhzx 3, 3, var_short@tls 52 entry: 53 %0 = load i16, i16* @var_short, align 2, !tbaa !7 54 ret i16 %0 55 } 56 57 define dso_local void @test_short_two(i32 signext %a) { 58 ; CHECK-LABEL: test_short_two: 59 ; CHECK: # %bb.0: # %entry 60 ; CHECK: addis 4, 2, var_short@got@tprel@ha 61 ; CHECK-NEXT: ld 4, var_short@got@tprel@l(4) 62 ; CHECK-NEXT: sthx 3, 4, var_short@tls 63 entry: 64 %conv = trunc i32 %a to i16 65 store i16 %conv, i16* @var_short, align 2, !tbaa !7 66 ret void 67 } 68 69 define dso_local signext i16 @test_short_three(i16 signext %a) { 70 ; CHECK-LABEL: test_short_three: 71 ; CHECK: # %bb.0: # %entry 72 ; CHECK: addis 4, 2, var_short@got@tprel@ha 73 ; CHECK-NEXT: ld 4, var_short@got@tprel@l(4) 74 ; CHECK-NEXT: lhzx 5, 4, var_short@tls 75 ; CHECK: sthx {{[0-9]+}}, 4, var_short@tls 76 entry: 77 %0 = load i16, i16* @var_short, align 2, !tbaa !7 78 %add = add i16 %0, %a 79 store i16 %add, i16* @var_short, align 2, !tbaa !7 80 ret i16 %add 81 } 82 83 define dso_local signext i32 @test_int_one() { 84 ; CHECK-LABEL: test_int_one: 85 ; CHECK: # %bb.0: # %entry 86 ; CHECK: addis 3, 2, var_int@got@tprel@ha 87 ; CHECK-NEXT: ld 3, var_int@got@tprel@l(3) 88 ; CHECK-NEXT: lwzx 3, 3, var_int@tls 89 entry: 90 %0 = load i32, i32* @var_int, align 4, !tbaa !9 91 ret i32 %0 92 } 93 94 define dso_local void @test_int_two(i32 signext %a) { 95 ; CHECK-LABEL: test_int_two: 96 ; CHECK: # %bb.0: # %entry 97 ; CHECK: addis 4, 2, var_int@got@tprel@ha 98 ; CHECK-NEXT: ld 4, var_int@got@tprel@l(4) 99 ; CHECK-NEXT: stwx 3, 4, var_int@tls 100 entry: 101 store i32 %a, i32* @var_int, align 4, !tbaa !9 102 ret void 103 } 104 105 define dso_local signext i32 @test_int_three(i32 signext %a) { 106 ; CHECK-LABEL: test_int_three: 107 ; CHECK: # %bb.0: # %entry 108 ; CHECK: addis 4, 2, var_int@got@tprel@ha 109 ; CHECK-NEXT: ld 4, var_int@got@tprel@l(4) 110 ; CHECK-NEXT: lwzx 5, 4, var_int@tls 111 ; CHECK: stwx {{[0-9]+}}, 4, var_int@tls 112 entry: 113 %0 = load i32, i32* @var_int, align 4, !tbaa !9 114 %add = add nsw i32 %0, %a 115 store i32 %add, i32* @var_int, align 4, !tbaa !9 116 ret i32 %add 117 } 118 119 define dso_local i64 @test_longlong_one() { 120 ; CHECK-LABEL: test_longlong_one: 121 ; CHECK: # %bb.0: # %entry 122 ; CHECK: addis 3, 2, var_long_long@got@tprel@ha 123 ; CHECK-NEXT: ld 3, var_long_long@got@tprel@l(3) 124 ; CHECK-NEXT: ldx 3, 3, var_long_long@tls 125 entry: 126 %0 = load i64, i64* @var_long_long, align 8, !tbaa !11 127 ret i64 %0 128 } 129 130 define dso_local void @test_longlong_two(i32 signext %a) { 131 ; CHECK-LABEL: test_longlong_two: 132 ; CHECK: # %bb.0: # %entry 133 ; CHECK: addis 4, 2, var_long_long@got@tprel@ha 134 ; CHECK-NEXT: ld 4, var_long_long@got@tprel@l(4) 135 ; CHECK-NEXT: stdx 3, 4, var_long_long@tls 136 entry: 137 %conv = sext i32 %a to i64 138 store i64 %conv, i64* @var_long_long, align 8, !tbaa !11 139 ret void 140 } 141 142 define dso_local i64 @test_longlong_three(i64 %a) { 143 ; CHECK-LABEL: test_longlong_three: 144 ; CHECK: # %bb.0: # %entry 145 ; CHECK: addis 4, 2, var_long_long@got@tprel@ha 146 ; CHECK-NEXT: ld 4, var_long_long@got@tprel@l(4) 147 ; CHECK-NEXT: ldx 5, 4, var_long_long@tls 148 ; CHECK: stdx {{[0-9]+}}, 4, var_long_long@tls 149 entry: 150 %0 = load i64, i64* @var_long_long, align 8, !tbaa !11 151 %add = add nsw i64 %0, %a 152 store i64 %add, i64* @var_long_long, align 8, !tbaa !11 153 ret i64 %add 154 } 155 156 !llvm.module.flags = !{!0, !1, !2} 157 158 !0 = !{i32 1, !"wchar_size", i32 4} 159 !1 = !{i32 7, !"PIC Level", i32 1} 160 !2 = !{i32 7, !"PIE Level", i32 1} 161 !4 = !{!5, !5, i64 0} 162 !5 = !{!"omnipotent char", !6, i64 0} 163 !6 = !{!"Simple C/C++ TBAA"} 164 !7 = !{!8, !8, i64 0} 165 !8 = !{!"short", !5, i64 0} 166 !9 = !{!10, !10, i64 0} 167 !10 = !{!"int", !5, i64 0} 168 !11 = !{!12, !12, i64 0} 169 !12 = !{!"long long", !5, i64 0} 170