1 /* 2 * Copyright (c) 2003, 2004, Oracle and/or its affiliates. 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 20 * or visit www.oracle.com if you need additional information or have any 21 * questions. 22 * 23 */ 24 25 #ifndef _JAVA_JVMTI_EVENT_CONTROLLER_H_ 26 #define _JAVA_JVMTI_EVENT_CONTROLLER_H_ 27 28 // forward declaration 29 class JvmtiEventControllerPrivate; 30 class JvmtiEventController; 31 class JvmtiEnvThreadState; 32 class JvmtiFramePop; 33 class JvmtiEnvBase; 34 35 36 // Extension event support 37 // 38 // jvmtiExtEvent is the extensions equivalent of jvmtiEvent 39 // jvmtiExtCallbacks is the extensions equivalent of jvmtiEventCallbacks 40 41 // Extension events start JVMTI_MIN_EVENT_TYPE_VAL-1 and work towards 0. 42 typedef enum { 43 EXT_EVENT_CLASS_UNLOAD = JVMTI_MIN_EVENT_TYPE_VAL-1, 44 EXT_MIN_EVENT_TYPE_VAL = EXT_EVENT_CLASS_UNLOAD, 45 EXT_MAX_EVENT_TYPE_VAL = EXT_EVENT_CLASS_UNLOAD 46 } jvmtiExtEvent; 47 48 typedef struct { 49 jvmtiExtensionEvent ClassUnload; 50 } jvmtiExtEventCallbacks; 51 52 53 // The complete range of events is EXT_MIN_EVENT_TYPE_VAL to 54 // JVMTI_MAX_EVENT_TYPE_VAL (inclusive and contiguous). 55 const int TOTAL_MIN_EVENT_TYPE_VAL = EXT_MIN_EVENT_TYPE_VAL; 56 const int TOTAL_MAX_EVENT_TYPE_VAL = JVMTI_MAX_EVENT_TYPE_VAL; 57 58 59 /////////////////////////////////////////////////////////////// 60 // 61 // JvmtiEventEnabled 62 // 63 // Utility class 64 // 65 // A boolean array indexed by event_type, used as an internal 66 // data structure to track what JVMTI event types are enabled. 67 // Used for user set enabling and disabling (globally and on a 68 // per thread basis), and for computed merges across environments, 69 // threads and the VM as a whole. 70 // 71 // for inlines see jvmtiEventController_inline.hpp 72 // 73 74 class JvmtiEventEnabled VALUE_OBJ_CLASS_SPEC { 75 private: 76 friend class JvmtiEventControllerPrivate; 77 jlong _enabled_bits; 78 #ifndef PRODUCT 79 enum { 80 JEE_INIT_GUARD = 0xEAD0 81 } _init_guard; 82 #endif 83 static jlong bit_for(jvmtiEvent event_type); 84 jlong get_bits(); 85 void set_bits(jlong bits); 86 public: 87 JvmtiEventEnabled(); 88 void clear(); 89 bool is_enabled(jvmtiEvent event_type); 90 void set_enabled(jvmtiEvent event_type, bool enabled); 91 }; 92 93 94 /////////////////////////////////////////////////////////////// 95 // 96 // JvmtiEnvThreadEventEnable 97 // 98 // JvmtiEventController data specific to a particular environment and thread. 99 // 100 // for inlines see jvmtiEventController_inline.hpp 101 // 102 103 class JvmtiEnvThreadEventEnable VALUE_OBJ_CLASS_SPEC { 104 private: 105 friend class JvmtiEventControllerPrivate; 106 JvmtiEventEnabled _event_user_enabled; 107 JvmtiEventEnabled _event_enabled; 108 109 public: 110 JvmtiEnvThreadEventEnable(); 111 ~JvmtiEnvThreadEventEnable(); 112 bool is_enabled(jvmtiEvent event_type); 113 void set_user_enabled(jvmtiEvent event_type, bool enabled); 114 }; 115 116 117 /////////////////////////////////////////////////////////////// 118 // 119 // JvmtiThreadEventEnable 120 // 121 // JvmtiEventController data specific to a particular thread. 122 // 123 // for inlines see jvmtiEventController_inline.hpp 124 // 125 126 class JvmtiThreadEventEnable VALUE_OBJ_CLASS_SPEC { 127 private: 128 friend class JvmtiEventControllerPrivate; 129 JvmtiEventEnabled _event_enabled; 130 131 public: 132 JvmtiThreadEventEnable(); 133 ~JvmtiThreadEventEnable(); 134 bool is_enabled(jvmtiEvent event_type); 135 }; 136 137 138 /////////////////////////////////////////////////////////////// 139 // 140 // JvmtiEnvEventEnable 141 // 142 // JvmtiEventController data specific to a particular environment. 143 // 144 // for inlines see jvmtiEventController_inline.hpp 145 // 146 147 class JvmtiEnvEventEnable VALUE_OBJ_CLASS_SPEC { 148 private: 149 friend class JvmtiEventControllerPrivate; 150 151 // user set global event enablement indexed by jvmtiEvent 152 JvmtiEventEnabled _event_user_enabled; 153 154 // this flag indicates the presence (true) or absence (false) of event callbacks 155 // it is indexed by jvmtiEvent 156 JvmtiEventEnabled _event_callback_enabled; 157 158 // indexed by jvmtiEvent true if enabled globally or on any thread. 159 // True only if there is a callback for it. 160 JvmtiEventEnabled _event_enabled; 161 162 public: 163 JvmtiEnvEventEnable(); 164 ~JvmtiEnvEventEnable(); 165 bool is_enabled(jvmtiEvent event_type); 166 void set_user_enabled(jvmtiEvent event_type, bool enabled); 167 }; 168 169 170 /////////////////////////////////////////////////////////////// 171 // 172 // JvmtiEventController 173 // 174 // The class is the access point for all actions that change 175 // which events are active, this include: 176 // enabling and disabling events 177 // changing the callbacks/eventhook (they may be null) 178 // setting and clearing field watchpoints 179 // setting frame pops 180 // encountering frame pops 181 // 182 // for inlines see jvmtiEventController_inline.hpp 183 // 184 185 class JvmtiEventController : AllStatic { 186 private: 187 friend class JvmtiEventControllerPrivate; 188 189 // for all environments, global array indexed by jvmtiEvent 190 static JvmtiEventEnabled _universal_global_event_enabled; 191 192 public: 193 static bool is_enabled(jvmtiEvent event_type); 194 195 // events that can ONLY be enabled/disabled globally (can't toggle on individual threads). 196 static bool is_global_event(jvmtiEvent event_type); 197 198 // is the event_type valid? 199 // to do: check against valid event array 200 static bool is_valid_event_type(jvmtiEvent event_type) { 201 return ((int)event_type >= TOTAL_MIN_EVENT_TYPE_VAL) 202 && ((int)event_type <= TOTAL_MAX_EVENT_TYPE_VAL); 203 } 204 205 // Use (thread == NULL) to enable/disable an event globally. 206 // Use (thread != NULL) to enable/disable an event for a particular thread. 207 // thread is ignored for events that can only be specified globally 208 static void set_user_enabled(JvmtiEnvBase *env, JavaThread *thread, 209 jvmtiEvent event_type, bool enabled); 210 211 // Setting callbacks changes computed enablement and must be done 212 // at a safepoint otherwise a NULL callback could be attempted 213 static void set_event_callbacks(JvmtiEnvBase *env, 214 const jvmtiEventCallbacks* callbacks, 215 jint size_of_callbacks); 216 217 // Sets the callback function for a single extension event and enables 218 // (or disables it). 219 static void set_extension_event_callback(JvmtiEnvBase* env, 220 jint extension_event_index, 221 jvmtiExtensionEvent callback); 222 223 static void set_frame_pop(JvmtiEnvThreadState *env_thread, JvmtiFramePop fpop); 224 static void clear_frame_pop(JvmtiEnvThreadState *env_thread, JvmtiFramePop fpop); 225 static void clear_to_frame_pop(JvmtiEnvThreadState *env_thread, JvmtiFramePop fpop); 226 227 static void change_field_watch(jvmtiEvent event_type, bool added); 228 229 static void thread_started(JavaThread *thread); 230 static void thread_ended(JavaThread *thread); 231 232 static void env_initialize(JvmtiEnvBase *env); 233 static void env_dispose(JvmtiEnvBase *env); 234 235 static void vm_start(); 236 static void vm_init(); 237 static void vm_death(); 238 }; 239 240 #endif /* _JAVA_JVMTI_EVENT_CONTROLLER_H_ */