mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-24 13:33:37 +02:00
2be41be7b9
MS-style inline assembly. This is a follow-on to r175334. Forcing a FP to be emitted doesn't ensure it will be used. Therefore, force the base pointer as well. We now treat MS inline assembly in the same way we treat functions with dynamic stack realignment and VLAs. This guarantees the BP will be used to reference parameters and locals. rdar://13218191 llvm-svn: 175576
111 lines
3.2 KiB
LLVM
111 lines
3.2 KiB
LLVM
; RUN: llc < %s -march=x86 -mcpu=core2 | FileCheck %s
|
|
|
|
define i32 @t1() nounwind {
|
|
entry:
|
|
%0 = tail call i32 asm sideeffect inteldialect "mov eax, $1\0A\09mov $0, eax", "=r,r,~{eax},~{dirflag},~{fpsr},~{flags}"(i32 1) nounwind
|
|
ret i32 %0
|
|
; CHECK: t1
|
|
; CHECK: movl %esp, %ebp
|
|
; CHECK: {{## InlineAsm Start|#APP}}
|
|
; CHECK: .intel_syntax
|
|
; CHECK: mov eax, ecx
|
|
; CHECK: mov ecx, eax
|
|
; CHECK: .att_syntax
|
|
; CHECK: {{## InlineAsm End|#NO_APP}}
|
|
}
|
|
|
|
define void @t2() nounwind {
|
|
entry:
|
|
call void asm sideeffect inteldialect "mov eax, $$1", "~{eax},~{dirflag},~{fpsr},~{flags}"() nounwind
|
|
ret void
|
|
; CHECK: t2
|
|
; CHECK: movl %esp, %ebp
|
|
; CHECK: {{## InlineAsm Start|#APP}}
|
|
; CHECK: .intel_syntax
|
|
; CHECK: mov eax, 1
|
|
; CHECK: .att_syntax
|
|
; CHECK: {{## InlineAsm End|#NO_APP}}
|
|
}
|
|
|
|
define void @t3(i32 %V) nounwind {
|
|
entry:
|
|
%V.addr = alloca i32, align 4
|
|
store i32 %V, i32* %V.addr, align 4
|
|
call void asm sideeffect inteldialect "mov eax, DWORD PTR [$0]", "*m,~{eax},~{dirflag},~{fpsr},~{flags}"(i32* %V.addr) nounwind
|
|
ret void
|
|
; CHECK: t3
|
|
; CHECK: movl %esp, %ebp
|
|
; CHECK: {{## InlineAsm Start|#APP}}
|
|
; CHECK: .intel_syntax
|
|
; CHECK: mov eax, DWORD PTR {{[[esp]}}
|
|
; CHECK: .att_syntax
|
|
; CHECK: {{## InlineAsm End|#NO_APP}}
|
|
}
|
|
|
|
%struct.t18_type = type { i32, i32 }
|
|
|
|
define i32 @t18() nounwind {
|
|
entry:
|
|
%foo = alloca %struct.t18_type, align 4
|
|
%a = getelementptr inbounds %struct.t18_type* %foo, i32 0, i32 0
|
|
store i32 1, i32* %a, align 4
|
|
%b = getelementptr inbounds %struct.t18_type* %foo, i32 0, i32 1
|
|
store i32 2, i32* %b, align 4
|
|
call void asm sideeffect inteldialect "lea ebx, foo\0A\09mov eax, [ebx].0\0A\09mov [ebx].4, ecx", "~{eax},~{dirflag},~{fpsr},~{flags}"() nounwind
|
|
%b1 = getelementptr inbounds %struct.t18_type* %foo, i32 0, i32 1
|
|
%0 = load i32* %b1, align 4
|
|
ret i32 %0
|
|
; CHECK: t18
|
|
; CHECK: movl %esp, %ebp
|
|
; CHECK: {{## InlineAsm Start|#APP}}
|
|
; CHECK: .intel_syntax
|
|
; CHECK: lea ebx, foo
|
|
; CHECK: mov eax, [ebx].0
|
|
; CHECK: mov [ebx].4, ecx
|
|
; CHECK: .att_syntax
|
|
; CHECK: {{## InlineAsm End|#NO_APP}}
|
|
}
|
|
|
|
define void @t19_helper() nounwind {
|
|
entry:
|
|
ret void
|
|
}
|
|
|
|
define void @t19() nounwind {
|
|
entry:
|
|
call void asm sideeffect inteldialect "call $0", "r,~{dirflag},~{fpsr},~{flags}"(void ()* @t19_helper) nounwind
|
|
ret void
|
|
; CHECK: t19:
|
|
; CHECK: movl %esp, %ebp
|
|
; CHECK: movl ${{_?}}t19_helper, %eax
|
|
; CHECK: {{## InlineAsm Start|#APP}}
|
|
; CHECK: .intel_syntax
|
|
; CHECK: call eax
|
|
; CHECK: .att_syntax
|
|
; CHECK: {{## InlineAsm End|#NO_APP}}
|
|
}
|
|
|
|
@results = global [2 x i32] [i32 3, i32 2], align 4
|
|
|
|
define i32* @t30() nounwind ssp {
|
|
entry:
|
|
%res = alloca i32*, align 4
|
|
call void asm sideeffect inteldialect "lea edi, dword ptr $0", "*m,~{edi},~{dirflag},~{fpsr},~{flags}"([2 x i32]* @results) nounwind
|
|
call void asm sideeffect inteldialect "mov dword ptr $0, edi", "=*m,~{dirflag},~{fpsr},~{flags}"(i32** %res) nounwind
|
|
%0 = load i32** %res, align 4
|
|
ret i32* %0
|
|
; CHECK: t30:
|
|
; CHECK: movl %esp, %ebp
|
|
; CHECK: {{## InlineAsm Start|#APP}}
|
|
; CHECK: .intel_syntax
|
|
; CHECK: lea edi, dword ptr [{{_?}}results]
|
|
; CHECK: .att_syntax
|
|
; CHECK: {{## InlineAsm End|#NO_APP}}
|
|
; CHECK: {{## InlineAsm Start|#APP}}
|
|
; CHECK: .intel_syntax
|
|
; CHECK: mov dword ptr [esi], edi
|
|
; CHECK: .att_syntax
|
|
; CHECK: {{## InlineAsm End|#NO_APP}}
|
|
; CHECK: movl (%esi), %eax
|
|
}
|