RFR (S): 8024943: ciReplay: fails to dump replay data during safepointing

Vladimir Ivanov vladimir.x.ivanov at oracle.com
Thu Oct 3 07:30:30 PDT 2013


Updated webrev:
   http://cr.openjdk.java.net/~vlivanov/8024943/webrev.01/

Verified that replay data is dumped correctly in the following combinations:
   - thread_in_native
   - thread_in_vm
   - thread_in_vm + Compile_lock

Regarding ciEnv in invalid state (leaving aside the cases when the 
instance is corrupted), the only case when it is possible is when the VM 
crashed in ~ciEnv(). Don't know whether fixing it is worth the effort - 
in both cases we don't get valid replay data file.

Best regards,
Vladimir Ivanov

On 10/3/13 12:57 AM, John Rose wrote:
> On Oct 2, 2013, at 1:15 PM, Vladimir Ivanov <vladimir.x.ivanov at oracle.com> wrote:
>
>> http://cr.openjdk.java.net/~vlivanov/8024943/webrev.00/
>> 15 lines changed: 11 ins; 0 del; 4 mod
>>
>> In some situations VM fails to dump compiler replay file (produces empty replay_pid%p.log). The reason is that ciEnv::dump_replay_data tries to do thread state transition to VM unconditionally and acquire Compile_lock. It doesn't always work in context of VM error reporter.
>>
>> The fix is to provide new method specifically for VM error reporter (ciEnv::dump_replay_data_unsafe) which doesn't perform aforementioned actions.
>>
>> Testing: manual (checked that a valid dump is produced for a crash during safepointing).
>
> Is is possible that you've pushed a bug further into the CI code?  I would like you to take a look at this (if you haven't already) and either make code adjustments or describe current assumptions in comments, for the next maintainer.
>
> What I mean about "pushed a bug" is that the CI is (generally speaking) sensitive to the thread state.  (Note the GUARDED_VM_ENTRY macros everywhere.)  The dump_replay_data function calls a bunch of dump_replay_data subroutines on lots of little data structures in the CI.  Are any of them also sensitive to thread state?  If so, perhaps you want to have your
>
> Also, the ciEnv::current() call returns something to the error reporter, and if that something is non-null, it is assumed to be (up to high probability, of course) a valid ciEnv structure.  Are there any places where the ciEnv guy is in an inconsistent state but still published by ciEnv::current()?  Probably not, but it might be worth a comment noting the appropriate conditions.  My specific worry is that the call to remove_symbols in ~ciEnv might leave a space where the dumper would not see valid state.
>
> This crash dumper stuff cannot be nailed down 100%, of course, but this might be a good moment to make sure we've at least stomped on it a bit.
>
> Reviewed, pending resolution of the above.
>
> Thanks,
> — John
>


More information about the hotspot-compiler-dev mailing list