1 /*
   2  * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
   3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   4  *
   5  * This code is free software; you can redistribute it and/or modify it
   6  * under the terms of the GNU General Public License version 2 only, as
   7  * published by the Free Software Foundation.
   8  *
   9  * This code is distributed in the hope that it will be useful, but WITHOUT
  10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  12  * version 2 for more details (a copy is included in the LICENSE file that
  13  * accompanied this code).
  14  *
  15  * You should have received a copy of the GNU General Public License version
  16  * 2 along with this work; if not, write to the Free Software Foundation,
  17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  18  *
  19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  20  * or visit www.oracle.com if you need additional information or have any
  21  * questions.
  22  *
  23  */
  24 
  25 #include "precompiled.hpp"
  26 #include "c1/c1_ValueType.hpp"
  27 #include "ci/ciArray.hpp"
  28 #include "ci/ciInstance.hpp"
  29 #include "ci/ciNullObject.hpp"
  30 
  31 
  32 // predefined types
  33 VoidType*       voidType     = NULL;
  34 IntType*        intType      = NULL;
  35 LongType*       longType     = NULL;
  36 FloatType*      floatType    = NULL;
  37 DoubleType*     doubleType   = NULL;
  38 ObjectType*     objectType   = NULL;
  39 ArrayType*      arrayType    = NULL;
  40 InstanceType*   instanceType = NULL;
  41 ClassType*      classType    = NULL;
  42 AddressType*    addressType  = NULL;
  43 IllegalType*    illegalType  = NULL;
  44 
  45 
  46 // predefined constants
  47 IntConstant*    intZero      = NULL;
  48 IntConstant*    intOne       = NULL;
  49 ObjectConstant* objectNull   = NULL;
  50 
  51 
  52 void ValueType::initialize(Arena* arena) {
  53   // Note: Must initialize all types for each compilation
  54   //       as they are allocated within a ResourceMark!
  55 
  56   // types
  57   voidType     = new (arena) VoidType();
  58   intType      = new (arena) IntType();
  59   longType     = new (arena) LongType();
  60   floatType    = new (arena) FloatType();
  61   doubleType   = new (arena) DoubleType();
  62   objectType   = new (arena) ObjectType();
  63   arrayType    = new (arena) ArrayType();
  64   instanceType = new (arena) InstanceType();
  65   classType    = new (arena) ClassType();
  66   addressType  = new (arena) AddressType();
  67   illegalType  = new (arena) IllegalType();
  68 
  69   intZero     = new (arena) IntConstant(0);
  70   intOne      = new (arena) IntConstant(1);
  71   objectNull  = new (arena) ObjectConstant(ciNullObject::make());
  72 };
  73 
  74 
  75 ValueType* ValueType::meet(ValueType* y) const {
  76   // incomplete & conservative solution for now - fix this!
  77   assert(tag() == y->tag(), "types must match");
  78   return base();
  79 }
  80 
  81 
  82 ValueType* ValueType::join(ValueType* y) const {
  83   Unimplemented();
  84   return NULL;
  85 }
  86 
  87 
  88 
  89 jobject ObjectType::encoding() const {
  90   assert(is_constant(), "must be");
  91   return constant_value()->constant_encoding();
  92 }
  93 
  94 bool ObjectType::is_loaded() const {
  95   assert(is_constant(), "must be");
  96   return constant_value()->is_loaded();
  97 }
  98 
  99 ciObject* ObjectConstant::constant_value() const                   { return _value; }
 100 ciObject* ArrayConstant::constant_value() const                    { return _value; }
 101 ciObject* InstanceConstant::constant_value() const                 { return _value; }
 102 ciObject* ClassConstant::constant_value() const                    { return _value; }
 103 
 104 
 105 ValueType* as_ValueType(BasicType type) {
 106   switch (type) {
 107     case T_VOID   : return voidType;
 108     case T_BYTE   : // fall through
 109     case T_CHAR   : // fall through
 110     case T_SHORT  : // fall through
 111     case T_BOOLEAN: // fall through
 112     case T_INT    : return intType;
 113     case T_LONG   : return longType;
 114     case T_FLOAT  : return floatType;
 115     case T_DOUBLE : return doubleType;
 116     case T_ARRAY  : return arrayType;
 117     case T_OBJECT : return objectType;
 118     case T_ADDRESS: return addressType;
 119     case T_ILLEGAL: return illegalType;
 120   }
 121   ShouldNotReachHere();
 122   return illegalType;
 123 }
 124 
 125 
 126 ValueType* as_ValueType(ciConstant value) {
 127   switch (value.basic_type()) {
 128     case T_BYTE   : // fall through
 129     case T_CHAR   : // fall through
 130     case T_SHORT  : // fall through
 131     case T_BOOLEAN: // fall through
 132     case T_INT    : return new IntConstant   (value.as_int   ());
 133     case T_LONG   : return new LongConstant  (value.as_long  ());
 134     case T_FLOAT  : return new FloatConstant (value.as_float ());
 135     case T_DOUBLE : return new DoubleConstant(value.as_double());
 136     case T_ARRAY  : // fall through (ciConstant doesn't have an array accessor)
 137     case T_OBJECT : return new ObjectConstant(value.as_object());
 138   }
 139   ShouldNotReachHere();
 140   return illegalType;
 141 }
 142 
 143 
 144 BasicType as_BasicType(ValueType* type) {
 145   switch (type->tag()) {
 146     case voidTag:    return T_VOID;
 147     case intTag:     return T_INT;
 148     case longTag:    return T_LONG;
 149     case floatTag:   return T_FLOAT;
 150     case doubleTag:  return T_DOUBLE;
 151     case objectTag:  return T_OBJECT;
 152     case addressTag: return T_ADDRESS;
 153     case illegalTag: return T_ILLEGAL;
 154   }
 155   ShouldNotReachHere();
 156   return T_ILLEGAL;
 157 }