annotate src/cpu/sparc/vm/registerMap_sparc.hpp @ 113:ba764ed4b6f2

6420645: Create a vm that uses compressed oops for up to 32gb heapsizes Summary: Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
author coleenp
date Sun, 13 Apr 2008 17:43:42 -0400
parents a61af66fc99e
children c18cbe5936b8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
2 * Copyright 1998-2007 Sun Microsystems, Inc. All Rights Reserved.
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 // machine-dependent implemention for register maps
a61af66fc99e Initial load
duke
parents:
diff changeset
26 friend class frame;
a61af66fc99e Initial load
duke
parents:
diff changeset
27
a61af66fc99e Initial load
duke
parents:
diff changeset
28 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
29 intptr_t* _window; // register window save area (for L and I regs)
a61af66fc99e Initial load
duke
parents:
diff changeset
30 intptr_t* _younger_window; // previous save area (for O regs, if needed)
a61af66fc99e Initial load
duke
parents:
diff changeset
31
a61af66fc99e Initial load
duke
parents:
diff changeset
32 address pd_location(VMReg reg) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
33 void pd_clear();
a61af66fc99e Initial load
duke
parents:
diff changeset
34 void pd_initialize_from(const RegisterMap* map) {
a61af66fc99e Initial load
duke
parents:
diff changeset
35 _window = map->_window;
a61af66fc99e Initial load
duke
parents:
diff changeset
36 _younger_window = map->_younger_window;
a61af66fc99e Initial load
duke
parents:
diff changeset
37 _location_valid[0] = 0; // avoid the shift_individual_registers game
a61af66fc99e Initial load
duke
parents:
diff changeset
38 }
a61af66fc99e Initial load
duke
parents:
diff changeset
39 void pd_initialize() {
a61af66fc99e Initial load
duke
parents:
diff changeset
40 _window = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
41 _younger_window = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
42 _location_valid[0] = 0; // avoid the shift_individual_registers game
a61af66fc99e Initial load
duke
parents:
diff changeset
43 }
a61af66fc99e Initial load
duke
parents:
diff changeset
44 void shift_window(intptr_t* sp, intptr_t* younger_sp) {
a61af66fc99e Initial load
duke
parents:
diff changeset
45 _window = sp;
a61af66fc99e Initial load
duke
parents:
diff changeset
46 _younger_window = younger_sp;
a61af66fc99e Initial load
duke
parents:
diff changeset
47 // Throw away locations for %i, %o, and %l registers:
a61af66fc99e Initial load
duke
parents:
diff changeset
48 // But do not throw away %g register locs.
a61af66fc99e Initial load
duke
parents:
diff changeset
49 if (_location_valid[0] != 0) shift_individual_registers();
a61af66fc99e Initial load
duke
parents:
diff changeset
50 }
a61af66fc99e Initial load
duke
parents:
diff changeset
51 void shift_individual_registers();
a61af66fc99e Initial load
duke
parents:
diff changeset
52 // When popping out of compiled frames, we make all IRegs disappear.
a61af66fc99e Initial load
duke
parents:
diff changeset
53 void make_integer_regs_unsaved() { _location_valid[0] = 0; }