2016-09-22 21:49:25 +08:00
|
|
|
; RUN: llc -mtriple=aarch64-apple-ios -O0 -stop-after=irtranslator -global-isel -verify-machineinstrs %s -o - 2>&1 | FileCheck %s
|
|
|
|
|
|
|
|
|
|
|
|
; CHECK-LABEL: name: test_stack_slots
|
|
|
|
; CHECK: fixedStack:
|
2017-06-06 16:16:19 +08:00
|
|
|
; CHECK-DAG: - { id: [[STACK0:[0-9]+]], type: default, offset: 0, size: 1,
|
|
|
|
; CHECK-DAG: - { id: [[STACK8:[0-9]+]], type: default, offset: 1, size: 1,
|
2017-10-25 02:04:54 +08:00
|
|
|
; CHECK: [[LHS_ADDR:%[0-9]+]]:_(p0) = G_FRAME_INDEX %fixed-stack.[[STACK0]]
|
2019-08-28 12:01:46 +08:00
|
|
|
; CHECK: [[LHS:%[0-9]+]]:_(s8) = G_LOAD [[LHS_ADDR]](p0) :: (invariant load 1 from %fixed-stack.[[STACK0]], align 16)
|
2017-10-25 02:04:54 +08:00
|
|
|
; CHECK: [[RHS_ADDR:%[0-9]+]]:_(p0) = G_FRAME_INDEX %fixed-stack.[[STACK8]]
|
2019-01-31 09:38:47 +08:00
|
|
|
; CHECK: [[RHS:%[0-9]+]]:_(s8) = G_LOAD [[RHS_ADDR]](p0) :: (invariant load 1 from %fixed-stack.[[STACK8]])
|
2017-10-25 02:04:54 +08:00
|
|
|
; CHECK: [[SUM:%[0-9]+]]:_(s8) = G_ADD [[LHS]], [[RHS]]
|
|
|
|
; CHECK: [[SUM32:%[0-9]+]]:_(s32) = G_SEXT [[SUM]](s8)
|
2018-02-01 06:04:26 +08:00
|
|
|
; CHECK: $w0 = COPY [[SUM32]](s32)
|
2016-09-22 21:49:25 +08:00
|
|
|
define signext i8 @test_stack_slots([8 x i64], i8 signext %lhs, i8 signext %rhs) {
|
|
|
|
%sum = add i8 %lhs, %rhs
|
|
|
|
ret i8 %sum
|
|
|
|
}
|
|
|
|
|
|
|
|
; CHECK-LABEL: name: test_call_stack
|
2017-10-25 02:04:54 +08:00
|
|
|
; CHECK: [[C42:%[0-9]+]]:_(s8) = G_CONSTANT i8 42
|
|
|
|
; CHECK: [[C12:%[0-9]+]]:_(s8) = G_CONSTANT i8 12
|
2018-02-01 06:04:26 +08:00
|
|
|
; CHECK: [[SP:%[0-9]+]]:_(p0) = COPY $sp
|
2017-10-25 02:04:54 +08:00
|
|
|
; CHECK: [[C42_OFFS:%[0-9]+]]:_(s64) = G_CONSTANT i64 0
|
[globalisel] Rename G_GEP to G_PTR_ADD
Summary:
G_GEP is rather poorly named. It's a simple pointer+scalar addition and
doesn't support any of the complexities of getelementptr. I therefore
propose that we rename it. There's a G_PTR_MASK so let's follow that
convention and go with G_PTR_ADD
Reviewers: volkan, aditya_nandakumar, bogner, rovka, arsenm
Subscribers: sdardis, jvesely, wdng, nhaehnle, hiraditya, jrtc27, atanasyan, arphaman, Petar.Avramovic, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D69734
2019-11-02 04:18:00 +08:00
|
|
|
; CHECK: [[C42_LOC:%[0-9]+]]:_(p0) = G_PTR_ADD [[SP]], [[C42_OFFS]](s64)
|
2019-01-31 09:38:47 +08:00
|
|
|
; CHECK: G_STORE [[C42]](s8), [[C42_LOC]](p0) :: (store 1 into stack)
|
2017-10-25 02:04:54 +08:00
|
|
|
; CHECK: [[C12_OFFS:%[0-9]+]]:_(s64) = G_CONSTANT i64 1
|
[globalisel] Rename G_GEP to G_PTR_ADD
Summary:
G_GEP is rather poorly named. It's a simple pointer+scalar addition and
doesn't support any of the complexities of getelementptr. I therefore
propose that we rename it. There's a G_PTR_MASK so let's follow that
convention and go with G_PTR_ADD
Reviewers: volkan, aditya_nandakumar, bogner, rovka, arsenm
Subscribers: sdardis, jvesely, wdng, nhaehnle, hiraditya, jrtc27, atanasyan, arphaman, Petar.Avramovic, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D69734
2019-11-02 04:18:00 +08:00
|
|
|
; CHECK: [[C12_LOC:%[0-9]+]]:_(p0) = G_PTR_ADD [[SP]], [[C12_OFFS]](s64)
|
2019-01-31 09:38:47 +08:00
|
|
|
; CHECK: G_STORE [[C12]](s8), [[C12_LOC]](p0) :: (store 1 into stack + 1)
|
2016-09-22 21:49:25 +08:00
|
|
|
; CHECK: BL @test_stack_slots
|
|
|
|
define void @test_call_stack() {
|
|
|
|
call signext i8 @test_stack_slots([8 x i64] undef, i8 signext 42, i8 signext 12)
|
|
|
|
ret void
|
|
|
|
}
|
2017-08-22 05:56:11 +08:00
|
|
|
|
|
|
|
; CHECK-LABEL: name: test_128bit_struct
|
2018-02-01 06:04:26 +08:00
|
|
|
; CHECK: $x0 = COPY
|
|
|
|
; CHECK: $x1 = COPY
|
|
|
|
; CHECK: $x2 = COPY
|
2017-08-22 05:56:11 +08:00
|
|
|
; CHECK: BL @take_128bit_struct
|
|
|
|
define void @test_128bit_struct([2 x i64]* %ptr) {
|
|
|
|
%struct = load [2 x i64], [2 x i64]* %ptr
|
|
|
|
call void @take_128bit_struct([2 x i64]* null, [2 x i64] %struct)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; CHECK-LABEL: name: take_128bit_struct
|
2018-02-01 06:04:26 +08:00
|
|
|
; CHECK: {{%.*}}:_(p0) = COPY $x0
|
|
|
|
; CHECK: {{%.*}}:_(s64) = COPY $x1
|
|
|
|
; CHECK: {{%.*}}:_(s64) = COPY $x2
|
2017-08-22 05:56:11 +08:00
|
|
|
define void @take_128bit_struct([2 x i64]* %ptr, [2 x i64] %in) {
|
|
|
|
store [2 x i64] %in, [2 x i64]* %ptr
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; CHECK-LABEL: name: test_split_struct
|
2018-05-16 18:32:02 +08:00
|
|
|
; CHECK: [[LD1:%[0-9]+]]:_(s64) = G_LOAD %0(p0) :: (load 8 from %ir.ptr)
|
|
|
|
; CHECK: [[CST:%[0-9]+]]:_(s64) = G_CONSTANT i64 8
|
[globalisel] Rename G_GEP to G_PTR_ADD
Summary:
G_GEP is rather poorly named. It's a simple pointer+scalar addition and
doesn't support any of the complexities of getelementptr. I therefore
propose that we rename it. There's a G_PTR_MASK so let's follow that
convention and go with G_PTR_ADD
Reviewers: volkan, aditya_nandakumar, bogner, rovka, arsenm
Subscribers: sdardis, jvesely, wdng, nhaehnle, hiraditya, jrtc27, atanasyan, arphaman, Petar.Avramovic, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D69734
2019-11-02 04:18:00 +08:00
|
|
|
; CHECK: [[GEP:%[0-9]+]]:_(p0) = G_PTR_ADD %0, [[CST]](s64)
|
2018-05-16 18:32:02 +08:00
|
|
|
; CHECK: [[LD2:%[0-9]+]]:_(s64) = G_LOAD %3(p0) :: (load 8 from %ir.ptr + 8)
|
2017-08-22 05:56:11 +08:00
|
|
|
|
2018-02-01 06:04:26 +08:00
|
|
|
; CHECK: [[SP:%[0-9]+]]:_(p0) = COPY $sp
|
2017-10-25 02:04:54 +08:00
|
|
|
; CHECK: [[OFF:%[0-9]+]]:_(s64) = G_CONSTANT i64 0
|
[globalisel] Rename G_GEP to G_PTR_ADD
Summary:
G_GEP is rather poorly named. It's a simple pointer+scalar addition and
doesn't support any of the complexities of getelementptr. I therefore
propose that we rename it. There's a G_PTR_MASK so let's follow that
convention and go with G_PTR_ADD
Reviewers: volkan, aditya_nandakumar, bogner, rovka, arsenm
Subscribers: sdardis, jvesely, wdng, nhaehnle, hiraditya, jrtc27, atanasyan, arphaman, Petar.Avramovic, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D69734
2019-11-02 04:18:00 +08:00
|
|
|
; CHECK: [[ADDR:%[0-9]+]]:_(p0) = G_PTR_ADD [[SP]], [[OFF]](s64)
|
2019-06-27 17:18:03 +08:00
|
|
|
; CHECK: G_STORE [[LD1]](s64), [[ADDR]](p0) :: (store 8 into stack, align 1)
|
2017-08-22 05:56:11 +08:00
|
|
|
|
[GlobalISel] Tidy up unnecessary calls to createGenericVirtualRegister
Summary:
As a side effect some redundant copies of constant values are removed by
CSEMIRBuilder.
Reviewers: aemerson, arsenm, dsanders, aditya_nandakumar
Subscribers: sdardis, jvesely, wdng, nhaehnle, rovka, hiraditya, jrtc27, atanasyan, volkan, Petar.Avramovic, kerbowa, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D73789
2020-01-31 20:40:31 +08:00
|
|
|
; CHECK: [[ADDR:%[0-9]+]]:_(p0) = G_PTR_ADD [[SP]], [[CST]]
|
2019-06-27 17:18:03 +08:00
|
|
|
; CHECK: G_STORE [[LD2]](s64), [[ADDR]](p0) :: (store 8 into stack + 8, align 1)
|
2017-08-22 05:56:11 +08:00
|
|
|
define void @test_split_struct([2 x i64]* %ptr) {
|
|
|
|
%struct = load [2 x i64], [2 x i64]* %ptr
|
|
|
|
call void @take_split_struct([2 x i64]* null, i64 1, i64 2, i64 3,
|
|
|
|
i64 4, i64 5, i64 6,
|
|
|
|
[2 x i64] %struct)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; CHECK-LABEL: name: take_split_struct
|
|
|
|
; CHECK: fixedStack:
|
|
|
|
; CHECK-DAG: - { id: [[LO_FRAME:[0-9]+]], type: default, offset: 0, size: 8
|
|
|
|
; CHECK-DAG: - { id: [[HI_FRAME:[0-9]+]], type: default, offset: 8, size: 8
|
|
|
|
|
2017-10-25 02:04:54 +08:00
|
|
|
; CHECK: [[LOPTR:%[0-9]+]]:_(p0) = G_FRAME_INDEX %fixed-stack.[[LO_FRAME]]
|
2019-08-28 12:01:46 +08:00
|
|
|
; CHECK: [[LO:%[0-9]+]]:_(s64) = G_LOAD [[LOPTR]](p0) :: (invariant load 8 from %fixed-stack.[[LO_FRAME]], align 16)
|
2017-08-22 05:56:11 +08:00
|
|
|
|
2017-10-25 02:04:54 +08:00
|
|
|
; CHECK: [[HIPTR:%[0-9]+]]:_(p0) = G_FRAME_INDEX %fixed-stack.[[HI_FRAME]]
|
2019-08-28 12:01:46 +08:00
|
|
|
; CHECK: [[HI:%[0-9]+]]:_(s64) = G_LOAD [[HIPTR]](p0) :: (invariant load 8 from %fixed-stack.[[HI_FRAME]])
|
2017-08-22 05:56:11 +08:00
|
|
|
define void @take_split_struct([2 x i64]* %ptr, i64, i64, i64,
|
|
|
|
i64, i64, i64,
|
|
|
|
[2 x i64] %in) {
|
|
|
|
store [2 x i64] %in, [2 x i64]* %ptr
|
|
|
|
ret void
|
|
|
|
}
|