mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-12 23:40:54 +00:00
2c3be3c856
Code that doesn't use floating point and doesn't use SSE (kernel code) shouldn't save and restore SSE registers. Fixes PR30503 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@282819 91177308-0d34-0410-b5e6-96231b3b80d8
31 lines
648 B
LLVM
31 lines
648 B
LLVM
; RUN: llc < %s -mattr="-sse,-mmx,+soft-float" | FileCheck %s
|
|
|
|
; CHECK: peach:
|
|
; CHECK: pushq %rsi
|
|
; CHECK: pushq %rdi
|
|
; CHECK-NOT: movaps
|
|
; CHECK: callq banana
|
|
; CHECK-NOT: movaps
|
|
; CHECK: popq %rdi
|
|
; CHECK: popq %rsi
|
|
; CHECK: retq
|
|
|
|
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
|
|
target triple = "x86_64-unknown-linux-gnu"
|
|
|
|
; Function Attrs: uwtable
|
|
define internal i64 @banana() unnamed_addr #0 {
|
|
entry-block:
|
|
ret i64 0
|
|
}
|
|
|
|
; Function Attrs: nounwind uwtable
|
|
define x86_64_win64cc i64 @peach() unnamed_addr #1 {
|
|
entry-block:
|
|
%0 = call i64 @banana()
|
|
ret i64 %0
|
|
}
|
|
|
|
attributes #0 = { uwtable }
|
|
attributes #1 = { nounwind uwtable }
|