Mercurial > hg > Members > tobaru > cbc > CbC_llvm
view lib/Target/NVPTX/NVPTXLowerAggrCopies.h @ 33:e4204d083e25
LLVM 3.5
author | Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp> |
---|---|
date | Thu, 12 Dec 2013 14:32:10 +0900 |
parents | 95c75e76d11b |
children | 54457678186b |
line wrap: on
line source
//===-- llvm/lib/Target/NVPTX/NVPTXLowerAggrCopies.h ------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This file contains the declaration of the NVIDIA specific lowering of // aggregate copies // //===----------------------------------------------------------------------===// #ifndef NVPTX_LOWER_AGGR_COPIES_H #define NVPTX_LOWER_AGGR_COPIES_H #include "llvm/CodeGen/MachineFunctionAnalysis.h" #include "llvm/IR/DataLayout.h" #include "llvm/Pass.h" namespace llvm { // actual analysis class, which is a functionpass struct NVPTXLowerAggrCopies : public FunctionPass { static char ID; NVPTXLowerAggrCopies() : FunctionPass(ID) {} void getAnalysisUsage(AnalysisUsage &AU) const { AU.addRequired<DataLayout>(); AU.addPreserved<MachineFunctionAnalysis>(); } virtual bool runOnFunction(Function &F); static const unsigned MaxAggrCopySize = 128; virtual const char *getPassName() const { return "Lower aggregate copies/intrinsics into loops"; } }; extern FunctionPass *createLowerAggrCopies(); } #endif