annotate src/os_cpu/linux_zero/vm/os_linux_zero.hpp @ 1266:3b687c53c266

6927165: Zero S/390 fixes Summary: Fixes two failures on 31-bit S/390. Reviewed-by: twisti Contributed-by: Gary Benson <gbenson@redhat.com>
author twisti
date Thu, 18 Feb 2010 06:54:48 -0800
parents 354d3184f6b2
children c18cbe5936b8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1010
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
1 /*
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
2 * Copyright 2003-2004 Sun Microsystems, Inc. All Rights Reserved.
1266
3b687c53c266 6927165: Zero S/390 fixes
twisti
parents: 1010
diff changeset
3 * Copyright 2007, 2008, 2010 Red Hat, Inc.
1010
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
4 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
5 *
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
6 * This code is free software; you can redistribute it and/or modify it
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
7 * under the terms of the GNU General Public License version 2 only, as
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
8 * published by the Free Software Foundation.
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
9 *
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
10 * This code is distributed in the hope that it will be useful, but WITHOUT
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
12 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
13 * version 2 for more details (a copy is included in the LICENSE file that
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
14 * accompanied this code).
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
15 *
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
16 * You should have received a copy of the GNU General Public License version
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
17 * 2 along with this work; if not, write to the Free Software Foundation,
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
18 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
19 *
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
20 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
21 * CA 95054 USA or visit www.sun.com if you need additional information or
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
22 * have any questions.
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
23 *
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
24 */
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
25
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
26 static void setup_fpu() {}
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
27
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
28 static bool is_allocatable(size_t bytes);
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
29
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
30 // Used to register dynamic code cache area with the OS
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
31 // Note: Currently only used in 64 bit Windows implementations
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
32 static bool register_code_area(char *low, char *high) { return true; }
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
33
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
34 // Atomically copy 64 bits of data
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
35 static void atomic_copy64(volatile void *src, volatile void *dst) {
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
36 #if defined(PPC) && !defined(_LP64)
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
37 double tmp;
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
38 asm volatile ("lfd %0, 0(%1)\n"
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
39 "stfd %0, 0(%2)\n"
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
40 : "=f"(tmp)
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
41 : "b"(src), "b"(dst));
1266
3b687c53c266 6927165: Zero S/390 fixes
twisti
parents: 1010
diff changeset
42 #elif defined(S390) && !defined(_LP64)
3b687c53c266 6927165: Zero S/390 fixes
twisti
parents: 1010
diff changeset
43 double tmp;
3b687c53c266 6927165: Zero S/390 fixes
twisti
parents: 1010
diff changeset
44 asm volatile ("ld %0, 0(%1)\n"
3b687c53c266 6927165: Zero S/390 fixes
twisti
parents: 1010
diff changeset
45 "std %0, 0(%2)\n"
3b687c53c266 6927165: Zero S/390 fixes
twisti
parents: 1010
diff changeset
46 : "=r"(tmp)
3b687c53c266 6927165: Zero S/390 fixes
twisti
parents: 1010
diff changeset
47 : "a"(src), "a"(dst));
1010
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
48 #else
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
49 *(jlong *) dst = *(jlong *) src;
1266
3b687c53c266 6927165: Zero S/390 fixes
twisti
parents: 1010
diff changeset
50 #endif
1010
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
51 }