annotate src/os_cpu/linux_zero/vm/os_linux_zero.hpp @ 1010:354d3184f6b2

6890308: integrate zero assembler hotspot changes Reviewed-by: never Contributed-by: gbenson@redhat.com
author never
date Tue, 13 Oct 2009 12:04:21 -0700
parents
children 3b687c53c266
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.
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
3 * Copyright 2007, 2008 Red Hat, Inc.
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));
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
42 #else
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
43 *(jlong *) dst = *(jlong *) src;
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
44 #endif // PPC && !_LP64
354d3184f6b2 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
45 }