Mercurial > hg > truffle
view src/share/vm/graal/graalVmIds.hpp @ 2890:c23d45daff9b
Renamed cpp/hpp file directory.
author | Thomas Wuerthinger <thomas@wuerthinger.net> |
---|---|
date | Wed, 08 Jun 2011 13:40:25 +0200 |
parents | src/share/vm/c1x/graalVmIds.hpp@2fb867285938 |
children | f00918f35c7f |
line wrap: on
line source
/* * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ #include "memory/allocation.hpp" #include "utilities/growableArray.hpp" #include "oops/oop.hpp" #include "runtime/handles.hpp" #include "runtime/thread.hpp" #include "classfile/javaClasses.hpp" #include "runtime/jniHandles.hpp" class VmIds : public AllStatic { private: static GrowableArray<address>* _stubs; static GrowableArray<jobject>* _localHandles; static oop getObject(jlong id); public: // these constants needs to have the same values as the one in HotSpotProxy.java static const jlong STUB = 0x100000000000000LL; // address static const jlong METHOD = 0x200000000000000LL; // methodOop static const jlong CLASS = 0x300000000000000LL; // klassOop static const jlong CONSTANT_POOL = 0x500000000000000LL; // constantPoolOop static const jlong CONSTANT = 0x600000000000000LL; // oop static const jlong TYPE_MASK = 0xf00000000000000LL; static const jlong DUMMY_CONSTANT = 0x6ffffffffffffffLL; // Initializes the VmIds for a compilation, by creating the arrays static void initializeObjects(); // Cleans up after a compilation, by deallocating the arrays static void cleanupLocalObjects(); // Adds a stub address, and returns the corresponding vmId (which is of type STUB) static jlong addStub(address stub); // Adds an object, and returns the corresponding vmId (with the given type) static jlong add(Handle obj, jlong type); // Adds an object, and returns the corresponding vmId (the type of which is determined by the template parameter) template <typename T> static jlong add(T obj); // Returns the stub address with the given vmId static address getStub(jlong id); // Returns the stub address with the given vmId taken from a java.lang.Long static address getStub(oop id); // Returns the object with the given id, the return type is defined by the template parameter (which must correspond to the actual type of the vmId) template <typename T> static T get(jlong id); // Helper function to convert a symbol to a java.lang.String object template <typename T> static T toString(Symbol* symbol, TRAPS); // Helper function to convert a java.lang.String object to a symbol (this will return NULL if the symbol doesn't exist in the system) static Symbol* toSymbol(jstring string); // Helper function to get the contents of a java.lang.Long static jlong getBoxedLong(oop obj); }; template <> inline jlong VmIds::add<methodOop>(methodOop obj){ assert(obj != NULL, "trying to add NULL<methodOop>"); assert(obj->is_method(), "trying to add mistyped object"); return add(Handle(obj), METHOD); } template <> inline jlong VmIds::add<klassOop>(klassOop obj) { assert(obj != NULL, "trying to add NULL<klassOop>"); assert(obj->is_klass(), "trying to add mistyped object"); return add(Handle(obj), CLASS); } template <> inline jlong VmIds::add<constantPoolOop>(constantPoolOop obj) { assert(obj != NULL, "trying to add NULL<constantPoolOop>"); assert(obj->is_constantPool(), "trying to add mistyped object"); return add(Handle(obj), CONSTANT_POOL); } template <> inline jlong VmIds::add<oop>(oop obj) { assert(obj != NULL, "trying to add NULL<oop>"); assert(obj->is_oop(), "trying to add mistyped object"); return add(Handle(obj), CONSTANT); } template <> inline methodOop VmIds::get<methodOop>(jlong id){ assert((id & TYPE_MASK) == METHOD, "METHOD expected"); assert(getObject(id)->is_method(), "methodOop expected"); return (methodOop)getObject(id); } template <> inline klassOop VmIds::get<klassOop>(jlong id) { assert((id & TYPE_MASK) == CLASS, "CLASS expected"); assert(getObject(id)->is_klass(), "klassOop expected"); return (klassOop)getObject(id); } template <> inline constantPoolOop VmIds::get<constantPoolOop>(jlong id) { assert((id & TYPE_MASK) == CONSTANT_POOL, "CONSTANT_POOL expected"); assert(getObject(id)->is_constantPool(), "constantPoolOop expected"); return (constantPoolOop)getObject(id); } template <> inline oop VmIds::get<oop>(jlong id) { assert((id & TYPE_MASK) == CONSTANT, "CONSTANT expected"); assert(getObject(id)->is_oop(true), "oop expected"); return (oop)getObject(id); } inline address VmIds::getStub(oop obj) { return getStub(getBoxedLong(obj)); } template <> inline Handle VmIds::toString<Handle>(Symbol* symbol, TRAPS) { return java_lang_String::create_from_symbol(symbol, THREAD); } template <> inline oop VmIds::toString<oop>(Symbol* symbol, TRAPS) { return toString<Handle>(symbol, THREAD)(); } template <> inline jstring VmIds::toString<jstring>(Symbol* symbol, TRAPS) { return (jstring)JNIHandles::make_local(toString<oop>(symbol, THREAD)); } template <> inline jobject VmIds::toString<jobject>(Symbol* symbol, TRAPS) { return JNIHandles::make_local(toString<oop>(symbol, THREAD)); } inline Symbol* VmIds::toSymbol(jstring string) { return java_lang_String::as_symbol_or_null(JNIHandles::resolve(string)); } inline jlong VmIds::getBoxedLong(oop obj) { assert(obj->is_oop(true), "cannot unbox null or non-oop"); return obj->long_field(java_lang_boxing_object::value_offset_in_bytes(T_LONG)); }