annotate llvm/unittests/Analysis/TBAATest.cpp @ 236:c4bab56944e8 llvm-original

LLVM 16
author kono
date Wed, 09 Nov 2022 17:45:10 +0900
parents 1d019706d866
children 1f2b6ac9f198
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 //===--- TBAATest.cpp - Mixed TBAA unit tests -----------------------------===//
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 #include "llvm/Analysis/AliasAnalysisEvaluator.h"
anatofuz
parents:
diff changeset
10 #include "llvm/Analysis/Passes.h"
anatofuz
parents:
diff changeset
11 #include "llvm/IR/Constants.h"
anatofuz
parents:
diff changeset
12 #include "llvm/IR/Instructions.h"
anatofuz
parents:
diff changeset
13 #include "llvm/IR/LLVMContext.h"
anatofuz
parents:
diff changeset
14 #include "llvm/IR/LegacyPassManager.h"
anatofuz
parents:
diff changeset
15 #include "llvm/IR/MDBuilder.h"
anatofuz
parents:
diff changeset
16 #include "llvm/IR/Module.h"
anatofuz
parents:
diff changeset
17 #include "llvm/IR/Verifier.h"
anatofuz
parents:
diff changeset
18 #include "llvm/Support/CommandLine.h"
anatofuz
parents:
diff changeset
19 #include "gtest/gtest.h"
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 namespace llvm {
anatofuz
parents:
diff changeset
22 namespace {
anatofuz
parents:
diff changeset
23
anatofuz
parents:
diff changeset
24 class TBAATest : public testing::Test {
anatofuz
parents:
diff changeset
25 protected:
anatofuz
parents:
diff changeset
26 TBAATest() : M("TBAATest", C), MD(C) {}
anatofuz
parents:
diff changeset
27
anatofuz
parents:
diff changeset
28 LLVMContext C;
anatofuz
parents:
diff changeset
29 Module M;
anatofuz
parents:
diff changeset
30 MDBuilder MD;
anatofuz
parents:
diff changeset
31 };
anatofuz
parents:
diff changeset
32
anatofuz
parents:
diff changeset
33 static StoreInst *getFunctionWithSingleStore(Module *M, StringRef Name) {
anatofuz
parents:
diff changeset
34 auto &C = M->getContext();
anatofuz
parents:
diff changeset
35 FunctionType *FTy = FunctionType::get(Type::getVoidTy(C), {});
anatofuz
parents:
diff changeset
36 auto *F = Function::Create(FTy, Function::ExternalLinkage, Name, M);
anatofuz
parents:
diff changeset
37 auto *BB = BasicBlock::Create(C, "entry", F);
anatofuz
parents:
diff changeset
38 auto *IntType = Type::getInt32Ty(C);
anatofuz
parents:
diff changeset
39 auto *PtrType = Type::getInt32PtrTy(C);
anatofuz
parents:
diff changeset
40 auto *SI = new StoreInst(ConstantInt::get(IntType, 42),
anatofuz
parents:
diff changeset
41 ConstantPointerNull::get(PtrType), BB);
anatofuz
parents:
diff changeset
42 ReturnInst::Create(C, nullptr, BB);
anatofuz
parents:
diff changeset
43
anatofuz
parents:
diff changeset
44 return SI;
anatofuz
parents:
diff changeset
45 }
anatofuz
parents:
diff changeset
46
anatofuz
parents:
diff changeset
47 TEST_F(TBAATest, checkVerifierBehaviorForOldTBAA) {
anatofuz
parents:
diff changeset
48 auto *SI = getFunctionWithSingleStore(&M, "f1");
anatofuz
parents:
diff changeset
49 auto *F = SI->getFunction();
anatofuz
parents:
diff changeset
50
anatofuz
parents:
diff changeset
51 // C++ unit test case to avoid going through the auto upgrade logic.
anatofuz
parents:
diff changeset
52 auto *RootMD = MD.createTBAARoot("Simple C/C++ TBAA");
anatofuz
parents:
diff changeset
53 auto *MD1 = MD.createTBAANode("omnipotent char", RootMD);
anatofuz
parents:
diff changeset
54 auto *MD2 = MD.createTBAANode("int", MD1);
anatofuz
parents:
diff changeset
55 SI->setMetadata(LLVMContext::MD_tbaa, MD2);
anatofuz
parents:
diff changeset
56
anatofuz
parents:
diff changeset
57 SmallVector<char, 0> ErrorMsg;
anatofuz
parents:
diff changeset
58 raw_svector_ostream Outs(ErrorMsg);
anatofuz
parents:
diff changeset
59
anatofuz
parents:
diff changeset
60 StringRef ExpectedFailureMsg(
anatofuz
parents:
diff changeset
61 "Old-style TBAA is no longer allowed, use struct-path TBAA instead");
anatofuz
parents:
diff changeset
62
anatofuz
parents:
diff changeset
63 EXPECT_TRUE(verifyFunction(*F, &Outs));
anatofuz
parents:
diff changeset
64 EXPECT_TRUE(StringRef(ErrorMsg.begin(), ErrorMsg.size())
anatofuz
parents:
diff changeset
65 .startswith(ExpectedFailureMsg));
anatofuz
parents:
diff changeset
66 }
anatofuz
parents:
diff changeset
67
anatofuz
parents:
diff changeset
68 TEST_F(TBAATest, checkTBAAMerging) {
anatofuz
parents:
diff changeset
69 auto *SI = getFunctionWithSingleStore(&M, "f2");
anatofuz
parents:
diff changeset
70 auto *F = SI->getFunction();
anatofuz
parents:
diff changeset
71
anatofuz
parents:
diff changeset
72 auto *RootMD = MD.createTBAARoot("tbaa-root");
anatofuz
parents:
diff changeset
73 auto *MD1 = MD.createTBAANode("scalar-a", RootMD);
anatofuz
parents:
diff changeset
74 auto *StructTag1 = MD.createTBAAStructTagNode(MD1, MD1, 0);
anatofuz
parents:
diff changeset
75 auto *MD2 = MD.createTBAANode("scalar-b", RootMD);
anatofuz
parents:
diff changeset
76 auto *StructTag2 = MD.createTBAAStructTagNode(MD2, MD2, 0);
anatofuz
parents:
diff changeset
77
anatofuz
parents:
diff changeset
78 auto *GenericMD = MDNode::getMostGenericTBAA(StructTag1, StructTag2);
anatofuz
parents:
diff changeset
79
anatofuz
parents:
diff changeset
80 EXPECT_EQ(GenericMD, nullptr);
anatofuz
parents:
diff changeset
81
anatofuz
parents:
diff changeset
82 // Despite GenericMD being nullptr, we expect the setMetadata call to be well
anatofuz
parents:
diff changeset
83 // defined and produce a well-formed function.
anatofuz
parents:
diff changeset
84 SI->setMetadata(LLVMContext::MD_tbaa, GenericMD);
anatofuz
parents:
diff changeset
85
anatofuz
parents:
diff changeset
86 EXPECT_TRUE(!verifyFunction(*F));
anatofuz
parents:
diff changeset
87 }
anatofuz
parents:
diff changeset
88
anatofuz
parents:
diff changeset
89 } // end anonymous namspace
anatofuz
parents:
diff changeset
90 } // end llvm namespace