summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target
diff options
context:
space:
mode:
authorChe-Liang Chiou <clchiou@gmail.com>2010-11-30 10:14:14 +0000
committerChe-Liang Chiou <clchiou@gmail.com>2010-11-30 10:14:14 +0000
commite9baf136574a0877f7ccfaed36933d67281e9076 (patch)
tree2bffe1d7eea6ede620852aeaa77122a2d71af2b7 /llvm/lib/Target
parent824fd1dcff88353a7b9754db28bcbc4d6d0cbed5 (diff)
downloadbcm5719-llvm-e9baf136574a0877f7ccfaed36933d67281e9076.tar.gz
bcm5719-llvm-e9baf136574a0877f7ccfaed36933d67281e9076.zip
ptx: add command-line options for gpu target and ptx version
llvm-svn: 120423
Diffstat (limited to 'llvm/lib/Target')
-rw-r--r--llvm/lib/Target/PTX/PTXAsmPrinter.cpp18
1 files changed, 18 insertions, 0 deletions
diff --git a/llvm/lib/Target/PTX/PTXAsmPrinter.cpp b/llvm/lib/Target/PTX/PTXAsmPrinter.cpp
index 03f177b2fa8..8fb1f53d2b5 100644
--- a/llvm/lib/Target/PTX/PTXAsmPrinter.cpp
+++ b/llvm/lib/Target/PTX/PTXAsmPrinter.cpp
@@ -27,12 +27,21 @@
#include "llvm/MC/MCSymbol.h"
#include "llvm/Target/TargetLoweringObjectFile.h"
#include "llvm/Target/TargetRegistry.h"
+#include "llvm/Support/CommandLine.h"
#include "llvm/Support/Debug.h"
#include "llvm/Support/ErrorHandling.h"
#include "llvm/Support/raw_ostream.h"
using namespace llvm;
+static cl::opt<std::string>
+OptPTXVersion("ptx-version", cl::desc("Set PTX version"),
+ cl::init("1.4"));
+
+static cl::opt<std::string>
+OptPTXTarget("ptx-target", cl::desc("Set GPU target (comma-separated list)"),
+ cl::init("sm_10"));
+
namespace {
class PTXAsmPrinter : public AsmPrinter {
public:
@@ -41,6 +50,8 @@ public:
const char *getPassName() const { return "PTX Assembly Printer"; }
+ virtual void EmitStartOfAsmFile(Module &M);
+
virtual bool runOnMachineFunction(MachineFunction &MF);
virtual void EmitFunctionBodyStart();
@@ -85,6 +96,13 @@ static const char *getInstructionTypeName(const MachineInstr *MI) {
return NULL;
}
+void PTXAsmPrinter::EmitStartOfAsmFile(Module &M)
+{
+ OutStreamer.EmitRawText(Twine("\t.version " + OptPTXVersion));
+ OutStreamer.EmitRawText(Twine("\t.target " + OptPTXTarget));
+ OutStreamer.AddBlankLine();
+}
+
bool PTXAsmPrinter::runOnMachineFunction(MachineFunction &MF) {
SetupMachineFunction(MF);
EmitFunctionDeclaration();
OpenPOWER on IntegriCloud