|
1 | | -; RUN: llc < %s -mtriple=i386-linux | FileCheck %s |
2 | | -; PR1339 |
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 |
| 2 | +;; See also dollar-name-asm.ll for module asm tests, which update_llc_test_checks.py doesn't support. |
| 3 | +; RUN: llc < %s -mtriple=i686 -relocation-model=static | FileCheck %s --check-prefix=STATIC |
| 4 | +; RUN: llc < %s -mtriple=x86_64 -relocation-model=pic | FileCheck %s --check-prefix=PIC |
| 5 | +; RUN: llc < %s -mtriple=x86_64 -relocation-model=pic -output-asm-variant=1 | FileCheck %s --check-prefix=INTEL-PIC |
3 | 6 |
|
4 | | -@"$bar" = global i32 zeroinitializer |
5 | | -@"$qux" = external dso_local global i32 |
| 7 | +@"$arr" = global [2 x i32] zeroinitializer |
| 8 | +@"$arr_h" = hidden global [2 x i32] zeroinitializer |
| 9 | +@"$tls" = hidden thread_local global i32 0 |
6 | 10 |
|
7 | 11 | define i32 @"$foo"() nounwind { |
8 | | -; CHECK: movl $bar, |
9 | | -; CHECK: addl $qux, |
10 | | -; CHECK: calll $hen |
11 | | - %m = load i32, ptr @"$bar" |
12 | | - %n = load i32, ptr @"$qux" |
13 | | - %t = add i32 %m, %n |
14 | | - %u = call i32 @"$hen"(i32 %t) |
| 12 | +; STATIC-LABEL: $foo: |
| 13 | +; STATIC: # %bb.0: |
| 14 | +; STATIC-NEXT: movl ($arr), %eax |
| 15 | +; STATIC-NEXT: movl %gs:0, %ecx |
| 16 | +; STATIC-NEXT: addl ($arr+4), %eax |
| 17 | +; STATIC-NEXT: addl ($tls@NTPOFF)(%ecx), %eax |
| 18 | +; STATIC-NEXT: pushl ($arr_h) |
| 19 | +; STATIC-NEXT: pushl %eax |
| 20 | +; STATIC-NEXT: calll ($hen@PLT) |
| 21 | +; STATIC-NEXT: addl $8, %esp |
| 22 | +; STATIC-NEXT: retl |
| 23 | +; |
| 24 | +; PIC-LABEL: $foo: |
| 25 | +; PIC: # %bb.0: |
| 26 | +; PIC-NEXT: pushq %rbp |
| 27 | +; PIC-NEXT: pushq %r14 |
| 28 | +; PIC-NEXT: pushq %rbx |
| 29 | +; PIC-NEXT: movq ($arr@GOTPCREL)(%rip), %r14 |
| 30 | +; PIC-NEXT: movl (%r14), %ebx |
| 31 | +; PIC-NEXT: movl ($arr_h)(%rip), %ebp |
| 32 | +; PIC-NEXT: leaq ($tls@TLSLD)(%rip), %rdi |
| 33 | +; PIC-NEXT: callq __tls_get_addr@PLT |
| 34 | +; PIC-NEXT: addl 4(%r14), %ebx |
| 35 | +; PIC-NEXT: addl ($tls@DTPOFF)(%rax), %ebx |
| 36 | +; PIC-NEXT: movl %ebx, %edi |
| 37 | +; PIC-NEXT: movl %ebp, %esi |
| 38 | +; PIC-NEXT: callq ($hen@PLT) |
| 39 | +; PIC-NEXT: popq %rbx |
| 40 | +; PIC-NEXT: popq %r14 |
| 41 | +; PIC-NEXT: popq %rbp |
| 42 | +; PIC-NEXT: retq |
| 43 | +; |
| 44 | +; INTEL-PIC-LABEL: $foo: |
| 45 | +; INTEL-PIC: # %bb.0: |
| 46 | +; INTEL-PIC-NEXT: push rbp |
| 47 | +; INTEL-PIC-NEXT: push r14 |
| 48 | +; INTEL-PIC-NEXT: push rbx |
| 49 | +; INTEL-PIC-NEXT: mov r14, qword ptr [rip + $arr@GOTPCREL] |
| 50 | +; INTEL-PIC-NEXT: mov ebx, dword ptr [r14] |
| 51 | +; INTEL-PIC-NEXT: mov ebp, dword ptr [rip + $arr_h] |
| 52 | +; INTEL-PIC-NEXT: lea rdi, [rip + $tls@TLSLD] |
| 53 | +; INTEL-PIC-NEXT: call __tls_get_addr@PLT |
| 54 | +; INTEL-PIC-NEXT: add ebx, dword ptr [r14 + 4] |
| 55 | +; INTEL-PIC-NEXT: add ebx, dword ptr [rax + $tls@DTPOFF] |
| 56 | +; INTEL-PIC-NEXT: mov edi, ebx |
| 57 | +; INTEL-PIC-NEXT: mov esi, ebp |
| 58 | +; INTEL-PIC-NEXT: call $hen@PLT |
| 59 | +; INTEL-PIC-NEXT: pop rbx |
| 60 | +; INTEL-PIC-NEXT: pop r14 |
| 61 | +; INTEL-PIC-NEXT: pop rbp |
| 62 | +; INTEL-PIC-NEXT: ret |
| 63 | + %m = load i32, ptr @"$arr" |
| 64 | + %m1 = load i32, ptr getelementptr inbounds nuw (i32, ptr @"$arr", i23 1) |
| 65 | + %m2 = load i32, ptr @"$arr_h" |
| 66 | + %tls_v = load i32, ptr @"$tls" |
| 67 | + %t0 = add i32 %m, %m1 |
| 68 | + %t1 = add i32 %t0, %tls_v |
| 69 | + %u = call i32 @"$hen"(i32 %t1, i32 %m2) |
15 | 70 | ret i32 %u |
16 | 71 | } |
17 | 72 |
|
18 | | -declare i32 @"$hen"(i32 %a) |
| 73 | +declare i32 @"$hen"(i32 %a, i32 %b) |
0 commit comments