hotspot/src/share/vm/classfile/compactHashtable.hpp
author iklam
Wed, 06 Apr 2016 21:53:44 -0700
changeset 39713 29ece76096cb
parent 37995 92aec042a43b
child 46742 24ec8a039c90
permissions -rw-r--r--
8150752: Share Class Data Reviewed-by: acorn, hseigel, mschoene
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
     1
/*
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
     2
 * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved.
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
     4
 *
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
     7
 * published by the Free Software Foundation.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
     8
 *
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    13
 * accompanied this code).
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    14
 *
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    18
 *
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    21
 * questions.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    22
 *
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    23
 */
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    24
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    25
#ifndef SHARE_VM_CLASSFILE_COMPACTHASHTABLE_HPP
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    26
#define SHARE_VM_CLASSFILE_COMPACTHASHTABLE_HPP
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    27
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    28
#include "classfile/stringTable.hpp"
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    29
#include "classfile/symbolTable.hpp"
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    30
#include "oops/symbol.hpp"
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    31
#include "services/diagnosticCommand.hpp"
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    32
#include "utilities/hashtable.hpp"
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    33
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    34
template <class T, class N> class CompactHashtable;
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    35
class NumberSeq;
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    36
class SimpleCompactHashtable;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    37
class SerializeClosure;
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    38
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    39
// Stats for symbol tables in the CDS archive
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    40
class CompactHashtableStats VALUE_OBJ_CLASS_SPEC {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    41
public:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    42
  int hashentry_count;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    43
  int hashentry_bytes;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    44
  int bucket_count;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    45
  int bucket_bytes;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    46
};
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    47
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    48
/////////////////////////////////////////////////////////////////////////
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    49
//
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    50
// The compact hash table writer. Used at dump time for writing out
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    51
// the compact table to the shared archive.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    52
//
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    53
// At dump time, the CompactHashtableWriter obtains all entries from the
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
    54
// symbol/string table and adds them to a new temporary hash table. The hash
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    55
// table size (number of buckets) is calculated using
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    56
// '(num_entries + bucket_size - 1) / bucket_size'. The default bucket
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    57
// size is 4 and can be changed by -XX:SharedSymbolTableBucketSize option.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    58
// 4 is chosen because it produces smaller sized bucket on average for
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    59
// faster lookup. It also has relatively small number of empty buckets and
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    60
// good distribution of the entries.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    61
//
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
    62
// We use a simple hash function (hash % num_bucket) for the table.
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    63
// The new table is compacted when written out. Please see comments
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    64
// above the CompactHashtable class for the table layout detail. The bucket
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    65
// offsets are written to the archive as part of the compact table. The
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    66
// bucket offset is encoded in the low 30-bit (0-29) and the bucket type
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    67
// (regular or compact) are encoded in bit[31, 30]. For buckets with more
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
    68
// than one entry, both hash and entry offset are written to the
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
    69
// table. For buckets with only one entry, only the entry offset is written
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    70
// to the table and the buckets are tagged as compact in their type bits.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    71
// Buckets without entry are skipped from the table. Their offsets are
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    72
// still written out for faster lookup.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    73
//
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    74
class CompactHashtableWriter: public StackObj {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    75
public:
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    76
  class Entry VALUE_OBJ_CLASS_SPEC {
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    77
    unsigned int _hash;
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    78
    u4 _value;
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    79
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    80
  public:
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    81
    Entry() {}
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    82
    Entry(unsigned int hash, u4 val) : _hash(hash), _value(val) {}
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    83
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    84
    u4 value() {
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    85
      return _value;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
    86
    }
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    87
    unsigned int hash() {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    88
      return _hash;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    89
    }
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    90
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    91
    bool operator==(const CompactHashtableWriter::Entry& other) {
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    92
      return (_value == other._value && _hash == other._hash);
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    93
    }
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    94
  }; // class CompactHashtableWriter::Entry
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    95
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    96
private:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    97
  int _num_entries;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
    98
  int _num_buckets;
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
    99
  int _num_empty_buckets;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   100
  int _num_value_only_buckets;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   101
  int _num_other_buckets;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   102
  GrowableArray<Entry>** _buckets;
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   103
  CompactHashtableStats* _stats;
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   104
  Array<u4>* _compact_buckets;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   105
  Array<u4>* _compact_entries;
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   106
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   107
public:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   108
  // This is called at dump-time only
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   109
  CompactHashtableWriter(int num_buckets, CompactHashtableStats* stats);
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   110
  ~CompactHashtableWriter();
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   111
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   112
  void add(unsigned int hash, u4 value);
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   113
  void add(u4 value) {
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   114
    add((unsigned int)value, value);
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   115
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   116
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   117
private:
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   118
  void allocate_table();
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   119
  void dump_table(NumberSeq* summary);
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   120
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   121
public:
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   122
  void dump(SimpleCompactHashtable *cht, const char* table_name);
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   123
  const char* table_name();
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   124
};
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   125
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   126
class CompactSymbolTableWriter: public CompactHashtableWriter {
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   127
public:
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   128
  CompactSymbolTableWriter(int num_buckets, CompactHashtableStats* stats) :
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   129
    CompactHashtableWriter(num_buckets, stats) {}
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   130
  void add(unsigned int hash, Symbol *symbol);
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   131
  void dump(CompactHashtable<Symbol*, char> *cht);
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   132
};
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   133
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   134
class CompactStringTableWriter: public CompactHashtableWriter {
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   135
public:
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   136
  CompactStringTableWriter(int num_entries, CompactHashtableStats* stats) :
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   137
    CompactHashtableWriter(num_entries, stats) {}
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   138
  void add(unsigned int hash, oop string);
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   139
  void dump(CompactHashtable<oop, char> *cht);
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   140
};
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   141
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   142
#define REGULAR_BUCKET_TYPE       0
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   143
#define VALUE_ONLY_BUCKET_TYPE    1
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   144
#define TABLEEND_BUCKET_TYPE      3
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   145
#define BUCKET_OFFSET_MASK        0x3FFFFFFF
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   146
#define BUCKET_OFFSET(info)       ((info) & BUCKET_OFFSET_MASK)
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   147
#define BUCKET_TYPE_SHIFT         30
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   148
#define BUCKET_TYPE(info)         (((info) & ~BUCKET_OFFSET_MASK) >> BUCKET_TYPE_SHIFT)
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   149
#define BUCKET_INFO(offset, type) (((type) << BUCKET_TYPE_SHIFT) | ((offset) & BUCKET_OFFSET_MASK))
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   150
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   151
/////////////////////////////////////////////////////////////////////////////
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   152
//
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   153
// CompactHashtable is used to stored the CDS archive's symbol/string table. Used
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   154
// at runtime only to access the compact table from the archive.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   155
//
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   156
// Because these tables are read-only (no entries can be added/deleted) at run-time
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   157
// and tend to have large number of entries, we try to minimize the footprint
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   158
// cost per entry.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   159
//
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   160
// The CompactHashtable is split into two arrays
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   161
//
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   162
//   u4 buckets[num_buckets+1]; // bit[31,30]: type; bit[29-0]: offset
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   163
//   u4 entries[<variable size>]
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   164
//
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   165
// The size of buckets[] is 'num_buckets + 1'. Each entry of
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   166
// buckets[] is a 32-bit encoding of the bucket type and bucket offset,
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   167
// with the type in the left-most 2-bit and offset in the remaining 30-bit.
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   168
// The last entry is a special type. It contains the end of the last
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   169
// bucket.
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   170
//
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   171
// There are two types of buckets, regular buckets and value_only buckets. The
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   172
// value_only buckets have '01' in their highest 2-bit, and regular buckets have
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   173
// '00' in their highest 2-bit.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   174
//
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   175
// For normal buckets, each entry is 8 bytes in the entries[]:
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   176
//   u4 hash;    /* symbol/string hash */
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   177
//   union {
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   178
//     u4 offset;  /* Symbol* sym = (Symbol*)(base_address + offset) */
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   179
//     narrowOop str; /* String narrowOop encoding */
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   180
//   }
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   181
//
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   182
//
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   183
// For value_only buckets, each entry has only the 4-byte 'offset' in the entries[].
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   184
//
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   185
// Example -- note that the second bucket is a VALUE_ONLY_BUCKET_TYPE so the hash code
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   186
//            is skipped.
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   187
// buckets[0, 4, 5, ....]
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   188
//         |  |  |
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   189
//         |  |  +---+
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   190
//         |  |      |
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   191
//         |  +----+ |
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   192
//         v       v v
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   193
// entries[H,O,H,O,O,H,O,H,O.....]
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   194
//
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   195
// See CompactHashtable::lookup() for how the table is searched at runtime.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   196
// See CompactHashtableWriter::dump() for how the table is written at CDS
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   197
// dump time.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   198
//
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   199
class SimpleCompactHashtable VALUE_OBJ_CLASS_SPEC {
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   200
protected:
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   201
  address  _base_address;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   202
  u4  _bucket_count;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   203
  u4  _entry_count;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   204
  u4* _buckets;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   205
  u4* _entries;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   206
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   207
public:
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   208
  SimpleCompactHashtable() {
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   209
    _entry_count = 0;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   210
    _bucket_count = 0;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   211
    _buckets = 0;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   212
    _entries = 0;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   213
  }
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   214
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   215
  void reset() {
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   216
    _bucket_count = 0;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   217
    _entry_count = 0;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   218
    _buckets = 0;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   219
    _entries = 0;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   220
  }
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   221
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   222
  void init(address base_address, u4 entry_count, u4 bucket_count, u4* buckets, u4* entries) {
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   223
    _base_address = base_address;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   224
    _bucket_count = bucket_count;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   225
    _entry_count = entry_count;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   226
    _buckets = buckets;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   227
    _entries = entries;
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   228
  }
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   229
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   230
  template <class I> inline void iterate(const I& iterator);
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   231
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   232
  bool exists(u4 value);
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   233
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   234
  // For reading from/writing to the CDS archive
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   235
  void serialize(SerializeClosure* soc);
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   236
};
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   237
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   238
template <class T, class N> class CompactHashtable : public SimpleCompactHashtable {
28822
fa57694ade05 8071962: The SA code needs to be updated to support Symbol lookup from the shared archive.
jiangli
parents: 28615
diff changeset
   239
  friend class VMStructs;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   240
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   241
public:
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   242
  enum CompactHashtableType {
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   243
    _symbol_table = 0,
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   244
    _string_table = 1
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   245
  };
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   246
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   247
private:
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   248
  u4 _type;
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   249
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   250
  inline Symbol* decode_entry(CompactHashtable<Symbol*, char>* const t,
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   251
                              u4 offset, const char* name, int len);
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   252
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   253
  inline oop decode_entry(CompactHashtable<oop, char>* const t,
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   254
                          u4 offset, const char* name, int len);
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   255
public:
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   256
  CompactHashtable() : SimpleCompactHashtable() {}
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   257
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   258
  void set_type(CompactHashtableType type) {
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   259
    _type = (u4)type;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   260
  }
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   261
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   262
  // Lookup an entry from the compact table
34659
3a7071043457 8143615: compactHashtable.hpp includes .inline.hpp file
iklam
parents: 31345
diff changeset
   263
  inline T lookup(const N* name, unsigned int hash, int len);
28615
1fb960ea5a7e 8067982: Some jcmd /gc/heap_dump tests failed: hprof output contains warning or error.
jiangli
parents: 28363
diff changeset
   264
1fb960ea5a7e 8067982: Some jcmd /gc/heap_dump tests failed: hprof output contains warning or error.
jiangli
parents: 28363
diff changeset
   265
  // iterate over symbols
1fb960ea5a7e 8067982: Some jcmd /gc/heap_dump tests failed: hprof output contains warning or error.
jiangli
parents: 28363
diff changeset
   266
  void symbols_do(SymbolClosure *cl);
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   267
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   268
  // iterate over strings
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   269
  void oops_do(OopClosure* f);
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   270
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   271
  // For reading from/writing to the CDS archive
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   272
  void serialize(SerializeClosure* soc);
39713
29ece76096cb 8150752: Share Class Data
iklam
parents: 37995
diff changeset
   273
29ece76096cb 8150752: Share Class Data
iklam
parents: 37995
diff changeset
   274
  uintx base_address() {
29ece76096cb 8150752: Share Class Data
iklam
parents: 37995
diff changeset
   275
    return (uintx) _base_address;
29ece76096cb 8150752: Share Class Data
iklam
parents: 37995
diff changeset
   276
  }
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   277
};
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   278
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   279
////////////////////////////////////////////////////////////////////////
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   280
//
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   281
// Read/Write the contents of a hashtable textual dump (created by
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   282
// SymbolTable::dump and StringTable::dump).
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   283
// Because the dump file may be big (hundred of MB in extreme cases),
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   284
// we use mmap for fast access when reading it.
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   285
//
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   286
class HashtableTextDump VALUE_OBJ_CLASS_SPEC {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   287
  int _fd;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   288
  const char* _base;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   289
  const char* _p;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   290
  const char* _end;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   291
  const char* _filename;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   292
  size_t      _size;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   293
  int         _prefix_type;
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   294
  int         _line_no;
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   295
public:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   296
  HashtableTextDump(const char* filename);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   297
  ~HashtableTextDump();
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   298
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   299
  enum {
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   300
    SymbolPrefix = 1 << 0,
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   301
    StringPrefix = 1 << 1,
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   302
    Unknown = 1 << 2
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   303
  };
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   304
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   305
  void quit(const char* err, const char* msg);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   306
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   307
  inline int remain() {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   308
    return (int)(_end - _p);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   309
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   310
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   311
  void corrupted(const char *p, const char *msg);
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   312
35868
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   313
  inline void corrupted_if(bool cond, const char *msg) {
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   314
    if (cond) {
35868
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   315
      corrupted(_p, msg);
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   316
    }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   317
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   318
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   319
  bool skip_newline();
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   320
  int skip(char must_be_char);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   321
  void skip_past(char c);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   322
  void check_version(const char* ver);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   323
35868
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   324
  inline void get_num(char delim, int *num) {
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   325
    const char* p   = _p;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   326
    const char* end = _end;
35868
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   327
    u8 n = 0;
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   328
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   329
    while (p < end) {
37995
92aec042a43b 8150607: Clean up CompactHashtable
iklam
parents: 35868
diff changeset
   330
      char c = *p++;
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   331
      if ('0' <= c && c <= '9') {
35868
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   332
        n = n * 10 + (c - '0');
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   333
        if (n > (u8)INT_MAX) {
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   334
          corrupted(_p, "Num overflow");
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   335
        }
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   336
      } else if (c == delim) {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   337
        _p = p;
35868
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   338
        *num = (int)n;
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   339
        return;
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   340
      } else {
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   341
        // Not [0-9], not 'delim'
35868
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   342
        corrupted(_p, "Unrecognized format");;
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   343
      }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   344
    }
35868
bf29f15cdf30 8147500: The HashtableTextDump::get_num() should check for integer overflow
jiangli
parents: 34659
diff changeset
   345
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   346
    corrupted(_end, "Incorrect format");
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   347
    ShouldNotReachHere();
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   348
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   349
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   350
  void scan_prefix_type();
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   351
  int scan_prefix(int* utf8_length);
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   352
  int scan_string_prefix();
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 28822
diff changeset
   353
  int scan_symbol_prefix();
28363
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   354
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   355
  jchar unescape(const char* from, const char* end, int count);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   356
  void get_utf8(char* utf8_buffer, int utf8_length);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   357
  static void put_utf8(outputStream* st, const char* utf8_string, int utf8_length);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   358
};
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   359
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   360
///////////////////////////////////////////////////////////////////////
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   361
//
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   362
// jcmd command support for symbol table and string table dumping:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   363
//   VM.symboltable -verbose: for dumping the symbol table
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   364
//   VM.stringtable -verbose: for dumping the string table
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   365
//
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   366
class VM_DumpHashtable : public VM_Operation {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   367
private:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   368
  outputStream* _out;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   369
  int _which;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   370
  bool _verbose;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   371
public:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   372
  enum {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   373
    DumpSymbols = 1 << 0,
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   374
    DumpStrings = 1 << 1,
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   375
    DumpSysDict = 1 << 2  // not implemented yet
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   376
  };
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   377
  VM_DumpHashtable(outputStream* out, int which, bool verbose) {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   378
    _out = out;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   379
    _which = which;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   380
    _verbose = verbose;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   381
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   382
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   383
  virtual VMOp_Type type() const { return VMOp_DumpHashtable; }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   384
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   385
  virtual void doit() {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   386
    switch (_which) {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   387
    case DumpSymbols:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   388
      SymbolTable::dump(_out, _verbose);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   389
      break;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   390
    case DumpStrings:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   391
      StringTable::dump(_out, _verbose);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   392
      break;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   393
    default:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   394
      ShouldNotReachHere();
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   395
    }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   396
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   397
};
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   398
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   399
class SymboltableDCmd : public DCmdWithParser {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   400
protected:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   401
  DCmdArgument<bool> _verbose;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   402
public:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   403
  SymboltableDCmd(outputStream* output, bool heap);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   404
  static const char* name() {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   405
    return "VM.symboltable";
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   406
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   407
  static const char* description() {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   408
    return "Dump symbol table.";
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   409
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   410
  static const char* impact() {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   411
    return "Medium: Depends on Java content.";
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   412
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   413
  static const JavaPermission permission() {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   414
    JavaPermission p = {"java.lang.management.ManagementPermission",
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   415
                        "monitor", NULL};
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   416
    return p;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   417
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   418
  static int num_arguments();
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   419
  virtual void execute(DCmdSource source, TRAPS);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   420
};
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   421
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   422
class StringtableDCmd : public DCmdWithParser {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   423
protected:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   424
  DCmdArgument<bool> _verbose;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   425
public:
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   426
  StringtableDCmd(outputStream* output, bool heap);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   427
  static const char* name() {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   428
    return "VM.stringtable";
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   429
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   430
  static const char* description() {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   431
    return "Dump string table.";
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   432
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   433
  static const char* impact() {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   434
    return "Medium: Depends on Java content.";
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   435
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   436
  static const JavaPermission permission() {
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   437
    JavaPermission p = {"java.lang.management.ManagementPermission",
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   438
                        "monitor", NULL};
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   439
    return p;
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   440
  }
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   441
  static int num_arguments();
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   442
  virtual void execute(DCmdSource source, TRAPS);
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   443
};
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   444
047115468f16 8059510: Compact symbol table layout inside shared archive.
jiangli
parents:
diff changeset
   445
#endif // SHARE_VM_CLASSFILE_COMPACTHASHTABLE_HPP