[cfe-commits] r139789 - /cfe/trunk/lib/Basic/Targets.cpp
Justin Holewinski
justin.holewinski at gmail.com
Thu Sep 15 05:13:38 PDT 2011
Author: jholewinski
Date: Thu Sep 15 07:13:38 2011
New Revision: 139789
URL: http://llvm.org/viewvc/llvm-project?rev=139789&view=rev
Log:
PTX: Define target options
Modified:
cfe/trunk/lib/Basic/Targets.cpp
Modified: cfe/trunk/lib/Basic/Targets.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Basic/Targets.cpp?rev=139789&r1=139788&r2=139789&view=diff
==============================================================================
--- cfe/trunk/lib/Basic/Targets.cpp (original)
+++ cfe/trunk/lib/Basic/Targets.cpp Thu Sep 15 07:13:38 2011
@@ -916,6 +916,10 @@
// FIXME: implement
return "typedef char* __builtin_va_list;";
}
+
+ virtual bool setFeatureEnabled(llvm::StringMap<bool> &Features,
+ const std::string &Name,
+ bool Enabled) const;
};
const Builtin::Info PTXTargetInfo::BuiltinInfo[] = {
@@ -935,6 +939,91 @@
NumNames = llvm::array_lengthof(GCCRegNames);
}
+ bool PTXTargetInfo::setFeatureEnabled(llvm::StringMap<bool> &Features,
+ const std::string &Name,
+ bool Enabled) const {
+ if (Enabled) {
+ if (Name == "double")
+ Features["double"] = true;
+ else if (Name == "no-fma")
+ Features["no-fma"] = true;
+ else if (Name == "compute10")
+ Features["compute10"] = true;
+ else if (Name == "compute11")
+ Features["compute11"] = true;
+ else if (Name == "compute12")
+ Features["compute12"] = true;
+ else if (Name == "compute13")
+ Features["compute13"] = true;
+ else if (Name == "compute20")
+ Features["compute20"] = true;
+ else if (Name == "ptx20")
+ Features["ptx20"] = true;
+ else if (Name == "ptx21")
+ Features["ptx21"] = true;
+ else if (Name == "ptx22")
+ Features["ptx22"] = true;
+ else if (Name == "ptx23")
+ Features["ptx23"] = true;
+ else if (Name == "sm10")
+ Features["sm10"] = true;
+ else if (Name == "sm11")
+ Features["sm11"] = true;
+ else if (Name == "sm12")
+ Features["sm12"] = true;
+ else if (Name == "sm13")
+ Features["sm13"] = true;
+ else if (Name == "sm20")
+ Features["sm20"] = true;
+ else if (Name == "sm21")
+ Features["sm21"] = true;
+ else if (Name == "sm22")
+ Features["sm22"] = true;
+ else if (Name == "sm23")
+ Features["sm23"] = true;
+ } else {
+ if (Name == "double")
+ Features["double"] = false;
+ else if (Name == "no-fma")
+ Features["no-fma"] = false;
+ else if (Name == "compute10")
+ Features["compute10"] = false;
+ else if (Name == "compute11")
+ Features["compute11"] = false;
+ else if (Name == "compute12")
+ Features["compute12"] = false;
+ else if (Name == "compute13")
+ Features["compute13"] = false;
+ else if (Name == "compute20")
+ Features["compute20"] = false;
+ else if (Name == "ptx20")
+ Features["ptx20"] = false;
+ else if (Name == "ptx21")
+ Features["ptx21"] = false;
+ else if (Name == "ptx22")
+ Features["ptx22"] = false;
+ else if (Name == "ptx23")
+ Features["ptx23"] = false;
+ else if (Name == "sm10")
+ Features["sm10"] = false;
+ else if (Name == "sm11")
+ Features["sm11"] = false;
+ else if (Name == "sm12")
+ Features["sm12"] = false;
+ else if (Name == "sm13")
+ Features["sm13"] = false;
+ else if (Name == "sm20")
+ Features["sm20"] = false;
+ else if (Name == "sm21")
+ Features["sm21"] = false;
+ else if (Name == "sm22")
+ Features["sm22"] = false;
+ else if (Name == "sm23")
+ Features["sm23"] = false;
+ }
+
+ return true;
+ }
class PTX32TargetInfo : public PTXTargetInfo {
public:
More information about the cfe-commits
mailing list