opcodes.hpp revision 113
0N/A/*
0N/A * Copyright 1997-2003 Sun Microsystems, Inc. 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 *
0N/A * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
0N/A * CA 95054 USA or visit www.sun.com if you need additional information or
0N/A * have any questions.
0N/A *
0N/A */
0N/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
0N/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
0N/A macro(RegFlags) // Machine flags register
0N/A _last_machine_leaf, // Split between regular opcodes and machine
0N/A#include "classes.hpp"
_last_opcode
};
#undef macro
// Table of names, indexed by Opcode
extern const char *NodeClassNames[];