From 17341dad94b2f36c0202ff0706ba5d2b9438ffed Mon Sep 17 00:00:00 2001 From: Aleksey Shipilev Date: Tue, 22 Jan 2019 21:18:25 +0100 Subject: [PATCH] 8217467: Access barriers are missing in C2 intrinsic for Base64 Reviewed-by: thartmann, roland, rkennke, kvn --- src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp | 3 +++ src/hotspot/share/opto/library_call.cpp | 5 +++++ 2 files changed, 8 insertions(+) diff --git a/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp b/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp index cbb35d36788..b32db7a8f35 100644 --- a/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp +++ b/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp @@ -1023,6 +1023,9 @@ void ShenandoahBarrierNode::verify(RootNode* root) { "sha512_implCompressMB", { { TypeFunc::Parms, ShenandoahLoad }, { TypeFunc::Parms+1, ShenandoahStore }, { -1, ShenandoahNone }, { -1, ShenandoahNone}, { -1, ShenandoahNone}, { -1, ShenandoahNone} }, + "encodeBlock", + { { TypeFunc::Parms, ShenandoahLoad }, { TypeFunc::Parms+3, ShenandoahStore }, { -1, ShenandoahNone }, + { -1, ShenandoahNone}, { -1, ShenandoahNone}, { -1, ShenandoahNone} }, }; if (call->is_call_to_arraycopystub()) { diff --git a/src/hotspot/share/opto/library_call.cpp b/src/hotspot/share/opto/library_call.cpp index 60d97657b00..afc0a622c3d 100644 --- a/src/hotspot/share/opto/library_call.cpp +++ b/src/hotspot/share/opto/library_call.cpp @@ -6260,6 +6260,11 @@ bool LibraryCallKit::inline_base64_encodeBlock() { Node* dp = argument(5); Node* isURL = argument(6); + src = must_be_not_null(src, true); + src = access_resolve(src, ACCESS_READ); + dest = must_be_not_null(dest, true); + dest = access_resolve(dest, ACCESS_WRITE); + Node* src_start = array_element_address(src, intcon(0), T_BYTE); assert(src_start, "source array is NULL"); Node* dest_start = array_element_address(dest, intcon(0), T_BYTE);