1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mcpu=atom -mtriple=i686-linux | FileCheck -check-prefix=ATOM32 %s 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mcpu=core2 -mtriple=i686-linux | FileCheck -check-prefix=ATOM-NOT32 %s 3*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mcpu=atom -mtriple=x86_64-linux | FileCheck -check-prefix=ATOM64 %s 4*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mcpu=core2 -mtriple=x86_64-linux | FileCheck -check-prefix=ATOM-NOT64 %s 5*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mcpu=slm -mtriple=i686-linux | FileCheck -check-prefix=SLM32 %s 6*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mcpu=slm -mtriple=x86_64-linux | FileCheck -check-prefix=SLM64 %s 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Worker; fn_ptr.ll 10*9880d681SAndroid Build Coastguard Worker%class.A = type { i32 (...)** } 11*9880d681SAndroid Build Coastguard Worker 12*9880d681SAndroid Build Coastguard Workerdefine i32 @test1() #0 { 13*9880d681SAndroid Build Coastguard Worker ;ATOM-LABEL: test1: 14*9880d681SAndroid Build Coastguard Workerentry: 15*9880d681SAndroid Build Coastguard Worker %call = tail call %class.A* @_Z3facv() 16*9880d681SAndroid Build Coastguard Worker %0 = bitcast %class.A* %call to void (%class.A*)*** 17*9880d681SAndroid Build Coastguard Worker %vtable = load void (%class.A*)**, void (%class.A*)*** %0, align 8 18*9880d681SAndroid Build Coastguard Worker %1 = load void (%class.A*)*, void (%class.A*)** %vtable, align 8 19*9880d681SAndroid Build Coastguard Worker ;ATOM32: movl (%ecx), %ecx 20*9880d681SAndroid Build Coastguard Worker ;ATOM32: calll *%ecx 21*9880d681SAndroid Build Coastguard Worker ;ATOM-NOT32: calll *(%ecx) 22*9880d681SAndroid Build Coastguard Worker ;ATOM64: movq (%rcx), %rcx 23*9880d681SAndroid Build Coastguard Worker ;ATOM64: callq *%rcx 24*9880d681SAndroid Build Coastguard Worker ;ATOM-NOT64: callq *(%rcx) 25*9880d681SAndroid Build Coastguard Worker ;SLM32: movl (%ecx), %ecx 26*9880d681SAndroid Build Coastguard Worker ;SLM32: calll *%ecx 27*9880d681SAndroid Build Coastguard Worker ;SLM64: movq (%rcx), %rcx 28*9880d681SAndroid Build Coastguard Worker ;SLM64: callq *%rcx 29*9880d681SAndroid Build Coastguard Worker tail call void %1(%class.A* %call) 30*9880d681SAndroid Build Coastguard Worker ret i32 0 31*9880d681SAndroid Build Coastguard Worker} 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Workerdeclare %class.A* @_Z3facv() #1 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Worker; virt_fn.ll 36*9880d681SAndroid Build Coastguard Worker@p = external global void (i32)** 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Workerdefine i32 @test2() #0 { 39*9880d681SAndroid Build Coastguard Worker ;ATOM-LABEL: test2: 40*9880d681SAndroid Build Coastguard Workerentry: 41*9880d681SAndroid Build Coastguard Worker %0 = load void (i32)**, void (i32)*** @p, align 8 42*9880d681SAndroid Build Coastguard Worker %1 = load void (i32)*, void (i32)** %0, align 8 43*9880d681SAndroid Build Coastguard Worker ;ATOM32: movl (%eax), %eax 44*9880d681SAndroid Build Coastguard Worker ;ATOM32: calll *%eax 45*9880d681SAndroid Build Coastguard Worker ;ATOM-NOT: calll *(%eax) 46*9880d681SAndroid Build Coastguard Worker ;ATOM64: movq (%rax), %rax 47*9880d681SAndroid Build Coastguard Worker ;ATOM64: callq *%rax 48*9880d681SAndroid Build Coastguard Worker ;ATOM-NOT64: callq *(%rax) 49*9880d681SAndroid Build Coastguard Worker ;SLM32: movl (%eax), %eax 50*9880d681SAndroid Build Coastguard Worker ;SLM32: calll *%eax 51*9880d681SAndroid Build Coastguard Worker ;SLM64: movq (%rax), %rax 52*9880d681SAndroid Build Coastguard Worker ;SLM64: callq *%rax 53*9880d681SAndroid Build Coastguard Worker tail call void %1(i32 2) 54*9880d681SAndroid Build Coastguard Worker ret i32 0 55*9880d681SAndroid Build Coastguard Worker} 56