1*9880d681SAndroid Build Coastguard Worker; RUN: llc -O0 -filetype=asm -mtriple=armv7-linux-gnuehabi < %s \ 2*9880d681SAndroid Build Coastguard Worker; RUN: | FileCheck %s 3*9880d681SAndroid Build Coastguard Worker; RUN: llc -O0 -filetype=asm -mtriple=armv7-linux-gnuehabi -emulated-tls < %s \ 4*9880d681SAndroid Build Coastguard Worker; RUN: | FileCheck %s --check-prefix=EMU 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Worker; Generated with clang with source 7*9880d681SAndroid Build Coastguard Worker; __thread int x; 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Worker@x = thread_local global i32 0, align 4 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Worker!llvm.dbg.cu = !{!0} 12*9880d681SAndroid Build Coastguard Worker!llvm.module.flags = !{!7, !8} 13*9880d681SAndroid Build Coastguard Worker!llvm.ident = !{!9} 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Worker; 6 byte of data 16*9880d681SAndroid Build Coastguard Worker; CHECK: .byte 6 @ DW_AT_location 17*9880d681SAndroid Build Coastguard Worker; DW_OP_const4u 18*9880d681SAndroid Build Coastguard Worker; CHECK: .byte 12 19*9880d681SAndroid Build Coastguard Worker; The debug relocation of the address of the tls variable 20*9880d681SAndroid Build Coastguard Worker; CHECK: .long x(tlsldo) 21*9880d681SAndroid Build Coastguard Worker 22*9880d681SAndroid Build Coastguard Worker; TODO: Add expected output for -emulated-tls tests. 23*9880d681SAndroid Build Coastguard Worker; EMU-NOT: .long x(tlsldo) 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Worker!0 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang version 3.5 ", isOptimized: false, emissionKind: FullDebug, file: !1, enums: !2, retainedTypes: !2, globals: !3, imports: !2) 26*9880d681SAndroid Build Coastguard Worker!1 = !DIFile(filename: "tls.c", directory: "/tmp") 27*9880d681SAndroid Build Coastguard Worker!2 = !{} 28*9880d681SAndroid Build Coastguard Worker!3 = !{!4} 29*9880d681SAndroid Build Coastguard Worker!4 = !DIGlobalVariable(name: "x", line: 1, isLocal: false, isDefinition: true, scope: null, file: !5, type: !6, variable: i32* @x) 30*9880d681SAndroid Build Coastguard Worker!5 = !DIFile(filename: "tls.c", directory: "/tmp") 31*9880d681SAndroid Build Coastguard Worker!6 = !DIBasicType(tag: DW_TAG_base_type, name: "int", size: 32, align: 32, encoding: DW_ATE_signed) 32*9880d681SAndroid Build Coastguard Worker!7 = !{i32 2, !"Dwarf Version", i32 4} 33*9880d681SAndroid Build Coastguard Worker!8 = !{i32 1, !"Debug Info Version", i32 3} 34*9880d681SAndroid Build Coastguard Worker!9 = !{!"clang version 3.5 "} 35