annotate src/share/vm/oops/methodCounters.cpp @ 20470:bc4ce33c0985

8049529: LogCompilation: annotate make_not_compilable with compilation level Reviewed-by: roland, iveresov
author vlivanov
date Mon, 14 Jul 2014 03:27:21 -0700
parents 631667807de7
children 7848fc12602b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
10105
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
1 /*
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
2 * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
4 *
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
7 * published by the Free Software Foundation.
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
8 *
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
13 * accompanied this code).
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
14 *
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
18 *
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
21 * questions.
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
22 *
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
23 */
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
24 #include "precompiled.hpp"
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
25 #include "oops/methodCounters.hpp"
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
26 #include "runtime/thread.inline.hpp"
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
27
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
28 MethodCounters* MethodCounters::allocate(ClassLoaderData* loader_data, TRAPS) {
10376
a1ebd310d5c1 8014912: Restore PrintSharedSpaces functionality after NPG
iklam
parents: 10105
diff changeset
29 return new(loader_data, size(), false, MetaspaceObj::MethodCountersType, THREAD) MethodCounters();
10105
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
30 }
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
31
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
32 void MethodCounters::clear_counters() {
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
33 invocation_counter()->reset();
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
34 backedge_counter()->reset();
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
35 set_interpreter_throwout_count(0);
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
36 set_interpreter_invocation_count(0);
20457
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
37 #ifdef TIERED
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
38 set_prev_time(0);
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
39 set_rate(0);
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
40 set_highest_comp_level(0);
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
41 set_highest_osr_comp_level(0);
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
42 #endif
10105
aeaca88565e6 8010862: The Method counter fields used for profiling can be allocated lazily.
jiangli
parents:
diff changeset
43 }
20457
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
44
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
45
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
46 int MethodCounters::highest_comp_level() const {
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
47 #ifdef TIERED
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
48 return _highest_comp_level;
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
49 #else
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
50 return CompLevel_none;
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
51 #endif
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
52 }
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
53
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
54 void MethodCounters::set_highest_comp_level(int level) {
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
55 #ifdef TIERED
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
56 _highest_comp_level = level;
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
57 #endif
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
58 }
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
59
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
60 int MethodCounters::highest_osr_comp_level() const {
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
61 #ifdef TIERED
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
62 return _highest_osr_comp_level;
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
63 #else
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
64 return CompLevel_none;
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
65 #endif
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
66 }
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
67
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
68 void MethodCounters::set_highest_osr_comp_level(int level) {
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
69 #ifdef TIERED
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
70 _highest_osr_comp_level = level;
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
71 #endif
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
72 }
631667807de7 8058184: Move _highest_comp_level and _highest_osr_comp_level from MethodData to MethodCounters
iveresov
parents: 10376
diff changeset
73