src/share/vm/prims/jvmtiTagMap.hpp

Fri, 07 Jan 2011 10:42:32 -0500

author
phh
date
Fri, 07 Jan 2011 10:42:32 -0500
changeset 2423
b1a2afa37ec4
parent 2314
f95d63e2154a
child 2445
7246a374a9f2
permissions
-rw-r--r--

7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
Summary: Track allocated bytes in Thread's, update on TLAB retirement and direct allocation in Eden and tenured, add JNI methods for ThreadMXBean.
Reviewed-by: coleenp, kvn, dholmes, ysr

duke@435 1 /*
stefank@2314 2 * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
duke@435 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
duke@435 4 *
duke@435 5 * This code is free software; you can redistribute it and/or modify it
duke@435 6 * under the terms of the GNU General Public License version 2 only, as
duke@435 7 * published by the Free Software Foundation.
duke@435 8 *
duke@435 9 * This code is distributed in the hope that it will be useful, but WITHOUT
duke@435 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
duke@435 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
duke@435 12 * version 2 for more details (a copy is included in the LICENSE file that
duke@435 13 * accompanied this code).
duke@435 14 *
duke@435 15 * You should have received a copy of the GNU General Public License version
duke@435 16 * 2 along with this work; if not, write to the Free Software Foundation,
duke@435 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
duke@435 18 *
trims@1907 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
trims@1907 20 * or visit www.oracle.com if you need additional information or have any
trims@1907 21 * questions.
duke@435 22 *
duke@435 23 */
duke@435 24
duke@435 25 // JvmtiTagMap
duke@435 26
stefank@2314 27 #ifndef SHARE_VM_PRIMS_JVMTITAGMAP_HPP
stefank@2314 28 #define SHARE_VM_PRIMS_JVMTITAGMAP_HPP
stefank@2314 29
stefank@2314 30 #ifndef JVMTI_KERNEL
stefank@2314 31 #include "gc_interface/collectedHeap.hpp"
stefank@2314 32 #include "jvmtifiles/jvmti.h"
stefank@2314 33 #include "jvmtifiles/jvmtiEnv.hpp"
stefank@2314 34 #include "memory/allocation.hpp"
stefank@2314 35 #include "memory/genCollectedHeap.hpp"
stefank@2314 36 #include "memory/universe.hpp"
stefank@2314 37 #endif
duke@435 38
duke@435 39 // forward references
duke@435 40 class JvmtiTagHashmap;
duke@435 41 class JvmtiTagHashmapEntry;
duke@435 42 class JvmtiTagHashmapEntryClosure;
duke@435 43
duke@435 44 class JvmtiTagMap : public CHeapObj {
duke@435 45 private:
duke@435 46
duke@435 47 enum{
duke@435 48 n_hashmaps = 2, // encapsulates 2 hashmaps
duke@435 49 max_free_entries = 4096 // maximum number of free entries per env
duke@435 50 };
duke@435 51
duke@435 52 // memory region for young generation
duke@435 53 static MemRegion _young_gen;
duke@435 54 static void get_young_generation();
duke@435 55
duke@435 56 JvmtiEnv* _env; // the jvmti environment
duke@435 57 Mutex _lock; // lock for this tag map
duke@435 58 JvmtiTagHashmap* _hashmap[n_hashmaps]; // the hashmaps
duke@435 59
duke@435 60 JvmtiTagHashmapEntry* _free_entries; // free list for this environment
duke@435 61 int _free_entries_count; // number of entries on the free list
duke@435 62
duke@435 63 // create a tag map
duke@435 64 JvmtiTagMap(JvmtiEnv* env);
duke@435 65
duke@435 66 // accessors
duke@435 67 inline Mutex* lock() { return &_lock; }
duke@435 68 inline JvmtiEnv* env() const { return _env; }
duke@435 69
duke@435 70 // rehash tags maps for generation start to end
duke@435 71 void rehash(int start, int end);
duke@435 72
duke@435 73 // indicates if the object is in the young generation
duke@435 74 static bool is_in_young(oop o);
duke@435 75
duke@435 76 // iterate over all entries in this tag map
duke@435 77 void entry_iterate(JvmtiTagHashmapEntryClosure* closure);
duke@435 78
duke@435 79 public:
duke@435 80
duke@435 81 // indicates if this tag map is locked
duke@435 82 bool is_locked() { return lock()->is_locked(); }
duke@435 83
duke@435 84 // return the appropriate hashmap for a given object
duke@435 85 JvmtiTagHashmap* hashmap_for(oop o);
duke@435 86
duke@435 87 // create/destroy entries
duke@435 88 JvmtiTagHashmapEntry* create_entry(jweak ref, jlong tag);
duke@435 89 void destroy_entry(JvmtiTagHashmapEntry* entry);
duke@435 90
duke@435 91 // returns true if the hashmaps are empty
duke@435 92 bool is_empty();
duke@435 93
duke@435 94 // return tag for the given environment
duke@435 95 static JvmtiTagMap* tag_map_for(JvmtiEnv* env);
duke@435 96
duke@435 97 // destroy tag map
duke@435 98 ~JvmtiTagMap();
duke@435 99
duke@435 100 // set/get tag
duke@435 101 void set_tag(jobject obj, jlong tag);
duke@435 102 jlong get_tag(jobject obj);
duke@435 103
duke@435 104 // deprecated heap iteration functions
duke@435 105 void iterate_over_heap(jvmtiHeapObjectFilter object_filter,
duke@435 106 KlassHandle klass,
duke@435 107 jvmtiHeapObjectCallback heap_object_callback,
duke@435 108 const void* user_data);
duke@435 109
duke@435 110 void iterate_over_reachable_objects(jvmtiHeapRootCallback heap_root_callback,
duke@435 111 jvmtiStackReferenceCallback stack_ref_callback,
duke@435 112 jvmtiObjectReferenceCallback object_ref_callback,
duke@435 113 const void* user_data);
duke@435 114
duke@435 115 void iterate_over_objects_reachable_from_object(jobject object,
duke@435 116 jvmtiObjectReferenceCallback object_reference_callback,
duke@435 117 const void* user_data);
duke@435 118
duke@435 119
duke@435 120 // advanced (JVMTI 1.1) heap iteration functions
duke@435 121 void iterate_through_heap(jint heap_filter,
duke@435 122 KlassHandle klass,
duke@435 123 const jvmtiHeapCallbacks* callbacks,
duke@435 124 const void* user_data);
duke@435 125
duke@435 126 void follow_references(jint heap_filter,
duke@435 127 KlassHandle klass,
duke@435 128 jobject initial_object,
duke@435 129 const jvmtiHeapCallbacks* callbacks,
duke@435 130 const void* user_data);
duke@435 131
duke@435 132 // get tagged objects
duke@435 133 jvmtiError get_objects_with_tags(const jlong* tags, jint count,
duke@435 134 jint* count_ptr, jobject** object_result_ptr,
duke@435 135 jlong** tag_result_ptr);
duke@435 136
duke@435 137 // call post-GC to rehash the tag maps.
duke@435 138 static void gc_epilogue(bool full);
duke@435 139
duke@435 140 // call after referencing processing has completed (CMS)
duke@435 141 static void cms_ref_processing_epilogue();
duke@435 142 };
duke@435 143
stefank@2314 144 #endif // SHARE_VM_PRIMS_JVMTITAGMAP_HPP

mercurial