Mercurial > hg > truffle
annotate test/gc/metaspace/TestMetaspacePerfCounters.java @ 12245:17deed6716af
8024914: Swapped usage of idx_t and bm_word_t types in bitMap.inline.hpp
Summary: Incorrect usage of idx_t where bm_word_t is appropriate.
Reviewed-by: tschatzl, brutisso
Contributed-by: Dan Horak <dhorak@redhat.com>
author | tschatzl |
---|---|
date | Tue, 17 Sep 2013 12:04:11 +0200 |
parents | 7944aba7ba41 |
children | 73d0d0218068 |
rev | line source |
---|---|
12063
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
1 /* |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
2 * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
4 * |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
5 * This code is free software; you can redistribute it and/or modify it |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
6 * under the terms of the GNU General Public License version 2 only, as |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
7 * published by the Free Software Foundation. |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
8 * |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
9 * This code is distributed in the hope that it will be useful, but WITHOUT |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
12 * version 2 for more details (a copy is included in the LICENSE file that |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
13 * accompanied this code). |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
14 * |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
15 * You should have received a copy of the GNU General Public License version |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
16 * 2 along with this work; if not, write to the Free Software Foundation, |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
18 * |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
20 * or visit www.oracle.com if you need additional information or have any |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
21 * questions. |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
22 */ |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
23 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
24 import java.util.List; |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
25 import java.util.ArrayList; |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
26 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
27 import com.oracle.java.testlibrary.*; |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
28 import static com.oracle.java.testlibrary.Asserts.*; |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
29 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
30 /* @test TestMetaspacePerfCounters |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
31 * @bug 8014659 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
32 * @library /testlibrary |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
33 * @summary Tests that performance counters for metaspace and compressed class |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
34 * space exists and works. |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
35 * |
12226
7944aba7ba41
8015107: NPG: Use consistent naming for metaspace concepts
ehelin
parents:
12063
diff
changeset
|
36 * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-UseCompressedOops -XX:-UseCompressedClassPointers -XX:+UsePerfData -XX:+UseSerialGC TestMetaspacePerfCounters |
7944aba7ba41
8015107: NPG: Use consistent naming for metaspace concepts
ehelin
parents:
12063
diff
changeset
|
37 * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-UseCompressedOops -XX:-UseCompressedClassPointers -XX:+UsePerfData -XX:+UseParallelGC -XX:+UseParallelOldGC TestMetaspacePerfCounters |
7944aba7ba41
8015107: NPG: Use consistent naming for metaspace concepts
ehelin
parents:
12063
diff
changeset
|
38 * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-UseCompressedOops -XX:-UseCompressedClassPointers -XX:+UsePerfData -XX:+UseG1GC TestMetaspacePerfCounters |
12063
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
39 * |
12226
7944aba7ba41
8015107: NPG: Use consistent naming for metaspace concepts
ehelin
parents:
12063
diff
changeset
|
40 * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+UseCompressedOops -XX:+UseCompressedClassPointers -XX:+UsePerfData -XX:+UseSerialGC TestMetaspacePerfCounters |
7944aba7ba41
8015107: NPG: Use consistent naming for metaspace concepts
ehelin
parents:
12063
diff
changeset
|
41 * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+UseCompressedOops -XX:+UseCompressedClassPointers -XX:+UsePerfData -XX:+UseParallelGC -XX:+UseParallelOldGC TestMetaspacePerfCounters |
7944aba7ba41
8015107: NPG: Use consistent naming for metaspace concepts
ehelin
parents:
12063
diff
changeset
|
42 * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+UseCompressedOops -XX:+UseCompressedClassPointers -XX:+UsePerfData -XX:+UseG1GC TestMetaspacePerfCounters |
12063
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
43 */ |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
44 public class TestMetaspacePerfCounters { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
45 public static Class fooClass = null; |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
46 private static final String[] counterNames = {"minCapacity", "maxCapacity", "capacity", "used"}; |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
47 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
48 public static void main(String[] args) throws Exception { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
49 String metaspace = "sun.gc.metaspace"; |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
50 String ccs = "sun.gc.compressedclassspace"; |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
51 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
52 checkPerfCounters(metaspace); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
53 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
54 if (isUsingCompressedClassPointers()) { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
55 checkPerfCounters(ccs); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
56 checkUsedIncreasesWhenLoadingClass(ccs); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
57 } else { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
58 checkEmptyPerfCounters(ccs); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
59 checkUsedIncreasesWhenLoadingClass(metaspace); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
60 } |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
61 } |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
62 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
63 private static void checkPerfCounters(String ns) throws Exception { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
64 for (PerfCounter counter : countersInNamespace(ns)) { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
65 String msg = "Expected " + counter.getName() + " to be larger than 0"; |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
66 assertGT(counter.longValue(), 0L, msg); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
67 } |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
68 } |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
69 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
70 private static void checkEmptyPerfCounters(String ns) throws Exception { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
71 for (PerfCounter counter : countersInNamespace(ns)) { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
72 String msg = "Expected " + counter.getName() + " to equal 0"; |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
73 assertEQ(counter.longValue(), 0L, msg); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
74 } |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
75 } |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
76 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
77 private static void checkUsedIncreasesWhenLoadingClass(String ns) throws Exception { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
78 PerfCounter used = PerfCounters.findByName(ns + ".used"); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
79 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
80 long before = used.longValue(); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
81 fooClass = compileAndLoad("Foo", "public class Foo { }"); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
82 System.gc(); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
83 long after = used.longValue(); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
84 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
85 assertGT(after, before); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
86 } |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
87 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
88 private static List<PerfCounter> countersInNamespace(String ns) throws Exception { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
89 List<PerfCounter> counters = new ArrayList<>(); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
90 for (String name : counterNames) { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
91 counters.add(PerfCounters.findByName(ns + "." + name)); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
92 } |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
93 return counters; |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
94 } |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
95 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
96 private static Class<?> compileAndLoad(String name, String source) throws Exception { |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
97 byte[] byteCode = InMemoryJavaCompiler.compile(name, source); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
98 return ByteCodeLoader.load(name, byteCode); |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
99 } |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
100 |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
101 private static boolean isUsingCompressedClassPointers() { |
12226
7944aba7ba41
8015107: NPG: Use consistent naming for metaspace concepts
ehelin
parents:
12063
diff
changeset
|
102 return Platform.is64bit() && InputArguments.contains("-XX:+UseCompressedClassPointers"); |
12063
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
103 } |
1a8fb39bdbc4
8014659: NPG: performance counters for compressed klass space
ehelin
parents:
diff
changeset
|
104 } |