mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
Add -sse[,2,3] arguments to LLC
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@16018 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
47d2f2bb50
commit
6f0161aac3
@ -23,6 +23,12 @@ class TargetMachine;
|
|||||||
class FunctionPass;
|
class FunctionPass;
|
||||||
class IntrinsicLowering;
|
class IntrinsicLowering;
|
||||||
|
|
||||||
|
enum X86VectorEnum {
|
||||||
|
NoSSE, SSE, SSE2, SSE3
|
||||||
|
};
|
||||||
|
|
||||||
|
extern X86VectorEnum X86Vector;
|
||||||
|
|
||||||
/// createX86SimpleInstructionSelector - This pass converts an LLVM function
|
/// createX86SimpleInstructionSelector - This pass converts an LLVM function
|
||||||
/// into a machine code representation in a very simple peep-hole fashion. The
|
/// into a machine code representation in a very simple peep-hole fashion. The
|
||||||
/// generated code sucks but the implementation is nice and simple.
|
/// generated code sucks but the implementation is nice and simple.
|
||||||
|
@ -25,6 +25,8 @@
|
|||||||
#include "Support/Statistic.h"
|
#include "Support/Statistic.h"
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
|
X86VectorEnum llvm::X86Vector = NoSSE;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
cl::opt<bool> NoSSAPeephole("disable-ssa-peephole", cl::init(true),
|
cl::opt<bool> NoSSAPeephole("disable-ssa-peephole", cl::init(true),
|
||||||
cl::desc("Disable the ssa-based peephole optimizer "
|
cl::desc("Disable the ssa-based peephole optimizer "
|
||||||
@ -33,6 +35,18 @@ namespace {
|
|||||||
cl::desc("Disable the X86 asm printer, for use "
|
cl::desc("Disable the X86 asm printer, for use "
|
||||||
"when profiling the code generator."));
|
"when profiling the code generator."));
|
||||||
|
|
||||||
|
// FIXME: This should eventually be handled with target triples and
|
||||||
|
// subtarget support!
|
||||||
|
cl::opt<X86VectorEnum, true>
|
||||||
|
SSEArg(
|
||||||
|
cl::desc("Enable SSE support in the X86 target:"),
|
||||||
|
cl::values(
|
||||||
|
clEnumValN(SSE, "sse", " Enable SSE support"),
|
||||||
|
clEnumValN(SSE2, "sse2", " Enable SSE and SSE2 support"),
|
||||||
|
clEnumValN(SSE3, "sse3", " Enable SSE, SSE2, and SSE3 support"),
|
||||||
|
clEnumValEnd),
|
||||||
|
cl::location(X86Vector), cl::init(NoSSE));
|
||||||
|
|
||||||
// Register the target.
|
// Register the target.
|
||||||
RegisterTarget<X86TargetMachine> X("x86", " IA-32 (Pentium and above)");
|
RegisterTarget<X86TargetMachine> X("x86", " IA-32 (Pentium and above)");
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user