0N/A/*
3845N/A * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
0N/A * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
0N/A *
0N/A * This code is free software; you can redistribute it and/or modify it
0N/A * under the terms of the GNU General Public License version 2 only, as
0N/A * published by the Free Software Foundation.
0N/A *
0N/A * This code is distributed in the hope that it will be useful, but WITHOUT
0N/A * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
0N/A * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
0N/A * version 2 for more details (a copy is included in the LICENSE file that
0N/A * accompanied this code).
0N/A *
0N/A * You should have received a copy of the GNU General Public License version
0N/A * 2 along with this work; if not, write to the Free Software Foundation,
0N/A * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
0N/A *
1472N/A * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1472N/A * or visit www.oracle.com if you need additional information or have any
1472N/A * questions.
0N/A *
0N/A */
0N/A
1879N/A#ifndef SHARE_VM_OPTO_OPCODES_HPP
1879N/A#define SHARE_VM_OPTO_OPCODES_HPP
1879N/A
0N/A// Build a big enum of class names to give them dense integer indices
0N/A#define macro(x) Op_##x,
0N/Aenum Opcodes {
0N/A Op_Node = 0,
0N/A macro(Set) // Instruction selection match rule
113N/A macro(RegN) // Machine narrow oop register
0N/A macro(RegI) // Machine integer register
0N/A macro(RegP) // Machine pointer register
0N/A macro(RegF) // Machine float register
0N/A macro(RegD) // Machine double register
0N/A macro(RegL) // Machine long register
3845N/A macro(VecS) // Machine vectors register
3845N/A macro(VecD) // Machine vectord register
3845N/A macro(VecX) // Machine vectorx register
3845N/A macro(VecY) // Machine vectory register
0N/A macro(RegFlags) // Machine flags register
0N/A _last_machine_leaf, // Split between regular opcodes and machine
0N/A#include "classes.hpp"
0N/A _last_opcode
0N/A};
0N/A#undef macro
0N/A
0N/A// Table of names, indexed by Opcode
0N/Aextern const char *NodeClassNames[];
1879N/A
1879N/A#endif // SHARE_VM_OPTO_OPCODES_HPP