From c0475c81f2add596d1b84a1a248fc39231ab1d1a Mon Sep 17 00:00:00 2001 From: Mandy Chung Date: Thu, 11 Jun 2020 11:07:09 -0700 Subject: [PATCH] 8247247: JFR tests fail due to JDK-8235521 missing doPrivileged block Reviewed-by: egahlin --- .../jdk/jfr/internal/MetadataRepository.java | 12 +++++++----- .../classes/jdk/jfr/internal/SecuritySupport.java | 15 ++++++++++++++- 2 files changed, 21 insertions(+), 6 deletions(-) diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/MetadataRepository.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/MetadataRepository.java index 5acefa6ec1f..fe6775af4a6 100644 --- a/src/jdk.jfr/share/classes/jdk/jfr/internal/MetadataRepository.java +++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/MetadataRepository.java @@ -109,7 +109,7 @@ public final class MetadataRepository { } public synchronized EventType getEventType(Class eventClass) { - EventHandler h = getHandler(eventClass); + EventHandler h = getHandler(eventClass, false); if (h != null && h.isRegistered()) { return h.getEventType(); } @@ -118,7 +118,7 @@ public final class MetadataRepository { public synchronized void unregister(Class eventClass) { Utils.checkRegisterPermission(); - EventHandler handler = getHandler(eventClass); + EventHandler handler = getHandler(eventClass, false); if (handler != null) { handler.setRegistered(false); } @@ -130,7 +130,7 @@ public final class MetadataRepository { public synchronized EventType register(Class eventClass, List dynamicAnnotations, List dynamicFields) { Utils.checkRegisterPermission(); - EventHandler handler = getHandler(eventClass); + EventHandler handler = getHandler(eventClass, true); if (handler == null) { if (eventClass.getAnnotation(MirrorEvent.class) != null) { // don't register mirrors @@ -165,10 +165,12 @@ public final class MetadataRepository { return et; } - private EventHandler getHandler(Class eventClass) { + private EventHandler getHandler(Class eventClass, boolean ensureInitialized) { Utils.ensureValidEventSubclass(eventClass); SecuritySupport.makeVisibleToJFR(eventClass); - Utils.ensureInitialized(eventClass); + if (ensureInitialized) { + Utils.ensureInitialized(eventClass); + } return Utils.getHandler(eventClass); } diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/SecuritySupport.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/SecuritySupport.java index f60040defe5..73b9a9fed8c 100644 --- a/src/jdk.jfr/share/classes/jdk/jfr/internal/SecuritySupport.java +++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/SecuritySupport.java @@ -432,9 +432,22 @@ public final class SecuritySupport { static void ensureClassIsInitialized(Class clazz) { try { - MethodHandles.privateLookupIn(clazz, LOOKUP).ensureInitialized(clazz); + MethodHandles.Lookup lookup; + if (System.getSecurityManager() == null) { + lookup = MethodHandles.privateLookupIn(clazz, LOOKUP); + } else { + lookup = AccessController.doPrivileged(new PrivilegedExceptionAction<>() { + @Override + public MethodHandles.Lookup run() throws IllegalAccessException { + return MethodHandles.privateLookupIn(clazz, LOOKUP); + } + }, null, new ReflectPermission("suppressAccessChecks")); + } + lookup.ensureInitialized(clazz); } catch (IllegalAccessException e) { throw new InternalError(e); + } catch (PrivilegedActionException e) { + throw new InternalError(e.getCause()); } }