1 /* 2 * Copyright (c) 2016, 2018, 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. Oracle designates this 8 * particular file as subject to the "Classpath" exception as provided 9 * by Oracle in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 22 * or visit www.oracle.com if you need additional information or have any 23 * questions. 24 */ 25 package jdk.jfr.internal; 26 27 import java.io.IOException; 28 29 /** 30 * Checks if the running VM supports Flight Recorder. 31 * 32 * Purpose of this helper class is to detect early and cleanly if the VM has 33 * support for Flight Recorder, i.e. not throw {@link UnsatisfiedLinkError} in 34 * unexpected places. 35 * <p> 36 * This is needed so a disabled-jfr.jar can be built for non Oracle JDKs. 37 */ 38 public final class JVMSupport { 39 40 private static final String UNSUPPORTED_VM_MESSAGE = "Flight Recorder is not supported on this VM"; 41 private static final boolean notAvailable = !checkAvailability(); 42 43 private static boolean checkAvailability() { 44 // set jfr.unsupported.vm to true to test API on an unsupported VM 45 try { 46 if (SecuritySupport.getBooleanProperty("jfr.unsupported.vm")) { 47 return false; 48 } 49 } catch (NoClassDefFoundError cnfe) { 50 return false; 51 } 52 try { 53 // Will typically throw UnsatisfiedLinkError if 54 // there is no native implementation 55 JVM.getJVM().isAvailable(); 56 return true; 57 } catch (Throwable t) { 58 return false; 59 } 60 } 61 62 public static void ensureWithInternalError() { 63 if (notAvailable) { 64 throw new InternalError(UNSUPPORTED_VM_MESSAGE); 65 } 66 } 67 68 public static void ensureWithIOException() throws IOException { 69 if (notAvailable) { 70 throw new IOException(UNSUPPORTED_VM_MESSAGE); 71 } 72 } 73 74 public static void ensureWithIllegalStateException() { 75 if (notAvailable) { 76 throw new IllegalStateException(UNSUPPORTED_VM_MESSAGE); 77 } 78 } 79 80 public static boolean isNotAvailable() { 81 return notAvailable; 82 } 83 84 public static void tryToInitializeJVM() { 85 } 86 }