For PR950:
[oota-llvm.git] / lib / VMCore / ValueTypes.cpp
1 //===-- ValueTypes.cpp - Implementation of MVT::ValueType methods ---------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file was developed by the LLVM research group and is distributed under
6 // the University of Illinois Open Source License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file implements methods in the CodeGen/ValueTypes.h header.
11 //
12 //===----------------------------------------------------------------------===//
13
14 #include "llvm/CodeGen/ValueTypes.h"
15 #include "llvm/Type.h"
16 using namespace llvm;
17
18 /// MVT::getValueTypeString - This function returns value type as a string,
19 /// e.g. "i32".
20 const char *MVT::getValueTypeString(MVT::ValueType VT) {
21   switch (VT) {
22   default: assert(0 && "Invalid ValueType!");
23   case MVT::i1:    return "i1";
24   case MVT::i8:    return "i8";
25   case MVT::i16:   return "i16";
26   case MVT::i32:   return "i32";
27   case MVT::i64:   return "i64";
28   case MVT::i128:  return "i128";
29   case MVT::f32:   return "f32";
30   case MVT::f64:   return "f64";
31   case MVT::f80:   return "f80";
32   case MVT::f128:  return "f128";
33   case MVT::isVoid:return "isVoid";
34   case MVT::Other: return "ch";
35   case MVT::Flag:  return "flag";
36   case MVT::Vector:return "vec";
37   case MVT::v8i8:  return "v8i8";
38   case MVT::v4i16: return "v4i16";
39   case MVT::v2i32: return "v2i32";
40   case MVT::v16i8: return "v16i8";
41   case MVT::v8i16: return "v8i16";
42   case MVT::v4i32: return "v4i32";
43   case MVT::v2i64: return "v2i64";
44   case MVT::v4f32: return "v4f32";
45   case MVT::v2f64: return "v2f64";
46   }
47 }
48
49 /// MVT::getVectorType - Returns the ValueType that represents a vector
50 /// NumElements in length, where each element is of type VT.  If there is no
51 /// ValueType that represents this vector, a ValueType of Other is returned.
52 ///
53 MVT::ValueType MVT::getVectorType(ValueType VT, unsigned NumElements) {
54   switch (VT) {
55   default: 
56     break;
57   case MVT::i8:
58     if (NumElements == 8)  return MVT::v8i8;
59     if (NumElements == 16) return MVT::v16i8;
60     break;
61   case MVT::i16:
62     if (NumElements == 4)  return MVT::v4i16;
63     if (NumElements == 8)  return MVT::v8i16;
64     break;
65   case MVT::i32:
66     if (NumElements == 2)  return MVT::v2i32;
67     if (NumElements == 4)  return MVT::v4i32;
68     break;
69   case MVT::i64:
70     if (NumElements == 2)  return MVT::v2i64;
71     break;
72   case MVT::f32:
73     if (NumElements == 2)  return MVT::v2f32;
74     if (NumElements == 4)  return MVT::v4f32;
75     break;
76   case MVT::f64:
77     if (NumElements == 2)  return MVT::v2f64;
78     break;
79   }
80   return MVT::Other;
81 }
82
83 /// MVT::getTypeForValueType - This method returns an LLVM type corresponding
84 /// to the specified ValueType.  For integer types, this returns an unsigned
85 /// type.  Note that this will abort for types that cannot be represented.
86 const Type *MVT::getTypeForValueType(MVT::ValueType VT) {
87   switch (VT) {
88   default: assert(0 && "ValueType does not correspond to LLVM type!");
89   case MVT::isVoid:return Type::VoidTy;
90   case MVT::i1:    return Type::BoolTy;
91   case MVT::i8:    return Type::Int8Ty;
92   case MVT::i16:   return Type::Int16Ty;
93   case MVT::i32:   return Type::Int32Ty;
94   case MVT::i64:   return Type::Int64Ty;
95   case MVT::f32:   return Type::FloatTy;
96   case MVT::f64:   return Type::DoubleTy;
97   }
98 }