From: weiyu Date: Wed, 27 Mar 2019 23:51:11 +0000 (-0700) Subject: complete merging X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=d71a52e6e9027b684797e93af926b2021a81cf40;p=c11llvm.git complete merging --- diff --git a/CDSPass.cpp b/CDSPass.cpp index 81d7d4e..a807928 100644 --- a/CDSPass.cpp +++ b/CDSPass.cpp @@ -1,8 +1,4 @@ -<<<<<<< HEAD //===-- CDSPass.cpp - xxx -------------------------------===// -======= -//===-- CdsPass.cpp - xxx -------------------------------===// ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec // // The LLVM Compiler Infrastructure // @@ -80,7 +76,6 @@ Type * Int64PtrTy; Type * VoidTy; -<<<<<<< HEAD Constant * CDSLoad[FUNCARRAYSIZE]; Constant * CDSStore[FUNCARRAYSIZE]; Constant * CDSAtomicLoad[FUNCARRAYSIZE]; @@ -90,15 +85,6 @@ Constant * CDSAtomicCAS[FUNCARRAYSIZE]; Constant * CDSAtomicThreadFence; bool start = false; -======= -Constant * CdsLoad[FUNCARRAYSIZE]; -Constant * CdsStore[FUNCARRAYSIZE]; -Constant * CdsAtomicLoad[FUNCARRAYSIZE]; -Constant * CdsAtomicStore[FUNCARRAYSIZE]; -Constant * CdsAtomicRMW[AtomicRMWInst::LAST_BINOP + 1][FUNCARRAYSIZE]; -Constant * CdsAtomicCAS[FUNCARRAYSIZE]; -Constant * CdsAtomicThreadFence; ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec int getAtomicOrderIndex(AtomicOrdering order){ switch (order) { @@ -147,15 +133,9 @@ static int sizetoindex(int size) { } namespace { -<<<<<<< HEAD struct CDSPass : public FunctionPass { static char ID; CDSPass() : FunctionPass(ID) {} -======= - struct CdsPass : public FunctionPass { - static char ID; - CdsPass() : FunctionPass(ID) {} ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec bool runOnFunction(Function &F) override; private: @@ -169,11 +149,7 @@ namespace { }; } -<<<<<<< HEAD void CDSPass::initializeCallbacks(Module &M) { -======= -void CdsPass::initializeCallbacks(Module &M) { ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec LLVMContext &Ctx = M.getContext(); Int8Ty = Type::getInt8Ty(Ctx); @@ -208,9 +184,6 @@ void CdsPass::initializeCallbacks(Module &M) { SmallString<32> AtomicLoadName("cds_atomic_load" + BitSizeStr); SmallString<32> AtomicStoreName("cds_atomic_store" + BitSizeStr); -<<<<<<< HEAD -// CDSLoad[i] = M.getOrInsertFunction(LoadName, Ty, PtrTy); -// CDSStore[i] = M.getOrInsertFunction(StoreName, VoidTy, PtrTy, Ty); CDSLoad[i] = M.getOrInsertFunction(LoadName, VoidTy, PtrTy); CDSStore[i] = M.getOrInsertFunction(StoreName, VoidTy, PtrTy); CDSAtomicLoad[i] = M.getOrInsertFunction(AtomicLoadName, Ty, PtrTy, OrdTy); @@ -218,17 +191,6 @@ void CdsPass::initializeCallbacks(Module &M) { for (int op = AtomicRMWInst::FIRST_BINOP; op <= AtomicRMWInst::LAST_BINOP; ++op) { CDSAtomicRMW[op][i] = nullptr; -======= -// CdsLoad[i] = M.getOrInsertFunction(LoadName, Ty, PtrTy); -// CdsStore[i] = M.getOrInsertFunction(StoreName, VoidTy, PtrTy, Ty); - CdsLoad[i] = M.getOrInsertFunction(LoadName, VoidTy, PtrTy); - CdsStore[i] = M.getOrInsertFunction(StoreName, VoidTy, PtrTy); - CdsAtomicLoad[i] = M.getOrInsertFunction(AtomicLoadName, Ty, PtrTy, OrdTy); - CdsAtomicStore[i] = M.getOrInsertFunction(AtomicStoreName, VoidTy, PtrTy, OrdTy, Ty); - - for (int op = AtomicRMWInst::FIRST_BINOP; op <= AtomicRMWInst::LAST_BINOP; ++op) { - CdsAtomicRMW[op][i] = nullptr; ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec std::string NamePart; if (op == AtomicRMWInst::Xchg) @@ -247,26 +209,15 @@ void CdsPass::initializeCallbacks(Module &M) { continue; SmallString<32> AtomicRMWName("cds_atomic" + NamePart + BitSizeStr); -<<<<<<< HEAD CDSAtomicRMW[op][i] = M.getOrInsertFunction(AtomicRMWName, Ty, PtrTy, OrdTy, Ty); -======= - CdsAtomicRMW[op][i] = M.getOrInsertFunction(AtomicRMWName, Ty, PtrTy, OrdTy, Ty); ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec } // only supportes strong version SmallString<32> AtomicCASName("cds_atomic_compare_exchange" + BitSizeStr); -<<<<<<< HEAD CDSAtomicCAS[i] = M.getOrInsertFunction(AtomicCASName, Ty, PtrTy, Ty, Ty, OrdTy, OrdTy); } CDSAtomicThreadFence = M.getOrInsertFunction("cds_atomic_thread_fence", VoidTy, OrdTy); -======= - CdsAtomicCAS[i] = M.getOrInsertFunction(AtomicCASName, Ty, PtrTy, Ty, Ty, OrdTy, OrdTy); - } - - CdsAtomicThreadFence = M.getOrInsertFunction("cds_atomic_thread_fence", VoidTy, OrdTy); ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec } static bool isVtableAccess(Instruction *I) { @@ -306,11 +257,7 @@ static bool shouldInstrumentReadWriteFromAddress(const Module *M, Value *Addr) { return true; } -<<<<<<< HEAD bool CDSPass::addrPointsToConstantData(Value *Addr) { -======= -bool CdsPass::addrPointsToConstantData(Value *Addr) { ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec // If this is a GEP, just analyze its pointer operand. if (GetElementPtrInst *GEP = dyn_cast(Addr)) Addr = GEP->getPointerOperand(); @@ -331,7 +278,6 @@ bool CdsPass::addrPointsToConstantData(Value *Addr) { return false; } -<<<<<<< HEAD bool CDSPass::runOnFunction(Function &F) { if (F.getName() == "main") { F.setName("user_main"); @@ -348,8 +294,8 @@ bool CDSPass::runOnFunction(Function &F) { bool Res = false; const DataLayout &DL = F.getParent()->getDataLayout(); - errs() << "Before\n"; - F.dump(); +// errs() << "Before\n"; +// F.dump(); for (auto &B : F) { for (auto &I : B) { @@ -365,71 +311,21 @@ bool CDSPass::runOnFunction(Function &F) { } for (auto Inst : AllLoadsAndStores) { -// Res |= instrumentLoadOrStore(Inst, DL); -// errs() << "load and store are not replaced\n"; + Res |= instrumentLoadOrStore(Inst, DL); +// errs() << "load and store are replaced\n"; } for (auto Inst : AtomicAccesses) { Res |= instrumentAtomic(Inst); } - - if (Res) { - errs() << F.getName(); - errs() << " has above instructions replaced\n"; - } } // errs() << "After\n"; // F.dump(); -======= -bool CdsPass::runOnFunction(Function &F) { - if (F.getName() == "main") - F.setName("user_main"); - - initializeCallbacks( *F.getParent() ); - - SmallVector AllLoadsAndStores; - SmallVector LocalLoadsAndStores; - SmallVector AtomicAccesses; - - std::vector worklist; - - bool Res = false; - const DataLayout &DL = F.getParent()->getDataLayout(); - - errs() << "Before\n"; - F.dump(); - - for (auto &B : F) { - for (auto &I : B) { - if ( (&I)->isAtomic() ) { - AtomicAccesses.push_back(&I); - } else if (isa(I) || isa(I)) { - LocalLoadsAndStores.push_back(&I); - } - } - chooseInstructionsToInstrument(LocalLoadsAndStores, AllLoadsAndStores, DL); - } - - for (auto Inst : AllLoadsAndStores) { - Res |= instrumentLoadOrStore(Inst, DL); - } - - for (auto Inst : AtomicAccesses) { - Res |= instrumentAtomic(Inst); - } - - errs() << "After\n"; - F.dump(); ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec return false; } -<<<<<<< HEAD void CDSPass::chooseInstructionsToInstrument( -======= -void CdsPass::chooseInstructionsToInstrument( ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec SmallVectorImpl &Local, SmallVectorImpl &All, const DataLayout &DL) { SmallPtrSet WriteTargets; @@ -472,11 +368,7 @@ void CdsPass::chooseInstructionsToInstrument( } -<<<<<<< HEAD bool CDSPass::instrumentLoadOrStore(Instruction *I, -======= -bool CdsPass::instrumentLoadOrStore(Instruction *I, ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec const DataLayout &DL) { IRBuilder<> IRB(I); bool IsWrite = isa(*I); @@ -493,11 +385,7 @@ bool CdsPass::instrumentLoadOrStore(Instruction *I, int size = getTypeSize(Addr->getType()); int index = sizetoindex(size); -<<<<<<< HEAD // not supported by CDS yet -======= -// not supported by Cds yet ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec /* if (IsWrite && isVtableAccess(I)) { LLVM_DEBUG(dbgs() << " VPTR : " << *I << "\n"); Value *StoredValue = cast(I)->getValueOperand(); @@ -526,7 +414,6 @@ bool CdsPass::instrumentLoadOrStore(Instruction *I, */ Value *OnAccessFunc = nullptr; -<<<<<<< HEAD OnAccessFunc = IsWrite ? CDSStore[index] : CDSLoad[index]; Type *ArgType = IRB.CreatePointerCast(Addr, Addr->getType())->getType(); @@ -538,10 +425,6 @@ bool CdsPass::instrumentLoadOrStore(Instruction *I, //errs() << " is passed in\n"; return false; // if other types of load or stores are passed in } -======= - OnAccessFunc = IsWrite ? CdsStore[index] : CdsLoad[index]; - ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec IRB.CreateCall(OnAccessFunc, IRB.CreatePointerCast(Addr, Addr->getType())); if (IsWrite) NumInstrumentedWrites++; else NumInstrumentedReads++; @@ -549,11 +432,7 @@ bool CdsPass::instrumentLoadOrStore(Instruction *I, } -<<<<<<< HEAD bool CDSPass::instrumentAtomic(Instruction * I) { -======= -bool CdsPass::instrumentAtomic(Instruction * I) { ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec IRBuilder<> IRB(I); // LLVMContext &Ctx = IRB.getContext(); @@ -568,11 +447,7 @@ bool CdsPass::instrumentAtomic(Instruction * I) { int size=getTypeSize(ptr->getType()); int index=sizetoindex(size); -<<<<<<< HEAD Instruction* funcInst=CallInst::Create(CDSAtomicStore[index], args,""); -======= - Instruction* funcInst=CallInst::Create(CdsAtomicStore[index], args,""); ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec ReplaceInstWithInst(SI, funcInst); errs() << "Store replaced\n"; } else if (LoadInst *LI = dyn_cast(I)) { @@ -585,11 +460,7 @@ bool CdsPass::instrumentAtomic(Instruction * I) { int size=getTypeSize(ptr->getType()); int index=sizetoindex(size); -<<<<<<< HEAD Instruction* funcInst=CallInst::Create(CDSAtomicLoad[index], args, ""); -======= - Instruction* funcInst=CallInst::Create(CdsAtomicLoad[index], args, ""); ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec ReplaceInstWithInst(LI, funcInst); errs() << "Load Replaced\n"; } else if (AtomicRMWInst *RMWI = dyn_cast(I)) { @@ -603,11 +474,7 @@ bool CdsPass::instrumentAtomic(Instruction * I) { int size = getTypeSize(ptr->getType()); int index = sizetoindex(size); -<<<<<<< HEAD Instruction* funcInst = CallInst::Create(CDSAtomicRMW[RMWI->getOperation()][index], args, ""); -======= - Instruction* funcInst = CallInst::Create(CdsAtomicRMW[RMWI->getOperation()][index], args, ""); ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec ReplaceInstWithInst(RMWI, funcInst); errs() << RMWI->getOperationName(RMWI->getOperation()); errs() << " replaced\n"; @@ -635,11 +502,7 @@ bool CdsPass::instrumentAtomic(Instruction * I) { CmpOperand, NewOperand, order_succ, order_fail}; -<<<<<<< HEAD CallInst *funcInst = IRB.CreateCall(CDSAtomicCAS[index], Args); -======= - CallInst *funcInst = IRB.CreateCall(CdsAtomicCAS[index], Args); ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec Value *Success = IRB.CreateICmpEQ(funcInst, CmpOperand); Value *OldVal = funcInst; @@ -660,11 +523,7 @@ bool CdsPass::instrumentAtomic(Instruction * I) { Value *order = ConstantInt::get(OrdTy, atomic_order_index); Value *Args[] = {order}; -<<<<<<< HEAD CallInst *funcInst = CallInst::Create(CDSAtomicThreadFence, Args); -======= - CallInst *funcInst = CallInst::Create(CdsAtomicThreadFence, Args); ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec ReplaceInstWithInst(FI, funcInst); errs() << "Thread Fences replaced\n"; } @@ -673,7 +532,6 @@ bool CdsPass::instrumentAtomic(Instruction * I) { -<<<<<<< HEAD char CDSPass::ID = 0; // Automatically enable the pass. @@ -685,16 +543,3 @@ static void registerCDSPass(const PassManagerBuilder &, static RegisterStandardPasses RegisterMyPass(PassManagerBuilder::EP_EarlyAsPossible, registerCDSPass); -======= -char CdsPass::ID = 0; - -// Automatically enable the pass. -// http://adriansampson.net/blog/clangpass.html -static void registerCdsPass(const PassManagerBuilder &, - legacy::PassManagerBase &PM) { - PM.add(new CdsPass()); -} -static RegisterStandardPasses - RegisterMyPass(PassManagerBuilder::EP_EarlyAsPossible, -registerCdsPass); ->>>>>>> 0d737ead79278a1a67c5829f9c6bf84ee6a90cec