13 * This code is distributed in the hope that it will be useful, but WITHOUT
14 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 * version 2 for more details (a copy is included in the LICENSE file that
17 * accompanied this code).
18 *
19 * You should have received a copy of the GNU General Public License version
20 * 2 along with this work; if not, write to the Free Software Foundation,
21 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
22 *
23 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
24 * or visit www.oracle.com if you need additional information or have any
25 * questions.
26 *
27 */
28
29 package jdk.internal.foreign.abi.riscv64.linux;
30
31 import jdk.internal.foreign.abi.AbstractLinker;
32 import jdk.internal.foreign.abi.LinkerOptions;
33
34 import java.lang.foreign.FunctionDescriptor;
35 import java.lang.invoke.MethodHandle;
36 import java.lang.invoke.MethodType;
37 import java.nio.ByteOrder;
38
39 public final class LinuxRISCV64Linker extends AbstractLinker {
40
41 public static LinuxRISCV64Linker getInstance() {
42 final class Holder {
43 private static final LinuxRISCV64Linker INSTANCE = new LinuxRISCV64Linker();
44 }
45
46 return Holder.INSTANCE;
47 }
48
49 private LinuxRISCV64Linker() {
50 // Ensure there is only one instance
51 }
52
53 @Override
54 protected MethodHandle arrangeDowncall(MethodType inferredMethodType, FunctionDescriptor function, LinkerOptions options) {
55 return LinuxRISCV64CallArranger.arrangeDowncall(inferredMethodType, function, options);
56 }
57
58 @Override
59 protected UpcallStubFactory arrangeUpcall(MethodType targetType, FunctionDescriptor function, LinkerOptions options) {
60 return LinuxRISCV64CallArranger.arrangeUpcall(targetType, function, options);
61 }
62
63 @Override
64 protected ByteOrder linkerByteOrder() {
65 return ByteOrder.LITTLE_ENDIAN;
66 }
67 }
|
13 * This code is distributed in the hope that it will be useful, but WITHOUT
14 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 * version 2 for more details (a copy is included in the LICENSE file that
17 * accompanied this code).
18 *
19 * You should have received a copy of the GNU General Public License version
20 * 2 along with this work; if not, write to the Free Software Foundation,
21 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
22 *
23 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
24 * or visit www.oracle.com if you need additional information or have any
25 * questions.
26 *
27 */
28
29 package jdk.internal.foreign.abi.riscv64.linux;
30
31 import jdk.internal.foreign.abi.AbstractLinker;
32 import jdk.internal.foreign.abi.LinkerOptions;
33 import jdk.internal.foreign.abi.SharedUtils;
34
35 import java.lang.foreign.FunctionDescriptor;
36 import java.lang.foreign.MemoryLayout;
37 import java.lang.foreign.ValueLayout;
38 import java.lang.invoke.MethodHandle;
39 import java.lang.invoke.MethodType;
40 import java.nio.ByteOrder;
41 import java.util.Map;
42
43 public final class LinuxRISCV64Linker extends AbstractLinker {
44
45 static final Map<String, MemoryLayout> CANONICAL_LAYOUTS =
46 SharedUtils.canonicalLayouts(ValueLayout.JAVA_LONG, ValueLayout.JAVA_LONG, ValueLayout.JAVA_INT);
47
48 public static LinuxRISCV64Linker getInstance() {
49 final class Holder {
50 private static final LinuxRISCV64Linker INSTANCE = new LinuxRISCV64Linker();
51 }
52
53 return Holder.INSTANCE;
54 }
55
56 private LinuxRISCV64Linker() {
57 // Ensure there is only one instance
58 }
59
60 @Override
61 protected MethodHandle arrangeDowncall(MethodType inferredMethodType, FunctionDescriptor function, LinkerOptions options) {
62 return LinuxRISCV64CallArranger.arrangeDowncall(inferredMethodType, function, options);
63 }
64
65 @Override
66 protected UpcallStubFactory arrangeUpcall(MethodType targetType, FunctionDescriptor function, LinkerOptions options) {
67 return LinuxRISCV64CallArranger.arrangeUpcall(targetType, function, options);
68 }
69
70 @Override
71 protected ByteOrder linkerByteOrder() {
72 return ByteOrder.LITTLE_ENDIAN;
73 }
74
75 @Override
76 public Map<String, MemoryLayout> canonicalLayouts() {
77 return CANONICAL_LAYOUTS;
78 }
79 }
|