diff options
author | Tom Tromey <tromey@redhat.com> | 2003-08-28 22:17:37 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 2003-08-28 22:17:37 +0000 |
commit | 91edd042ff3b7b58be7c20bf7483445f60c43210 (patch) | |
tree | a5d84d77e14c8eed9bc348be5e03ab4e6490a077 /libjava/gnu/gcj/runtime/natSharedLibLoader.cc | |
parent | ff2865f2dde326797f4061c32c19fc75dcd4fec5 (diff) | |
download | gcc-91edd042ff3b7b58be7c20bf7483445f60c43210.zip gcc-91edd042ff3b7b58be7c20bf7483445f60c43210.tar.gz gcc-91edd042ff3b7b58be7c20bf7483445f60c43210.tar.bz2 |
Makefile.in: Rebuilt.
* Makefile.in: Rebuilt.
* Makefile.am (ordinary_java_source_files): Added new files.
* java/lang/Class.h (_Jv_sharedlib_register_hook): Declare as
friend.
* java/net/URLClassLoader.java (findClass): Don't use
findURLResource. Use loader's getClass method.
(URLLoader.getClass): New method.
(addURL): Handle `gcjlib' URLs.
(SoURLLoader): New class.
(SoResource): Likewise.
* gnu/gcj/protocol/gcjlib/Connection.java: New file.
* gnu/gcj/protocol/gcjlib/Handler.java: New file.
* include/jvm.h (struct _Jv_core_chain): Moved from natCore.cc.
(_Jv_RegisterCoreHook): Declare.
(_Jv_FindCore): Declare.
* gnu/gcj/runtime/SharedLibHelper.java: New file.
* gnu/gcj/runtime/natSharedLibLoader.cc (CoreHookFunc): New
typedef.
(core_hook): New function.
(struct SharedLibDummy) [saved_core]: New field.
(init): Set _Jv_RegisterCoreHook. Throw exception on failure.
(register_hook): Set protection domain and class loader on new
class.
(finalize): Free core chain.
* gnu/gcj/Core.java (Core): New constructor.
* gnu/gcj/runtime/SharedLibLoader.java: Rewrote to use
SharedLibHelper.
* gnu/gcj/natCore.cc (_Jv_RegisterResource): Indentation fixlet.
(_Jv_create_core): New function.
(create): Use it.
(default_register_resource): New function.
(_Jv_RegisterCoreHook): New global.
(_Jv_RegisterResource): Use it.
(core_chain_struct): Removed.
(_Jv_FindCore): New function.
(_Jv_FreeCoreChain): New function.
From-SVN: r70892
Diffstat (limited to 'libjava/gnu/gcj/runtime/natSharedLibLoader.cc')
-rw-r--r-- | libjava/gnu/gcj/runtime/natSharedLibLoader.cc | 79 |
1 files changed, 59 insertions, 20 deletions
diff --git a/libjava/gnu/gcj/runtime/natSharedLibLoader.cc b/libjava/gnu/gcj/runtime/natSharedLibLoader.cc index 49bcfb4..46eef75 100644 --- a/libjava/gnu/gcj/runtime/natSharedLibLoader.cc +++ b/libjava/gnu/gcj/runtime/natSharedLibLoader.cc @@ -1,4 +1,4 @@ -// natSharedLibLoader.cc - Implementation of FirstThread native methods. +// natSharedLibLoader.cc - Implementation of SharedLibHelper native methods. /* Copyright (C) 2001, 2003 Free Software Foundation @@ -11,74 +11,113 @@ details. */ #include <config.h> #include <gcj/cni.h> -#include <gnu/gcj/runtime/SharedLibLoader.h> +#include <jvm.h> +#include <gnu/gcj/runtime/SharedLibHelper.h> #include <java/io/IOException.h> #include <java/lang/UnsupportedOperationException.h> -#include <java/lang/UnsatisfiedLinkError.h> +#include <java/lang/UnknownError.h> #ifdef HAVE_DLOPEN #include <dlfcn.h> /* Only used during dlopen, while having a lock on Class.class. */ -static gnu::gcj::runtime::SharedLibLoader* curLoader; +static java::lang::ClassLoader *curLoader; +static gnu::gcj::runtime::SharedLibHelper *curHelper; typedef void (*ClassHookFunc) (jclass); +typedef void (*CoreHookFunc) (_Jv_core_chain *); + +void +_Jv_sharedlib_register_hook (jclass cls) +{ + curHelper->registerClass(cls->getName(), cls); + cls->protectionDomain = curHelper->domain; + cls->loader = curLoader; +} static void -::register_hook(jclass cls) +core_hook (_Jv_core_chain *chain) { - curLoader->registerClass(cls->getName(), cls); + chain->next = (_Jv_core_chain *) curHelper->core_chain; + curHelper->core_chain = (gnu::gcj::RawData *) chain; } struct SharedLibDummy { ClassHookFunc saved; + CoreHookFunc saved_core; SharedLibDummy() { saved = _Jv_RegisterClassHook; + saved_core = _Jv_RegisterCoreHook; } ~SharedLibDummy() { _Jv_RegisterClassHook = saved; + _Jv_RegisterCoreHook = saved_core; curLoader = NULL; } }; #endif void -gnu::gcj::runtime::SharedLibLoader::init(jstring libname, jint flags) +gnu::gcj::runtime::SharedLibHelper::init(void) { #ifdef HAVE_DLOPEN - jint len = _Jv_GetStringUTFLength (libname); - char lname[len + 1]; - JvGetStringUTFRegion (libname, 0, libname->length(), lname); - lname[len] = '\0'; + char *lname = (char *) __builtin_alloca (JvGetStringUTFLength (baseName) + + 1); + jsize total = JvGetStringUTFRegion (baseName, 0, baseName->length(), lname); + lname[total] = '\0'; if (flags==0) - flags = RTLD_LAZY; + flags = RTLD_GLOBAL | RTLD_LAZY; JvSynchronize dummy1(&java::lang::Class::class$); SharedLibDummy dummy2; - curLoader = this; - _Jv_RegisterClassHook = ::register_hook; + curLoader = loader; + curHelper = this; + _Jv_RegisterClassHook = _Jv_sharedlib_register_hook; + _Jv_RegisterCoreHook = core_hook; void *h = dlopen(lname, flags); if (h == NULL) { const char *msg = dlerror(); - jstring str = JvNewStringLatin1 (lname); - str = str->concat (JvNewStringLatin1 (": ")); - str = str->concat (JvNewStringLatin1 (msg)); - throw new java::lang::UnsatisfiedLinkError (str); + throw new java::lang::UnknownError(JvNewStringLatin1(msg)); } handler = (gnu::gcj::RawData*) h; #else - const char *msg = "SharedLibLoader is not supported on this platform"; + const char *msg + = "shared library class loading is not supported on this platform"; throw new java::lang::UnsupportedOperationException(JvNewStringLatin1(msg)); #endif } +jboolean +gnu::gcj::runtime::SharedLibHelper::hasResource (jstring name) +{ +#ifdef HAVE_DLOPEN + _Jv_core_chain *node = _Jv_FindCore ((_Jv_core_chain *) core_chain, name); + return node != NULL; +#else + return false; +#endif +} + +gnu::gcj::Core * +gnu::gcj::runtime::SharedLibHelper::findCore (jstring name) +{ +#ifdef HAVE_DLOPEN + extern gnu::gcj::Core *_Jv_create_core (_Jv_core_chain *node, jstring name); + ensureInit(); + return _Jv_create_core ((_Jv_core_chain *) core_chain, name); +#else + return NULL; +#endif +} + void -gnu::gcj::runtime::SharedLibLoader::finalize() +gnu::gcj::runtime::SharedLibHelper::finalize() { + _Jv_FreeCoreChain ((_Jv_core_chain *) core_chain); #ifdef HAVE_DLOPEN dlclose (handler); #endif |