2013-10-16 07:33:07 +08:00
|
|
|
; RUN: llc < %s -mcpu=generic -enable-misched=false -mtriple=x86_64-mingw32 | FileCheck %s -check-prefix=M64
|
|
|
|
; RUN: llc < %s -mcpu=generic -enable-misched=false -mtriple=x86_64-win32 | FileCheck %s -check-prefix=W64
|
2015-01-30 07:58:04 +08:00
|
|
|
; RUN: llc < %s -mcpu=generic -enable-misched=false -mtriple=x86_64-win32 -code-model=large | FileCheck %s -check-prefix=L64
|
2013-10-16 07:33:07 +08:00
|
|
|
; RUN: llc < %s -mcpu=generic -enable-misched=false -mtriple=x86_64-win32-macho | FileCheck %s -check-prefix=EFI
|
2011-03-24 15:07:00 +08:00
|
|
|
; PR8777
|
|
|
|
; PR8778
|
|
|
|
|
2013-10-14 15:26:51 +08:00
|
|
|
define i64 @unaligned(i64 %n, i64 %x) nounwind {
|
|
|
|
; M64-LABEL: unaligned:
|
|
|
|
; W64-LABEL: unaligned:
|
|
|
|
; EFI-LABEL: unaligned:
|
2011-03-24 15:07:00 +08:00
|
|
|
entry:
|
|
|
|
|
|
|
|
%buf0 = alloca i8, i64 4096, align 1
|
|
|
|
|
2013-12-13 13:37:05 +08:00
|
|
|
; ___chkstk_ms does not adjust %rsp.
|
2015-02-24 05:50:30 +08:00
|
|
|
; M64: $4096, %eax
|
2013-12-13 13:37:05 +08:00
|
|
|
; M64: callq ___chkstk_ms
|
|
|
|
; M64: subq %rax, %rsp
|
2015-02-10 08:57:42 +08:00
|
|
|
; M64: leaq 128(%rsp), %rbp
|
2011-03-24 15:07:00 +08:00
|
|
|
|
|
|
|
; __chkstk does not adjust %rsp.
|
2015-02-24 05:50:30 +08:00
|
|
|
; W64: $4096, %eax
|
2011-03-24 15:07:00 +08:00
|
|
|
; W64: callq __chkstk
|
2013-07-08 19:20:11 +08:00
|
|
|
; W64: subq %rax, %rsp
|
2015-02-10 08:57:42 +08:00
|
|
|
; W64: leaq 128(%rsp), %rbp
|
2011-03-24 15:07:00 +08:00
|
|
|
|
2015-01-30 07:58:04 +08:00
|
|
|
; Use %r11 for the large model.
|
2015-02-24 05:50:30 +08:00
|
|
|
; L64: $4096, %eax
|
2015-01-30 07:58:04 +08:00
|
|
|
; L64: movabsq $__chkstk, %r11
|
|
|
|
; L64: callq *%r11
|
|
|
|
; L64: subq %rax, %rsp
|
|
|
|
|
2011-03-24 15:07:00 +08:00
|
|
|
; Freestanding
|
|
|
|
; EFI: $[[B0OFS:4096|4104]], %rsp
|
|
|
|
; EFI-NOT: call
|
|
|
|
|
|
|
|
%buf1 = alloca i8, i64 %n, align 1
|
|
|
|
|
2012-05-18 07:44:19 +08:00
|
|
|
; M64: leaq 15(%{{.*}}), %rax
|
2011-03-24 15:07:00 +08:00
|
|
|
; M64: andq $-16, %rax
|
2015-01-30 07:58:04 +08:00
|
|
|
; M64: callq ___chkstk_ms
|
|
|
|
; M64: subq %rax, %rsp
|
2011-03-24 15:07:00 +08:00
|
|
|
; M64: movq %rsp, %rax
|
|
|
|
|
2012-05-18 07:44:19 +08:00
|
|
|
; W64: leaq 15(%{{.*}}), %rax
|
2011-03-24 15:07:00 +08:00
|
|
|
; W64: andq $-16, %rax
|
|
|
|
; W64: callq __chkstk
|
|
|
|
; W64: subq %rax, %rsp
|
|
|
|
; W64: movq %rsp, %rax
|
|
|
|
|
2015-01-30 07:58:04 +08:00
|
|
|
; L64: leaq 15(%{{.*}}), %rax
|
|
|
|
; L64: andq $-16, %rax
|
|
|
|
; L64: movabsq $__chkstk, %r11
|
|
|
|
; L64: callq *%r11
|
|
|
|
; L64: subq %rax, %rsp
|
|
|
|
; L64: movq %rsp, %rax
|
|
|
|
|
2012-05-18 07:44:19 +08:00
|
|
|
; EFI: leaq 15(%{{.*}}), [[R1:%r.*]]
|
2011-04-05 08:32:44 +08:00
|
|
|
; EFI: andq $-16, [[R1]]
|
2013-06-25 10:48:58 +08:00
|
|
|
; EFI: movq %rsp, [[R64:%r.*]]
|
2011-04-05 08:32:44 +08:00
|
|
|
; EFI: subq [[R1]], [[R64]]
|
2011-03-24 15:07:00 +08:00
|
|
|
; EFI: movq [[R64]], %rsp
|
|
|
|
|
|
|
|
%r = call i64 @bar(i64 %n, i64 %x, i64 %n, i8* %buf0, i8* %buf1) nounwind
|
|
|
|
|
|
|
|
; M64: subq $48, %rsp
|
2013-06-25 10:48:58 +08:00
|
|
|
; M64: movq %rax, 32(%rsp)
|
2015-02-10 08:57:42 +08:00
|
|
|
; M64: leaq -128(%rbp), %r9
|
2011-03-24 15:07:00 +08:00
|
|
|
; M64: callq bar
|
|
|
|
|
|
|
|
; W64: subq $48, %rsp
|
2013-06-25 10:48:58 +08:00
|
|
|
; W64: movq %rax, 32(%rsp)
|
2015-02-10 08:57:42 +08:00
|
|
|
; W64: leaq -128(%rbp), %r9
|
2011-03-24 15:07:00 +08:00
|
|
|
; W64: callq bar
|
|
|
|
|
|
|
|
; EFI: subq $48, %rsp
|
2013-06-25 10:48:58 +08:00
|
|
|
; EFI: movq [[R64]], 32(%rsp)
|
2013-10-16 07:33:07 +08:00
|
|
|
; EFI: leaq -[[B0OFS]](%rbp), %r9
|
2011-03-24 15:07:00 +08:00
|
|
|
; EFI: callq _bar
|
|
|
|
|
|
|
|
ret i64 %r
|
|
|
|
|
2015-02-10 08:57:42 +08:00
|
|
|
; M64: leaq 3968(%rbp), %rsp
|
2011-03-24 15:07:00 +08:00
|
|
|
|
2015-02-10 08:57:42 +08:00
|
|
|
; W64: leaq 3968(%rbp), %rsp
|
2011-03-24 15:07:00 +08:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2013-10-14 15:26:51 +08:00
|
|
|
define i64 @aligned(i64 %n, i64 %x) nounwind {
|
|
|
|
; M64-LABEL: aligned:
|
|
|
|
; W64-LABEL: aligned:
|
|
|
|
; EFI-LABEL: aligned:
|
|
|
|
entry:
|
|
|
|
|
|
|
|
%buf1 = alloca i8, i64 %n, align 128
|
|
|
|
|
|
|
|
; M64: leaq 15(%{{.*}}), %rax
|
|
|
|
; M64: andq $-16, %rax
|
2015-01-30 07:58:04 +08:00
|
|
|
; M64: callq ___chkstk_ms
|
|
|
|
; M64: subq %rax, %rsp
|
2013-10-14 15:26:51 +08:00
|
|
|
; M64: movq %rsp, [[R2:%r.*]]
|
|
|
|
; M64: andq $-128, [[R2]]
|
|
|
|
; M64: movq [[R2]], %rsp
|
|
|
|
|
|
|
|
; W64: leaq 15(%{{.*}}), %rax
|
|
|
|
; W64: andq $-16, %rax
|
|
|
|
; W64: callq __chkstk
|
|
|
|
; W64: subq %rax, %rsp
|
|
|
|
; W64: movq %rsp, [[R2:%r.*]]
|
|
|
|
; W64: andq $-128, [[R2]]
|
|
|
|
; W64: movq [[R2]], %rsp
|
|
|
|
|
|
|
|
; EFI: leaq 15(%{{.*}}), [[R1:%r.*]]
|
|
|
|
; EFI: andq $-16, [[R1]]
|
|
|
|
; EFI: movq %rsp, [[R64:%r.*]]
|
|
|
|
; EFI: subq [[R1]], [[R64]]
|
|
|
|
; EFI: andq $-128, [[R64]]
|
|
|
|
; EFI: movq [[R64]], %rsp
|
|
|
|
|
|
|
|
%r = call i64 @bar(i64 %n, i64 %x, i64 %n, i8* undef, i8* %buf1) nounwind
|
|
|
|
|
|
|
|
; M64: subq $48, %rsp
|
|
|
|
; M64: movq [[R2]], 32(%rsp)
|
|
|
|
; M64: callq bar
|
|
|
|
|
|
|
|
; W64: subq $48, %rsp
|
|
|
|
; W64: movq [[R2]], 32(%rsp)
|
|
|
|
; W64: callq bar
|
|
|
|
|
|
|
|
; EFI: subq $48, %rsp
|
|
|
|
; EFI: movq [[R64]], 32(%rsp)
|
|
|
|
; EFI: callq _bar
|
|
|
|
|
|
|
|
ret i64 %r
|
|
|
|
}
|
|
|
|
|
2011-03-24 15:07:00 +08:00
|
|
|
declare i64 @bar(i64, i64, i64, i8* nocapture, i8* nocapture) nounwind
|