mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-07 11:51:13 +00:00
214b27286d
CodeGenDAGPatterns, where it can be used in other tablegen backends. This allows the inference to be done for DAGISelEmitter so that it gets accurate mayLoad/mayStore/isSimpleLoad flags. This brings MemOperand functionality back to where it was before 48329. However, it doesn't solve the problem of anonymous patterns which expand to code that does loads or stores. llvm-svn: 49123
61 lines
2.0 KiB
C++
61 lines
2.0 KiB
C++
//===- CodeGenIntrinsic.h - Intrinsic Class Wrapper ------------*- C++ -*--===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file defines a wrapper class for the 'Intrinsic' TableGen class.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef CODEGEN_INTRINSIC_H
|
|
#define CODEGEN_INTRINSIC_H
|
|
|
|
#include <string>
|
|
#include <vector>
|
|
#include "llvm/CodeGen/ValueTypes.h"
|
|
|
|
namespace llvm {
|
|
class Record;
|
|
class RecordKeeper;
|
|
class CodeGenTarget;
|
|
|
|
struct CodeGenIntrinsic {
|
|
Record *TheDef; // The actual record defining this intrinsic.
|
|
std::string Name; // The name of the LLVM function "llvm.bswap.i32"
|
|
std::string EnumName; // The name of the enum "bswap_i32"
|
|
std::string GCCBuiltinName;// Name of the corresponding GCC builtin, or "".
|
|
std::string TargetPrefix; // Target prefix, e.g. "ppc" for t-s intrinsics.
|
|
|
|
/// ArgVTs - The MVT::ValueType for each argument type. Note that this list
|
|
/// is only populated when in the context of a target .td file. When
|
|
/// building Intrinsics.td, this isn't available, because we don't know the
|
|
/// target pointer size.
|
|
std::vector<MVT::ValueType> ArgVTs;
|
|
|
|
/// ArgTypeDefs - The records for each argument type.
|
|
///
|
|
std::vector<Record*> ArgTypeDefs;
|
|
|
|
// Memory mod/ref behavior of this intrinsic.
|
|
enum {
|
|
NoMem, ReadArgMem, ReadMem, WriteArgMem, WriteMem
|
|
} ModRef;
|
|
|
|
// This is set to true if the intrinsic is overloaded by its argument
|
|
// types.
|
|
bool isOverloaded;
|
|
|
|
CodeGenIntrinsic(Record *R);
|
|
};
|
|
|
|
/// LoadIntrinsics - Read all of the intrinsics defined in the specified
|
|
/// .td file.
|
|
std::vector<CodeGenIntrinsic> LoadIntrinsics(const RecordKeeper &RC);
|
|
}
|
|
|
|
#endif
|