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 | |
| 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')
| -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(); | 

