diff options
| author | Che-Liang Chiou <clchiou@gmail.com> | 2010-11-30 10:14:14 +0000 |
|---|---|---|
| committer | Che-Liang Chiou <clchiou@gmail.com> | 2010-11-30 10:14:14 +0000 |
| commit | e9baf136574a0877f7ccfaed36933d67281e9076 (patch) | |
| tree | 2bffe1d7eea6ede620852aeaa77122a2d71af2b7 /llvm/lib/Target | |
| parent | 824fd1dcff88353a7b9754db28bcbc4d6d0cbed5 (diff) | |
| download | bcm5719-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.cpp | 18 |
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(); |

