Fri, 20 Sep 2013 10:53:28 +0200
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
dcubed@485 | 1 | os_family = linux |
dcubed@485 | 2 | |
dcubed@485 | 3 | arch = x86 |
dcubed@485 | 4 | |
dcubed@485 | 5 | arch_model = x86_64 |
dcubed@485 | 6 | |
dcubed@485 | 7 | os_arch = linux_x86 |
dcubed@485 | 8 | |
dcubed@485 | 9 | os_arch_model = linux_x86_64 |
dcubed@485 | 10 | |
dcubed@485 | 11 | lib_arch = amd64 |
dcubed@485 | 12 | |
dcubed@485 | 13 | compiler = sparcWorks |
dcubed@485 | 14 | |
dcubed@485 | 15 | gnu_dis_arch = amd64 |
dcubed@485 | 16 | |
dcubed@485 | 17 | sysdefs = -DLINUX -DSPARC_WORKS -D_GNU_SOURCE -DAMD64 |