mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 20:23:11 +01:00
fc4e42741b
This patch allows generating TLS variables in assembly files on AIX. Initialized and external uninitialized variables are generated with the .csect pseudo-op and local uninitialized variables are generated with the .comm/.lcomm pseudo-ops. The patch also adds a check to explicitly say that TLS is not yet supported on AIX. Reviewed by: daltenty, jasonliu, lei, nemanjai, sfertile Originally patched by: bsaleil Commandeered by: NeHuang Differential Revision: https://reviews.llvm.org/D96184
262 lines
12 KiB
LLVM
262 lines
12 KiB
LLVM
; This file tests 32 bit TLS variable generation.
|
|
|
|
; RUN: llc -verify-machineinstrs -mcpu=pwr7 -mattr=-altivec -mtriple \
|
|
; RUN: powerpc-ibm-aix-xcoff < %s | FileCheck %s
|
|
; RUN: llc -verify-machineinstrs -mcpu=pwr7 -mattr=-altivec -mtriple \
|
|
; RUN: powerpc-ibm-aix-xcoff -data-sections=false < %s | FileCheck %s \
|
|
; RUN: --check-prefix=NODATASEC
|
|
|
|
; When data-sections is true (default), we emit data into separate sections.
|
|
; When data-sections is false, we emit data into the .data / .tdata sections.
|
|
|
|
; Int global variable, TLS/Non-TLS, local/external/weak/common linkage
|
|
; CHECK: .csect global_int_external_val_initialized[RW],2
|
|
; CHECK-NEXT: .globl global_int_external_val_initialized[RW]
|
|
; CHECK-NEXT: .align 2
|
|
; CHECK-NEXT: .vbyte 4, 1
|
|
|
|
; NODATASEC: .csect .data[RW],3
|
|
; NODATASEC-NEXT: .globl global_int_external_val_initialized
|
|
; NODATASEC-NEXT: .align 2
|
|
; NODATASEC-NEXT:global_int_external_val_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 1
|
|
@global_int_external_val_initialized = global i32 1, align 4
|
|
|
|
; CHECK-NEXT: .csect global_int_external_zero_initialized[RW],2
|
|
; CHECK-NEXT: .globl global_int_external_zero_initialized[RW]
|
|
; CHECK-NEXT: .align 2
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
|
|
; NODATASEC-NEXT: .globl global_int_external_zero_initialized
|
|
; NODATASEC-NEXT: .align 2
|
|
; NODATASEC-NEXT:global_int_external_zero_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
@global_int_external_zero_initialized = global i32 0, align 4
|
|
|
|
; CHECK-NEXT: .csect tls_global_int_external_val_initialized[TL],2
|
|
; CHECK-NEXT: .globl tls_global_int_external_val_initialized[TL]
|
|
; CHECK-NEXT: .align 2
|
|
; CHECK-NEXT: .vbyte 4, 1
|
|
|
|
; NODATASEC-NEXT: .csect .tdata[TL],3
|
|
; NODATASEC-NEXT: .globl tls_global_int_external_val_initialized
|
|
; NODATASEC-NEXT: .align 2
|
|
; NODATASEC-NEXT:tls_global_int_external_val_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 1
|
|
@tls_global_int_external_val_initialized = thread_local global i32 1, align 4
|
|
|
|
; CHECK-NEXT: .csect tls_global_int_external_zero_initialized[TL],2
|
|
; CHECK-NEXT: .globl tls_global_int_external_zero_initialized[TL]
|
|
; CHECK-NEXT: .align 2
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
|
|
; NODATASEC-NEXT: .globl tls_global_int_external_zero_initialized
|
|
; NODATASEC-NEXT: .align 2
|
|
; NODATASEC-NEXT:tls_global_int_external_zero_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
@tls_global_int_external_zero_initialized = thread_local global i32 0, align 4
|
|
|
|
; CHECK-NEXT: .csect global_int_local_val_initialized[RW],2
|
|
; CHECK-NEXT: .lglobl global_int_local_val_initialized[RW]
|
|
; CHECK-NEXT: .align 2
|
|
; CHECK-NEXT: .vbyte 4, 2
|
|
|
|
; NODATASEC-NEXT: .csect .data[RW],3
|
|
; NODATASEC-NEXT: .lglobl global_int_local_val_initialized
|
|
; NODATASEC-NEXT: .align 2
|
|
; NODATASEC-NEXT:global_int_local_val_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 2
|
|
@global_int_local_val_initialized = internal global i32 2, align 4
|
|
|
|
; CHECK-NEXT: .csect tls_global_int_local_val_initialized[TL],2
|
|
; CHECK-NEXT: .lglobl tls_global_int_local_val_initialized[TL]
|
|
; CHECK-NEXT: .align 2
|
|
; CHECK-NEXT: .vbyte 4, 2
|
|
|
|
; NODATASEC-NEXT: .csect .tdata[TL],3
|
|
; NODATASEC-NEXT: .lglobl tls_global_int_local_val_initialized
|
|
; NODATASEC-NEXT: .align 2
|
|
; NODATASEC-NEXT:tls_global_int_local_val_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 2
|
|
@tls_global_int_local_val_initialized = internal thread_local global i32 2, align 4
|
|
|
|
; CHECK-NEXT: .lcomm global_int_local_zero_initialized,4,global_int_local_zero_initialized[BS],2
|
|
; NODATASEC-NEXT: .lcomm global_int_local_zero_initialized,4,global_int_local_zero_initialized[BS],2
|
|
@global_int_local_zero_initialized = internal global i32 0, align 4
|
|
|
|
; CHECK-NEXT: .lcomm tls_global_int_local_zero_initialized,4,tls_global_int_local_zero_initialized[UL],2
|
|
; NODATASEC-NEXT: .lcomm tls_global_int_local_zero_initialized,4,tls_global_int_local_zero_initialized[UL],2
|
|
@tls_global_int_local_zero_initialized = internal thread_local global i32 0, align 4
|
|
|
|
; CHECK-NEXT: .csect global_int_weak_zero_initialized[RW],2
|
|
; CHECK-NEXT: .weak global_int_weak_zero_initialized[RW]
|
|
; CHECK-NEXT: .align 2
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
|
|
; NODATASEC-NEXT: .csect .data[RW],3
|
|
; NODATASEC-NEXT: .weak global_int_weak_zero_initialized
|
|
; NODATASEC-NEXT: .align 2
|
|
; NODATASEC-NEXT:global_int_weak_zero_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
@global_int_weak_zero_initialized = weak global i32 0, align 4
|
|
|
|
; CHECK-NEXT: .csect tls_global_int_weak_zero_initialized[TL],2
|
|
; CHECK-NEXT: .weak tls_global_int_weak_zero_initialized[TL]
|
|
; CHECK-NEXT: .align 2
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
|
|
; NODATASEC-NEXT: .csect .tdata[TL],3
|
|
; NODATASEC-NEXT: .weak tls_global_int_weak_zero_initialized
|
|
; NODATASEC-NEXT: .align 2
|
|
; NODATASEC-NEXT:tls_global_int_weak_zero_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
@tls_global_int_weak_zero_initialized = weak thread_local global i32 0, align 4
|
|
|
|
; CHECK-NEXT: .comm global_int_common_zero_initialized[RW],4,2
|
|
; NODATASEC-NEXT: .comm global_int_common_zero_initialized[RW],4,2
|
|
@global_int_common_zero_initialized = common global i32 0, align 4
|
|
|
|
; CHECK-NEXT: .comm tls_global_int_common_zero_initialized[UL],4,2
|
|
; NODATASEC-NEXT: .comm tls_global_int_common_zero_initialized[UL],4,2
|
|
@tls_global_int_common_zero_initialized = common thread_local global i32 0, align 4
|
|
|
|
; CHECK-NEXT: .csect global_int_weak_val_initialized[RW],2
|
|
; CHECK-NEXT: .weak global_int_weak_val_initialized[RW]
|
|
; CHECK-NEXT: .align 2
|
|
; CHECK-NEXT: .vbyte 4, 1
|
|
|
|
; NODATASEC-NEXT: .csect .data[RW],3
|
|
; NODATASEC-NEXT: .weak global_int_weak_val_initialized
|
|
; NODATASEC-NEXT: .align 2
|
|
; NODATASEC-NEXT:global_int_weak_val_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 1
|
|
@global_int_weak_val_initialized = weak global i32 1, align 4
|
|
|
|
; CHECK-NEXT: .csect tls_global_int_weak_val_initialized[TL],2
|
|
; CHECK-NEXT: .weak tls_global_int_weak_val_initialized[TL]
|
|
; CHECK-NEXT: .align 2
|
|
; CHECK-NEXT: .vbyte 4, 1
|
|
|
|
; NODATASEC-NEXT: .csect .tdata[TL],3
|
|
; NODATASEC-NEXT: .weak tls_global_int_weak_val_initialized
|
|
; NODATASEC-NEXT: .align 2
|
|
; NODATASEC-NEXT:tls_global_int_weak_val_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 1
|
|
@tls_global_int_weak_val_initialized = weak thread_local global i32 1, align 4
|
|
|
|
; CHECK-NEXT: .extern global_int_external_uninitialized[UA]
|
|
; NODATASEC-NEXT: .extern global_int_external_uninitialized[UA]
|
|
@global_int_external_uninitialized = external global i32, align 4
|
|
|
|
; CHECK-NEXT: .extern tls_global_int_external_uninitialized[UL]
|
|
; NODATASEC-NEXT: .extern tls_global_int_external_uninitialized[UL]
|
|
@tls_global_int_external_uninitialized = external thread_local global i32, align 4
|
|
|
|
|
|
; double global variable, TLS/Non-TLS, common/external linkage
|
|
|
|
; CHECK-NEXT: .comm global_double_common_zero_initialized[RW],8,3
|
|
; NODATASEC-NEXT: .comm global_double_common_zero_initialized[RW],8,3
|
|
@global_double_common_zero_initialized = common global double 0.000000e+00, align 8
|
|
|
|
; CHECK-NEXT: .comm tls_global_double_common_zero_initialized[UL],8,3
|
|
; NODATASEC-NEXT: .comm tls_global_double_common_zero_initialized[UL],8,3
|
|
@tls_global_double_common_zero_initialized = common thread_local global double 0.000000e+00, align 8
|
|
|
|
; CHECK-NEXT: .extern global_double_external_uninitialized[UA]
|
|
; NODATASEC-NEXT: .extern global_double_external_uninitialized[UA]
|
|
@global_double_external_uninitialized = external global i64, align 8
|
|
|
|
; CHECK-NEXT: .extern tls_global_double_external_uninitialized[UL]
|
|
; NODATASEC-NEXT: .extern tls_global_double_external_uninitialized[UL]
|
|
@tls_global_double_external_uninitialized = external thread_local global i64, align 8
|
|
|
|
|
|
; Long long global variable, TLS/Non-TLS, local/weak linkage
|
|
|
|
; CHECK-NEXT: .csect global_long_long_internal_val_initialized[RW],3
|
|
; CHECK-NEXT: .lglobl global_long_long_internal_val_initialized[RW]
|
|
; CHECK-NEXT: .align 3
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
; CHECK-NEXT: .vbyte 4, 1
|
|
; NODATASEC-NEXT: .csect .data[RW],3
|
|
; NODATASEC-NEXT: .lglobl global_long_long_internal_val_initialized
|
|
; NODATASEC-NEXT: .align 3
|
|
; NODATASEC-NEXT:global_long_long_internal_val_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
; NODATASEC-NEXT: .vbyte 4, 1
|
|
@global_long_long_internal_val_initialized = internal global i64 1, align 8
|
|
|
|
; CHECK-NEXT: .csect tls_global_long_long_internal_val_initialized[TL],3
|
|
; CHECK-NEXT: .lglobl tls_global_long_long_internal_val_initialized[TL]
|
|
; CHECK-NEXT: .align 3
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
; CHECK-NEXT: .vbyte 4, 1
|
|
; NODATASEC-NEXT: .csect .tdata[TL],3
|
|
; NODATASEC-NEXT: .lglobl tls_global_long_long_internal_val_initialized
|
|
; NODATASEC-NEXT: .align 3
|
|
; NODATASEC-NEXT:tls_global_long_long_internal_val_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
; NODATASEC-NEXT: .vbyte 4, 1
|
|
@tls_global_long_long_internal_val_initialized = internal thread_local global i64 1, align 8
|
|
|
|
; CHECK-NEXT: .lcomm global_long_long_internal_zero_initialized,8,global_long_long_internal_zero_initialized[BS],3
|
|
; NODATASEC-NEXT: .lcomm global_long_long_internal_zero_initialized,8,global_long_long_internal_zero_initialized[BS],3
|
|
@global_long_long_internal_zero_initialized = internal global i64 0, align 8
|
|
|
|
; CHECK-NEXT: .lcomm tls_global_long_long_internal_zero_initialized,8,tls_global_long_long_internal_zero_initialized[UL],3
|
|
; NODATASEC-NEXT: .lcomm tls_global_long_long_internal_zero_initialized,8,tls_global_long_long_internal_zero_initialized[UL],3
|
|
@tls_global_long_long_internal_zero_initialized = internal thread_local global i64 0, align 8
|
|
|
|
; CHECK-NEXT: .csect global_long_long_weak_val_initialized[RW],3
|
|
; CHECK-NEXT: .weak global_long_long_weak_val_initialized[RW]
|
|
; CHECK-NEXT: .align 3
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
; CHECK-NEXT: .vbyte 4, 1
|
|
; NODATASEC-NEXT: .csect .data[RW],3
|
|
; NODATASEC-NEXT: .weak global_long_long_weak_val_initialized
|
|
; NODATASEC-NEXT: .align 3
|
|
; NODATASEC-NEXT:global_long_long_weak_val_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
; NODATASEC-NEXT: .vbyte 4, 1
|
|
@global_long_long_weak_val_initialized = weak global i64 1, align 8
|
|
|
|
; CHECK-NEXT: .csect tls_global_long_long_weak_val_initialized[TL],3
|
|
; CHECK-NEXT: .weak tls_global_long_long_weak_val_initialized[TL]
|
|
; CHECK-NEXT: .align 3
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
; CHECK-NEXT: .vbyte 4, 1
|
|
; NODATASEC-NEXT: .csect .tdata[TL],3
|
|
; NODATASEC-NEXT: .weak tls_global_long_long_weak_val_initialized
|
|
; NODATASEC-NEXT: .align 3
|
|
; NODATASEC-NEXT:tls_global_long_long_weak_val_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
; NODATASEC-NEXT: .vbyte 4, 1
|
|
@tls_global_long_long_weak_val_initialized = weak thread_local global i64 1, align 8
|
|
|
|
; CHECK-NEXT: .csect global_long_long_weak_zero_initialized[RW],3
|
|
; CHECK-NEXT: .weak global_long_long_weak_zero_initialized[RW]
|
|
; CHECK-NEXT: .align 3
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
; NODATASEC-NEXT: .csect .data[RW],3
|
|
; NODATASEC-NEXT: .weak global_long_long_weak_zero_initialized
|
|
; NODATASEC-NEXT: .align 3
|
|
; NODATASEC-NEXT:global_long_long_weak_zero_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
@global_long_long_weak_zero_initialized = weak global i64 0, align 8
|
|
|
|
; CHECK-NEXT: .csect tls_global_long_long_weak_zero_initialized[TL],3
|
|
; CHECK-NEXT: .weak tls_global_long_long_weak_zero_initialized[TL]
|
|
; CHECK-NEXT: .align 3
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
; CHECK-NEXT: .vbyte 4, 0
|
|
; NODATASEC-NEXT: .csect .tdata[TL],3
|
|
; NODATASEC-NEXT: .weak tls_global_long_long_weak_zero_initialized
|
|
; NODATASEC-NEXT: .align 3
|
|
; NODATASEC-NEXT:tls_global_long_long_weak_zero_initialized:
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
; NODATASEC-NEXT: .vbyte 4, 0
|
|
@tls_global_long_long_weak_zero_initialized = weak thread_local global i64 0, align 8
|