Fri, 20 Sep 2013 10:53:28 +0200 8024974: Incorrect use of GC_locker::is_active()
stefank [Fri, 20 Sep 2013 10:53:28 +0200] rev 20079
8024974: Incorrect use of GC_locker::is_active() Summary: SymbolTable and StringTable can make calls to GC_locker::is_active() outside a safepoint. This isn't safe because the GC_locker active state (lock count) is only updated at a safepoint and only remains valid as long as _needs_gc is true. However, outside a safepoint_needs_gc can change to false at any time, which makes it impossible to do a correct call to is_active() in that context. In this case these calls can just be removed since the input argument to basic_add() should never be on the heap and so there's no need to check the GC_locker state. This change also adjusts the assert() in is_active() to makes sure all calls to this function are always done under a safepoint. Reviewed-by: brutisso, dcubed Contributed-by: per.liden@oracle.com
Thu, 26 Sep 2013 04:00:09 -0700 Merge
bdelsart [Thu, 26 Sep 2013 04:00:09 -0700] rev 20078
Merge
(0) -10000 -3000 -1000 -300 -100 -30 -10 -2 +2 +10 +30 +100 +300 +1000 +3000 +10000 +30000 tip