make/linux/platform_ppc

Fri, 20 Sep 2013 10:53:28 +0200

author
stefank
date
Fri, 20 Sep 2013 10:53:28 +0200
changeset 5769
2c022e432e10
parent 2508
b92c45f2bc75
child 6440
0f03ff49c720
permissions
-rw-r--r--

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

bobv@2508 1 os_family = linux
bobv@2508 2
bobv@2508 3 arch = ppc
bobv@2508 4
bobv@2508 5 arch_model = ppc
bobv@2508 6
bobv@2508 7 os_arch = linux_ppc
bobv@2508 8
bobv@2508 9 os_arch_model = linux_ppc
bobv@2508 10
bobv@2508 11 lib_arch = ppc
bobv@2508 12
bobv@2508 13 compiler = gcc
bobv@2508 14
bobv@2508 15 gnu_dis_arch = ppc
bobv@2508 16
bobv@2508 17 sysdefs = -DLINUX -D_GNU_SOURCE -DPPC

mercurial