< prev index next >

src/hotspot/share/utilities/globalDefinitions.cpp

Print this page
*** 1,7 ***
  /*
!  * Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
   * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   *
   * This code is free software; you can redistribute it and/or modify it
   * under the terms of the GNU General Public License version 2 only, as
   * published by the Free Software Foundation.
--- 1,7 ---
  /*
!  * Copyright (c) 1997, 2025, Oracle and/or its affiliates. All rights reserved.
   * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   *
   * This code is free software; you can redistribute it and/or modify it
   * under the terms of the GNU General Public License version 2 only, as
   * published by the Free Software Foundation.

*** 114,11 ***
        assert(char2type(type2char((BasicType)i)) == i, "proper inverses");
        assert(Signature::basic_type(type2char((BasicType)i)) == i, "proper inverses");
        num_type_chars++;
      }
    }
!   assert(num_type_chars == 11, "must have tested the right number of mappings");
    assert(char2type(0) == T_ILLEGAL, "correct illegality");
  
    {
      for (int i = T_BOOLEAN; i <= T_CONFLICT; i++) {
        BasicType vt = (BasicType)i;
--- 114,11 ---
        assert(char2type(type2char((BasicType)i)) == i, "proper inverses");
        assert(Signature::basic_type(type2char((BasicType)i)) == i, "proper inverses");
        num_type_chars++;
      }
    }
!   assert(num_type_chars == 12, "must have tested the right number of mappings");
    assert(char2type(0) == T_ILLEGAL, "correct illegality");
  
    {
      for (int i = T_BOOLEAN; i <= T_CONFLICT; i++) {
        BasicType vt = (BasicType)i;

*** 196,10 ***
--- 196,11 ---
      BytesPerHeapOop    = BytesPerWord;
      BitsPerHeapOop     = BitsPerWord;
    }
    _type2aelembytes[T_OBJECT] = heapOopSize;
    _type2aelembytes[T_ARRAY]  = heapOopSize;
+   _type2aelembytes[T_FLAT_ELEMENT]  = heapOopSize;
  }
  
  
  // Map BasicType to signature character
  char type2char_tab[T_CONFLICT+1] = {

*** 207,12 ***
    JVM_SIGNATURE_BOOLEAN, JVM_SIGNATURE_CHAR,
    JVM_SIGNATURE_FLOAT,   JVM_SIGNATURE_DOUBLE,
    JVM_SIGNATURE_BYTE,    JVM_SIGNATURE_SHORT,
    JVM_SIGNATURE_INT,     JVM_SIGNATURE_LONG,
    JVM_SIGNATURE_CLASS,   JVM_SIGNATURE_ARRAY,
!   JVM_SIGNATURE_VOID,    0,
!   0, 0, 0, 0
  };
  
  // Map BasicType to Java type name
  const char* type2name_tab[T_CONFLICT+1] = {
    nullptr, nullptr, nullptr, nullptr,
--- 208,12 ---
    JVM_SIGNATURE_BOOLEAN, JVM_SIGNATURE_CHAR,
    JVM_SIGNATURE_FLOAT,   JVM_SIGNATURE_DOUBLE,
    JVM_SIGNATURE_BYTE,    JVM_SIGNATURE_SHORT,
    JVM_SIGNATURE_INT,     JVM_SIGNATURE_LONG,
    JVM_SIGNATURE_CLASS,   JVM_SIGNATURE_ARRAY,
!   JVM_SIGNATURE_FLAT_ELEMENT, JVM_SIGNATURE_VOID,
!   0, 0, 0, 0, 0
  };
  
  // Map BasicType to Java type name
  const char* type2name_tab[T_CONFLICT+1] = {
    nullptr, nullptr, nullptr, nullptr,

*** 224,10 ***
--- 225,11 ---
    "short",
    "int",
    "long",
    "object",
    "array",
+   "inline_type",
    "void",
    "*address*",
    "*narrowoop*",
    "*metadata*",
    "*narrowklass*",

*** 254,11 ***
    }
    return T_ILLEGAL;
  }
  
  // Map BasicType to size in words
! int type2size[T_CONFLICT+1]={ -1, 0, 0, 0, 1, 1, 1, 2, 1, 1, 1, 2, 1, 1, 0, 1, 1, 1, 1, -1};
  
  BasicType type2field[T_CONFLICT+1] = {
    (BasicType)0,            // 0,
    (BasicType)0,            // 1,
    (BasicType)0,            // 2,
--- 256,11 ---
    }
    return T_ILLEGAL;
  }
  
  // Map BasicType to size in words
! int type2size[T_CONFLICT+1]={ -1, 0, 0, 0, 1, 1, 1, 2, 1, 1, 1, 2, 1, 1, 1, 0, 1, 1, 1, 1, -1};
  
  BasicType type2field[T_CONFLICT+1] = {
    (BasicType)0,            // 0,
    (BasicType)0,            // 1,
    (BasicType)0,            // 2,

*** 271,16 ***
    T_SHORT,                 // T_SHORT    =  9,
    T_INT,                   // T_INT      = 10,
    T_LONG,                  // T_LONG     = 11,
    T_OBJECT,                // T_OBJECT   = 12,
    T_OBJECT,                // T_ARRAY    = 13,
!   T_VOID,                  // T_VOID     = 14,
!   T_ADDRESS,               // T_ADDRESS  = 15,
!   T_NARROWOOP,             // T_NARROWOOP= 16,
!   T_METADATA,              // T_METADATA = 17,
!   T_NARROWKLASS,           // T_NARROWKLASS = 18,
!   T_CONFLICT               // T_CONFLICT = 19,
  };
  
  
  BasicType type2wfield[T_CONFLICT+1] = {
    (BasicType)0,            // 0,
--- 273,17 ---
    T_SHORT,                 // T_SHORT    =  9,
    T_INT,                   // T_INT      = 10,
    T_LONG,                  // T_LONG     = 11,
    T_OBJECT,                // T_OBJECT   = 12,
    T_OBJECT,                // T_ARRAY    = 13,
!   T_OBJECT,                // T_PRIMITIVE_OBJECT = 14,
!   T_VOID,                  // T_VOID     = 15,
!   T_ADDRESS,               // T_ADDRESS  = 16,
!   T_NARROWOOP,             // T_NARROWOOP= 17,
!   T_METADATA,              // T_METADATA = 18,
!   T_NARROWKLASS,           // T_NARROWKLASS = 19,
+   T_CONFLICT               // T_CONFLICT = 20
  };
  
  
  BasicType type2wfield[T_CONFLICT+1] = {
    (BasicType)0,            // 0,

*** 295,16 ***
    T_INT,     // T_SHORT    =  9,
    T_INT,     // T_INT      = 10,
    T_LONG,    // T_LONG     = 11,
    T_OBJECT,  // T_OBJECT   = 12,
    T_OBJECT,  // T_ARRAY    = 13,
!   T_VOID,    // T_VOID     = 14,
!   T_ADDRESS, // T_ADDRESS  = 15,
!   T_NARROWOOP, // T_NARROWOOP  = 16,
!   T_METADATA,  // T_METADATA   = 17,
!   T_NARROWKLASS, // T_NARROWKLASS  = 18,
!   T_CONFLICT // T_CONFLICT = 19,
  };
  
  
  int _type2aelembytes[T_CONFLICT+1] = {
    0,                         // 0
--- 298,17 ---
    T_INT,     // T_SHORT    =  9,
    T_INT,     // T_INT      = 10,
    T_LONG,    // T_LONG     = 11,
    T_OBJECT,  // T_OBJECT   = 12,
    T_OBJECT,  // T_ARRAY    = 13,
!   T_OBJECT,  // T_PRIMITIVE_OBJECT = 14,
!   T_VOID,    // T_VOID     = 15,
!   T_ADDRESS, // T_ADDRESS  = 16,
!   T_NARROWOOP, // T_NARROWOOP  = 17,
!   T_METADATA,  // T_METADATA   = 18,
!   T_NARROWKLASS, // T_NARROWKLASS  = 19,
+   T_CONFLICT // T_CONFLICT = 20
  };
  
  
  int _type2aelembytes[T_CONFLICT+1] = {
    0,                         // 0

*** 319,16 ***
    T_SHORT_aelem_bytes,       // T_SHORT    =  9,
    T_INT_aelem_bytes,         // T_INT      = 10,
    T_LONG_aelem_bytes,        // T_LONG     = 11,
    T_OBJECT_aelem_bytes,      // T_OBJECT   = 12,
    T_ARRAY_aelem_bytes,       // T_ARRAY    = 13,
!   0,                         // T_VOID     = 14,
!   T_OBJECT_aelem_bytes,      // T_ADDRESS  = 15,
!   T_NARROWOOP_aelem_bytes,   // T_NARROWOOP= 16,
!   T_OBJECT_aelem_bytes,      // T_METADATA = 17,
!   T_NARROWKLASS_aelem_bytes, // T_NARROWKLASS= 18,
!   0                          // T_CONFLICT = 19,
  };
  
  #ifdef ASSERT
  int type2aelembytes(BasicType t, bool allow_address) {
    assert((allow_address || t != T_ADDRESS) && t <= T_CONFLICT, "unexpected basic type");
--- 323,17 ---
    T_SHORT_aelem_bytes,       // T_SHORT    =  9,
    T_INT_aelem_bytes,         // T_INT      = 10,
    T_LONG_aelem_bytes,        // T_LONG     = 11,
    T_OBJECT_aelem_bytes,      // T_OBJECT   = 12,
    T_ARRAY_aelem_bytes,       // T_ARRAY    = 13,
!   T_FLAT_ELEMENT_aelem_bytes, // T_PRIMITIVE_OBJECT = 14,
!   0,                         // T_VOID     = 15,
!   T_OBJECT_aelem_bytes,      // T_ADDRESS  = 16,
!   T_NARROWOOP_aelem_bytes,   // T_NARROWOOP= 17,
!   T_OBJECT_aelem_bytes,      // T_METADATA = 18,
!   T_NARROWKLASS_aelem_bytes, // T_NARROWKLASS= 19,
+   0                          // T_CONFLICT = 20
  };
  
  #ifdef ASSERT
  int type2aelembytes(BasicType t, bool allow_address) {
    assert((allow_address || t != T_ADDRESS) && t <= T_CONFLICT, "unexpected basic type");
< prev index next >