annotate test/runtime/NMT/ShutdownTwice.java @ 12986:1b422ef5288a

8025728: Missing volatile specifier for field G1AllocRegion::_alloc_region Summary: The field G1AllocRegion::_alloc_region needs to be declared volatile as it is used with that intention. Otherwise the compiler may generate the code that reloads the value which might have changed in the meantime, leading to spurious crashes. Reviewed-by: iveresov, simonis, tschatzl Contributed-by: Axel Siebenborn <axel.siebenborn@sap.com>
author tschatzl
date Wed, 23 Oct 2013 10:23:06 +0200
parents 879c6de913d6
children ac12996df59b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
7977
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
1 /*
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
2 * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
4 *
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
7 * published by the Free Software Foundation.
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
8 *
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
13 * accompanied this code).
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
14 *
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
18 *
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
21 * questions.
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
22 */
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
23
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
24 /*
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
25 * @test
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
26 * @key nmt jcmd
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
27 * @summary Run shutdown twice
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
28 * @library /testlibrary
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
29 * @run main/othervm -XX:NativeMemoryTracking=detail ShutdownTwice
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
30 */
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
31
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
32 import com.oracle.java.testlibrary.*;
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
33
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
34 public class ShutdownTwice {
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
35
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
36 public static void main(String args[]) throws Exception {
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
37 // Grab my own PID
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
38 String pid = Integer.toString(ProcessTools.getProcessId());
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
39 OutputAnalyzer output;
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
40
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
41 ProcessBuilder pb = new ProcessBuilder();
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
42
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
43 // Run 'jcmd <pid> VM.native_memory shutdown'
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
44 pb.command(new String[] { JDKToolFinder.getJDKTool("jcmd"), pid, "VM.native_memory", "shutdown"});
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
45 output = new OutputAnalyzer(pb.start());
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
46
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
47 // Verify that jcmd reports that NMT is shutting down
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
48 output.shouldContain("Shutdown is in progress, it will take a few moments to completely shutdown");
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
49
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
50 // Run shutdown again
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
51 output = new OutputAnalyzer(pb.start());
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
52
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
53 // Verify that jcmd reports that NMT has been shutdown already
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
54 output.shouldContain("Native memory tracking has been shutdown by user");
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
55 }
879c6de913d6 8005013: Add NMT tests
ctornqvi
parents:
diff changeset
56 }