hg: jdk8u/hs-dev/hotspot: 8050978: Fix bad field access check in C1 and C2

vladimir.kozlov at oracle.com vladimir.kozlov at oracle.com
Thu Jul 24 18:33:24 UTC 2014


Changeset: f72d8917322a
Author:    goetz
Date:      2014-07-18 09:04 +0200
URL:       http://hg.openjdk.java.net/jdk8u/hs-dev/hotspot/rev/f72d8917322a

8050978: Fix bad field access check in C1 and C2
Summary: JCK8 test vm/constantpool/accessControl/accessControl004/accessControl00402m3/accessControl00402m3.html fails with -Xbatch -Xcomp due to bad field access check in C1 and C2. Fix: In ciField::ciField(), just before the canonical holder is stored into the _holder variable (and which is used by ciField::will_link()) perform an additional access check with the holder declared in the class file. If this check fails, store the declared holder instead and ciField::will_link() will bail out compilation for this field later on. Then, the interpreter will throw an PrivilegedAccessException at runtime.
Reviewed-by: kvn, vlivanov
Contributed-by: andreas.schoesser at sap.com

! src/share/vm/ci/ciField.cpp



More information about the jdk8u-all-changes mailing list