annotate src/share/vm/runtime/atomic.hpp @ 1145:e018e6884bd8

6631166: CMS: better heuristics when combatting fragmentation Summary: Autonomic per-worker free block cache sizing, tunable coalition policies, fixes to per-size block statistics, retuned gain and bandwidth of some feedback loop filters to allow quicker reactivity to abrupt changes in ambient demand, and other heuristics to reduce fragmentation of the CMS old gen. Also tightened some assertions, including those related to locking. Reviewed-by: jmasa
author ysr
date Wed, 23 Dec 2009 09:23:54 -0800
parents 89e0543e1737
children c18cbe5936b8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
948
89e0543e1737 6884624: Update copyright year
xdono
parents: 894
diff changeset
2 * Copyright 1999-2009 Sun Microsystems, Inc. All Rights Reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
a61af66fc99e Initial load
duke
parents:
diff changeset
19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
a61af66fc99e Initial load
duke
parents:
diff changeset
20 * CA 95054 USA or visit www.sun.com if you need additional information or
a61af66fc99e Initial load
duke
parents:
diff changeset
21 * have any questions.
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
a61af66fc99e Initial load
duke
parents:
diff changeset
25 class Atomic : AllStatic {
a61af66fc99e Initial load
duke
parents:
diff changeset
26 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
27 // Atomically store to a location
a61af66fc99e Initial load
duke
parents:
diff changeset
28 static void store (jbyte store_value, jbyte* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
29 static void store (jshort store_value, jshort* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
30 static void store (jint store_value, jint* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
31 static void store (jlong store_value, jlong* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
32 static void store_ptr(intptr_t store_value, intptr_t* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
33 static void store_ptr(void* store_value, void* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
34
a61af66fc99e Initial load
duke
parents:
diff changeset
35 static void store (jbyte store_value, volatile jbyte* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
36 static void store (jshort store_value, volatile jshort* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
37 static void store (jint store_value, volatile jint* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
38 static void store (jlong store_value, volatile jlong* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
39 static void store_ptr(intptr_t store_value, volatile intptr_t* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
40 static void store_ptr(void* store_value, volatile void* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
41
894
665be97e8704 6863420: os::javaTimeNanos() go backward on Solaris x86
kvn
parents: 196
diff changeset
42 static jlong load(volatile jlong* src);
665be97e8704 6863420: os::javaTimeNanos() go backward on Solaris x86
kvn
parents: 196
diff changeset
43
0
a61af66fc99e Initial load
duke
parents:
diff changeset
44 // Atomically add to a location, return updated value
a61af66fc99e Initial load
duke
parents:
diff changeset
45 static jint add (jint add_value, volatile jint* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
46 static intptr_t add_ptr(intptr_t add_value, volatile intptr_t* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
47 static void* add_ptr(intptr_t add_value, volatile void* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
48
a61af66fc99e Initial load
duke
parents:
diff changeset
49 // Atomically increment location
a61af66fc99e Initial load
duke
parents:
diff changeset
50 static void inc (volatile jint* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
51 static void inc_ptr(volatile intptr_t* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
52 static void inc_ptr(volatile void* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
53
a61af66fc99e Initial load
duke
parents:
diff changeset
54 // Atomically decrement a location
a61af66fc99e Initial load
duke
parents:
diff changeset
55 static void dec (volatile jint* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
56 static void dec_ptr(volatile intptr_t* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
57 static void dec_ptr(volatile void* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
58
a61af66fc99e Initial load
duke
parents:
diff changeset
59 // Performs atomic exchange of *dest with exchange_value. Returns old prior value of *dest.
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
60 static jint xchg(jint exchange_value, volatile jint* dest);
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
61 static unsigned int xchg(unsigned int exchange_value,
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
62 volatile unsigned int* dest);
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
63
0
a61af66fc99e Initial load
duke
parents:
diff changeset
64 static intptr_t xchg_ptr(intptr_t exchange_value, volatile intptr_t* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
65 static void* xchg_ptr(void* exchange_value, volatile void* dest);
a61af66fc99e Initial load
duke
parents:
diff changeset
66
a61af66fc99e Initial load
duke
parents:
diff changeset
67 // Performs atomic compare of *dest and compare_value, and exchanges *dest with exchange_value
a61af66fc99e Initial load
duke
parents:
diff changeset
68 // if the comparison succeeded. Returns prior value of *dest. Guarantees a two-way memory
a61af66fc99e Initial load
duke
parents:
diff changeset
69 // barrier across the cmpxchg. I.e., it's really a 'fence_cmpxchg_acquire'.
a61af66fc99e Initial load
duke
parents:
diff changeset
70 static jbyte cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value);
a61af66fc99e Initial load
duke
parents:
diff changeset
71 static jint cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value);
a61af66fc99e Initial load
duke
parents:
diff changeset
72 static jlong cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value);
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
73
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
74 static unsigned int cmpxchg(unsigned int exchange_value,
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
75 volatile unsigned int* dest,
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
76 unsigned int compare_value);
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
77
0
a61af66fc99e Initial load
duke
parents:
diff changeset
78 static intptr_t cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value);
a61af66fc99e Initial load
duke
parents:
diff changeset
79 static void* cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value);
a61af66fc99e Initial load
duke
parents:
diff changeset
80 };