jdk/test/java/util/logging/LogManager/Configuration/TestConfigurationLock.java
author martin
Tue, 15 Sep 2015 21:56:04 -0700
changeset 32649 2ee9017c7597
parent 30643 1fcf87dbdc3c
child 35768 7066da300a08
permissions -rw-r--r--
8136583: Core libraries should use blessed modifier order Summary: Run blessed-modifier-order script (see bug) Reviewed-by: psandoz, chegar, alanb, plevart
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
30643
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
     1
/*
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
     2
 * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
     4
 *
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
     7
 * published by the Free Software Foundation.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
     8
 *
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    13
 * accompanied this code).
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    14
 *
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    18
 *
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    21
 * questions.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    22
 */
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    23
import java.io.File;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    24
import java.io.IOException;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    25
import java.lang.management.LockInfo;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    26
import java.lang.management.ManagementFactory;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    27
import java.lang.management.MonitorInfo;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    28
import java.lang.management.ThreadInfo;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    29
import java.security.Permission;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    30
import java.security.Policy;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    31
import java.security.ProtectionDomain;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    32
import java.util.ArrayList;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    33
import java.util.List;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    34
import java.util.concurrent.atomic.AtomicLong;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    35
import java.util.logging.Level;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    36
import java.util.logging.LogManager;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    37
import java.util.logging.Logger;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    38
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    39
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    40
/**
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    41
 * @test
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    42
 * @bug 8077846
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    43
 * @key randomness
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    44
 * @summary Test that using a reentrant configuration lock does not introduce
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    45
 *       new synchronization issues in Logger and LogManager. This test
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    46
 *       focuses more particularly on potential deadlock in
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    47
 *       drainLoggerRefQueueBounded / readConfiguration / reset
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    48
 *       todo: add at randomness
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    49
 * @run main/othervm TestConfigurationLock
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    50
 * @author danielfuchs
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    51
 */
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    52
// This test is a best effort to try & detect issues. The test itself will run
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    53
// for 8secs. This might be unsufficient to detect issues.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    54
// To get a greater confidence it is recommended to run this test in a loop:
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    55
// e.g. use something like:
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    56
// $ while jtreg -jdk:$JDK -verbose:all  \
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    57
//      test/java/util/logging/TestConfigurationLock.java ; \
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    58
//      do echo Running test again ; done
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    59
// and let it run for a few hours...
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    60
//
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    61
public class TestConfigurationLock {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    62
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    63
    static volatile Exception thrown = null;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    64
    static volatile boolean goOn = true;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    65
    static volatile boolean deadlock = false;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    66
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    67
    static final double CONFSYNCTHRESHOLD = 0.3;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    68
    static final double LOGSYNCTHRESHOLD = 0.3;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    69
    static final int RESETERS = 0;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    70
    static final int READERS = 3;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    71
    static final int LOGGERS = 4;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    72
    static final long TIME = 8 * 1000; // 8 sec.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    73
    static final long STEP = 1 * 1000;  // message every 1 sec.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    74
    static final int  LCOUNT = 50; // 50 loggers created in a row...
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    75
    static final AtomicLong nextLogger = new AtomicLong(0);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    76
    static final AtomicLong resetCount = new AtomicLong(0);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    77
    static final AtomicLong readCount = new AtomicLong(0);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    78
    static final AtomicLong checkCount = new AtomicLong(0);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    79
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    80
    static final String BLAH = "blah";
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    81
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    82
    static Object fakeConfExternalLock() {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    83
        return LogManager.getLogManager();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    84
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    85
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    86
    static Object fakeLogExternalLock() {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    87
        return LogManager.getLogManager();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    88
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    89
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    90
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    91
     /**
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    92
     * This test will run both with and without a security manager.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    93
     *
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    94
     * The test starts a number of threads that will call
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    95
     *     LogManager.reset() concurrently (ResetConf), and a number of threads
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    96
     *     that will call readConfiguration() (ReadConf), and then starts a
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    97
     *     number of threads that will create new loggers concurrently
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    98
     *     (AddLogger), and finally two additional threads:
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
    99
     *     - one (Stopper) that will stop the test after 4secs (TIME ms),
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   100
     *     - and one DeadlockDetector that will attempt to detect deadlocks.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   101
     * If after 4secs no deadlock was detected and no exception was thrown
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   102
     * then the test is considered a success and passes.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   103
     *
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   104
     * This procedure is done twice: once without a security manager and once
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   105
     * again with a security manager - which means the test takes ~8secs to
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   106
     * run.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   107
     *
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   108
     * Note that 8sec may not be enough to detect issues if there are some.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   109
     * This is a best effort test.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   110
     *
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   111
     * @param args the command line arguments
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   112
     * @throws java.lang.Exception if the test fails
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   113
     */
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   114
    public static void main(String[] args) throws Exception {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   115
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   116
        File conf = new File(System.getProperty("test.src", "./src"),
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   117
                TestConfigurationLock.class.getSimpleName() + ".properties");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   118
        if (!conf.canRead()) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   119
            throw new IOException("Can't read config file: " + conf.getAbsolutePath());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   120
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   121
        System.setProperty("java.util.logging.config.file", conf.getAbsolutePath());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   122
        // test without security
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   123
        System.out.println("No security");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   124
        test();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   125
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   126
        // test with security
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   127
        System.out.println("\nWith security");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   128
        Policy.setPolicy(new Policy() {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   129
            @Override
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   130
            public boolean implies(ProtectionDomain domain, Permission permission) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   131
                if (super.implies(domain, permission)) return true;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   132
                // System.out.println("Granting " + permission);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   133
                return true; // all permissions
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   134
            }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   135
        });
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   136
        System.setSecurityManager(new SecurityManager());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   137
        test();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   138
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   139
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   140
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   141
    /**
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   142
     * Starts all threads, wait 4secs, then stops all threads.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   143
     * @throws Exception if a deadlock was detected or an error occurred.
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   144
     */
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   145
    public static void test() throws Exception {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   146
          goOn = true;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   147
          thrown = null;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   148
          long sNextLogger = nextLogger.get();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   149
          long sUpdateCount  = resetCount.get();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   150
          long sReadCount  = readCount.get();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   151
          long sCheckCount = checkCount.get();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   152
          List<Thread> threads = new ArrayList<>();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   153
          for (int i = 0; i<RESETERS; i++) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   154
              threads.add(new ResetConf());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   155
          }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   156
          for (int i = 0; i<READERS; i++) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   157
              threads.add(new ReadConf());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   158
          }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   159
          for (int i = 0; i<LOGGERS; i++) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   160
              threads.add(new AddLogger());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   161
          }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   162
          threads.add(0, new Stopper(TIME));
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   163
          threads.stream().forEach(Thread::start);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   164
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   165
          Thread deadLockDetector = new DeadlockDetector();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   166
          deadLockDetector.start();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   167
          deadLockDetector.join();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   168
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   169
          if (!deadlock) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   170
              threads.stream().forEach(TestConfigurationLock::join);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   171
          } else {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   172
              System.err.println("Deadlock found: exiting forcibly.");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   173
              Runtime.getRuntime().halt(-1);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   174
          }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   175
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   176
          if (thrown != null) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   177
              throw thrown;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   178
          }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   179
          System.out.println("Passed: " + (nextLogger.get() - sNextLogger)
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   180
                  + " loggers created by " + LOGGERS + " Thread(s),");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   181
          System.out.println("\t LogManager.reset() called "
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   182
                  + (resetCount.get() - sUpdateCount) + " times by " + RESETERS
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   183
                  + " Thread(s).");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   184
          System.out.println("\t LogManager.readConfiguration() called "
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   185
                  + (readCount.get() - sReadCount) + " times by " + READERS
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   186
                  + " Thread(s).");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   187
          System.out.println("\t ThreadMXBean.findDeadlockedThreads called "
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   188
                  + (checkCount.get() -sCheckCount) + " times by 1 Thread.");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   189
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   190
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   191
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   192
    static void join(Thread t) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   193
        try {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   194
            t.join();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   195
        } catch (Exception x) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   196
            fail(x);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   197
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   198
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   199
32649
2ee9017c7597 8136583: Core libraries should use blessed modifier order
martin
parents: 30643
diff changeset
   200
    static final class ResetConf extends Thread {
30643
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   201
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   202
        public ResetConf() {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   203
            setDaemon(true);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   204
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   205
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   206
        @Override
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   207
        public void run() {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   208
            while (goOn) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   209
                try {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   210
                    if (Math.random() > CONFSYNCTHRESHOLD) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   211
                        // calling reset while holding a lock can increase
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   212
                        // deadlock probability...
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   213
                        synchronized(fakeConfExternalLock()) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   214
                            LogManager.getLogManager().reset();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   215
                        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   216
                    } else {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   217
                        LogManager.getLogManager().reset();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   218
                    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   219
                    Logger blah = Logger.getLogger(BLAH);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   220
                    blah.setLevel(Level.FINEST);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   221
                    blah.fine(BLAH);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   222
                    resetCount.incrementAndGet();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   223
                    pause(1);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   224
                } catch (Exception x) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   225
                    fail(x);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   226
                }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   227
            }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   228
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   229
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   230
32649
2ee9017c7597 8136583: Core libraries should use blessed modifier order
martin
parents: 30643
diff changeset
   231
    static final class ReadConf extends Thread {
30643
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   232
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   233
        public ReadConf() {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   234
            setDaemon(true);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   235
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   236
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   237
        @Override
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   238
        public void run() {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   239
            while (goOn) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   240
                try {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   241
                    if (Math.random() > CONFSYNCTHRESHOLD) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   242
                        // calling readConfiguration while holding a lock can
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   243
                        // increase deadlock probability...
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   244
                        synchronized(fakeConfExternalLock()) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   245
                            LogManager.getLogManager().readConfiguration();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   246
                        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   247
                    } else {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   248
                        LogManager.getLogManager().readConfiguration();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   249
                    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   250
                    Logger blah = Logger.getLogger(BLAH);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   251
                    blah.setLevel(Level.FINEST);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   252
                    blah.fine(BLAH);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   253
                    readCount.incrementAndGet();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   254
                    pause(1);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   255
                } catch (Exception x) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   256
                    fail(x);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   257
                }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   258
            }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   259
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   260
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   261
32649
2ee9017c7597 8136583: Core libraries should use blessed modifier order
martin
parents: 30643
diff changeset
   262
    static final class AddLogger extends Thread {
30643
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   263
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   264
        public AddLogger() {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   265
            setDaemon(true);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   266
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   267
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   268
        @Override
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   269
        public void run() {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   270
            try {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   271
                while (goOn) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   272
                    Logger l;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   273
                    Logger foo = Logger.getLogger("foo");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   274
                    Logger bar = Logger.getLogger("foo.bar");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   275
                    for (int i=0; i < LCOUNT ; i++) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   276
                        LogManager manager = LogManager.getLogManager();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   277
                        if (Math.random() > LOGSYNCTHRESHOLD) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   278
                            synchronized(fakeLogExternalLock()) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   279
                                l = Logger.getLogger("foo.bar.l"+nextLogger.incrementAndGet());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   280
                            }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   281
                        } else {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   282
                            l = Logger.getLogger("foo.bar.l"+nextLogger.incrementAndGet());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   283
                        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   284
                        l.setLevel(Level.FINEST);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   285
                        l.fine("I'm fine");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   286
                        if (!goOn) break;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   287
                        pause(1);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   288
                    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   289
                }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   290
            } catch (InterruptedException | RuntimeException x ) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   291
                fail(x);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   292
            }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   293
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   294
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   295
32649
2ee9017c7597 8136583: Core libraries should use blessed modifier order
martin
parents: 30643
diff changeset
   296
    static final class DeadlockDetector extends Thread {
30643
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   297
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   298
        @Override
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   299
        public void run() {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   300
            boolean deadlock = false;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   301
            while(goOn) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   302
                try {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   303
                    long[] ids = ManagementFactory.getThreadMXBean().findDeadlockedThreads();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   304
                    checkCount.incrementAndGet();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   305
                    ids = ids == null ? new long[0] : ids;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   306
                    if (ids.length == 1) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   307
                        throw new RuntimeException("Found 1 deadlocked thread: "+ids[0]);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   308
                    } else if (ids.length > 0) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   309
                        deadlock = true;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   310
                        ThreadInfo[] infos = ManagementFactory.getThreadMXBean()
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   311
                            .getThreadInfo(ids, true, true);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   312
                        System.err.println("Found "+ids.length+" deadlocked threads: ");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   313
                        for (ThreadInfo inf : infos) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   314
                            System.err.println(asString(inf));
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   315
                        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   316
                        throw new RuntimeException("Found "+ids.length+" deadlocked threads");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   317
                    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   318
                    pause(100);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   319
                } catch(InterruptedException | RuntimeException x) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   320
                    if (deadlock) deadlock(x);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   321
                    else fail(x);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   322
                }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   323
            }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   324
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   325
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   326
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   327
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   328
    static final class Stopper extends Thread {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   329
        long start;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   330
        long time;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   331
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   332
        Stopper(long time) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   333
            start = System.currentTimeMillis();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   334
            this.time = time;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   335
            setDaemon(true);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   336
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   337
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   338
        @Override
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   339
        public void run() {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   340
            try {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   341
                long rest, previous;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   342
                int msgCount = 0;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   343
                previous = time;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   344
                Logger logger =  Logger.getLogger("remaining");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   345
                while (goOn && (rest = start - System.currentTimeMillis() + time) > 0) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   346
                    if (previous == time || previous - rest >= STEP) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   347
                        logger.log(Level.INFO, "{0}ms remaining...", String.valueOf(rest));
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   348
                        msgCount++;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   349
                        previous = rest == time ? rest -1 : rest;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   350
                        System.gc();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   351
                    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   352
                    if (goOn == false) break;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   353
                    pause(Math.min(rest, 100));
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   354
                }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   355
                System.err.println(this + ": " + msgCount + " messages.");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   356
                System.err.flush();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   357
                System.out.println(System.currentTimeMillis() - start
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   358
                        + " ms elapsed ("+time+ " requested)");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   359
                goOn = false;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   360
            } catch(InterruptedException | RuntimeException x) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   361
                fail(x);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   362
            }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   363
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   364
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   365
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   366
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   367
    // ThreadInfo.toString() only prints 8 frames...
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   368
    static String asString(ThreadInfo inf) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   369
        StringBuilder sb = new StringBuilder();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   370
        sb.append("\"").append(inf.getThreadName()).append("\"")
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   371
                .append(inf.isDaemon() ? " daemon" : "")
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   372
                .append(" prio=").append(inf.getPriority())
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   373
                .append(" Id=").append(inf.getThreadId())
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   374
                .append(" ").append(inf.getThreadState());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   375
        if (inf.getLockName() != null) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   376
            sb.append(" on ").append(inf.getLockName());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   377
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   378
        if (inf.getLockOwnerName() != null) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   379
            sb.append(" owned by \"").append(inf.getLockOwnerName())
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   380
                    .append("\" Id=").append(inf.getLockOwnerId());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   381
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   382
        if (inf.isSuspended()) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   383
            sb.append(" (suspended)");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   384
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   385
        if (inf.isInNative()) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   386
            sb.append(" (in native)");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   387
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   388
        sb.append('\n');
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   389
        int i = 0;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   390
        StackTraceElement[] stackTrace = inf.getStackTrace();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   391
        for (; i < stackTrace.length; i++) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   392
            StackTraceElement ste = stackTrace[i];
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   393
            sb.append("\tat ").append(ste.toString());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   394
            sb.append('\n');
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   395
            if (i == 0 && inf.getLockInfo() != null) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   396
                Thread.State ts = inf.getThreadState();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   397
                switch (ts) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   398
                    case BLOCKED:
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   399
                        sb.append("\t-  blocked on ").append(inf.getLockInfo());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   400
                        sb.append('\n');
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   401
                        break;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   402
                    case WAITING:
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   403
                        sb.append("\t-  waiting on ").append(inf.getLockInfo());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   404
                        sb.append('\n');
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   405
                        break;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   406
                    case TIMED_WAITING:
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   407
                        sb.append("\t-  waiting on ").append(inf.getLockInfo());
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   408
                        sb.append('\n');
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   409
                        break;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   410
                    default:
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   411
                }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   412
            }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   413
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   414
            for (MonitorInfo mi : inf.getLockedMonitors()) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   415
                if (mi.getLockedStackDepth() == i) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   416
                    sb.append("\t-  locked ").append(mi);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   417
                    sb.append('\n');
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   418
                }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   419
            }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   420
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   421
        if (i < stackTrace.length) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   422
           sb.append("\t...");
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   423
           sb.append('\n');
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   424
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   425
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   426
        LockInfo[] locks = inf.getLockedSynchronizers();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   427
        if (locks.length > 0) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   428
           sb.append("\n\tNumber of locked synchronizers = ").append(locks.length);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   429
           sb.append('\n');
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   430
           for (LockInfo li : locks) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   431
               sb.append("\t- ").append(li);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   432
               sb.append('\n');
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   433
           }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   434
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   435
        sb.append('\n');
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   436
        return sb.toString();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   437
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   438
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   439
    static void pause(long millis) throws InterruptedException {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   440
        Thread.sleep(millis);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   441
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   442
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   443
    static void fail(Exception x) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   444
        x.printStackTrace(System.err);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   445
        if (thrown == null) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   446
            thrown = x;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   447
        }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   448
        goOn = false;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   449
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   450
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   451
    static void deadlock(Exception x) {
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   452
        deadlock = true;
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   453
        System.out.flush();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   454
        fail(x);
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   455
        System.err.flush();
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   456
    }
1fcf87dbdc3c 8077846: improve locking strategy for readConfiguration(), reset(), and initializeGlobalHandlers()
plevart
parents:
diff changeset
   457
}