annotate llvm/unittests/CodeGen/SelectionDAGAddressAnalysisTest.cpp @ 236:c4bab56944e8 llvm-original

LLVM 16
author kono
date Wed, 09 Nov 2022 17:45:10 +0900
parents 79ff65ed7e25
children 1f2b6ac9f198
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 //===- llvm/unittest/CodeGen/SelectionDAGAddressAnalysisTest.cpp ---------===//
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 //
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 //
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 #include "llvm/CodeGen/SelectionDAGAddressAnalysis.h"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 #include "llvm/Analysis/MemoryLocation.h"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 #include "llvm/Analysis/OptimizationRemarkEmitter.h"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 #include "llvm/AsmParser/Parser.h"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 #include "llvm/CodeGen/MachineModuleInfo.h"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 #include "llvm/CodeGen/SelectionDAG.h"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 #include "llvm/CodeGen/TargetLowering.h"
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
16 #include "llvm/MC/TargetRegistry.h"
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 #include "llvm/Support/SourceMgr.h"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 #include "llvm/Support/TargetSelect.h"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 #include "llvm/Target/TargetMachine.h"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 #include "gtest/gtest.h"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
21
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 namespace llvm {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
23
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 class SelectionDAGAddressAnalysisTest : public testing::Test {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 protected:
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 static void SetUpTestCase() {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 InitializeAllTargets();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 InitializeAllTargetMCs();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 }
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
30
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 void SetUp() override {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 StringRef Assembly = "@g = global i32 0\n"
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
33 "@g_alias = alias i32, i32* @g\n"
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 "define i32 @f() {\n"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 " %1 = load i32, i32* @g\n"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 " ret i32 %1\n"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 "}";
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 Triple TargetTriple("aarch64--");
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 std::string Error;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 const Target *T = TargetRegistry::lookupTarget("", TargetTriple, Error);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 // FIXME: These tests do not depend on AArch64 specifically, but we have to
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 // initialize a target. A skeleton Target for unittests would allow us to
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 // always run these tests.
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 if (!T)
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 GTEST_SKIP();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
47
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 TargetOptions Options;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 TM = std::unique_ptr<LLVMTargetMachine>(static_cast<LLVMTargetMachine *>(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 T->createTargetMachine("AArch64", "", "+sve", Options, None, None,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 CodeGenOpt::Aggressive)));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 if (!TM)
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 GTEST_SKIP();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
54
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
55 SMDiagnostic SMError;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 M = parseAssemblyString(Assembly, SMError, Context);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 if (!M)
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 report_fatal_error(SMError.getMessage());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 M->setDataLayout(TM->createDataLayout());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
60
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 F = M->getFunction("f");
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 if (!F)
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 report_fatal_error("F?");
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 G = M->getGlobalVariable("g");
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 if (!G)
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 report_fatal_error("G?");
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
67 AliasedG = M->getNamedAlias("g_alias");
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
68 if (!AliasedG)
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
69 report_fatal_error("AliasedG?");
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
70
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 MachineModuleInfo MMI(TM.get());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
72
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
73 MF = std::make_unique<MachineFunction>(*F, *TM, *TM->getSubtargetImpl(*F),
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74 0, MMI);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76 DAG = std::make_unique<SelectionDAG>(*TM, CodeGenOpt::None);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 if (!DAG)
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 report_fatal_error("DAG?");
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 OptimizationRemarkEmitter ORE(F);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
80 DAG->init(*MF, ORE, nullptr, nullptr, nullptr, nullptr, nullptr);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
81 }
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
82
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
83 TargetLoweringBase::LegalizeTypeAction getTypeAction(EVT VT) {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
84 return DAG->getTargetLoweringInfo().getTypeAction(Context, VT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
85 }
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
86
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
87 EVT getTypeToTransformTo(EVT VT) {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 return DAG->getTargetLoweringInfo().getTypeToTransformTo(Context, VT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
89 }
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
90
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
91 LLVMContext Context;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
92 std::unique_ptr<LLVMTargetMachine> TM;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
93 std::unique_ptr<Module> M;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
94 Function *F;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
95 GlobalVariable *G;
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
96 GlobalAlias *AliasedG;
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
97 std::unique_ptr<MachineFunction> MF;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
98 std::unique_ptr<SelectionDAG> DAG;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
99 };
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
100
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
101 TEST_F(SelectionDAGAddressAnalysisTest, sameFrameObject) {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
102 SDLoc Loc;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
103 auto Int8VT = EVT::getIntegerVT(Context, 8);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
104 auto VecVT = EVT::getVectorVT(Context, Int8VT, 4);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
105 SDValue FIPtr = DAG->CreateStackTemporary(VecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
106 int FI = cast<FrameIndexSDNode>(FIPtr.getNode())->getIndex();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
107 MachinePointerInfo PtrInfo = MachinePointerInfo::getFixedStack(*MF, FI);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
108 TypeSize Offset = TypeSize::Fixed(0);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
109 SDValue Value = DAG->getConstant(0, Loc, VecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
110 SDValue Index = DAG->getMemBasePlusOffset(FIPtr, Offset, Loc);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
111 SDValue Store = DAG->getStore(DAG->getEntryNode(), Loc, Value, Index,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
112 PtrInfo.getWithOffset(Offset));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
113 Optional<int64_t> NumBytes = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
114 cast<StoreSDNode>(Store)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
115
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
116 bool IsAlias;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
117 bool IsValid = BaseIndexOffset::computeAliasing(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
118 Store.getNode(), NumBytes, Store.getNode(), NumBytes, *DAG, IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
119
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
120 EXPECT_TRUE(IsValid);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
121 EXPECT_TRUE(IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
122 }
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
123
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
124 TEST_F(SelectionDAGAddressAnalysisTest, sameFrameObjectUnknownSize) {
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
125 SDLoc Loc;
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
126 auto Int8VT = EVT::getIntegerVT(Context, 8);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
127 auto VecVT = EVT::getVectorVT(Context, Int8VT, 4);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
128 SDValue FIPtr = DAG->CreateStackTemporary(VecVT);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
129 int FI = cast<FrameIndexSDNode>(FIPtr.getNode())->getIndex();
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
130 MachinePointerInfo PtrInfo = MachinePointerInfo::getFixedStack(*MF, FI);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
131 TypeSize Offset = TypeSize::Fixed(0);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
132 SDValue Value = DAG->getConstant(0, Loc, VecVT);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
133 SDValue Index = DAG->getMemBasePlusOffset(FIPtr, Offset, Loc);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
134 SDValue Store = DAG->getStore(DAG->getEntryNode(), Loc, Value, Index,
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
135 PtrInfo.getWithOffset(Offset));
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
136
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
137 // Maybe unlikely that BaseIndexOffset::computeAliasing is used with the
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
138 // optional NumBytes being unset like in this test, but it would be confusing
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
139 // if that function determined IsAlias=false here.
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
140 Optional<int64_t> NumBytes;
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
141
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
142 bool IsAlias;
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
143 bool IsValid = BaseIndexOffset::computeAliasing(
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
144 Store.getNode(), NumBytes, Store.getNode(), NumBytes, *DAG, IsAlias);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
145
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
146 EXPECT_FALSE(IsValid);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
147 }
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
148
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
149 TEST_F(SelectionDAGAddressAnalysisTest, noAliasingFrameObjects) {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
150 SDLoc Loc;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
151 auto Int8VT = EVT::getIntegerVT(Context, 8);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
152 // <4 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
153 auto VecVT = EVT::getVectorVT(Context, Int8VT, 4);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
154 // <2 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
155 auto SubVecVT = EVT::getVectorVT(Context, Int8VT, 2);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
156 SDValue FIPtr = DAG->CreateStackTemporary(VecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
157 int FI = cast<FrameIndexSDNode>(FIPtr.getNode())->getIndex();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
158 MachinePointerInfo PtrInfo = MachinePointerInfo::getFixedStack(*MF, FI);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
159 SDValue Value = DAG->getConstant(0, Loc, SubVecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
160 TypeSize Offset0 = TypeSize::Fixed(0);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
161 TypeSize Offset1 = SubVecVT.getStoreSize();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
162 SDValue Index0 = DAG->getMemBasePlusOffset(FIPtr, Offset0, Loc);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
163 SDValue Index1 = DAG->getMemBasePlusOffset(FIPtr, Offset1, Loc);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
164 SDValue Store0 = DAG->getStore(DAG->getEntryNode(), Loc, Value, Index0,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
165 PtrInfo.getWithOffset(Offset0));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
166 SDValue Store1 = DAG->getStore(DAG->getEntryNode(), Loc, Value, Index1,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
167 PtrInfo.getWithOffset(Offset1));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
168 Optional<int64_t> NumBytes0 = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
169 cast<StoreSDNode>(Store0)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
170 Optional<int64_t> NumBytes1 = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
171 cast<StoreSDNode>(Store1)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
172
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
173 bool IsAlias;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
174 bool IsValid = BaseIndexOffset::computeAliasing(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
175 Store0.getNode(), NumBytes0, Store1.getNode(), NumBytes1, *DAG, IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
176
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
177 EXPECT_TRUE(IsValid);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
178 EXPECT_FALSE(IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
179 }
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
180
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
181 TEST_F(SelectionDAGAddressAnalysisTest, unknownSizeFrameObjects) {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
182 SDLoc Loc;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
183 auto Int8VT = EVT::getIntegerVT(Context, 8);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
184 // <vscale x 4 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
185 auto VecVT = EVT::getVectorVT(Context, Int8VT, 4, true);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
186 // <vscale x 2 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
187 auto SubVecVT = EVT::getVectorVT(Context, Int8VT, 2, true);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
188 SDValue FIPtr = DAG->CreateStackTemporary(VecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
189 int FI = cast<FrameIndexSDNode>(FIPtr.getNode())->getIndex();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
190 MachinePointerInfo PtrInfo = MachinePointerInfo::getFixedStack(*MF, FI);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
191 SDValue Value = DAG->getConstant(0, Loc, SubVecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
192 TypeSize Offset1 = SubVecVT.getStoreSize();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
193 SDValue Index1 = DAG->getMemBasePlusOffset(FIPtr, Offset1, Loc);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
194 SDValue Store0 =
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
195 DAG->getStore(DAG->getEntryNode(), Loc, Value, FIPtr, PtrInfo);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
196 SDValue Store1 = DAG->getStore(DAG->getEntryNode(), Loc, Value, Index1,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
197 MachinePointerInfo(PtrInfo.getAddrSpace()));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
198 Optional<int64_t> NumBytes0 = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
199 cast<StoreSDNode>(Store0)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
200 Optional<int64_t> NumBytes1 = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
201 cast<StoreSDNode>(Store1)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
202
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
203 bool IsAlias;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
204 bool IsValid = BaseIndexOffset::computeAliasing(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
205 Store0.getNode(), NumBytes0, Store1.getNode(), NumBytes1, *DAG, IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
206
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
207 EXPECT_FALSE(IsValid);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
208 }
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
209
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
210 TEST_F(SelectionDAGAddressAnalysisTest, globalWithFrameObject) {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
211 SDLoc Loc;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
212 auto Int8VT = EVT::getIntegerVT(Context, 8);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
213 // <vscale x 4 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
214 auto VecVT = EVT::getVectorVT(Context, Int8VT, 4, true);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
215 SDValue FIPtr = DAG->CreateStackTemporary(VecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
216 int FI = cast<FrameIndexSDNode>(FIPtr.getNode())->getIndex();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
217 MachinePointerInfo PtrInfo = MachinePointerInfo::getFixedStack(*MF, FI);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
218 SDValue Value = DAG->getConstant(0, Loc, VecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
219 TypeSize Offset = TypeSize::Fixed(0);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
220 SDValue Index = DAG->getMemBasePlusOffset(FIPtr, Offset, Loc);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
221 SDValue Store = DAG->getStore(DAG->getEntryNode(), Loc, Value, Index,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
222 PtrInfo.getWithOffset(Offset));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
223 Optional<int64_t> NumBytes = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
224 cast<StoreSDNode>(Store)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
225 EVT GTy = DAG->getTargetLoweringInfo().getValueType(DAG->getDataLayout(),
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
226 G->getType());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
227 SDValue GValue = DAG->getConstant(0, Loc, GTy);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
228 SDValue GAddr = DAG->getGlobalAddress(G, Loc, GTy);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
229 SDValue GStore = DAG->getStore(DAG->getEntryNode(), Loc, GValue, GAddr,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
230 MachinePointerInfo(G, 0));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
231 Optional<int64_t> GNumBytes = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
232 cast<StoreSDNode>(GStore)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
233
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
234 bool IsAlias;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
235 bool IsValid = BaseIndexOffset::computeAliasing(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
236 Store.getNode(), NumBytes, GStore.getNode(), GNumBytes, *DAG, IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
237
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
238 EXPECT_TRUE(IsValid);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
239 EXPECT_FALSE(IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
240 }
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
241
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
242 TEST_F(SelectionDAGAddressAnalysisTest, globalWithAliasedGlobal) {
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
243 SDLoc Loc;
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
244
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
245 EVT GTy = DAG->getTargetLoweringInfo().getValueType(DAG->getDataLayout(),
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
246 G->getType());
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
247 SDValue GValue = DAG->getConstant(0, Loc, GTy);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
248 SDValue GAddr = DAG->getGlobalAddress(G, Loc, GTy);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
249 SDValue GStore = DAG->getStore(DAG->getEntryNode(), Loc, GValue, GAddr,
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
250 MachinePointerInfo(G, 0));
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
251 Optional<int64_t> GNumBytes = MemoryLocation::getSizeOrUnknown(
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
252 cast<StoreSDNode>(GStore)->getMemoryVT().getStoreSize());
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
253
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
254 SDValue AliasedGValue = DAG->getConstant(1, Loc, GTy);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
255 SDValue AliasedGAddr = DAG->getGlobalAddress(AliasedG, Loc, GTy);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
256 SDValue AliasedGStore =
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
257 DAG->getStore(DAG->getEntryNode(), Loc, AliasedGValue, AliasedGAddr,
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
258 MachinePointerInfo(AliasedG, 0));
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
259
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
260 bool IsAlias;
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
261 bool IsValid = BaseIndexOffset::computeAliasing(GStore.getNode(), GNumBytes,
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
262 AliasedGStore.getNode(),
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
263 GNumBytes, *DAG, IsAlias);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
264
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
265 // With some deeper analysis we could detect if G and AliasedG is aliasing or
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
266 // not. But computeAliasing is currently defensive and assumes that a
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
267 // GlobalAlias might alias with any global variable.
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
268 EXPECT_FALSE(IsValid);
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
269 }
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
270
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
271 TEST_F(SelectionDAGAddressAnalysisTest, fixedSizeFrameObjectsWithinDiff) {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
272 SDLoc Loc;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
273 auto Int8VT = EVT::getIntegerVT(Context, 8);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
274 // <vscale x 4 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
275 auto VecVT = EVT::getVectorVT(Context, Int8VT, 4, true);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
276 // <vscale x 2 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
277 auto SubVecVT = EVT::getVectorVT(Context, Int8VT, 2, true);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
278 // <2 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
279 auto SubFixedVecVT2xi8 = EVT::getVectorVT(Context, Int8VT, 2);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
280 SDValue FIPtr = DAG->CreateStackTemporary(VecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
281 int FI = cast<FrameIndexSDNode>(FIPtr.getNode())->getIndex();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
282 MachinePointerInfo PtrInfo = MachinePointerInfo::getFixedStack(*MF, FI);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
283 SDValue Value0 = DAG->getConstant(0, Loc, SubFixedVecVT2xi8);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
284 SDValue Value1 = DAG->getConstant(0, Loc, SubVecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
285 TypeSize Offset0 = TypeSize::Fixed(0);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
286 TypeSize Offset1 = SubFixedVecVT2xi8.getStoreSize();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
287 SDValue Index0 = DAG->getMemBasePlusOffset(FIPtr, Offset0, Loc);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
288 SDValue Index1 = DAG->getMemBasePlusOffset(FIPtr, Offset1, Loc);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
289 SDValue Store0 = DAG->getStore(DAG->getEntryNode(), Loc, Value0, Index0,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
290 PtrInfo.getWithOffset(Offset0));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
291 SDValue Store1 = DAG->getStore(DAG->getEntryNode(), Loc, Value1, Index1,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
292 PtrInfo.getWithOffset(Offset1));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
293 Optional<int64_t> NumBytes0 = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
294 cast<StoreSDNode>(Store0)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
295 Optional<int64_t> NumBytes1 = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
296 cast<StoreSDNode>(Store1)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
297
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
298 bool IsAlias;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
299 bool IsValid = BaseIndexOffset::computeAliasing(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
300 Store0.getNode(), NumBytes0, Store1.getNode(), NumBytes1, *DAG, IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
301 EXPECT_TRUE(IsValid);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
302 EXPECT_FALSE(IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
303
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
304 IsValid = BaseIndexOffset::computeAliasing(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
305 Store1.getNode(), NumBytes1, Store0.getNode(), NumBytes0, *DAG, IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
306 EXPECT_TRUE(IsValid);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
307 EXPECT_FALSE(IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
308 }
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
309
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
310 TEST_F(SelectionDAGAddressAnalysisTest, fixedSizeFrameObjectsOutOfDiff) {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
311 SDLoc Loc;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
312 auto Int8VT = EVT::getIntegerVT(Context, 8);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
313 // <vscale x 4 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
314 auto VecVT = EVT::getVectorVT(Context, Int8VT, 4, true);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
315 // <vscale x 2 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
316 auto SubVecVT = EVT::getVectorVT(Context, Int8VT, 2, true);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
317 // <2 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
318 auto SubFixedVecVT2xi8 = EVT::getVectorVT(Context, Int8VT, 2);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
319 // <4 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
320 auto SubFixedVecVT4xi8 = EVT::getVectorVT(Context, Int8VT, 4);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
321 SDValue FIPtr = DAG->CreateStackTemporary(VecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
322 int FI = cast<FrameIndexSDNode>(FIPtr.getNode())->getIndex();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
323 MachinePointerInfo PtrInfo = MachinePointerInfo::getFixedStack(*MF, FI);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
324 SDValue Value0 = DAG->getConstant(0, Loc, SubFixedVecVT4xi8);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
325 SDValue Value1 = DAG->getConstant(0, Loc, SubVecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
326 TypeSize Offset0 = TypeSize::Fixed(0);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
327 TypeSize Offset1 = SubFixedVecVT2xi8.getStoreSize();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
328 SDValue Index0 = DAG->getMemBasePlusOffset(FIPtr, Offset0, Loc);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
329 SDValue Index1 = DAG->getMemBasePlusOffset(FIPtr, Offset1, Loc);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
330 SDValue Store0 = DAG->getStore(DAG->getEntryNode(), Loc, Value0, Index0,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
331 PtrInfo.getWithOffset(Offset0));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
332 SDValue Store1 = DAG->getStore(DAG->getEntryNode(), Loc, Value1, Index1,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
333 PtrInfo.getWithOffset(Offset1));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
334 Optional<int64_t> NumBytes0 = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
335 cast<StoreSDNode>(Store0)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
336 Optional<int64_t> NumBytes1 = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
337 cast<StoreSDNode>(Store1)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
338
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
339 bool IsAlias;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
340 bool IsValid = BaseIndexOffset::computeAliasing(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
341 Store0.getNode(), NumBytes0, Store1.getNode(), NumBytes1, *DAG, IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
342 EXPECT_TRUE(IsValid);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
343 EXPECT_TRUE(IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
344 }
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
345
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
346 TEST_F(SelectionDAGAddressAnalysisTest, twoFixedStackObjects) {
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
347 SDLoc Loc;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
348 auto Int8VT = EVT::getIntegerVT(Context, 8);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
349 // <vscale x 2 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
350 auto VecVT = EVT::getVectorVT(Context, Int8VT, 2, true);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
351 // <2 x i8>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
352 auto FixedVecVT = EVT::getVectorVT(Context, Int8VT, 2);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
353 SDValue FIPtr0 = DAG->CreateStackTemporary(FixedVecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
354 SDValue FIPtr1 = DAG->CreateStackTemporary(VecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
355 int FI0 = cast<FrameIndexSDNode>(FIPtr0.getNode())->getIndex();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
356 int FI1 = cast<FrameIndexSDNode>(FIPtr1.getNode())->getIndex();
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
357 MachinePointerInfo PtrInfo0 = MachinePointerInfo::getFixedStack(*MF, FI0);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
358 MachinePointerInfo PtrInfo1 = MachinePointerInfo::getFixedStack(*MF, FI1);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
359 SDValue Value0 = DAG->getConstant(0, Loc, FixedVecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
360 SDValue Value1 = DAG->getConstant(0, Loc, VecVT);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
361 TypeSize Offset0 = TypeSize::Fixed(0);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
362 SDValue Index0 = DAG->getMemBasePlusOffset(FIPtr0, Offset0, Loc);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
363 SDValue Index1 = DAG->getMemBasePlusOffset(FIPtr1, Offset0, Loc);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
364 SDValue Store0 = DAG->getStore(DAG->getEntryNode(), Loc, Value0, Index0,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
365 PtrInfo0.getWithOffset(Offset0));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
366 SDValue Store1 = DAG->getStore(DAG->getEntryNode(), Loc, Value1, Index1,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
367 PtrInfo1.getWithOffset(Offset0));
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
368 Optional<int64_t> NumBytes0 = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
369 cast<StoreSDNode>(Store0)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
370 Optional<int64_t> NumBytes1 = MemoryLocation::getSizeOrUnknown(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
371 cast<StoreSDNode>(Store1)->getMemoryVT().getStoreSize());
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
372
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
373 bool IsAlias;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
374 bool IsValid = BaseIndexOffset::computeAliasing(
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
375 Store0.getNode(), NumBytes0, Store1.getNode(), NumBytes1, *DAG, IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
376 EXPECT_TRUE(IsValid);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
377 EXPECT_FALSE(IsAlias);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
378 }
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
379
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
380 } // end namespace llvm