re PR libgcj/25187 (dereferencing type-punned pointer warnings while building libgcj)
2006-02-08 Bryce McKinlay <mckinlay@redhat.com> PR libgcj/25187: * gnu/gcj/io/natSimpleSHSStream.cc (gnu::gcj::io::SimpleSHSStream::shsFinal): Remove bogus cast. * interpret.cc (_Jv_InterpMethod::run): Simplify arguments to _Jv_InterpFrame(). * boehm.cc: #undef some autoconf macros before including gc-config.h. (_Jv_MarkObject): Don't mark the class, it is reachable via the vtable. (_Jv_MarkArray): Likewise. * java/lang/ref/natReference.cc (java::lang::ref::Reference::create): Simplify _Jv_GCRegisterDisappearingLink() call. * java/lang/Class.h (getComponentType): Use element_type. (element_type): New field declaration, as a union with "methods". * java/lang/natClassLoader.cc (_Jv_NewArrayClass): Use "element_type". * java/net/natVMNetworkInterfacePosix.cc (java::net::VMNetworkInterface::getInterfaces): Add "int" cast to avoid sign comparison warning. * include/java-interp.h (_Jv_InterpFrame): Take thread as second argument, not parent call frame. * include/x86_64-signal.h (MAKE_THROW_FRAME): Use "gregs" directly, without a cast. (restore_rt): Declare with hidden visibility, not "static". * posix.cc (_Jv_platform_initProperties): Make "tmpdir" a string constant. * jni.cc (_Jv_JNI_DestroyJavaVM): Use a union to avoid strict alias warning From-SVN: r110783
This commit is contained in:
parent
c03a2b6f68
commit
1349c68851
12 changed files with 65 additions and 29 deletions
|
@ -22,6 +22,8 @@ details. */
|
|||
#include <java/lang/Class.h>
|
||||
#include <java/lang/ClassLoader.h>
|
||||
#include <java/lang/reflect/Modifier.h>
|
||||
#include <java/lang/Thread.h>
|
||||
#include <gnu/gcj/RawData.h>
|
||||
|
||||
// Define this to get the direct-threaded interpreter. If undefined,
|
||||
// we revert to a basic bytecode interpreter. The former is faster
|
||||
|
@ -290,22 +292,22 @@ public:
|
|||
struct _Jv_InterpFrame
|
||||
{
|
||||
_Jv_InterpMethod *self;
|
||||
_Jv_InterpFrame **ptr;
|
||||
java::lang::Thread *thread;
|
||||
_Jv_InterpFrame *next;
|
||||
pc_t pc;
|
||||
|
||||
_Jv_InterpFrame (_Jv_InterpMethod *s, _Jv_InterpFrame **n)
|
||||
_Jv_InterpFrame (_Jv_InterpMethod *s, java::lang::Thread *thr)
|
||||
{
|
||||
self = s;
|
||||
ptr = n;
|
||||
next = *n;
|
||||
*n = this;
|
||||
thread = thr;
|
||||
next = (_Jv_InterpFrame *) thr->interp_frame;
|
||||
thr->interp_frame = (gnu::gcj::RawData *) this;
|
||||
pc = NULL;
|
||||
}
|
||||
|
||||
~_Jv_InterpFrame ()
|
||||
{
|
||||
*ptr = next;
|
||||
thread->interp_frame = (gnu::gcj::RawData *) next;
|
||||
}
|
||||
};
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue