Mercurial > hg > truffle
annotate src/share/vm/utilities/ticks.cpp @ 20543:e7d0505c8a30
8059758: Footprint regressions with JDK-8038423
Summary: Changes in JDK-8038423 always initialize (zero out) virtual memory used for auxiliary data structures. This causes a footprint regression for G1 in startup benchmarks. This is because they do not touch that memory at all, so the operating system does not actually commit these pages. The fix is to, if the initialization value of the data structures matches the default value of just committed memory (=0), do not do anything.
Reviewed-by: jwilhelm, brutisso
author | tschatzl |
---|---|
date | Fri, 10 Oct 2014 15:51:58 +0200 |
parents | 86e6d691f2e1 |
children |
rev | line source |
---|---|
13400
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
1 /* |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
2 * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
4 * |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
5 * This code is free software; you can redistribute it and/or modify it |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
6 * under the terms of the GNU General Public License version 2 only, as |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
7 * published by the Free Software Foundation. |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
8 * |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
9 * This code is distributed in the hope that it will be useful, but WITHOUT |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
12 * version 2 for more details (a copy is included in the LICENSE file that |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
13 * accompanied this code). |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
14 * |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
15 * You should have received a copy of the GNU General Public License version |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
16 * 2 along with this work; if not, write to the Free Software Foundation, |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
18 * |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
20 * or visit www.oracle.com if you need additional information or have any |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
21 * questions. |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
22 * |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
23 */ |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
24 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
25 #include "precompiled.hpp" |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
26 #include "runtime/os.hpp" |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
27 #include "utilities/ticks.inline.hpp" |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
28 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
29 #ifdef ASSERT |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
30 const jlong Ticks::invalid_time_stamp = -2; // 0xFFFF FFFF`FFFF FFFE |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
31 #endif |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
32 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
33 void Ticks::stamp() { |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
34 _stamp_ticks = os::elapsed_counter(); |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
35 } |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
36 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
37 const Ticks Ticks::now() { |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
38 Ticks t; |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
39 t.stamp(); |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
40 return t; |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
41 } |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
42 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
43 Tickspan::Tickspan(const Ticks& end, const Ticks& start) { |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
44 assert(end.value() != Ticks::invalid_time_stamp, "end is unstamped!"); |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
45 assert(start.value() != Ticks::invalid_time_stamp, "start is unstamped!"); |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
46 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
47 assert(end >= start, "negative time!"); |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
48 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
49 _span_ticks = end.value() - start.value(); |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
50 } |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
51 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
52 template <typename ReturnType> |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
53 static ReturnType time_conversion(const Tickspan& span, TicksToTimeHelper::Unit unit) { |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
54 assert(TicksToTimeHelper::SECONDS == unit || |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
55 TicksToTimeHelper::MILLISECONDS == unit, "invalid unit!"); |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
56 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
57 ReturnType frequency_per_unit = (ReturnType)os::elapsed_frequency() / (ReturnType)unit; |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
58 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
59 return (ReturnType) ((ReturnType)span.value() / frequency_per_unit); |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
60 } |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
61 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
62 double TicksToTimeHelper::seconds(const Tickspan& span) { |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
63 return time_conversion<double>(span, SECONDS); |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
64 } |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
65 |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
66 jlong TicksToTimeHelper::milliseconds(const Tickspan& span) { |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
67 return time_conversion<jlong>(span, MILLISECONDS); |
86e6d691f2e1
8028128: Add a type safe alternative for working with counter based data
mgronlun
parents:
diff
changeset
|
68 } |