Blame SOURCES/pr3479-rh1486025-sunec_provider_can_have_multiple_instances_leading_to_premature_nss_shutdown.patch

2d54fe
# HG changeset patch
2d54fe
# User andrew
2d54fe
# Date 1508194072 -3600
2d54fe
#      Mon Oct 16 23:47:52 2017 +0100
2d54fe
# Node ID 5dcb55da00c1531264934559c9f10c2e0ae46420
2d54fe
# Parent  bf62c56e3604fee0018b19f65fd56c76dc156630
2d54fe
PR3479, RH1486025: ECC and NSS JVM crash
2d54fe
Summary: SunEC provider can have multiple instances, leading to premature NSS shutdown
2d54fe
Contributed-by: Martin Balao <mbalao@redhat.com>
2d54fe
2d54fe
diff --git a/make/mapfiles/libsunec/mapfile-vers b/make/mapfiles/libsunec/mapfile-vers
2d54fe
--- openjdk/jdk/make/mapfiles/libsunec/mapfile-vers
2d54fe
+++ openjdk/jdk/make/mapfiles/libsunec/mapfile-vers
2d54fe
@@ -32,7 +32,6 @@
2d54fe
                 Java_sun_security_ec_ECDSASignature_verifySignedDigest;
2d54fe
                 Java_sun_security_ec_ECDHKeyAgreement_deriveKey;
2d54fe
 		Java_sun_security_ec_SunEC_initialize;
2d54fe
-		Java_sun_security_ec_SunEC_cleanup;
2d54fe
         local:
2d54fe
                 *;
2d54fe
 };
2d54fe
diff --git a/src/share/classes/sun/security/ec/SunEC.java b/src/share/classes/sun/security/ec/SunEC.java
2d54fe
--- openjdk/jdk/src/share/classes/sun/security/ec/SunEC.java
2d54fe
+++ openjdk/jdk/src/share/classes/sun/security/ec/SunEC.java
2d54fe
@@ -83,21 +83,8 @@
2d54fe
     }
2d54fe
 
2d54fe
     /**
2d54fe
-     * Cleanup native resources during finalisation.
2d54fe
-     */
2d54fe
-    @Override
2d54fe
-    protected void finalize() {
2d54fe
-        cleanup();
2d54fe
-    }
2d54fe
-
2d54fe
-    /**
2d54fe
      * Initialize the native code.
2d54fe
      */
2d54fe
     private static native void initialize();
2d54fe
 
2d54fe
-    /**
2d54fe
-     * Cleanup in the native layer.
2d54fe
-     */
2d54fe
-    private static native void cleanup();
2d54fe
-
2d54fe
 }
2d54fe
diff --git a/src/share/native/sun/security/ec/ECC_JNI.cpp b/src/share/native/sun/security/ec/ECC_JNI.cpp
2d54fe
--- openjdk/jdk/src/share/native/sun/security/ec/ECC_JNI.cpp
2d54fe
+++ openjdk/jdk/src/share/native/sun/security/ec/ECC_JNI.cpp
2d54fe
@@ -525,14 +525,12 @@
2d54fe
 }
2d54fe
 
2d54fe
 JNIEXPORT void
2d54fe
-JNICALL Java_sun_security_ec_SunEC_cleanup
2d54fe
-  (JNIEnv *env, jclass UNUSED(clazz))
2d54fe
+JNICALL JNI_OnUnload
2d54fe
+  (JavaVM *vm, void *reserved)
2d54fe
 {
2d54fe
 #ifdef SYSTEM_NSS
2d54fe
     RNG_RNGShutdown();
2d54fe
-    if (SECOID_Shutdown() != SECSuccess) {
2d54fe
-	ThrowException(env, INTERNAL_ERROR);
2d54fe
-    }
2d54fe
+    SECOID_Shutdown();
2d54fe
 #endif
2d54fe
 }
2d54fe