aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/PowerPC/check-aix-small-local-exec-tls-opt.ll
blob: 25bab5b5efcd2b7c7a02f1e822b587b0d0ffb1f2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
; RUN: llc -mtriple powerpc64-ibm-aix-xcoff -mattr=+aix-small-local-exec-tls \
; RUN:   -ppc-asm-full-reg-names < %s | FileCheck %s
; RUN: not llc -mtriple powerpc-ibm-aix-xcoff -mattr=+aix-small-local-exec-tls \
; RUN:   -ppc-asm-full-reg-names < %s 2>&1 | \
; RUN:   FileCheck %s --check-prefix=CHECK-NOT-SUPPORTED
; RUN: not llc -mtriple powerpc64le-unknown-linux-gnu -mattr=+aix-small-local-exec-tls \
; RUN:   -ppc-asm-full-reg-names < %s 2>&1 | \
; RUN:   FileCheck %s --check-prefix=CHECK-NOT-SUPPORTED
; RUN: llc -mtriple powerpc64-ibm-aix-xcoff -mattr=+aix-small-local-dynamic-tls \
; RUN:   -ppc-asm-full-reg-names < %s | FileCheck %s
; RUN: not llc -mtriple powerpc-ibm-aix-xcoff -mattr=+aix-small-local-dynamic-tls \
; RUN:   -ppc-asm-full-reg-names < %s 2>&1 | \
; RUN:   FileCheck %s --check-prefix=CHECK-NOT-SUPPORTED
; RUN: not llc -mtriple powerpc64le-unknown-linux-gnu -mattr=+aix-small-local-dynamic-tls \
; RUN:   -ppc-asm-full-reg-names < %s 2>&1 | \
; RUN:   FileCheck %s --check-prefix=CHECK-NOT-SUPPORTED

define dso_local signext i32 @testNoIRAttr() {
entry:
  ret i32 0
}

; Check that the aix-small-local-[exec|dynamic]-tls attribute is not supported on Linux and AIX (32-bit).
; CHECK-NOT-SUPPORTED: The aix-small-local-[exec|dynamic]-tls attribute is only supported on AIX in 64-bit mode.

; Make sure that the test was actually compiled successfully after using the
; aix-small-local-[exec|dynamic]-tls attribute.
; CHECK-LABEL: testNoIRAttr:
; CHECK:        li r3, 0
; CHECK-NEXT:   blr