src/share/vm/memory/metaspaceTracer.cpp

Print this page
rev 6084 : 8036699: webrev.00 -> webrev.01

*** 23,39 **** */ #include "precompiled.hpp" #include "classfile/classLoaderData.hpp" #include "memory/metaspaceTracer.hpp" - #include "runtime/frame.hpp" - #include "runtime/os.hpp" - #include "runtime/thread.inline.hpp" #include "trace/tracing.hpp" #include "trace/traceBackend.hpp" - #include "utilities/decoder.hpp" - #include "utilities/ostream.hpp" void MetaspaceTracer::report_gc_threshold(size_t old_val, size_t new_val, MetaspaceGCThresholdUpdater::Type updater) const { EventMetaspaceGCThreshold event; --- 23,34 ----
*** 43,91 **** event.set_updater((u1)updater); event.commit(); } } - static bool get_method_name(address pc, char *buf, size_t buflen) { - if (os::address_is_in_vm(pc) && Decoder::can_decode_C_frame_in_vm()) { - return os::dll_address_to_function_name(pc, buf, (int) buflen, 0); - } - return false; - } - - static bool is_valid_frame_in_vm(const frame* f) { - return f->pc() && os::address_is_in_vm(f->pc()) && !f->is_java_frame(); - } - - static void write_vm_stack_trace(outputStream *stream) { - const size_t max_num_frames = 64; - size_t num_frames = 0; - - const size_t buflen = 256; - char *buf = NEW_RESOURCE_ARRAY(char, buflen); - - Thread* current_thread = Thread::current(); - frame fr = os::current_frame(); - while (is_valid_frame_in_vm(&fr) && num_frames < max_num_frames) { - if (get_method_name(fr.pc(), buf, buflen)) { - stream->print_cr("%s", buf); - } else { - stream->print_cr(PTR_FORMAT, fr.pc()); - } - - // Check if it safe to get the caller's stack frame. - if (fr.safe_for_sender(current_thread)) { - fr = os::get_sender_for_C_frame(&fr); - } else { - // Not safe to traverse the stack any further. - return; - } - - num_frames++; - } - } - void MetaspaceTracer::report_metaspace_allocation_failure(ClassLoaderData *cld, size_t word_size, MetaspaceObj::Type objtype, Metaspace::MetadataType mdtype) const { EventMetaspaceAllocationFailure event; --- 38,47 ----
*** 100,119 **** event.set_classLoader(cld->class_loader()->klass()); } event.set_anonymousClassLoader(false); } - #ifdef _WINDOWS - // Can not walk the stack on Windows using the frame pointer. - event.set_nativeStackTrace(NULL); - #else - ResourceMark rm; - stringStream stack_trace; - write_vm_stack_trace(&stack_trace); - event.set_nativeStackTrace(stack_trace.as_string()); - #endif - event.set_size(word_size * BytesPerWord); event.set_metadataType((u1) mdtype); event.set_metaspaceObjectType((u1) objtype); event.commit(); } --- 56,65 ----