2014-06-21 00:34:05 +08:00
|
|
|
; Verify that small structures and float arguments are passed in the
|
|
|
|
; least significant part of a stack slot doubleword.
|
|
|
|
|
2016-08-04 02:17:35 +08:00
|
|
|
; RUN: llc -verify-machineinstrs < %s | FileCheck %s
|
2014-06-21 00:34:05 +08:00
|
|
|
|
|
|
|
target datalayout = "e-m:e-i64:64-n32:64"
|
|
|
|
target triple = "powerpc64le-unknown-linux-gnu"
|
|
|
|
|
|
|
|
%struct.large_arg = type { [8 x i64] }
|
|
|
|
%struct.small_arg = type { i16, i8 }
|
|
|
|
|
|
|
|
@gl = common global %struct.large_arg zeroinitializer, align 8
|
|
|
|
@gs = common global %struct.small_arg zeroinitializer, align 2
|
|
|
|
@gf = common global float 0.000000e+00, align 4
|
|
|
|
|
2020-11-21 03:07:11 +08:00
|
|
|
define void @callee1(%struct.small_arg* noalias nocapture sret(%struct.small_arg) %agg.result, %struct.large_arg* byval(%struct.large_arg) nocapture readnone %pad, %struct.small_arg* byval(%struct.small_arg) nocapture readonly %x) {
|
2014-06-21 00:34:05 +08:00
|
|
|
entry:
|
|
|
|
%0 = bitcast %struct.small_arg* %x to i32*
|
|
|
|
%1 = bitcast %struct.small_arg* %agg.result to i32*
|
2015-02-28 05:17:42 +08:00
|
|
|
%2 = load i32, i32* %0, align 2
|
2014-06-21 00:34:05 +08:00
|
|
|
store i32 %2, i32* %1, align 2
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
; CHECK: @callee1
|
[PowerPC] ELFv2 stack space reduction
The ELFv2 ABI reduces the amount of stack required to implement an
ABI-compliant function call in two ways:
* the "linkage area" is reduced from 48 bytes to 32 bytes by
eliminating two unused doublewords
* the 64-byte "parameter save area" is now optional and need not be
present in certain cases (it remains mandatory in functions with
variable arguments, and functions that have any parameter that is
passed on the stack)
The following patch implements this required changes:
- reducing the linkage area, and associated relocation of the TOC save
slot, in getLinkageSize / getTOCSaveOffset (this requires updating all
callers of these routines to pass in the isELFv2ABI flag).
- (partially) handling the case where the parameter save are is optional
This latter part requires some extra explanation: Currently, we still
always allocate the parameter save area when *calling* a function.
That is certainly always compliant with the ABI, but may cause code to
allocate stack unnecessarily. This can be addressed by a follow-on
optimization patch.
On the *callee* side, in LowerFormalArguments, we *must* track
correctly whether the ABI guarantees that the caller has allocated
the parameter save area for our use, and the patch does so. However,
there is one complication: the code that handles incoming "byval"
arguments will currently *always* write to the parameter save area,
because it has to force incoming register arguments to the stack since
it must return an *address* to implement the byval semantics.
To fix this, the patch changes the LowerFormalArguments code to write
arguments to a freshly allocated stack slot on the function's own stack
frame instead of the argument save area in those cases where that area
is not present.
Reviewed by Hal Finkel.
llvm-svn: 213490
2014-07-21 07:43:15 +08:00
|
|
|
; CHECK: lwz {{[0-9]+}}, 104(1)
|
2014-06-21 00:34:05 +08:00
|
|
|
; CHECK: blr
|
|
|
|
|
|
|
|
define void @caller1() {
|
|
|
|
entry:
|
|
|
|
%tmp = alloca %struct.small_arg, align 2
|
2020-11-21 03:07:11 +08:00
|
|
|
call void @test1(%struct.small_arg* sret(%struct.small_arg) %tmp, %struct.large_arg* byval(%struct.large_arg) @gl, %struct.small_arg* byval(%struct.small_arg) @gs)
|
2014-06-21 00:34:05 +08:00
|
|
|
ret void
|
|
|
|
}
|
|
|
|
; CHECK: @caller1
|
[PowerPC] ELFv2 stack space reduction
The ELFv2 ABI reduces the amount of stack required to implement an
ABI-compliant function call in two ways:
* the "linkage area" is reduced from 48 bytes to 32 bytes by
eliminating two unused doublewords
* the 64-byte "parameter save area" is now optional and need not be
present in certain cases (it remains mandatory in functions with
variable arguments, and functions that have any parameter that is
passed on the stack)
The following patch implements this required changes:
- reducing the linkage area, and associated relocation of the TOC save
slot, in getLinkageSize / getTOCSaveOffset (this requires updating all
callers of these routines to pass in the isELFv2ABI flag).
- (partially) handling the case where the parameter save are is optional
This latter part requires some extra explanation: Currently, we still
always allocate the parameter save area when *calling* a function.
That is certainly always compliant with the ABI, but may cause code to
allocate stack unnecessarily. This can be addressed by a follow-on
optimization patch.
On the *callee* side, in LowerFormalArguments, we *must* track
correctly whether the ABI guarantees that the caller has allocated
the parameter save area for our use, and the patch does so. However,
there is one complication: the code that handles incoming "byval"
arguments will currently *always* write to the parameter save area,
because it has to force incoming register arguments to the stack since
it must return an *address* to implement the byval semantics.
To fix this, the patch changes the LowerFormalArguments code to write
arguments to a freshly allocated stack slot on the function's own stack
frame instead of the argument save area in those cases where that area
is not present.
Reviewed by Hal Finkel.
llvm-svn: 213490
2014-07-21 07:43:15 +08:00
|
|
|
; CHECK: stw {{[0-9]+}}, 104(1)
|
2014-06-21 00:34:05 +08:00
|
|
|
; CHECK: bl test1
|
|
|
|
|
2020-11-21 08:02:42 +08:00
|
|
|
declare void @test1(%struct.small_arg* sret(%struct.small_arg), %struct.large_arg* byval(%struct.large_arg), %struct.small_arg* byval(%struct.small_arg))
|
2014-06-21 00:34:05 +08:00
|
|
|
|
|
|
|
define float @callee2(float %pad1, float %pad2, float %pad3, float %pad4, float %pad5, float %pad6, float %pad7, float %pad8, float %pad9, float %pad10, float %pad11, float %pad12, float %pad13, float %x) {
|
|
|
|
entry:
|
|
|
|
ret float %x
|
|
|
|
}
|
|
|
|
; CHECK: @callee2
|
2020-11-20 23:52:27 +08:00
|
|
|
; CHECK: lfs {{[0-9]+}}, 136(1)
|
2014-06-21 00:34:05 +08:00
|
|
|
; CHECK: blr
|
|
|
|
|
|
|
|
define void @caller2() {
|
|
|
|
entry:
|
2015-02-28 05:17:42 +08:00
|
|
|
%0 = load float, float* @gf, align 4
|
2014-06-21 00:34:05 +08:00
|
|
|
%call = tail call float @test2(float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float %0)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
; CHECK: @caller2
|
2019-07-23 11:34:40 +08:00
|
|
|
; CHECK: std {{[0-9]+}}, 16({{[0-9]+}})
|
2014-06-21 00:34:05 +08:00
|
|
|
; CHECK: bl test2
|
|
|
|
|
|
|
|
declare float @test2(float, float, float, float, float, float, float, float, float, float, float, float, float, float)
|
|
|
|
|