comparison graal/com.oracle.max.asmdis/src/com/sun/max/asm/gen/risc/sparc/SPARCAssembly.java @ 3733:e233f5660da4

Added Java files from Maxine project.
author Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
date Sat, 17 Dec 2011 19:59:18 +0100
parents
children bc8527f3071c
comparison
equal deleted inserted replaced
3732:3e2e8b8abdaf 3733:e233f5660da4
1 /*
2 * Copyright (c) 2007, 2011, Oracle and/or its affiliates. All rights reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.
8 *
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 * or visit www.oracle.com if you need additional information or have any
21 * questions.
22 */
23 package com.sun.max.asm.gen.risc.sparc;
24
25 import java.util.*;
26
27 import com.sun.max.asm.gen.risc.*;
28 import com.sun.max.asm.gen.risc.bitRange.*;
29 import com.sun.max.lang.*;
30
31 /**
32 */
33 public final class SPARCAssembly extends RiscAssembly {
34
35 private static final boolean GENERATING_DEPRECATED_INSTRUCTIONS = true;
36 private static final boolean GENERATING_V9_INSTRUCTIONS = true;
37
38 private SPARCAssembly() {
39 super(ISA.SPARC, RiscTemplate.class);
40 }
41
42 public boolean generatingDeprecatedInstructions() {
43 return GENERATING_DEPRECATED_INSTRUCTIONS;
44 }
45
46 public boolean generatingV9Instructions() {
47 return GENERATING_V9_INSTRUCTIONS;
48 }
49
50 @Override
51 public BitRangeOrder bitRangeEndianness() {
52 return BitRangeOrder.DESCENDING;
53 }
54
55 @Override
56 protected List<RiscTemplate> createTemplates() {
57 final RiscTemplateCreator creator = new RiscTemplateCreator();
58 creator.createTemplates(new MemoryAccess(creator));
59 creator.createTemplates(new MemorySynchronization(creator));
60 creator.createTemplates(new IntegerArithmetic(creator));
61 creator.createTemplates(new ControlTransfer(creator));
62 creator.createTemplates(new ConditionalMove(creator));
63 creator.createTemplates(new RegisterWindowManagement(creator));
64 creator.createTemplates(new StateRegisterAccess(creator));
65 creator.createTemplates(new PrivilegedRegisterAccess(creator));
66 creator.createTemplates(new FloatingPointOperate(creator));
67 creator.createTemplates(new ImplementationDependent(creator));
68 creator.createTemplates(new SyntheticInstructions(creator));
69 return creator.templates();
70 }
71
72 public static final SPARCAssembly ASSEMBLY = new SPARCAssembly();
73 }