hotspot/src/share/vm/utilities/globalDefinitions.cpp
author coleenp
Sun, 13 Apr 2008 17:43:42 -0400
changeset 360 21d113ecbf6a
parent 202 dc13bf0e5d5d
child 670 ddf3e9583f2f
permissions -rw-r--r--
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes Summary: Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
     2
 * Copyright 1997-2006 Sun Microsystems, Inc.  All Rights Reserved.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    19
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    20
 * CA 95054 USA or visit www.sun.com if you need additional information or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    21
 * have any questions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
489c9b5090e2 Initial load
duke
parents:
diff changeset
    25
# include "incls/_precompiled.incl"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    26
# include "incls/_globalDefinitions.cpp.incl"
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
    27
// Basic error support
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    28
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
    29
// Info for oops within a java object.  Defaults are zero so
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
    30
// things will break badly if incorrectly initialized.
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
    31
int heapOopSize        = 0;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
    32
int LogBytesPerHeapOop = 0;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
    33
int LogBitsPerHeapOop  = 0;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
    34
int BytesPerHeapOop    = 0;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
    35
int BitsPerHeapOop     = 0;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
void basic_fatal(const char* msg) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
  fatal(msg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
// Something to help porters sleep at night
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
    43
void basic_types_init() {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
#ifdef _LP64
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
  assert(min_intx ==  (intx)CONST64(0x8000000000000000), "correct constant");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
  assert(max_intx ==  CONST64(0x7FFFFFFFFFFFFFFF), "correct constant");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
  assert(max_uintx == CONST64(0xFFFFFFFFFFFFFFFF), "correct constant");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
  assert( 8 == sizeof( intx),      "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
  assert( 8 == sizeof( jobject),   "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
  assert(min_intx ==  (intx)0x80000000,  "correct constant");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
  assert(max_intx ==  0x7FFFFFFF,  "correct constant");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
  assert(max_uintx == 0xFFFFFFFF,  "correct constant");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
  assert( 4 == sizeof( intx),      "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
  assert( 4 == sizeof( jobject),   "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
  assert( (~max_juint) == 0,  "max_juint has all its bits");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
  assert( (~max_uintx) == 0,  "max_uintx has all its bits");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
  assert( (~max_julong) == 0, "max_julong has all its bits");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
  assert( 1 == sizeof( jbyte),     "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
  assert( 2 == sizeof( jchar),     "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
  assert( 2 == sizeof( jshort),    "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
  assert( 4 == sizeof( juint),     "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
  assert( 4 == sizeof( jint),      "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
  assert( 1 == sizeof( jboolean),  "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
  assert( 8 == sizeof( jlong),     "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
  assert( 4 == sizeof( jfloat),    "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
  assert( 8 == sizeof( jdouble),   "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
  assert( 1 == sizeof( u1),        "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
  assert( 2 == sizeof( u2),        "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
  assert( 4 == sizeof( u4),        "wrong size for basic type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
  int num_type_chars = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
  for (int i = 0; i < 99; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
    if (type2char((BasicType)i) != 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
      assert(char2type(type2char((BasicType)i)) == i, "proper inverses");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
      num_type_chars++;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
  assert(num_type_chars == 11, "must have tested the right number of mappings");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
  assert(char2type(0) == T_ILLEGAL, "correct illegality");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
  {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
    for (int i = T_BOOLEAN; i <= T_CONFLICT; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
      BasicType vt = (BasicType)i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
      BasicType ft = type2field[vt];
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
      switch (vt) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
      // the following types might plausibly show up in memory layouts:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
      case T_BOOLEAN:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
      case T_BYTE:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
      case T_CHAR:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
      case T_SHORT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
      case T_INT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
      case T_FLOAT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
      case T_DOUBLE:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
      case T_LONG:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
      case T_OBJECT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
      case T_ADDRESS:   // random raw pointer
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   100
      case T_NARROWOOP: // compressed pointer
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
      case T_CONFLICT:  // might as well support a bottom type
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
      case T_VOID:      // padding or other unaddressed word
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
        // layout type must map to itself
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
        assert(vt == ft, "");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
      default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
        // non-layout type must map to a (different) layout type
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
        assert(vt != ft, "");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
        assert(ft == type2field[ft], "");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
      // every type must map to same-sized layout type:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
      assert(type2size[vt] == type2size[ft], "");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
  // These are assumed, e.g., when filling HeapWords with juints.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
  assert(is_power_of_2(sizeof(juint)), "juint must be power of 2");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
  assert(is_power_of_2(HeapWordSize), "HeapWordSize must be power of 2");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
  assert((size_t)HeapWordSize >= sizeof(juint),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
         "HeapWord should be at least as large as juint");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   120
  assert(sizeof(NULL) == sizeof(char*), "NULL must be same size as pointer");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
  if( JavaPriority1_To_OSPriority != -1 )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
    os::java_to_os_priority[1] = JavaPriority1_To_OSPriority;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
  if( JavaPriority2_To_OSPriority != -1 )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
    os::java_to_os_priority[2] = JavaPriority2_To_OSPriority;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
  if( JavaPriority3_To_OSPriority != -1 )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
    os::java_to_os_priority[3] = JavaPriority3_To_OSPriority;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
  if( JavaPriority4_To_OSPriority != -1 )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
    os::java_to_os_priority[4] = JavaPriority4_To_OSPriority;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
  if( JavaPriority5_To_OSPriority != -1 )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
    os::java_to_os_priority[5] = JavaPriority5_To_OSPriority;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
  if( JavaPriority6_To_OSPriority != -1 )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
    os::java_to_os_priority[6] = JavaPriority6_To_OSPriority;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
  if( JavaPriority7_To_OSPriority != -1 )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
    os::java_to_os_priority[7] = JavaPriority7_To_OSPriority;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
  if( JavaPriority8_To_OSPriority != -1 )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
    os::java_to_os_priority[8] = JavaPriority8_To_OSPriority;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
  if( JavaPriority9_To_OSPriority != -1 )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
    os::java_to_os_priority[9] = JavaPriority9_To_OSPriority;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
  if(JavaPriority10_To_OSPriority != -1 )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
    os::java_to_os_priority[10] = JavaPriority10_To_OSPriority;
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   143
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   144
  // Set the size of basic types here (after argument parsing but before
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   145
  // stub generation).
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   146
  if (UseCompressedOops) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   147
    // Size info for oops within java objects is fixed
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   148
    heapOopSize        = jintSize;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   149
    LogBytesPerHeapOop = LogBytesPerInt;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   150
    LogBitsPerHeapOop  = LogBitsPerInt;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   151
    BytesPerHeapOop    = BytesPerInt;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   152
    BitsPerHeapOop     = BitsPerInt;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   153
  } else {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   154
    heapOopSize        = oopSize;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   155
    LogBytesPerHeapOop = LogBytesPerWord;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   156
    LogBitsPerHeapOop  = LogBitsPerWord;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   157
    BytesPerHeapOop    = BytesPerWord;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   158
    BitsPerHeapOop     = BitsPerWord;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   159
  }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   160
  _type2aelembytes[T_OBJECT] = heapOopSize;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   161
  _type2aelembytes[T_ARRAY]  = heapOopSize;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   162
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
// Map BasicType to signature character
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   166
char type2char_tab[T_CONFLICT+1]={ 0, 0, 0, 0, 'Z', 'C', 'F', 'D', 'B', 'S', 'I', 'J', 'L', '[', 'V', 0, 0, 0};
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
// Map BasicType to Java type name
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
const char* type2name_tab[T_CONFLICT+1] = {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
  NULL, NULL, NULL, NULL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
  "boolean",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
  "char",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
  "float",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
  "double",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   175
  "byte",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
  "short",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   177
  "int",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   178
  "long",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   179
  "object",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   180
  "array",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   181
  "void",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   182
  "*address*",
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   183
  "*narrowoop*",
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   184
  "*conflict*"
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
   186
489c9b5090e2 Initial load
duke
parents:
diff changeset
   187
489c9b5090e2 Initial load
duke
parents:
diff changeset
   188
BasicType name2type(const char* name) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   189
  for (int i = T_BOOLEAN; i <= T_VOID; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   190
    BasicType t = (BasicType)i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   191
    if (type2name_tab[t] != NULL && 0 == strcmp(type2name_tab[t], name))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   192
      return t;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   193
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   194
  return T_ILLEGAL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   195
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   196
489c9b5090e2 Initial load
duke
parents:
diff changeset
   197
489c9b5090e2 Initial load
duke
parents:
diff changeset
   198
// Map BasicType to size in words
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   199
int type2size[T_CONFLICT+1]={ -1, 0, 0, 0, 1, 1, 1, 2, 1, 1, 1, 2, 1, 1, 0, 1, 1, -1};
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   200
489c9b5090e2 Initial load
duke
parents:
diff changeset
   201
BasicType type2field[T_CONFLICT+1] = {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   202
  (BasicType)0,            // 0,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   203
  (BasicType)0,            // 1,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   204
  (BasicType)0,            // 2,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   205
  (BasicType)0,            // 3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   206
  T_BOOLEAN,               // T_BOOLEAN  =  4,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   207
  T_CHAR,                  // T_CHAR     =  5,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   208
  T_FLOAT,                 // T_FLOAT    =  6,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   209
  T_DOUBLE,                // T_DOUBLE   =  7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   210
  T_BYTE,                  // T_BYTE     =  8,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   211
  T_SHORT,                 // T_SHORT    =  9,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   212
  T_INT,                   // T_INT      = 10,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   213
  T_LONG,                  // T_LONG     = 11,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   214
  T_OBJECT,                // T_OBJECT   = 12,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   215
  T_OBJECT,                // T_ARRAY    = 13,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   216
  T_VOID,                  // T_VOID     = 14,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   217
  T_ADDRESS,               // T_ADDRESS  = 15,
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   218
  T_NARROWOOP,             // T_NARROWOOP= 16,
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   219
  T_CONFLICT               // T_CONFLICT = 17,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   220
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
   221
489c9b5090e2 Initial load
duke
parents:
diff changeset
   222
489c9b5090e2 Initial load
duke
parents:
diff changeset
   223
BasicType type2wfield[T_CONFLICT+1] = {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   224
  (BasicType)0,            // 0,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   225
  (BasicType)0,            // 1,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   226
  (BasicType)0,            // 2,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   227
  (BasicType)0,            // 3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   228
  T_INT,     // T_BOOLEAN  =  4,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   229
  T_INT,     // T_CHAR     =  5,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   230
  T_FLOAT,   // T_FLOAT    =  6,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   231
  T_DOUBLE,  // T_DOUBLE   =  7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   232
  T_INT,     // T_BYTE     =  8,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   233
  T_INT,     // T_SHORT    =  9,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   234
  T_INT,     // T_INT      = 10,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   235
  T_LONG,    // T_LONG     = 11,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   236
  T_OBJECT,  // T_OBJECT   = 12,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   237
  T_OBJECT,  // T_ARRAY    = 13,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   238
  T_VOID,    // T_VOID     = 14,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   239
  T_ADDRESS, // T_ADDRESS  = 15,
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   240
  T_NARROWOOP, // T_NARROWOOP  = 16,
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   241
  T_CONFLICT // T_CONFLICT = 17,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   242
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
   243
489c9b5090e2 Initial load
duke
parents:
diff changeset
   244
202
dc13bf0e5d5d 6633953: type2aelembytes{T_ADDRESS} should be 8 bytes in 64 bit VM
kvn
parents: 1
diff changeset
   245
int _type2aelembytes[T_CONFLICT+1] = {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   246
  0,                      // 0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   247
  0,                      // 1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   248
  0,                      // 2
489c9b5090e2 Initial load
duke
parents:
diff changeset
   249
  0,                      // 3
489c9b5090e2 Initial load
duke
parents:
diff changeset
   250
  T_BOOLEAN_aelem_bytes,  // T_BOOLEAN  =  4,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   251
  T_CHAR_aelem_bytes,     // T_CHAR     =  5,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   252
  T_FLOAT_aelem_bytes,    // T_FLOAT    =  6,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   253
  T_DOUBLE_aelem_bytes,   // T_DOUBLE   =  7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   254
  T_BYTE_aelem_bytes,     // T_BYTE     =  8,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   255
  T_SHORT_aelem_bytes,    // T_SHORT    =  9,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   256
  T_INT_aelem_bytes,      // T_INT      = 10,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   257
  T_LONG_aelem_bytes,     // T_LONG     = 11,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   258
  T_OBJECT_aelem_bytes,   // T_OBJECT   = 12,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   259
  T_ARRAY_aelem_bytes,    // T_ARRAY    = 13,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   260
  0,                      // T_VOID     = 14,
202
dc13bf0e5d5d 6633953: type2aelembytes{T_ADDRESS} should be 8 bytes in 64 bit VM
kvn
parents: 1
diff changeset
   261
  T_OBJECT_aelem_bytes,   // T_ADDRESS  = 15,
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   262
  T_NARROWOOP_aelem_bytes,// T_NARROWOOP= 16,
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   263
  0                       // T_CONFLICT = 17,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   264
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
   265
202
dc13bf0e5d5d 6633953: type2aelembytes{T_ADDRESS} should be 8 bytes in 64 bit VM
kvn
parents: 1
diff changeset
   266
#ifdef ASSERT
dc13bf0e5d5d 6633953: type2aelembytes{T_ADDRESS} should be 8 bytes in 64 bit VM
kvn
parents: 1
diff changeset
   267
int type2aelembytes(BasicType t, bool allow_address) {
dc13bf0e5d5d 6633953: type2aelembytes{T_ADDRESS} should be 8 bytes in 64 bit VM
kvn
parents: 1
diff changeset
   268
  assert(allow_address || t != T_ADDRESS, " ");
dc13bf0e5d5d 6633953: type2aelembytes{T_ADDRESS} should be 8 bytes in 64 bit VM
kvn
parents: 1
diff changeset
   269
  return _type2aelembytes[t];
dc13bf0e5d5d 6633953: type2aelembytes{T_ADDRESS} should be 8 bytes in 64 bit VM
kvn
parents: 1
diff changeset
   270
}
dc13bf0e5d5d 6633953: type2aelembytes{T_ADDRESS} should be 8 bytes in 64 bit VM
kvn
parents: 1
diff changeset
   271
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   272
489c9b5090e2 Initial load
duke
parents:
diff changeset
   273
// Support for 64-bit integer arithmetic
489c9b5090e2 Initial load
duke
parents:
diff changeset
   274
489c9b5090e2 Initial load
duke
parents:
diff changeset
   275
// The following code is mostly taken from JVM typedefs_md.h and system_md.c
489c9b5090e2 Initial load
duke
parents:
diff changeset
   276
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 202
diff changeset
   277
static const jlong high_bit   = (jlong)1 << (jlong)63;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   278
static const jlong other_bits = ~high_bit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   279
489c9b5090e2 Initial load
duke
parents:
diff changeset
   280
jlong float2long(jfloat f) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   281
  jlong tmp = (jlong) f;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   282
  if (tmp != high_bit) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   283
    return tmp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   284
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   285
    if (g_isnan((jdouble)f)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   286
      return 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   287
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   288
    if (f < 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   289
      return high_bit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   290
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   291
      return other_bits;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   292
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   293
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   294
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   295
489c9b5090e2 Initial load
duke
parents:
diff changeset
   296
489c9b5090e2 Initial load
duke
parents:
diff changeset
   297
jlong double2long(jdouble f) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   298
  jlong tmp = (jlong) f;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   299
  if (tmp != high_bit) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   300
    return tmp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   301
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   302
    if (g_isnan(f)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   303
      return 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   304
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   305
    if (f < 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   306
      return high_bit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   307
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   308
      return other_bits;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   309
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   310
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   311
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   312
489c9b5090e2 Initial load
duke
parents:
diff changeset
   313
// least common multiple
489c9b5090e2 Initial load
duke
parents:
diff changeset
   314
size_t lcm(size_t a, size_t b) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   315
    size_t cur, div, next;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   316
489c9b5090e2 Initial load
duke
parents:
diff changeset
   317
    cur = MAX2(a, b);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   318
    div = MIN2(a, b);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   319
489c9b5090e2 Initial load
duke
parents:
diff changeset
   320
    assert(div != 0, "lcm requires positive arguments");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   321
489c9b5090e2 Initial load
duke
parents:
diff changeset
   322
489c9b5090e2 Initial load
duke
parents:
diff changeset
   323
    while ((next = cur % div) != 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   324
        cur = div; div = next;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   325
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   326
489c9b5090e2 Initial load
duke
parents:
diff changeset
   327
489c9b5090e2 Initial load
duke
parents:
diff changeset
   328
    julong result = julong(a) * b / div;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   329
    assert(result <= (size_t)max_uintx, "Integer overflow in lcm");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   330
489c9b5090e2 Initial load
duke
parents:
diff changeset
   331
    return size_t(result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   332
}