mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-25 22:04:51 +02:00
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com> Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com> Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com> Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
This commit is contained in:
parent
36eee7c8c8
commit
5c58d27aac
853 changed files with 26124 additions and 82956 deletions
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright (c) 1998, 2011, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
|
@ -69,11 +69,11 @@
|
|||
// TODO-FIXME: probes should not fire when caller is _blocked. assert() accordingly.
|
||||
|
||||
|
||||
#define DTRACE_MONITOR_PROBE_COMMON(klassOop, thread) \
|
||||
#define DTRACE_MONITOR_PROBE_COMMON(obj, thread) \
|
||||
char* bytes = NULL; \
|
||||
int len = 0; \
|
||||
jlong jtid = SharedRuntime::get_java_tid(thread); \
|
||||
Symbol* klassname = ((oop)(klassOop))->klass()->klass_part()->name(); \
|
||||
Symbol* klassname = ((oop)obj)->klass()->name(); \
|
||||
if (klassname != NULL) { \
|
||||
bytes = (char*)klassname->bytes(); \
|
||||
len = klassname->utf8_length(); \
|
||||
|
@ -92,19 +92,19 @@ HS_DTRACE_PROBE_DECL4(hotspot, monitor__contended__entered,
|
|||
HS_DTRACE_PROBE_DECL4(hotspot, monitor__contended__exit,
|
||||
jlong, uintptr_t, char*, int);
|
||||
|
||||
#define DTRACE_MONITOR_WAIT_PROBE(monitor, klassOop, thread, millis) \
|
||||
#define DTRACE_MONITOR_WAIT_PROBE(monitor, obj, thread, millis) \
|
||||
{ \
|
||||
if (DTraceMonitorProbes) { \
|
||||
DTRACE_MONITOR_PROBE_COMMON(klassOop, thread); \
|
||||
DTRACE_MONITOR_PROBE_COMMON(obj, thread); \
|
||||
HS_DTRACE_PROBE5(hotspot, monitor__wait, jtid, \
|
||||
(monitor), bytes, len, (millis)); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define DTRACE_MONITOR_PROBE(probe, monitor, klassOop, thread) \
|
||||
#define DTRACE_MONITOR_PROBE(probe, monitor, obj, thread) \
|
||||
{ \
|
||||
if (DTraceMonitorProbes) { \
|
||||
DTRACE_MONITOR_PROBE_COMMON(klassOop, thread); \
|
||||
DTRACE_MONITOR_PROBE_COMMON(obj, thread); \
|
||||
HS_DTRACE_PROBE4(hotspot, monitor__##probe, jtid, \
|
||||
(uintptr_t)(monitor), bytes, len); \
|
||||
} \
|
||||
|
@ -112,10 +112,10 @@ HS_DTRACE_PROBE_DECL4(hotspot, monitor__contended__exit,
|
|||
|
||||
#else /* USDT2 */
|
||||
|
||||
#define DTRACE_MONITOR_WAIT_PROBE(monitor, klassOop, thread, millis) \
|
||||
#define DTRACE_MONITOR_WAIT_PROBE(monitor, obj, thread, millis) \
|
||||
{ \
|
||||
if (DTraceMonitorProbes) { \
|
||||
DTRACE_MONITOR_PROBE_COMMON(klassOop, thread); \
|
||||
DTRACE_MONITOR_PROBE_COMMON(obj, thread); \
|
||||
HOTSPOT_MONITOR_WAIT(jtid, \
|
||||
(monitor), bytes, len, (millis)); \
|
||||
} \
|
||||
|
@ -127,10 +127,10 @@ HS_DTRACE_PROBE_DECL4(hotspot, monitor__contended__exit,
|
|||
#define HOTSPOT_MONITOR_notify HOTSPOT_MONITOR_NOTIFY
|
||||
#define HOTSPOT_MONITOR_notifyAll HOTSPOT_MONITOR_NOTIFYALL
|
||||
|
||||
#define DTRACE_MONITOR_PROBE(probe, monitor, klassOop, thread) \
|
||||
#define DTRACE_MONITOR_PROBE(probe, monitor, obj, thread) \
|
||||
{ \
|
||||
if (DTraceMonitorProbes) { \
|
||||
DTRACE_MONITOR_PROBE_COMMON(klassOop, thread); \
|
||||
DTRACE_MONITOR_PROBE_COMMON(obj, thread); \
|
||||
HOTSPOT_MONITOR_##probe(jtid, \
|
||||
(uintptr_t)(monitor), bytes, len); \
|
||||
} \
|
||||
|
@ -139,8 +139,8 @@ HS_DTRACE_PROBE_DECL4(hotspot, monitor__contended__exit,
|
|||
#endif /* USDT2 */
|
||||
#else // ndef DTRACE_ENABLED
|
||||
|
||||
#define DTRACE_MONITOR_WAIT_PROBE(klassOop, thread, millis, mon) {;}
|
||||
#define DTRACE_MONITOR_PROBE(probe, klassOop, thread, mon) {;}
|
||||
#define DTRACE_MONITOR_WAIT_PROBE(obj, thread, millis, mon) {;}
|
||||
#define DTRACE_MONITOR_PROBE(probe, obj, thread, mon) {;}
|
||||
|
||||
#endif // ndef DTRACE_ENABLED
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue