summaryrefslogtreecommitdiffstats
path: root/llvm/utils/TableGen/IntrinsicEmitter.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2006-03-13 23:08:44 +0000
committerChris Lattner <sabre@nondot.org>2006-03-13 23:08:44 +0000
commitfea17a9901aac9c1fdd24afa6eadc01cf629f47e (patch)
tree8ce4f044d65e95f8374d46ff15c99a28d23389e9 /llvm/utils/TableGen/IntrinsicEmitter.cpp
parent5b6ec4a5eaa3ba36efffa914de20d0453c6fe053 (diff)
downloadbcm5719-llvm-fea17a9901aac9c1fdd24afa6eadc01cf629f47e.tar.gz
bcm5719-llvm-fea17a9901aac9c1fdd24afa6eadc01cf629f47e.zip
emit a mapping from LLVM intrinsic -> GCC builtins.
llvm-svn: 26736
Diffstat (limited to 'llvm/utils/TableGen/IntrinsicEmitter.cpp')
-rw-r--r--llvm/utils/TableGen/IntrinsicEmitter.cpp33
1 files changed, 26 insertions, 7 deletions
diff --git a/llvm/utils/TableGen/IntrinsicEmitter.cpp b/llvm/utils/TableGen/IntrinsicEmitter.cpp
index 9396bdfe6e5..074a8dbfc86 100644
--- a/llvm/utils/TableGen/IntrinsicEmitter.cpp
+++ b/llvm/utils/TableGen/IntrinsicEmitter.cpp
@@ -33,6 +33,7 @@ CodeGenIntrinsic::CodeGenIntrinsic(Record *R) {
std::string(DefName.begin(), DefName.begin()+4) != "int_")
throw "Intrinsic '" + DefName + "' does not start with 'int_'!";
EnumName = std::string(DefName.begin()+4, DefName.end());
+ GCCBuiltinName = R->getValueAsString("GCCBuiltinName");
Name = R->getValueAsString("LLVMName");
if (Name == "") {
@@ -105,6 +106,9 @@ void IntrinsicEmitter::run(std::ostream &OS) {
// Emit side effect info for each function.
EmitSideEffectInfo(Ints, OS);
+
+ // Emit a list of intrinsics with corresponding GCC builtins.
+ EmitGCCBuiltinList(Ints, OS);
}
void IntrinsicEmitter::EmitEnumInfo(const std::vector<CodeGenIntrinsic> &Ints,
@@ -221,16 +225,31 @@ EmitSideEffectInfo(const std::vector<CodeGenIntrinsic> &Ints, std::ostream &OS){
OS << " default: break;\n";
for (unsigned i = 0, e = Ints.size(); i != e; ++i) {
switch (Ints[i].ModRef) {
- default: break;
- case CodeGenIntrinsic::NoMem:
- case CodeGenIntrinsic::ReadArgMem:
- case CodeGenIntrinsic::ReadMem:
- OS << " case Intrinsic::" << Ints[i].EnumName << ":\n";
- break;
+ default: break;
+ case CodeGenIntrinsic::NoMem:
+ case CodeGenIntrinsic::ReadArgMem:
+ case CodeGenIntrinsic::ReadMem:
+ OS << " case Intrinsic::" << Ints[i].EnumName << ":\n";
+ break;
}
}
OS << " return true; // These intrinsics have no side effects.\n";
OS << " }\n";
OS << "#endif\n\n";
-
}
+
+void IntrinsicEmitter::
+EmitGCCBuiltinList(const std::vector<CodeGenIntrinsic> &Ints, std::ostream &OS){
+ OS << "// Get the GCC builtin that corresponds to an LLVM intrinsic.\n";
+ OS << "#ifdef GET_GCC_BUILTIN_NAME\n";
+ OS << " switch (F->getIntrinsicID()) {\n";
+ OS << " default: BuiltinName = \"\"; break;\n";
+ for (unsigned i = 0, e = Ints.size(); i != e; ++i) {
+ if (!Ints[i].GCCBuiltinName.empty()) {
+ OS << " case Intrinsic::" << Ints[i].EnumName << ": BuiltinName = \""
+ << Ints[i].GCCBuiltinName << "\"; break;\n";
+ }
+ }
+ OS << " }\n";
+ OS << "#endif\n\n";
+} \ No newline at end of file
OpenPOWER on IntegriCloud