HADOOP-15062. TestCryptoStreamsWithOpensslAesCtrCryptoCodec fails on Debian 9. Contributed by Miklos Szegedi.
This commit is contained in:
parent
ffc39ec3ab
commit
9014f98b60
|
@ -27,8 +27,12 @@
|
|||
#ifdef UNIX
|
||||
static EVP_CIPHER_CTX * (*dlsym_EVP_CIPHER_CTX_new)(void);
|
||||
static void (*dlsym_EVP_CIPHER_CTX_free)(EVP_CIPHER_CTX *);
|
||||
#if OPENSSL_API_COMPAT < 0x10100000L && OPENSSL_VERSION_NUMBER >= 0x10100000L
|
||||
static int (*dlsym_EVP_CIPHER_CTX_reset)(EVP_CIPHER_CTX *);
|
||||
#else
|
||||
static int (*dlsym_EVP_CIPHER_CTX_cleanup)(EVP_CIPHER_CTX *);
|
||||
static void (*dlsym_EVP_CIPHER_CTX_init)(EVP_CIPHER_CTX *);
|
||||
#endif
|
||||
static int (*dlsym_EVP_CIPHER_CTX_set_padding)(EVP_CIPHER_CTX *, int);
|
||||
static int (*dlsym_EVP_CIPHER_CTX_test_flags)(const EVP_CIPHER_CTX *, int);
|
||||
static int (*dlsym_EVP_CIPHER_CTX_block_size)(const EVP_CIPHER_CTX *);
|
||||
|
@ -123,10 +127,16 @@ JNIEXPORT void JNICALL Java_org_apache_hadoop_crypto_OpensslCipher_initIDs
|
|||
"EVP_CIPHER_CTX_new");
|
||||
LOAD_DYNAMIC_SYMBOL(dlsym_EVP_CIPHER_CTX_free, env, openssl, \
|
||||
"EVP_CIPHER_CTX_free");
|
||||
#if OPENSSL_API_COMPAT < 0x10100000L && OPENSSL_VERSION_NUMBER >= 0x10100000L
|
||||
LOAD_DYNAMIC_SYMBOL(dlsym_EVP_CIPHER_CTX_reset, env, openssl, \
|
||||
"EVP_CIPHER_CTX_reset");
|
||||
#else
|
||||
LOAD_DYNAMIC_SYMBOL(dlsym_EVP_CIPHER_CTX_cleanup, env, openssl, \
|
||||
"EVP_CIPHER_CTX_cleanup");
|
||||
LOAD_DYNAMIC_SYMBOL(dlsym_EVP_CIPHER_CTX_init, env, openssl, \
|
||||
"EVP_CIPHER_CTX_init");
|
||||
#endif
|
||||
|
||||
LOAD_DYNAMIC_SYMBOL(dlsym_EVP_CIPHER_CTX_set_padding, env, openssl, \
|
||||
"EVP_CIPHER_CTX_set_padding");
|
||||
LOAD_DYNAMIC_SYMBOL(dlsym_EVP_CIPHER_CTX_test_flags, env, openssl, \
|
||||
|
@ -271,7 +281,11 @@ JNIEXPORT jlong JNICALL Java_org_apache_hadoop_crypto_OpensslCipher_init
|
|||
(*env)->ReleaseByteArrayElements(env, key, jKey, 0);
|
||||
(*env)->ReleaseByteArrayElements(env, iv, jIv, 0);
|
||||
if (rc == 0) {
|
||||
#if OPENSSL_API_COMPAT < 0x10100000L && OPENSSL_VERSION_NUMBER >= 0x10100000L
|
||||
dlsym_EVP_CIPHER_CTX_reset(context);
|
||||
#else
|
||||
dlsym_EVP_CIPHER_CTX_cleanup(context);
|
||||
#endif
|
||||
THROW(env, "java/lang/InternalError", "Error in EVP_CipherInit_ex.");
|
||||
return (jlong)0;
|
||||
}
|
||||
|
@ -334,7 +348,11 @@ JNIEXPORT jint JNICALL Java_org_apache_hadoop_crypto_OpensslCipher_update
|
|||
int output_len = 0;
|
||||
if (!dlsym_EVP_CipherUpdate(context, output_bytes, &output_len, \
|
||||
input_bytes, input_len)) {
|
||||
#if OPENSSL_API_COMPAT < 0x10100000L && OPENSSL_VERSION_NUMBER >= 0x10100000L
|
||||
dlsym_EVP_CIPHER_CTX_reset(context);
|
||||
#else
|
||||
dlsym_EVP_CIPHER_CTX_cleanup(context);
|
||||
#endif
|
||||
THROW(env, "java/lang/InternalError", "Error in EVP_CipherUpdate.");
|
||||
return 0;
|
||||
}
|
||||
|
@ -376,7 +394,11 @@ JNIEXPORT jint JNICALL Java_org_apache_hadoop_crypto_OpensslCipher_doFinal
|
|||
|
||||
int output_len = 0;
|
||||
if (!dlsym_EVP_CipherFinal_ex(context, output_bytes, &output_len)) {
|
||||
#if OPENSSL_API_COMPAT < 0x10100000L && OPENSSL_VERSION_NUMBER >= 0x10100000L
|
||||
dlsym_EVP_CIPHER_CTX_reset(context);
|
||||
#else
|
||||
dlsym_EVP_CIPHER_CTX_cleanup(context);
|
||||
#endif
|
||||
THROW(env, "java/lang/InternalError", "Error in EVP_CipherFinal_ex.");
|
||||
return 0;
|
||||
}
|
||||
|
@ -396,6 +418,16 @@ JNIEXPORT jstring JNICALL Java_org_apache_hadoop_crypto_OpensslCipher_getLibrary
|
|||
(JNIEnv *env, jclass clazz)
|
||||
{
|
||||
#ifdef UNIX
|
||||
#if OPENSSL_API_COMPAT < 0x10100000L && OPENSSL_VERSION_NUMBER >= 0x10100000L
|
||||
if (dlsym_EVP_CIPHER_CTX_reset) {
|
||||
Dl_info dl_info;
|
||||
if(dladdr(
|
||||
dlsym_EVP_CIPHER_CTX_reset,
|
||||
&dl_info)) {
|
||||
return (*env)->NewStringUTF(env, dl_info.dli_fname);
|
||||
}
|
||||
}
|
||||
#else
|
||||
if (dlsym_EVP_CIPHER_CTX_init) {
|
||||
Dl_info dl_info;
|
||||
if(dladdr(
|
||||
|
@ -404,6 +436,7 @@ JNIEXPORT jstring JNICALL Java_org_apache_hadoop_crypto_OpensslCipher_getLibrary
|
|||
return (*env)->NewStringUTF(env, dl_info.dli_fname);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
return (*env)->NewStringUTF(env, HADOOP_OPENSSL_LIBRARY);
|
||||
#endif
|
||||
|
|
Loading…
Reference in New Issue