[9] RFR(M): 7194669: CodeCache::mark_for_deoptimization should avoid verifying dependencies multiple times
Albert Noll
albert.noll at oracle.com
Tue Jan 14 02:21:32 PST 2014
Hi, thanks for looking at the patch.
@Roland: Thanks for your suggestion. The current version follows your
suggestion
and uses pointers to the dependency arguments as
identifiers. As a result,
the argument identifiers are guaranteed to be unique
if no safepoint occurs.
A No_SafepointVerifier checks this assumption. For
testing, used -XX:+SafepointALot;
so far, no problem.
@Dean: I hope the above explanation answers your question.
@Christian: The current version uses an overloaded '==' operator in the
class DependencySignature.
Here is the new webrev:
http://cr.openjdk.java.net/~anoll/7194669/webrev.02/
Best,
Albert
On 01/10/2014 09:59 PM, Christian Thalinger wrote:
> This looks good. Just a suggestion (you can ignore that if you want): GrowableArray has find() and contains() methods. If you would override operator== in DependencySignature you could use GrowableArray::find().
>
> On Jan 10, 2014, at 5:28 AM, Albert Noll <albert.noll at oracle.com> wrote:
>
>> Hi,
>>
>> I've evaluated the performance difference (nashorn + octane) between binary search
>> and a linear search. The linear-search version uses one GrowableArray<DependencySignature*>
>> for each dependency type. The difference in dependency checking time is 15-20%, i.e., binary
>> search is 15-20% faster than linear search. However, using linear search to cache checked
>> dependencies is still ~4X faster compared to checking all dependencies.
>>
>> I guess 15-20% is not enough to justify using the new data structure. Here is the new
>> webrev that uses linear search:
>> http://cr.openjdk.java.net/~anoll/7194669/webrev.01/
>>
>> Best,
>> Albert
>>
>> On 01/09/2014 06:57 PM, Roland Westrelin wrote:
>>>> As I recall running some nashorn benchmarks takes about 10X more time when using fastdebug VM if VerifyDependencies is not switched off.
>>> Thanks Vladimir.
>>> What about simply pushing the dependency signatures to an unsorted growableArray() and doing a linear search? Maybe that’s good enough?
>>>
>>> Roland.
>>>
More information about the hotspot-compiler-dev
mailing list