blob: 3cbdcb269b28b14ba6aff5208c9bdc832c9265f6 [file] [log] [blame]
Andrew Lenharth120ab482005-09-29 22:54:56 +00001//===- AlphaSubtarget.cpp - Alpha Subtarget Information ---------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file was developed by Andrew Lenharth and is distributed under the
6// University of Illinois Open Source License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file implements the Alpha specific subclass of TargetSubtarget.
11//
12//===----------------------------------------------------------------------===//
13
14#include "AlphaSubtarget.h"
15#include "Alpha.h"
16#include "llvm/Module.h"
17#include "llvm/Support/CommandLine.h"
18#include "llvm/Target/SubtargetFeature.h"
Chris Lattnered465f52005-10-23 22:15:34 +000019#include "AlphaGenSubtarget.inc"
Andrew Lenharth120ab482005-09-29 22:54:56 +000020using namespace llvm;
21
Chris Lattnered465f52005-10-23 22:15:34 +000022
23enum {
24 FeatureKVSize = sizeof(FeatureKV) / sizeof(SubtargetFeatureKV),
25 SubTypeKVSize = sizeof(SubTypeKV) / sizeof(SubtargetFeatureKV)
Andrew Lenharthac35cd22005-09-30 20:24:38 +000026};
27
Andrew Lenharth120ab482005-09-29 22:54:56 +000028AlphaSubtarget::AlphaSubtarget(const Module &M, const std::string &FS)
Chris Lattnered465f52005-10-23 22:15:34 +000029 : HasF2I(false), HasCT(false) {
Andrew Lenharthac35cd22005-09-30 20:24:38 +000030 std::string CPU = "generic";
31 uint32_t Bits =
Chris Lattnered465f52005-10-23 22:15:34 +000032 SubtargetFeatures::Parse(FS, CPU,
33 SubTypeKV, SubTypeKVSize,
34 FeatureKV, FeatureKVSize);
35 HasF2I = (Bits & FeatureFIX) != 0;
36 HasCT = (Bits & FeatureCIX) != 0;
Andrew Lenharth120ab482005-09-29 22:54:56 +000037}