Copyright (c) 2007, 2018, 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 under the terms of the GNU General Public License version 2 only, as published by the Free Software Foundation. This code is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License version 2 for more details (a copy is included in the LICENSE file that accompanied this code). You should have received a copy of the GNU General Public License version 2 along with this work; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA or visit www.oracle.com if you need additional information or have any questions. All gc/lock/ tests do approximately the same thing. They verify that GC is appropriately synchronized with certain class of functions. - gc/lock/jni - uses JNI GetPrimitiveArrayCritical and GetStringCritical - gc/lock/jniref - uses JNI NewGlobalRef, NewLocalRef, NewWeakGlobalRef - gc/lock/malloc - uses malloc() - gc/lock/jvmti - uses JVMTI Allocate A number of threads is started. There are some threads that repeatedly enter a critical section of code where functions describe above are repeatedly called in a loop. There are also some threads that eat memory in a loop. The idea here is to force GC to crash or deadlock.