From 6247736fc9dedf60881639b768be68a2de8bd981 Mon Sep 17 00:00:00 2001 From: Lance Andersen Date: Wed, 11 Nov 2020 15:34:03 +0000 Subject: [PATCH] 8256018: Adler32/CRC32/CRC32C missing reachabilityFence Reviewed-by: naoto, alanb --- .../share/classes/java/util/zip/Adler32.java | 9 +++++++-- src/java.base/share/classes/java/util/zip/CRC32.java | 9 +++++++-- src/java.base/share/classes/java/util/zip/CRC32C.java | 11 ++++++++--- 3 files changed, 22 insertions(+), 7 deletions(-) diff --git a/src/java.base/share/classes/java/util/zip/Adler32.java b/src/java.base/share/classes/java/util/zip/Adler32.java index ee7c06e619d..33aac1ad79d 100644 --- a/src/java.base/share/classes/java/util/zip/Adler32.java +++ b/src/java.base/share/classes/java/util/zip/Adler32.java @@ -25,6 +25,7 @@ package java.util.zip; +import java.lang.ref.Reference; import java.nio.ByteBuffer; import sun.nio.ch.DirectBuffer; @@ -96,8 +97,12 @@ public class Adler32 implements Checksum { int rem = limit - pos; if (rem <= 0) return; - if (buffer instanceof DirectBuffer) { - adler = updateByteBuffer(adler, ((DirectBuffer)buffer).address(), pos, rem); + if (buffer.isDirect()) { + try { + adler = updateByteBuffer(adler, ((DirectBuffer)buffer).address(), pos, rem); + } finally { + Reference.reachabilityFence(buffer); + } } else if (buffer.hasArray()) { adler = updateBytes(adler, buffer.array(), pos + buffer.arrayOffset(), rem); } else { diff --git a/src/java.base/share/classes/java/util/zip/CRC32.java b/src/java.base/share/classes/java/util/zip/CRC32.java index a70afb90e51..17264eb1798 100644 --- a/src/java.base/share/classes/java/util/zip/CRC32.java +++ b/src/java.base/share/classes/java/util/zip/CRC32.java @@ -25,6 +25,7 @@ package java.util.zip; +import java.lang.ref.Reference; import java.nio.ByteBuffer; import java.util.Objects; @@ -95,8 +96,12 @@ public class CRC32 implements Checksum { int rem = limit - pos; if (rem <= 0) return; - if (buffer instanceof DirectBuffer) { - crc = updateByteBuffer(crc, ((DirectBuffer)buffer).address(), pos, rem); + if (buffer.isDirect()) { + try { + crc = updateByteBuffer(crc, ((DirectBuffer)buffer).address(), pos, rem); + } finally { + Reference.reachabilityFence(buffer); + } } else if (buffer.hasArray()) { crc = updateBytes(crc, buffer.array(), pos + buffer.arrayOffset(), rem); } else { diff --git a/src/java.base/share/classes/java/util/zip/CRC32C.java b/src/java.base/share/classes/java/util/zip/CRC32C.java index 0359a798816..fa138d4d3f6 100644 --- a/src/java.base/share/classes/java/util/zip/CRC32C.java +++ b/src/java.base/share/classes/java/util/zip/CRC32C.java @@ -24,6 +24,7 @@ */ package java.util.zip; +import java.lang.ref.Reference; import java.nio.ByteBuffer; import java.nio.ByteOrder; @@ -170,9 +171,13 @@ public final class CRC32C implements Checksum { return; } - if (buffer instanceof DirectBuffer) { - crc = updateDirectByteBuffer(crc, ((DirectBuffer) buffer).address(), - pos, limit); + if (buffer.isDirect()) { + try { + crc = updateDirectByteBuffer(crc, ((DirectBuffer) buffer).address(), + pos, limit); + } finally { + Reference.reachabilityFence(buffer); + } } else if (buffer.hasArray()) { crc = updateBytes(crc, buffer.array(), pos + buffer.arrayOffset(), limit + buffer.arrayOffset());