heapInspection.hpp revision 0:a61af66fc99e
1/*
2 * Copyright 2002-2006 Sun Microsystems, Inc.  All Rights Reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.
8 *
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
20 * CA 95054 USA or visit www.sun.com if you need additional information or
21 * have any questions.
22 *
23 */
24
25#ifndef SERVICES_KERNEL
26
27
28// HeapInspection
29
30// KlassInfoTable is a bucket hash table that
31// maps klassOops to extra information:
32//    instance count and instance word size.
33//
34// A KlassInfoBucket is the head of a link list
35// of KlassInfoEntry's
36//
37// KlassInfoHisto is a growable array of pointers
38// to KlassInfoEntry's and is used to sort
39// the entries.
40
41class KlassInfoEntry: public CHeapObj {
42 private:
43  KlassInfoEntry* _next;
44  klassOop        _klass;
45  long            _instance_count;
46  size_t          _instance_words;
47
48 public:
49  KlassInfoEntry(klassOop k, KlassInfoEntry* next) :
50    _klass(k), _instance_count(0), _instance_words(0), _next(next)
51  {}
52  KlassInfoEntry* next()     { return _next; }
53  bool is_equal(klassOop k)  { return k == _klass; }
54  klassOop klass()           { return _klass; }
55  long count()               { return _instance_count; }
56  void set_count(long ct)    { _instance_count = ct; }
57  size_t words()             { return _instance_words; }
58  void set_words(size_t wds) { _instance_words = wds; }
59  int compare(KlassInfoEntry* e1, KlassInfoEntry* e2);
60  void print_on(outputStream* st) const;
61};
62
63class KlassInfoClosure: public StackObj {
64 public:
65  // Called for each KlassInfoEntry.
66  virtual void do_cinfo(KlassInfoEntry* cie) = 0;
67};
68
69class KlassInfoBucket: public CHeapObj {
70 private:
71  KlassInfoEntry* _list;
72  KlassInfoEntry* list()           { return _list; }
73  void set_list(KlassInfoEntry* l) { _list = l; }
74 public:
75  KlassInfoEntry* lookup(const klassOop k);
76  void initialize() { _list = NULL; }
77  void empty();
78  void iterate(KlassInfoClosure* cic);
79};
80
81class KlassInfoTable: public StackObj {
82 private:
83  int _size;
84
85  // An aligned reference address (typically the least
86  // address in the perm gen) used for hashing klass
87  // objects.
88  HeapWord* _ref;
89
90  KlassInfoBucket* _buckets;
91  uint hash(klassOop p);
92  KlassInfoEntry* lookup(const klassOop k);
93
94 public:
95  // Table size
96  enum {
97    cit_size = 20011
98  };
99  KlassInfoTable(int size, HeapWord* ref);
100  ~KlassInfoTable();
101  void record_instance(const oop obj);
102  void iterate(KlassInfoClosure* cic);
103};
104
105class KlassInfoHisto : public StackObj {
106 private:
107  GrowableArray<KlassInfoEntry*>* _elements;
108  GrowableArray<KlassInfoEntry*>* elements() const { return _elements; }
109  const char* _title;
110  const char* title() const { return _title; }
111  static int sort_helper(KlassInfoEntry** e1, KlassInfoEntry** e2);
112  void print_elements(outputStream* st) const;
113 public:
114  enum {
115    histo_initial_size = 1000
116  };
117  KlassInfoHisto(const char* title,
118             int estimatedCount);
119  ~KlassInfoHisto();
120  void add(KlassInfoEntry* cie);
121  void print_on(outputStream* st) const;
122  void sort();
123};
124
125#endif // SERVICES_KERNEL
126
127class HeapInspection : public AllStatic {
128 public:
129  static void heap_inspection(outputStream* st) KERNEL_RETURN;
130  static void find_instances_at_safepoint(klassOop k, GrowableArray<oop>* result) KERNEL_RETURN;
131};
132