src/cpu/sparc/vm/globalDefinitions_sparc.hpp

Wed, 18 Sep 2013 14:34:56 -0700

author
goetz
date
Wed, 18 Sep 2013 14:34:56 -0700
changeset 6468
cfd05ec74089
parent 5067
6b388e7d4905
child 6503
a9becfeecd1b
permissions
-rw-r--r--

8024342: PPC64 (part 111): Support for C calling conventions that require 64-bit ints.
Summary: Some platforms, as ppc and s390x/zArch require that 32-bit ints are passed as 64-bit values to C functions. This change adds support to adapt the signature and to issue proper casts to c2-compiled stubs. The functions are used in generate_native_wrapper(). Adapt signature used by the compiler as in PhaseIdealLoop::intrinsify_fill().
Reviewed-by: kvn

duke@435 1 /*
stefank@2314 2 * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
duke@435 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
duke@435 4 *
duke@435 5 * This code is free software; you can redistribute it and/or modify it
duke@435 6 * under the terms of the GNU General Public License version 2 only, as
duke@435 7 * published by the Free Software Foundation.
duke@435 8 *
duke@435 9 * This code is distributed in the hope that it will be useful, but WITHOUT
duke@435 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
duke@435 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
duke@435 12 * version 2 for more details (a copy is included in the LICENSE file that
duke@435 13 * accompanied this code).
duke@435 14 *
duke@435 15 * You should have received a copy of the GNU General Public License version
duke@435 16 * 2 along with this work; if not, write to the Free Software Foundation,
duke@435 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
duke@435 18 *
trims@1907 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
trims@1907 20 * or visit www.oracle.com if you need additional information or have any
trims@1907 21 * questions.
duke@435 22 *
duke@435 23 */
duke@435 24
stefank@2314 25 #ifndef CPU_SPARC_VM_GLOBALDEFINITIONS_SPARC_HPP
stefank@2314 26 #define CPU_SPARC_VM_GLOBALDEFINITIONS_SPARC_HPP
stefank@2314 27
duke@435 28 // Size of Sparc Instructions
duke@435 29 const int BytesPerInstWord = 4;
duke@435 30
duke@435 31 const int StackAlignmentInBytes = (2*wordSize);
stefank@2314 32
goetz@6468 33 // Indicates whether the C calling conventions require that
goetz@6468 34 // 32-bit integer argument values are properly extended to 64 bits.
goetz@6468 35 // If set, SharedRuntime::c_calling_convention() must adapt
goetz@6468 36 // signatures accordingly.
goetz@6468 37 const bool CCallingConventionRequiresIntsAsLongs = false;
goetz@6468 38
bpittore@5067 39 #define SUPPORTS_NATIVE_CX8
bpittore@5067 40
stefank@2314 41 #endif // CPU_SPARC_VM_GLOBALDEFINITIONS_SPARC_HPP

mercurial