[patch] Fix oddity in personality routine

Andrew Haley aph@redhat.com
Tue Dec 1 17:24:00 GMT 2009


Jack Howarth wrote:
> On Tue, Dec 01, 2009 at 09:29:36AM +0000, Andrew Haley wrote:
>> Jack Howarth wrote:
>>>>> (gdb) 
>>> 54	 (*real_main) (args);
>>> (gdb) 
>>>>>> Program received signal EXC_BAD_ACCESS, Could not access memory.
>>> Reason: KERN_PROTECTION_FAILURE at address: 0x0000000103f05db0
>>> 0x0000000103f05db0 in ?? () at RowSetEvent.java:51
>>> 51	RowSetEvent.java: No such file or directory.
>>> 	in RowSetEvent.java
>>> (gdb) 
>>>>>> A backtrace only shows...
>>>>>> (gdb) bt
>>> #0 0x0000000103f05db0 in ?? () at RowSetEvent.java:51
>>> #1 0x00000001000485be in gnu::java::lang::MainThread::call_main (this=0x104875dc0) at ../../../gcc-4.5-20091128/libjava/gnu/java/lang/natMainThread.cc:54
>>> Previous frame inner to this frame (gdb could not unwind past this frame)
>>>>>> Let me know if you have any suggestions for debugging this further.
>> Disassemble the first 10 or so instructions at the instruction where the
>> EXC_BAD_ACCESS occurs. I think this is a libffi bug.
>>>> Andrew.
>> Andrew,
> So just to clarify, for the instance of...
>> -------------------
>> (gdb) 
> 0x00000001004168df in _ZN4java4lang7reflect8Modifier8isPublicEJbi (mod=9) at Modifier.java:258
> 258	 return (mod & PUBLIC) != 0;
> (gdb) 
> gnu::java::lang::MainThread::call_main (this=0x104875dc0) at ../../../gcc-4.5-20091128/libjava/gnu/java/lang/natMainThread.cc:46
> 46	 msg = "`main' must be public";
> (gdb) 
> 45	 else if (! ::java::lang::reflect::Modifier::isPublic(meth->accflags))
> (gdb) 
> 54	 (*real_main) (args);
> (gdb) 
>> Program received signal EXC_BAD_ACCESS, Could not access memory.
> Reason: KERN_PROTECTION_FAILURE at address: 0x0000000103f05db0
> 0x0000000103f05db0 in ?? () at RowSetEvent.java:51
> 51	RowSetEvent.java: No such file or directory.
> 	in RowSetEvent.java
> (gdb) 
>> A backtrace only shows...
>> (gdb) bt
> #0 0x0000000103f05db0 in ?? () at RowSetEvent.java:51
> #1 0x00000001000485be in gnu::java::lang::MainThread::call_main (this=0x104875dc0) at ../../../gcc-4.5-20091128/libjava/gnu/java/lang/natMainThread.cc:54
> Previous frame inner to this frame (gdb could not unwind past this frame)
>> -----------------
>> I want to disassemble from 0x00000001000485be, right?

0x0000000103f05db0, where the fault happens. I think it's a libffi stub,
and I think its page permissions are not correctly set.
But let's see.
What I would do is, at
> 54	 (*real_main) (args);

disassemble the call instruction, it's probably call ($rax) or somesuch.
look in $rax with
p $rax
and disassemble from the address that's in there.
Andrew.


More information about the Java mailing list

AltStyle によって変換されたページ (->オリジナル) /