llvm/test/CodeGen/X86/inline-asm.ll
Jakob Stoklund Olesen 9cda1be0aa Prioritize smaller register classes for urgent evictions.
It helps compile exotic inline asm. In the test case, normal GR32
virtual registers use up eax-edx so the final GR32_ABCD live range has
no registers left. Since all the live ranges were tiny, we had no way of
prioritizing the smaller register class.

This patch allows tiny unspillable live ranges to be evicted by tiny
unspillable live ranges from a smaller register class.

<rdar://problem/11542429>

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@157715 91177308-0d34-0410-b5e6-96231b3b80d8
2012-05-30 21:46:58 +00:00

55 lines
1.6 KiB
LLVM

; RUN: llc < %s -march=x86
define i32 @test1() nounwind {
; Dest is AX, dest type = i32.
%tmp4 = call i32 asm sideeffect "FROB $0", "={ax}"()
ret i32 %tmp4
}
define void @test2(i32 %V) nounwind {
; input is AX, in type = i32.
call void asm sideeffect "FROB $0", "{ax}"(i32 %V)
ret void
}
define void @test3() nounwind {
; FP constant as a memory operand.
tail call void asm sideeffect "frob $0", "m"( float 0x41E0000000000000)
ret void
}
define void @test4() nounwind {
; J means a constant in range 0 to 63.
tail call void asm sideeffect "bork $0", "J"(i32 37) nounwind
ret void
}
; rdar://9738585
define i32 @test5() nounwind {
entry:
%0 = tail call i32 asm "test", "=l,~{dirflag},~{fpsr},~{flags}"() nounwind
ret i32 0
}
; rdar://9777108 PR10352
define void @test6(i1 zeroext %desired) nounwind {
entry:
tail call void asm sideeffect "foo $0", "q,~{dirflag},~{fpsr},~{flags}"(i1 %desired) nounwind
ret void
}
define void @test7(i1 zeroext %desired, i32* %p) nounwind {
entry:
%0 = tail call i8 asm sideeffect "xchg $0, $1", "=r,*m,0,~{memory},~{dirflag},~{fpsr},~{flags}"(i32* %p, i1 %desired) nounwind
ret void
}
; <rdar://problem/11542429>
; The constrained GR32_ABCD register class of the 'q' constraint requires
; special handling after the preceding outputs used up eax-edx.
define void @constrain_abcd(i8* %h) nounwind ssp {
entry:
%0 = call { i32, i32, i32, i32, i32 } asm sideeffect "", "=&r,=&r,=&r,=&r,=&q,r,~{ecx},~{memory},~{dirflag},~{fpsr},~{flags}"(i8* %h) nounwind
ret void
}