2005-09-29 22:54:56 +00:00
|
|
|
//===- AlphaSubtarget.cpp - Alpha Subtarget Information ---------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file was developed by Andrew Lenharth and is distributed under the
|
|
|
|
// University of Illinois Open Source License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file implements the Alpha specific subclass of TargetSubtarget.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "AlphaSubtarget.h"
|
|
|
|
#include "Alpha.h"
|
|
|
|
#include "llvm/Module.h"
|
|
|
|
#include "llvm/Support/CommandLine.h"
|
|
|
|
#include "llvm/Target/SubtargetFeature.h"
|
2005-09-30 20:24:38 +00:00
|
|
|
#include "llvm/Support/Debug.h"
|
2005-09-29 22:54:56 +00:00
|
|
|
|
|
|
|
using namespace llvm;
|
|
|
|
|
2005-09-30 20:24:38 +00:00
|
|
|
enum AlphaFeature {
|
|
|
|
AlphaFeatureCIX = 1 << 0,
|
|
|
|
AlphaFeatureFIX = 1 << 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
/// Sorted (by key) array of values for CPU subtype.
|
|
|
|
static const SubtargetFeatureKV AlphaSubTypeKV[] = {
|
|
|
|
{ "ev56" , "Select the Alpha EV56 processor", 0 },
|
|
|
|
{ "ev6" , "Select the Alpha EV6 processor", AlphaFeatureFIX },
|
|
|
|
{ "ev67" , "Select the Alpha EV67 processor", AlphaFeatureFIX | AlphaFeatureCIX },
|
2005-10-02 07:13:52 +00:00
|
|
|
{ "generic", "Select instructions for a generic Alpha processor (EV56)", 0 },
|
2005-09-30 20:24:38 +00:00
|
|
|
{ "pca56" , "Select the Alpha PCA56 processor", 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
/// Length of AlphaSubTypeKV.
|
|
|
|
static const unsigned AlphaSubTypeKVSize = sizeof(AlphaSubTypeKV)
|
|
|
|
/ sizeof(SubtargetFeatureKV);
|
|
|
|
|
|
|
|
/// Sorted (by key) array of values for CPU features.
|
|
|
|
static SubtargetFeatureKV AlphaFeatureKV[] = {
|
2005-10-02 07:13:52 +00:00
|
|
|
{ "CIX", "Should CIX extentions be used" , AlphaFeatureCIX },
|
2005-09-30 20:24:38 +00:00
|
|
|
{ "FIX" , "Should FIX extentions be used" , AlphaFeatureFIX },
|
|
|
|
};
|
|
|
|
/// Length of AlphaFeatureKV.
|
|
|
|
static const unsigned AlphaFeatureKVSize = sizeof(AlphaFeatureKV)
|
|
|
|
/ sizeof(SubtargetFeatureKV);
|
2005-09-29 22:54:56 +00:00
|
|
|
|
|
|
|
AlphaSubtarget::AlphaSubtarget(const Module &M, const std::string &FS)
|
|
|
|
:HasF2I(false), HasCT(false)
|
|
|
|
{
|
2005-09-30 20:24:38 +00:00
|
|
|
std::string CPU = "generic";
|
|
|
|
uint32_t Bits =
|
|
|
|
SubtargetFeatures::Parse(FS, CPU,
|
|
|
|
AlphaSubTypeKV, AlphaSubTypeKVSize,
|
|
|
|
AlphaFeatureKV, AlphaFeatureKVSize);
|
|
|
|
HasF2I = (Bits & AlphaFeatureFIX) != 0;
|
|
|
|
HasCT = (Bits & AlphaFeatureCIX) != 0;
|
|
|
|
|
2005-09-29 22:54:56 +00:00
|
|
|
}
|