# HG changeset patch # User weijun # Date 1523604573 -28800 # Node ID 2918e1146106b819ff04fc00ea65a2c6391bff28 # Parent 4beba2c2a329d629bc271a87bb9e328b9c17674f 8200468: Port the native GSS-API bridge to Windows Reviewed-by: ihse, valeriep diff -r 4beba2c2a329 -r 2918e1146106 make/lib/Lib-java.security.jgss.gmk --- a/make/lib/Lib-java.security.jgss.gmk Fri Apr 13 03:05:19 2018 +0200 +++ b/make/lib/Lib-java.security.jgss.gmk Fri Apr 13 15:29:33 2018 +0800 @@ -27,25 +27,22 @@ ################################################################################ -ifneq ($(OPENJDK_TARGET_OS), windows) - LIBJ2GSS_SRC := $(TOPDIR)/src/java.security.jgss/share/native/libj2gss \ - $(TOPDIR)/src/java.security.jgss/$(OPENJDK_TARGET_OS_TYPE)/native/libj2gss \ - # +LIBJ2GSS_SRC := $(TOPDIR)/src/java.security.jgss/share/native/libj2gss \ + # - $(eval $(call SetupJdkLibrary, BUILD_LIBJ2GSS, \ - NAME := j2gss, \ - SRC := $(LIBJ2GSS_SRC), \ - OPTIMIZATION := LOW, \ - CFLAGS := $(CFLAGS_JDKLIB) $(addprefix -I, $(LIBJ2GSS_SRC)) \ - $(LIBJAVA_HEADER_FLAGS) \ - -I$(SUPPORT_OUTPUTDIR)/headers/java.security.jgss, \ - LDFLAGS := $(LDFLAGS_JDKLIB) \ - $(call SET_SHARED_LIBRARY_ORIGIN), \ - LIBS := $(LIBDL), \ - )) +$(eval $(call SetupJdkLibrary, BUILD_LIBJ2GSS, \ + NAME := j2gss, \ + SRC := $(LIBJ2GSS_SRC), \ + OPTIMIZATION := LOW, \ + CFLAGS := $(CFLAGS_JDKLIB) $(addprefix -I, $(LIBJ2GSS_SRC)) \ + $(LIBJAVA_HEADER_FLAGS) \ + -I$(SUPPORT_OUTPUTDIR)/headers/java.security.jgss, \ + LDFLAGS := $(LDFLAGS_JDKLIB) \ + $(call SET_SHARED_LIBRARY_ORIGIN), \ + LIBS := $(LIBDL), \ +)) - TARGETS += $(BUILD_LIBJ2GSS) -endif +TARGETS += $(BUILD_LIBJ2GSS) ################################################################################ diff -r 4beba2c2a329 -r 2918e1146106 src/java.security.jgss/share/classes/sun/security/jgss/GSSManagerImpl.java --- a/src/java.security.jgss/share/classes/sun/security/jgss/GSSManagerImpl.java Fri Apr 13 03:05:19 2018 +0200 +++ b/src/java.security.jgss/share/classes/sun/security/jgss/GSSManagerImpl.java Fri Apr 13 15:29:33 2018 +0800 @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -46,14 +46,8 @@ USE_NATIVE = AccessController.doPrivileged(new PrivilegedAction() { public Boolean run() { - String osname = System.getProperty("os.name"); - if (osname.startsWith("SunOS") || - osname.contains("OS X") || - osname.startsWith("Linux")) { - return Boolean.valueOf(System.getProperty - (USE_NATIVE_PROP)); - } - return Boolean.FALSE; + return Boolean.valueOf(System.getProperty + (USE_NATIVE_PROP)); } }); diff -r 4beba2c2a329 -r 2918e1146106 src/java.security.jgss/share/native/libj2gss/GSSLibStub.c --- a/src/java.security.jgss/share/native/libj2gss/GSSLibStub.c Fri Apr 13 03:05:19 2018 +0200 +++ b/src/java.security.jgss/share/native/libj2gss/GSSLibStub.c Fri Apr 13 15:29:33 2018 +0800 @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -45,6 +45,7 @@ jstring jlibName, jboolean jDebug) { const char *libName; + int failed; char *error = NULL; if (!jDebug) { @@ -65,13 +66,38 @@ TRACE1("[GSSLibStub_init] libName=%s", libName); /* initialize global function table */ - error = loadNative(libName); + failed = loadNative(libName); (*env)->ReleaseStringUTFChars(env, jlibName, libName); - if (error == NULL) { + if (!failed) { return JNI_TRUE; } else { - TRACE0(error); + if (JGSS_DEBUG) { +#ifdef WIN32 + #define MAX_MSG_SIZE 256 + static CHAR szMsgBuf[MAX_MSG_SIZE]; + DWORD dwRes; + DWORD dwError = GetLastError(); + dwRes = FormatMessage ( + FORMAT_MESSAGE_FROM_SYSTEM, + NULL, + dwError, + 0, + szMsgBuf, + MAX_MSG_SIZE, + NULL); + if (0 == dwRes) { + printf("GSS-API: Unknown failure %d\n", dwError); + } else { + printf("GSS-API: %s\n",szMsgBuf); + } +#else + char* error = dlerror(); + if (error) { + TRACE0(error); + } +#endif + } return JNI_FALSE; } } @@ -88,7 +114,6 @@ gss_OID cOid; unsigned int i, len; jbyte* bytes; - jthrowable gssEx; int found; if (jbytes != NULL) { @@ -125,8 +150,6 @@ * structure. */ void deleteGSSCB(gss_channel_bindings_t cb) { - jobject jinetAddr; - jbyteArray value; if (cb == GSS_C_NO_CHANNEL_BINDINGS) return; @@ -154,7 +177,6 @@ gss_channel_bindings_t cb; jobject jinetAddr; jbyteArray value; - int i; if (jcb == NULL) { return GSS_C_NO_CHANNEL_BINDINGS; @@ -355,7 +377,7 @@ GSS_S_BAD_MECH */ major = (*ftab->importName)(&minor, &nameVal, nameType, &nameHdl); - TRACE1("[GSSLibStub_importName] %ld", (long) nameHdl); + TRACE1("[GSSLibStub_importName] %" PRIuPTR "", (uintptr_t) nameHdl); /* release intermediate buffers */ deleteGSSOID(nameType); @@ -426,7 +448,7 @@ GSS_S_BAD_NAME, GSS_S_BAD_MECH */ major = (*ftab->canonicalizeName)(&minor, nameHdl, mech, &mnNameHdl); - TRACE1("[GSSLibStub_canonicalizeName] MN=%ld", (long)mnNameHdl); + TRACE1("[GSSLibStub_canonicalizeName] MN=%" PRIuPTR "", (uintptr_t)mnNameHdl); checkStatus(env, jobj, major, minor, "[GSSLibStub_canonicalizeName]"); if ((*env)->ExceptionCheck(env)) { @@ -596,7 +618,7 @@ /* release intermediate buffers */ deleteGSSOIDSet(mechs); - TRACE1("[GSSLibStub_acquireCred] pCred=%ld", (long) credHdl); + TRACE1("[GSSLibStub_acquireCred] pCred=%" PRIuPTR "", (uintptr_t) credHdl); checkStatus(env, jobj, major, minor, "[GSSLibStub_acquireCred]"); if ((*env)->ExceptionCheck(env)) { @@ -645,7 +667,7 @@ credHdl = pCred; - TRACE1("[gss_inquire_cred] %ld", (long) pCred); + TRACE1("[gss_inquire_cred] %" PRIuPTR "", (uintptr_t) pCred); /* gss_inquire_cred(...) => GSS_S_DEFECTIVE_CREDENTIAL(!), GSS_S_CREDENTIALS_EXPIRED(!), GSS_S_NO_CRED(!) */ @@ -694,7 +716,7 @@ return jlong_zero; } - TRACE1("[GSSLibStub_getCredName] pName=%ld", (long) nameHdl); + TRACE1("[GSSLibStub_getCredName] pName=%" PRIuPTR "", (uintptr_t) nameHdl); return ptr_to_jlong(nameHdl); } @@ -775,7 +797,7 @@ GSS_S_UNAVAILABLE, GSS_S_UNAUTHORIZED */ major = (*ftab->importSecContext)(&minor, &ctxtToken, &contextHdl); - TRACE1("[GSSLibStub_importContext] pContext=%ld", (long) contextHdl); + TRACE1("[GSSLibStub_importContext] pContext=%" PRIuPTR "", (uintptr_t) contextHdl); /* release intermediate buffers */ resetGSSBuffer(&ctxtToken); @@ -866,8 +888,8 @@ return NULL; } - TRACE2( "[GSSLibStub_initContext] before: pCred=%ld, pContext=%ld", - (long)credHdl, (long)contextHdl); + TRACE2( "[GSSLibStub_initContext] before: pCred=%" PRIuPTR ", pContext=%" PRIuPTR "", + (uintptr_t)credHdl, (uintptr_t)contextHdl); /* gss_init_sec_context(...) => GSS_S_CONTINUE_NEEDED(!), GSS_S_DEFECTIVE_TOKEN, GSS_S_NO_CRED, GSS_S_DEFECTIVE_CREDENTIAL(!), @@ -879,8 +901,8 @@ flags, time, cb, &inToken, NULL /*aMech*/, &outToken, &aFlags, &aTime); - TRACE2("[GSSLibStub_initContext] after: pContext=%ld, outToken len=%ld", - (long)contextHdl, (long)outToken.length); + TRACE2("[GSSLibStub_initContext] after: pContext=%" PRIuPTR ", outToken len=%ld", + (uintptr_t)contextHdl, (long)outToken.length); // update context handle with the latest value if changed // this is to work with both MIT and Solaris. Former deletes half-built @@ -888,7 +910,7 @@ if (contextHdl != contextHdlSave) { (*env)->SetLongField(env, jcontextSpi, FID_NativeGSSContext_pContext, ptr_to_jlong(contextHdl)); - TRACE1("[GSSLibStub_initContext] set pContext=%ld", (long)contextHdl); + TRACE1("[GSSLibStub_initContext] set pContext=%" PRIuPTR "", (uintptr_t)contextHdl); } if (GSS_ERROR(major) == GSS_S_COMPLETE) { @@ -959,7 +981,6 @@ jobject jsrcName=GSS_C_NO_NAME; jobject jdelCred; jobject jMech; - jbyteArray jresult; jboolean setTarget; gss_name_t targetName; jobject jtargetName; @@ -983,8 +1004,8 @@ setTarget = (credHdl == GSS_C_NO_CREDENTIAL); aFlags = 0; - TRACE2( "[GSSLibStub_acceptContext] before: pCred=%ld, pContext=%ld", - (long) credHdl, (long) contextHdl); + TRACE2( "[GSSLibStub_acceptContext] before: pCred=%" PRIuPTR ", pContext=%" PRIuPTR "", + (uintptr_t) credHdl, (uintptr_t) contextHdl); /* gss_accept_sec_context(...) => GSS_S_CONTINUE_NEEDED(!), GSS_S_DEFECTIVE_TOKEN, GSS_S_DEFECTIVE_CREDENTIAL(!), @@ -1000,8 +1021,8 @@ deleteGSSCB(cb); resetGSSBuffer(&inToken); - TRACE3("[GSSLibStub_acceptContext] after: pCred=%ld, pContext=%ld, pDelegCred=%ld", - (long)credHdl, (long)contextHdl, (long) delCred); + TRACE3("[GSSLibStub_acceptContext] after: pCred=%" PRIuPTR ", pContext=%" PRIuPTR ", pDelegCred=%" PRIuPTR "", + (uintptr_t)credHdl, (uintptr_t)contextHdl, (uintptr_t) delCred); // update context handle with the latest value if changed // this is to work with both MIT and Solaris. Former deletes half-built @@ -1009,7 +1030,7 @@ if (contextHdl != contextHdlSave) { (*env)->SetLongField(env, jcontextSpi, FID_NativeGSSContext_pContext, ptr_to_jlong(contextHdl)); - TRACE1("[GSSLibStub_acceptContext] set pContext=%ld", (long)contextHdl); + TRACE1("[GSSLibStub_acceptContext] set pContext=%" PRIuPTR "", (uintptr_t)contextHdl); } if (GSS_ERROR(major) == GSS_S_COMPLETE) { @@ -1038,8 +1059,8 @@ goto error; } - TRACE1("[GSSLibStub_acceptContext] set targetName=%ld", - (long)targetName); + TRACE1("[GSSLibStub_acceptContext] set targetName=%" PRIuPTR "", + (uintptr_t)targetName); (*env)->SetObjectField(env, jcontextSpi, FID_NativeGSSContext_targetName, jtargetName); @@ -1055,7 +1076,7 @@ goto error; } - TRACE1("[GSSLibStub_acceptContext] set srcName=%ld", (long)srcName); + TRACE1("[GSSLibStub_acceptContext] set srcName=%" PRIuPTR "", (uintptr_t)srcName); (*env)->SetObjectField(env, jcontextSpi, FID_NativeGSSContext_srcName, jsrcName); @@ -1090,8 +1111,8 @@ (*env)->SetObjectField(env, jcontextSpi, FID_NativeGSSContext_delegatedCred, jdelCred); - TRACE1("[GSSLibStub_acceptContext] set delegatedCred=%ld", - (long) delCred); + TRACE1("[GSSLibStub_acceptContext] set delegatedCred=%" PRIuPTR "", + (uintptr_t) delCred); if ((*env)->ExceptionCheck(env)) { goto error; @@ -1144,7 +1165,7 @@ contextHdl = (gss_ctx_id_t) jlong_to_ptr(pContext); - TRACE1("[GSSLibStub_inquireContext] %ld", (long)contextHdl); + TRACE1("[GSSLibStub_inquireContext] %" PRIuPTR "", (uintptr_t)contextHdl); srcName = targetName = GSS_C_NO_NAME; time = 0; @@ -1155,8 +1176,8 @@ &targetName, &time, NULL, &flags, &isInitiator, &isEstablished); /* update member values if needed */ - TRACE2("[GSSLibStub_inquireContext] srcName %ld, targetName %ld", - (long)srcName, (long)targetName); + TRACE2("[GSSLibStub_inquireContext] srcName %" PRIuPTR ", targetName %" PRIuPTR "", + (uintptr_t)srcName, (uintptr_t)targetName); checkStatus(env, jobj, major, minor, "[GSSLibStub_inquireContext]"); if ((*env)->ExceptionCheck(env)) { @@ -1225,8 +1246,8 @@ contextHdl = (gss_ctx_id_t) jlong_to_ptr(pContext); - TRACE2("[GSSLibStub_getContextName] %ld, isSrc=%d", - (long)contextHdl, isSrc); + TRACE2("[GSSLibStub_getContextName] %" PRIuPTR ", isSrc=%d", + (uintptr_t)contextHdl, isSrc); nameHdl = GSS_C_NO_NAME; if (isSrc == JNI_TRUE) { @@ -1243,7 +1264,7 @@ return jlong_zero; } - TRACE1("[GSSLibStub_getContextName] pName=%ld", (long) nameHdl); + TRACE1("[GSSLibStub_getContextName] pName=%" PRIuPTR "", (uintptr_t) nameHdl); return ptr_to_jlong(nameHdl); } @@ -1263,7 +1284,7 @@ contextHdl = (gss_ctx_id_t) jlong_to_ptr(pContext); - TRACE1("[GSSLibStub_getContextTime] %ld", (long)contextHdl); + TRACE1("[GSSLibStub_getContextTime] %" PRIuPTR "", (uintptr_t)contextHdl); if (contextHdl == GSS_C_NO_CONTEXT) return 0; @@ -1295,7 +1316,7 @@ contextHdl = (gss_ctx_id_t) jlong_to_ptr(pContext); - TRACE1("[GSSLibStub_deleteContext] %ld", (long)contextHdl); + TRACE1("[GSSLibStub_deleteContext] %" PRIuPTR "", (uintptr_t)contextHdl); if (contextHdl == GSS_C_NO_CONTEXT) return ptr_to_jlong(GSS_C_NO_CONTEXT); @@ -1329,7 +1350,7 @@ contextHdl = (gss_ctx_id_t) jlong_to_ptr(pContext); - TRACE1("[GSSLibStub_wrapSizeLimit] %ld", (long)contextHdl); + TRACE1("[GSSLibStub_wrapSizeLimit] %" PRIuPTR "", (uintptr_t)contextHdl); if (contextHdl == GSS_C_NO_CONTEXT) { // Twik per javadoc @@ -1369,7 +1390,7 @@ contextHdl = (gss_ctx_id_t) jlong_to_ptr(pContext); - TRACE1("[GSSLibStub_exportContext] %ld", (long)contextHdl); + TRACE1("[GSSLibStub_exportContext] %" PRIuPTR "", (uintptr_t)contextHdl); if (contextHdl == GSS_C_NO_CONTEXT) { // Twik per javadoc @@ -1413,7 +1434,7 @@ contextHdl = (gss_ctx_id_t) jlong_to_ptr(pContext); - TRACE1("[GSSLibStub_getMic] %ld", (long)contextHdl); + TRACE1("[GSSLibStub_getMic] %" PRIuPTR "", (uintptr_t)contextHdl); if (contextHdl == GSS_C_NO_CONTEXT) { // Twik per javadoc @@ -1466,7 +1487,7 @@ contextHdl = (gss_ctx_id_t) jlong_to_ptr(pContext); - TRACE1("[GSSLibStub_verifyMic] %ld", (long)contextHdl); + TRACE1("[GSSLibStub_verifyMic] %" PRIuPTR "", (uintptr_t)contextHdl); if (contextHdl == GSS_C_NO_CONTEXT) { // Twik per javadoc @@ -1537,7 +1558,7 @@ contextHdl = (gss_ctx_id_t) jlong_to_ptr(pContext); - TRACE1("[GSSLibStub_wrap] %ld", (long)contextHdl); + TRACE1("[GSSLibStub_wrap] %" PRIuPTR "", (uintptr_t)contextHdl); if (contextHdl == GSS_C_NO_CONTEXT) { // Twik per javadoc @@ -1609,7 +1630,7 @@ contextHdl = (gss_ctx_id_t) jlong_to_ptr(pContext); - TRACE1("[GSSLibStub_unwrap] %ld", (long)contextHdl); + TRACE1("[GSSLibStub_unwrap] %" PRIuPTR "", (uintptr_t)contextHdl); if (contextHdl == GSS_C_NO_CONTEXT) { // Twik per javadoc diff -r 4beba2c2a329 -r 2918e1146106 src/java.security.jgss/share/native/libj2gss/NativeFunc.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/java.security.jgss/share/native/libj2gss/NativeFunc.c Fri Apr 13 15:29:33 2018 +0800 @@ -0,0 +1,284 @@ +/* + * Copyright (c) 2005, 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +#include +#include +#include "NativeFunc.h" + +/* standard GSS method names (ordering is from mapfile) */ +static const char RELEASE_NAME[] = "gss_release_name"; +static const char IMPORT_NAME[] = "gss_import_name"; +static const char COMPARE_NAME[] = "gss_compare_name"; +static const char CANONICALIZE_NAME[] = "gss_canonicalize_name"; +static const char EXPORT_NAME[] = "gss_export_name"; +static const char DISPLAY_NAME[] = "gss_display_name"; +static const char ACQUIRE_CRED[] = "gss_acquire_cred"; +static const char RELEASE_CRED[] = "gss_release_cred"; +static const char INQUIRE_CRED[] = "gss_inquire_cred"; +static const char IMPORT_SEC_CONTEXT[] = "gss_import_sec_context"; +static const char INIT_SEC_CONTEXT[] = "gss_init_sec_context"; +static const char ACCEPT_SEC_CONTEXT[] = "gss_accept_sec_context"; +static const char INQUIRE_CONTEXT[] = "gss_inquire_context"; +static const char DELETE_SEC_CONTEXT[] = "gss_delete_sec_context"; +static const char CONTEXT_TIME[] = "gss_context_time"; +static const char WRAP_SIZE_LIMIT[] = "gss_wrap_size_limit"; +static const char EXPORT_SEC_CONTEXT[] = "gss_export_sec_context"; +static const char GET_MIC[] = "gss_get_mic"; +static const char VERIFY_MIC[] = "gss_verify_mic"; +static const char WRAP[] = "gss_wrap"; +static const char UNWRAP[] = "gss_unwrap"; +static const char INDICATE_MECHS[] = "gss_indicate_mechs"; +static const char INQUIRE_NAMES_FOR_MECH[] = "gss_inquire_names_for_mech"; + +/* additional GSS methods not public thru mapfile */ + +static const char ADD_OID_SET_MEMBER[] = "gss_add_oid_set_member"; +static const char DISPLAY_STATUS[] = "gss_display_status"; +static const char CREATE_EMPTY_OID_SET[] = "gss_create_empty_oid_set"; +static const char RELEASE_OID_SET[] = "gss_release_oid_set"; +static const char RELEASE_BUFFER[] = "gss_release_buffer"; + +/** + * Initialize native GSS function pointers + */ +int loadNative(const char *libName) { + + void *gssLib; + int failed; + OM_uint32 minor, major; + + ftab = NULL; + failed = FALSE; + + gssLib = GETLIB(libName); + if (gssLib == NULL) { + failed = TRUE; + goto out; + } + + /* global function table instance */ + ftab = (GSS_FUNCTION_TABLE_PTR)malloc(sizeof(GSS_FUNCTION_TABLE)); + if (ftab == NULL) { + failed = TRUE; + goto out; + } + + ftab->releaseName = (RELEASE_NAME_FN_PTR)GETFUNC(gssLib, RELEASE_NAME); + if (ftab->releaseName == NULL) { + failed = TRUE; + goto out; + } + + ftab->importName = (IMPORT_NAME_FN_PTR)GETFUNC(gssLib, IMPORT_NAME); + if (ftab->importName == NULL) { + failed = TRUE; + goto out; + } + + ftab->compareName = (COMPARE_NAME_FN_PTR)GETFUNC(gssLib, COMPARE_NAME); + if (ftab->compareName == NULL) { + failed = TRUE; + goto out; + } + + ftab->canonicalizeName = (CANONICALIZE_NAME_FN_PTR) + GETFUNC(gssLib, CANONICALIZE_NAME); + if (ftab->canonicalizeName == NULL) { + failed = TRUE; + goto out; + } + + ftab->exportName = (EXPORT_NAME_FN_PTR)GETFUNC(gssLib, EXPORT_NAME); + if (ftab->exportName == NULL) { + failed = TRUE; + goto out; + } + + ftab->displayName = (DISPLAY_NAME_FN_PTR)GETFUNC(gssLib, DISPLAY_NAME); + if (ftab->displayName == NULL) { + failed = TRUE; + goto out; + } + + ftab->acquireCred = (ACQUIRE_CRED_FN_PTR)GETFUNC(gssLib, ACQUIRE_CRED); + if (ftab->acquireCred == NULL) { + failed = TRUE; + goto out; + } + + ftab->releaseCred = (RELEASE_CRED_FN_PTR)GETFUNC(gssLib, RELEASE_CRED); + if (ftab->releaseCred == NULL) { + failed = TRUE; + goto out; + } + + ftab->inquireCred = (INQUIRE_CRED_FN_PTR)GETFUNC(gssLib, INQUIRE_CRED); + if (ftab->inquireCred == NULL) { + failed = TRUE; + goto out; + } + + ftab->importSecContext = (IMPORT_SEC_CONTEXT_FN_PTR) + GETFUNC(gssLib, IMPORT_SEC_CONTEXT); + if (ftab->importSecContext == NULL) { + failed = TRUE; + goto out; + } + + ftab->initSecContext = (INIT_SEC_CONTEXT_FN_PTR) + GETFUNC(gssLib, INIT_SEC_CONTEXT); + if (ftab->initSecContext == NULL) { + failed = TRUE; + goto out; + } + + ftab->acceptSecContext = (ACCEPT_SEC_CONTEXT_FN_PTR) + GETFUNC(gssLib, ACCEPT_SEC_CONTEXT); + if (ftab->acceptSecContext == NULL) { + failed = TRUE; + goto out; + } + + ftab->inquireContext = (INQUIRE_CONTEXT_FN_PTR) + GETFUNC(gssLib, INQUIRE_CONTEXT); + if (ftab->inquireContext == NULL) { + failed = TRUE; + goto out; + } + + ftab->deleteSecContext = (DELETE_SEC_CONTEXT_FN_PTR) + GETFUNC(gssLib, DELETE_SEC_CONTEXT); + if (ftab->deleteSecContext == NULL) { + failed = TRUE; + goto out; + } + + ftab->contextTime = (CONTEXT_TIME_FN_PTR)GETFUNC(gssLib, CONTEXT_TIME); + if (ftab->contextTime == NULL) { + failed = TRUE; + goto out; + } + + ftab->wrapSizeLimit = (WRAP_SIZE_LIMIT_FN_PTR) + GETFUNC(gssLib, WRAP_SIZE_LIMIT); + if (ftab->wrapSizeLimit == NULL) { + failed = TRUE; + goto out; + } + + ftab->exportSecContext = (EXPORT_SEC_CONTEXT_FN_PTR) + GETFUNC(gssLib, EXPORT_SEC_CONTEXT); + if (ftab->exportSecContext == NULL) { + failed = TRUE; + goto out; + } + + ftab->getMic = (GET_MIC_FN_PTR)GETFUNC(gssLib, GET_MIC); + if (ftab->getMic == NULL) { + failed = TRUE; + goto out; + } + + ftab->verifyMic = (VERIFY_MIC_FN_PTR)GETFUNC(gssLib, VERIFY_MIC); + if (ftab->verifyMic == NULL) { + failed = TRUE; + goto out; + } + + ftab->wrap = (WRAP_FN_PTR)GETFUNC(gssLib, WRAP); + if (ftab->wrap == NULL) { + failed = TRUE; + goto out; + } + + ftab->unwrap = (UNWRAP_FN_PTR)GETFUNC(gssLib, UNWRAP); + if (ftab->unwrap == NULL) { + failed = TRUE; + goto out; + } + + ftab->indicateMechs = (INDICATE_MECHS_FN_PTR)GETFUNC(gssLib, INDICATE_MECHS); + if (ftab->indicateMechs == NULL) { + failed = TRUE; + goto out; + } + + ftab->inquireNamesForMech = (INQUIRE_NAMES_FOR_MECH_FN_PTR) + GETFUNC(gssLib, INQUIRE_NAMES_FOR_MECH); + if (ftab->inquireNamesForMech == NULL) { + failed = TRUE; + goto out; + } + + ftab->addOidSetMember = (ADD_OID_SET_MEMBER_FN_PTR) + GETFUNC(gssLib, ADD_OID_SET_MEMBER); + if (ftab->addOidSetMember == NULL) { + failed = TRUE; + goto out; + } + + ftab->displayStatus = (DISPLAY_STATUS_FN_PTR) + GETFUNC(gssLib, DISPLAY_STATUS); + if (ftab->displayStatus == NULL) { + failed = TRUE; + goto out; + } + + ftab->createEmptyOidSet = (CREATE_EMPTY_OID_SET_FN_PTR) + GETFUNC(gssLib, CREATE_EMPTY_OID_SET); + if (ftab->createEmptyOidSet == NULL) { + failed = TRUE; + goto out; + } + + ftab->releaseOidSet = (RELEASE_OID_SET_FN_PTR) + GETFUNC(gssLib, RELEASE_OID_SET); + if (ftab->releaseOidSet == NULL) { + failed = TRUE; + goto out; + } + + ftab->releaseBuffer = (RELEASE_BUFFER_FN_PTR) + GETFUNC(gssLib, RELEASE_BUFFER); + if (ftab->releaseBuffer == NULL) { + failed = TRUE; + goto out; + } + + ftab->mechs = GSS_C_NO_OID_SET; + major = (*ftab->indicateMechs)(&minor, &(ftab->mechs)); + if (ftab->mechs == NULL || ftab->mechs == GSS_C_NO_OID_SET) { + failed = TRUE; + goto out; + } + + +out: + if (failed == TRUE) { + if (gssLib != NULL) CLOSELIB(gssLib); + if (ftab != NULL) free(ftab); + } + return failed; +} diff -r 4beba2c2a329 -r 2918e1146106 src/java.security.jgss/share/native/libj2gss/NativeFunc.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/java.security.jgss/share/native/libj2gss/NativeFunc.h Fri Apr 13 15:29:33 2018 +0800 @@ -0,0 +1,282 @@ +/* + * Copyright (c) 2005, 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +#ifndef NATIVE_FUNC_H +#define NATIVE_FUNC_H + +#include "gssapi.h" + +#ifdef WIN32 +#include +#define GETLIB(libName) LoadLibrary(libName) +#define GETFUNC(lib,name) GetProcAddress(lib,name) +#define CLOSELIB(lib) CloseHandle(lib) +#else +#include +#define GETLIB(libName) dlopen(libName, RTLD_NOW) +#define GETFUNC(lib,name) dlsym(lib,name) +#define CLOSELIB(lib) dlclose(lib) +#endif + +#ifndef TRUE +#define TRUE 1 +#endif + +#ifndef FALSE +#define FALSE 0 +#endif + +int loadNative(const char *libName); + +/* function pointer definitions */ +typedef OM_uint32 (*RELEASE_NAME_FN_PTR) + (OM_uint32 *minor_status, + gss_name_t *name); + +typedef OM_uint32 (*IMPORT_NAME_FN_PTR) + (OM_uint32 *minor_status, + gss_buffer_t input_name_buffer, + gss_OID input_name_type, + gss_name_t *output_name); + +typedef OM_uint32 (*COMPARE_NAME_FN_PTR) + (OM_uint32 *minor_status, + gss_name_t name1, + gss_name_t name2, + int *name_equal); + +typedef OM_uint32 (*CANONICALIZE_NAME_FN_PTR) + (OM_uint32 *minor_status, + gss_name_t input_name, + gss_OID mech_type, + gss_name_t *output_name); + +typedef OM_uint32 (*EXPORT_NAME_FN_PTR) + (OM_uint32 *minor_status, + gss_name_t input_name, + gss_buffer_t exported_name); + +typedef OM_uint32 (*DISPLAY_NAME_FN_PTR) + (OM_uint32 *minor_status, + gss_name_t input_name, + gss_buffer_t output_name_buffer, + gss_OID *output_name_type); + +typedef OM_uint32 (*ACQUIRE_CRED_FN_PTR) + (OM_uint32 *minor_status, + gss_name_t desired_name, + OM_uint32 time_req, + gss_OID_set desired_mech, + gss_cred_usage_t cred_usage, + gss_cred_id_t *output_cred_handle, + gss_OID_set *actual_mechs, + OM_uint32 *time_rec); + +typedef OM_uint32 (*RELEASE_CRED_FN_PTR) + (OM_uint32 *minor_status, + gss_cred_id_t *cred_handle); + +typedef OM_uint32 (*INQUIRE_CRED_FN_PTR) + (OM_uint32 *minor_status, + gss_cred_id_t cred_handle, + gss_name_t *name, + OM_uint32 *lifetime, + gss_cred_usage_t *cred_usage, + gss_OID_set *mechanisms); + +typedef OM_uint32 (*IMPORT_SEC_CONTEXT_FN_PTR) + (OM_uint32 *minor_status, + gss_buffer_t interprocess_token, + gss_ctx_id_t *context_handle); + +typedef OM_uint32 (*INIT_SEC_CONTEXT_FN_PTR) + (OM_uint32 *minor_status, + gss_cred_id_t initiator_cred_handle, + gss_ctx_id_t *context_handle, + gss_name_t *target_name, + gss_OID mech_type, + OM_uint32 req_flags, + OM_uint32 time_req, + gss_channel_bindings_t input_chan_bindings, + gss_buffer_t input_token, + gss_OID *actual_mech_type, + gss_buffer_t output_token, + OM_uint32 *ret_flags, + OM_uint32 *time_rec); + +typedef OM_uint32 (*ACCEPT_SEC_CONTEXT_FN_PTR) + (OM_uint32 *minor_status, + gss_ctx_id_t *context_handle, + gss_cred_id_t acceptor_cred_handle, + gss_buffer_t input_token, + gss_channel_bindings_t input_chan_bindings, + gss_name_t *src_name, + gss_OID *mech_type, + gss_buffer_t output_token, + OM_uint32 *ret_flags, + OM_uint32 *time_rec, + gss_cred_id_t *delegated_cred_handle); + +typedef OM_uint32 (*INQUIRE_CONTEXT_FN_PTR) + (OM_uint32 *minor_status, + gss_ctx_id_t context_handle, + gss_name_t *src_name, + gss_name_t *targ_name, + OM_uint32 *lifetime_rec, + gss_OID *mech_type, + OM_uint32 *ctx_flags, + int *locally_initiated, + int *open); + +typedef OM_uint32 (*DELETE_SEC_CONTEXT_FN_PTR) + (OM_uint32 *minor_status, + gss_ctx_id_t *context_handle, + gss_buffer_t output_token); + +typedef OM_uint32 (*CONTEXT_TIME_FN_PTR) + (OM_uint32 *minor_status, + gss_ctx_id_t *context_handle, + OM_uint32 *time_rec); + +typedef OM_uint32 (*WRAP_SIZE_LIMIT_FN_PTR) + (OM_uint32 *minor_status, + gss_ctx_id_t context_handle, + int conf_req_flag, + gss_qop_t qop_req, + OM_uint32 req_output_size, + OM_uint32 *max_input_size); + +typedef OM_uint32 (*EXPORT_SEC_CONTEXT_FN_PTR) + (OM_uint32 *minor_status, + gss_ctx_id_t *context_handle, + gss_buffer_t interprocess_token); + +typedef OM_uint32 (*GET_MIC_FN_PTR) + (OM_uint32 *minor_status, + gss_ctx_id_t context_handle, + gss_qop_t qop_req, + gss_buffer_t message_buffer, + gss_buffer_t msg_token); + +typedef OM_uint32 (*VERIFY_MIC_FN_PTR) + (OM_uint32 *minor_status, + gss_ctx_id_t context_handle, + gss_buffer_t message_buffer, + gss_buffer_t token_buffer, + gss_qop_t *qop_state); + +typedef OM_uint32 (*WRAP_FN_PTR) + (OM_uint32 *minor_status, + gss_ctx_id_t context_handle, + int conf_req_flag, + gss_qop_t qop_req, + gss_buffer_t input_message_buffer, + int *conf_state, + gss_buffer_t output_message_buffer); + +typedef OM_uint32 (*UNWRAP_FN_PTR) + (OM_uint32 *minor_status, + gss_ctx_id_t context_handle, + gss_buffer_t input_message_buffer, + gss_buffer_t output_message_buffer, + int *conf_state, + gss_qop_t *qop_state); + +typedef OM_uint32 (*INDICATE_MECHS_FN_PTR) + (OM_uint32 *minor_status, + gss_OID_set *mech_set); + +typedef OM_uint32 (*INQUIRE_NAMES_FOR_MECH_FN_PTR) + (OM_uint32 *minor_status, + const gss_OID mechanism, + gss_OID_set *name_types); + +typedef OM_uint32 (*ADD_OID_SET_MEMBER_FN_PTR) + (OM_uint32 *minor_status, + gss_OID member_oid, + gss_OID_set *oid_set); + +typedef OM_uint32 (*DISPLAY_STATUS_FN_PTR) + (OM_uint32 *minor_status, + OM_uint32 status_value, + int status_type, + gss_OID mech_type, + OM_uint32 *message_context, + gss_buffer_t status_string); + +typedef OM_uint32 (*CREATE_EMPTY_OID_SET_FN_PTR) + (OM_uint32 *minor_status, + gss_OID_set *oid_set); + +typedef OM_uint32 (*RELEASE_OID_SET_FN_PTR) + (OM_uint32 *minor_status, + gss_OID_set *set); + +typedef OM_uint32 (*RELEASE_BUFFER_FN_PTR) + (OM_uint32 *minor_status, + gss_buffer_t buffer); + + +/* dynamically resolved functions from gss library */ + +typedef struct GSS_FUNCTION_TABLE { + gss_OID_set mechs; + RELEASE_NAME_FN_PTR releaseName; + IMPORT_NAME_FN_PTR importName; + COMPARE_NAME_FN_PTR compareName; + CANONICALIZE_NAME_FN_PTR canonicalizeName; + EXPORT_NAME_FN_PTR exportName; + DISPLAY_NAME_FN_PTR displayName; + ACQUIRE_CRED_FN_PTR acquireCred; + RELEASE_CRED_FN_PTR releaseCred; + INQUIRE_CRED_FN_PTR inquireCred; + IMPORT_SEC_CONTEXT_FN_PTR importSecContext; + INIT_SEC_CONTEXT_FN_PTR initSecContext; + ACCEPT_SEC_CONTEXT_FN_PTR acceptSecContext; + INQUIRE_CONTEXT_FN_PTR inquireContext; + DELETE_SEC_CONTEXT_FN_PTR deleteSecContext; + CONTEXT_TIME_FN_PTR contextTime; + WRAP_SIZE_LIMIT_FN_PTR wrapSizeLimit; + EXPORT_SEC_CONTEXT_FN_PTR exportSecContext; + GET_MIC_FN_PTR getMic; + VERIFY_MIC_FN_PTR verifyMic; + WRAP_FN_PTR wrap; + UNWRAP_FN_PTR unwrap; + INDICATE_MECHS_FN_PTR indicateMechs; + INQUIRE_NAMES_FOR_MECH_FN_PTR inquireNamesForMech; + ADD_OID_SET_MEMBER_FN_PTR addOidSetMember; + DISPLAY_STATUS_FN_PTR displayStatus; + CREATE_EMPTY_OID_SET_FN_PTR createEmptyOidSet; + RELEASE_OID_SET_FN_PTR releaseOidSet; + RELEASE_BUFFER_FN_PTR releaseBuffer; + +} GSS_FUNCTION_TABLE; + +typedef GSS_FUNCTION_TABLE *GSS_FUNCTION_TABLE_PTR; + +/* global GSS function table */ +GSS_FUNCTION_TABLE_PTR ftab; + +#endif diff -r 4beba2c2a329 -r 2918e1146106 src/java.security.jgss/share/native/libj2gss/NativeUtil.c --- a/src/java.security.jgss/share/native/libj2gss/NativeUtil.c Fri Apr 13 03:05:19 2018 +0200 +++ b/src/java.security.jgss/share/native/libj2gss/NativeUtil.c Fri Apr 13 15:29:33 2018 +0800 @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -469,7 +469,7 @@ if (bytes != NULL) { /* constructs the String object with new String(byte[]) NOTE: do NOT include the trailing NULL */ - len = bytes->length; + len = (int) bytes->length; jbytes = (*env)->NewByteArray(env, len); if (jbytes == NULL) { goto finish; @@ -497,7 +497,6 @@ OM_uint32 messageContext, minor, major; gss_buffer_desc statusString; gss_OID mech; - jstring msg; messageContext = 0; if (jstub != NULL) { @@ -636,11 +635,11 @@ if (cbytes != NULL) { if ((cbytes != GSS_C_NO_BUFFER) && (cbytes->length != 0)) { - result = (*env)->NewByteArray(env, cbytes->length); + result = (*env)->NewByteArray(env, (int) cbytes->length); if (result == NULL) { goto finish; } - (*env)->SetByteArrayRegion(env, result, 0, cbytes->length, + (*env)->SetByteArrayRegion(env, result, 0, (int) cbytes->length, cbytes->value); if ((*env)->ExceptionCheck(env)) { result = NULL; @@ -661,7 +660,6 @@ gss_OID newGSSOID(JNIEnv *env, jobject jOid) { jbyteArray jbytes; gss_OID cOid; - jthrowable gssEx; if (jOid != NULL) { jbytes = (*env)->CallObjectMethod(env, jOid, MID_Oid_getDER); if ((*env)->ExceptionCheck(env)) { @@ -783,10 +781,9 @@ jobjectArray jOidSet; jobject jOid; int i; - jthrowable gssEx; if (cOidSet != NULL && cOidSet != GSS_C_NO_OID_SET) { - numOfOids = cOidSet->count; + numOfOids = (int) cOidSet->count; jOidSet = (*env)->NewObjectArray(env, numOfOids, CLS_Oid, NULL); if ((*env)->ExceptionCheck(env)) { return NULL; diff -r 4beba2c2a329 -r 2918e1146106 src/java.security.jgss/share/native/libj2gss/NativeUtil.h --- a/src/java.security.jgss/share/native/libj2gss/NativeUtil.h Fri Apr 13 03:05:19 2018 +0200 +++ b/src/java.security.jgss/share/native/libj2gss/NativeUtil.h Fri Apr 13 15:29:33 2018 +0800 @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,6 +26,7 @@ #include #include #include +#include #include "gssapi.h" #ifndef _Included_NATIVE_Util diff -r 4beba2c2a329 -r 2918e1146106 src/java.security.jgss/share/native/libj2gss/gssapi.h --- a/src/java.security.jgss/share/native/libj2gss/gssapi.h Fri Apr 13 03:05:19 2018 +0200 +++ b/src/java.security.jgss/share/native/libj2gss/gssapi.h Fri Apr 13 15:29:33 2018 +0800 @@ -387,7 +387,7 @@ /* Function Prototypes */ -OM_uint32 gss_acquire_cred( +GSS_DLLIMP OM_uint32 gss_acquire_cred( OM_uint32 *, /* minor_status */ gss_name_t, /* desired_name */ OM_uint32, /* time_req */ @@ -398,12 +398,12 @@ OM_uint32 * /* time_rec */ ); -OM_uint32 gss_release_cred( +GSS_DLLIMP OM_uint32 gss_release_cred( OM_uint32 *, /* minor_status */ gss_cred_id_t * /* cred_handle */ ); -OM_uint32 gss_init_sec_context( +GSS_DLLIMP OM_uint32 gss_init_sec_context( OM_uint32 *, /* minor_status */ gss_cred_id_t, /* claimant_cred_handle */ gss_ctx_id_t *, /* context_handle */ @@ -419,7 +419,7 @@ OM_uint32 * /* time_rec */ ); -OM_uint32 gss_accept_sec_context( +GSS_DLLIMP OM_uint32 gss_accept_sec_context( OM_uint32 *, /* minor_status */ gss_ctx_id_t *, /* context_handle */ gss_cred_id_t, /* acceptor_cred_handle */ @@ -433,26 +433,26 @@ gss_cred_id_t * /* delegated_cred_handle */ ); -OM_uint32 gss_process_context_token( +GSS_DLLIMP OM_uint32 gss_process_context_token( OM_uint32 *, /* minor_status */ gss_ctx_id_t, /* context_handle */ gss_buffer_t /* token_buffer */ ); -OM_uint32 gss_delete_sec_context( +GSS_DLLIMP OM_uint32 gss_delete_sec_context( OM_uint32 *, /* minor_status */ gss_ctx_id_t *, /* context_handle */ gss_buffer_t /* output_token */ ); -OM_uint32 gss_context_time( +GSS_DLLIMP OM_uint32 gss_context_time( OM_uint32 *, /* minor_status */ gss_ctx_id_t, /* context_handle */ OM_uint32 * /* time_rec */ ); /* New for V2 */ -OM_uint32 gss_get_mic( +GSS_DLLIMP OM_uint32 gss_get_mic( OM_uint32 *, /* minor_status */ gss_ctx_id_t, /* context_handle */ gss_qop_t, /* qop_req */ @@ -461,7 +461,7 @@ ); /* New for V2 */ -OM_uint32 gss_verify_mic( +GSS_DLLIMP OM_uint32 gss_verify_mic( OM_uint32 *, /* minor_status */ gss_ctx_id_t, /* context_handle */ gss_buffer_t, /* message_buffer */ @@ -470,7 +470,7 @@ ); /* New for V2 */ -OM_uint32 gss_wrap( +GSS_DLLIMP OM_uint32 gss_wrap( OM_uint32 *, /* minor_status */ gss_ctx_id_t, /* context_handle */ int, /* conf_req_flag */ @@ -481,7 +481,7 @@ ); /* New for V2 */ -OM_uint32 gss_unwrap( +GSS_DLLIMP OM_uint32 gss_unwrap( OM_uint32 *, /* minor_status */ gss_ctx_id_t, /* context_handle */ gss_buffer_t, /* input_message_buffer */ @@ -490,7 +490,7 @@ gss_qop_t * /* qop_state */ ); -OM_uint32 gss_display_status( +GSS_DLLIMP OM_uint32 gss_display_status( OM_uint32 *, /* minor_status */ OM_uint32, /* status_value */ int, /* status_type */ @@ -499,48 +499,48 @@ gss_buffer_t /* status_string */ ); -OM_uint32 gss_indicate_mechs( +GSS_DLLIMP OM_uint32 gss_indicate_mechs( OM_uint32 *, /* minor_status */ gss_OID_set * /* mech_set */ ); -OM_uint32 gss_compare_name( +GSS_DLLIMP OM_uint32 gss_compare_name( OM_uint32 *, /* minor_status */ gss_name_t, /* name1 */ gss_name_t, /* name2 */ int * /* name_equal */ ); -OM_uint32 gss_display_name( +GSS_DLLIMP OM_uint32 gss_display_name( OM_uint32 *, /* minor_status */ gss_name_t, /* input_name */ gss_buffer_t, /* output_name_buffer */ gss_OID * /* output_name_type */ ); -OM_uint32 gss_import_name( +GSS_DLLIMP OM_uint32 gss_import_name( OM_uint32 *, /* minor_status */ gss_buffer_t, /* input_name_buffer */ gss_OID, /* input_name_type(used to be const) */ gss_name_t * /* output_name */ ); -OM_uint32 gss_release_name( +GSS_DLLIMP OM_uint32 gss_release_name( OM_uint32 *, /* minor_status */ gss_name_t * /* input_name */ ); -OM_uint32 gss_release_buffer( +GSS_DLLIMP OM_uint32 gss_release_buffer( OM_uint32 *, /* minor_status */ gss_buffer_t /* buffer */ ); -OM_uint32 gss_release_oid_set( +GSS_DLLIMP OM_uint32 gss_release_oid_set( OM_uint32 *, /* minor_status */ gss_OID_set * /* set */ ); -OM_uint32 gss_inquire_cred( +GSS_DLLIMP OM_uint32 gss_inquire_cred( OM_uint32 *, /* minor_status */ gss_cred_id_t, /* cred_handle */ gss_name_t *, /* name */ @@ -550,7 +550,7 @@ ); /* Last argument new for V2 */ -OM_uint32 gss_inquire_context( +GSS_DLLIMP OM_uint32 gss_inquire_context( OM_uint32 *, /* minor_status */ gss_ctx_id_t, /* context_handle */ gss_name_t *, /* src_name */ @@ -563,7 +563,7 @@ ); /* New for V2 */ -OM_uint32 gss_wrap_size_limit( +GSS_DLLIMP OM_uint32 gss_wrap_size_limit( OM_uint32 *, /* minor_status */ gss_ctx_id_t, /* context_handle */ int, /* conf_req_flag */ @@ -573,7 +573,7 @@ ); /* New for V2 */ -OM_uint32 gss_add_cred( +GSS_DLLIMP OM_uint32 gss_add_cred( OM_uint32 *, /* minor_status */ gss_cred_id_t, /* input_cred_handle */ gss_name_t, /* desired_name */ @@ -588,7 +588,7 @@ ); /* New for V2 */ -OM_uint32 gss_inquire_cred_by_mech( +GSS_DLLIMP OM_uint32 gss_inquire_cred_by_mech( OM_uint32 *, /* minor_status */ gss_cred_id_t, /* cred_handle */ gss_OID, /* mech_type */ @@ -599,40 +599,40 @@ ); /* New for V2 */ -OM_uint32 gss_export_sec_context( +GSS_DLLIMP OM_uint32 gss_export_sec_context( OM_uint32 *, /* minor_status */ gss_ctx_id_t *, /* context_handle */ gss_buffer_t /* interprocess_token */ ); /* New for V2 */ -OM_uint32 gss_import_sec_context( +GSS_DLLIMP OM_uint32 gss_import_sec_context( OM_uint32 *, /* minor_status */ gss_buffer_t, /* interprocess_token */ gss_ctx_id_t * /* context_handle */ ); /* New for V2 */ -OM_uint32 gss_release_oid( +GSS_DLLIMP OM_uint32 gss_release_oid( OM_uint32 *, /* minor_status */ gss_OID * /* oid */ ); /* New for V2 */ -OM_uint32 gss_create_empty_oid_set( +GSS_DLLIMP OM_uint32 gss_create_empty_oid_set( OM_uint32 *, /* minor_status */ gss_OID_set * /* oid_set */ ); /* New for V2 */ -OM_uint32 gss_add_oid_set_member( +GSS_DLLIMP OM_uint32 gss_add_oid_set_member( OM_uint32 *, /* minor_status */ gss_OID, /* member_oid */ gss_OID_set * /* oid_set */ ); /* New for V2 */ -OM_uint32 gss_test_oid_set_member( +GSS_DLLIMP OM_uint32 gss_test_oid_set_member( OM_uint32 *, /* minor_status */ gss_OID, /* member */ gss_OID_set, /* set */ @@ -640,42 +640,42 @@ ); /* New for V2 */ -OM_uint32 gss_str_to_oid( +GSS_DLLIMP OM_uint32 gss_str_to_oid( OM_uint32 *, /* minor_status */ gss_buffer_t, /* oid_str */ gss_OID * /* oid */ ); /* New for V2 */ -OM_uint32 gss_oid_to_str( +GSS_DLLIMP OM_uint32 gss_oid_to_str( OM_uint32 *, /* minor_status */ gss_OID, /* oid */ gss_buffer_t /* oid_str */ ); /* New for V2 */ -OM_uint32 gss_inquire_names_for_mech( +GSS_DLLIMP OM_uint32 gss_inquire_names_for_mech( OM_uint32 *, /* minor_status */ gss_OID, /* mechanism */ gss_OID_set * /* name_types */ ); /* New for V2 */ -OM_uint32 gss_export_name( +GSS_DLLIMP OM_uint32 gss_export_name( OM_uint32 *, /* minor_status */ const gss_name_t, /* input_name */ gss_buffer_t /* exported_name */ ); /* New for V2 */ -OM_uint32 gss_duplicate_name( +GSS_DLLIMP OM_uint32 gss_duplicate_name( OM_uint32 *, /* minor_status */ const gss_name_t, /* input_name */ gss_name_t * /* dest_name */ ); /* New for V2 */ -OM_uint32 gss_canonicalize_name( +GSS_DLLIMP OM_uint32 gss_canonicalize_name( OM_uint32 *, /* minor_status */ const gss_name_t, /* input_name */ const gss_OID, /* mech_type */ diff -r 4beba2c2a329 -r 2918e1146106 src/java.security.jgss/unix/native/libj2gss/NativeFunc.c --- a/src/java.security.jgss/unix/native/libj2gss/NativeFunc.c Fri Apr 13 03:05:19 2018 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,288 +0,0 @@ -/* - * Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -#include -#include -#include -#include "NativeFunc.h" - -/* standard GSS method names (ordering is from mapfile) */ -static const char RELEASE_NAME[] = "gss_release_name"; -static const char IMPORT_NAME[] = "gss_import_name"; -static const char COMPARE_NAME[] = "gss_compare_name"; -static const char CANONICALIZE_NAME[] = "gss_canonicalize_name"; -static const char EXPORT_NAME[] = "gss_export_name"; -static const char DISPLAY_NAME[] = "gss_display_name"; -static const char ACQUIRE_CRED[] = "gss_acquire_cred"; -static const char RELEASE_CRED[] = "gss_release_cred"; -static const char INQUIRE_CRED[] = "gss_inquire_cred"; -static const char IMPORT_SEC_CONTEXT[] = "gss_import_sec_context"; -static const char INIT_SEC_CONTEXT[] = "gss_init_sec_context"; -static const char ACCEPT_SEC_CONTEXT[] = "gss_accept_sec_context"; -static const char INQUIRE_CONTEXT[] = "gss_inquire_context"; -static const char DELETE_SEC_CONTEXT[] = "gss_delete_sec_context"; -static const char CONTEXT_TIME[] = "gss_context_time"; -static const char WRAP_SIZE_LIMIT[] = "gss_wrap_size_limit"; -static const char EXPORT_SEC_CONTEXT[] = "gss_export_sec_context"; -static const char GET_MIC[] = "gss_get_mic"; -static const char VERIFY_MIC[] = "gss_verify_mic"; -static const char WRAP[] = "gss_wrap"; -static const char UNWRAP[] = "gss_unwrap"; -static const char INDICATE_MECHS[] = "gss_indicate_mechs"; -static const char INQUIRE_NAMES_FOR_MECH[] = "gss_inquire_names_for_mech"; - -/* additional GSS methods not public thru mapfile */ - -static const char ADD_OID_SET_MEMBER[] = "gss_add_oid_set_member"; -static const char DISPLAY_STATUS[] = "gss_display_status"; -static const char CREATE_EMPTY_OID_SET[] = "gss_create_empty_oid_set"; -static const char RELEASE_OID_SET[] = "gss_release_oid_set"; -static const char RELEASE_BUFFER[] = "gss_release_buffer"; - -/** - * Initialize native GSS function pointers - */ -char* loadNative(const char *libName) { - - char *error; - void *gssLib; - int failed; - OM_uint32 minor, major; - - ftab = NULL; - failed = FALSE; - error = NULL; - - gssLib = dlopen(libName, RTLD_NOW); - if (gssLib == NULL) { - failed = TRUE; - goto out; - } - - /* global function table instance */ - ftab = (GSS_FUNCTION_TABLE_PTR)malloc(sizeof(GSS_FUNCTION_TABLE)); - if (ftab == NULL) { - failed = TRUE; - goto out; - } - - ftab->releaseName = (RELEASE_NAME_FN_PTR)dlsym(gssLib, RELEASE_NAME); - if (ftab->releaseName == NULL) { - failed = TRUE; - goto out; - } - - ftab->importName = (IMPORT_NAME_FN_PTR)dlsym(gssLib, IMPORT_NAME); - if (ftab->importName == NULL) { - failed = TRUE; - goto out; - } - - ftab->compareName = (COMPARE_NAME_FN_PTR)dlsym(gssLib, COMPARE_NAME); - if (ftab->compareName == NULL) { - failed = TRUE; - goto out; - } - - ftab->canonicalizeName = (CANONICALIZE_NAME_FN_PTR) - dlsym(gssLib, CANONICALIZE_NAME); - if (ftab->canonicalizeName == NULL) { - failed = TRUE; - goto out; - } - - ftab->exportName = (EXPORT_NAME_FN_PTR)dlsym(gssLib, EXPORT_NAME); - if (ftab->exportName == NULL) { - failed = TRUE; - goto out; - } - - ftab->displayName = (DISPLAY_NAME_FN_PTR)dlsym(gssLib, DISPLAY_NAME); - if (ftab->displayName == NULL) { - failed = TRUE; - goto out; - } - - ftab->acquireCred = (ACQUIRE_CRED_FN_PTR)dlsym(gssLib, ACQUIRE_CRED); - if (ftab->acquireCred == NULL) { - failed = TRUE; - goto out; - } - - ftab->releaseCred = (RELEASE_CRED_FN_PTR)dlsym(gssLib, RELEASE_CRED); - if (ftab->releaseCred == NULL) { - failed = TRUE; - goto out; - } - - ftab->inquireCred = (INQUIRE_CRED_FN_PTR)dlsym(gssLib, INQUIRE_CRED); - if (ftab->inquireCred == NULL) { - failed = TRUE; - goto out; - } - - ftab->importSecContext = (IMPORT_SEC_CONTEXT_FN_PTR) - dlsym(gssLib, IMPORT_SEC_CONTEXT); - if (ftab->importSecContext == NULL) { - failed = TRUE; - goto out; - } - - ftab->initSecContext = (INIT_SEC_CONTEXT_FN_PTR) - dlsym(gssLib, INIT_SEC_CONTEXT); - if (ftab->initSecContext == NULL) { - failed = TRUE; - goto out; - } - - ftab->acceptSecContext = (ACCEPT_SEC_CONTEXT_FN_PTR) - dlsym(gssLib, ACCEPT_SEC_CONTEXT); - if (ftab->acceptSecContext == NULL) { - failed = TRUE; - goto out; - } - - ftab->inquireContext = (INQUIRE_CONTEXT_FN_PTR) - dlsym(gssLib, INQUIRE_CONTEXT); - if (ftab->inquireContext == NULL) { - failed = TRUE; - goto out; - } - - ftab->deleteSecContext = (DELETE_SEC_CONTEXT_FN_PTR) - dlsym(gssLib, DELETE_SEC_CONTEXT); - if (ftab->deleteSecContext == NULL) { - failed = TRUE; - goto out; - } - - ftab->contextTime = (CONTEXT_TIME_FN_PTR)dlsym(gssLib, CONTEXT_TIME); - if (ftab->contextTime == NULL) { - failed = TRUE; - goto out; - } - - ftab->wrapSizeLimit = (WRAP_SIZE_LIMIT_FN_PTR) - dlsym(gssLib, WRAP_SIZE_LIMIT); - if (ftab->wrapSizeLimit == NULL) { - failed = TRUE; - goto out; - } - - ftab->exportSecContext = (EXPORT_SEC_CONTEXT_FN_PTR) - dlsym(gssLib, EXPORT_SEC_CONTEXT); - if (ftab->exportSecContext == NULL) { - failed = TRUE; - goto out; - } - - ftab->getMic = (GET_MIC_FN_PTR)dlsym(gssLib, GET_MIC); - if (ftab->getMic == NULL) { - failed = TRUE; - goto out; - } - - ftab->verifyMic = (VERIFY_MIC_FN_PTR)dlsym(gssLib, VERIFY_MIC); - if (ftab->verifyMic == NULL) { - failed = TRUE; - goto out; - } - - ftab->wrap = (WRAP_FN_PTR)dlsym(gssLib, WRAP); - if (ftab->wrap == NULL) { - failed = TRUE; - goto out; - } - - ftab->unwrap = (UNWRAP_FN_PTR)dlsym(gssLib, UNWRAP); - if (ftab->unwrap == NULL) { - failed = TRUE; - goto out; - } - - ftab->indicateMechs = (INDICATE_MECHS_FN_PTR)dlsym(gssLib, INDICATE_MECHS); - if (ftab->indicateMechs == NULL) { - failed = TRUE; - goto out; - } - - ftab->inquireNamesForMech = (INQUIRE_NAMES_FOR_MECH_FN_PTR) - dlsym(gssLib, INQUIRE_NAMES_FOR_MECH); - if (ftab->inquireNamesForMech == NULL) { - failed = TRUE; - goto out; - } - - ftab->addOidSetMember = (ADD_OID_SET_MEMBER_FN_PTR) - dlsym(gssLib, ADD_OID_SET_MEMBER); - if (ftab->addOidSetMember == NULL) { - failed = TRUE; - goto out; - } - - ftab->displayStatus = (DISPLAY_STATUS_FN_PTR) - dlsym(gssLib, DISPLAY_STATUS); - if (ftab->displayStatus == NULL) { - failed = TRUE; - goto out; - } - - ftab->createEmptyOidSet = (CREATE_EMPTY_OID_SET_FN_PTR) - dlsym(gssLib, CREATE_EMPTY_OID_SET); - if (ftab->createEmptyOidSet == NULL) { - failed = TRUE; - goto out; - } - - ftab->releaseOidSet = (RELEASE_OID_SET_FN_PTR) - dlsym(gssLib, RELEASE_OID_SET); - if (ftab->releaseOidSet == NULL) { - failed = TRUE; - goto out; - } - - ftab->releaseBuffer = (RELEASE_BUFFER_FN_PTR) - dlsym(gssLib, RELEASE_BUFFER); - if (ftab->releaseBuffer == NULL) { - failed = TRUE; - goto out; - } - - ftab->mechs = GSS_C_NO_OID_SET; - major = (*ftab->indicateMechs)(&minor, &(ftab->mechs)); - if (ftab->mechs == NULL || ftab->mechs == GSS_C_NO_OID_SET) { - failed = TRUE; - goto out; - } - - -out: - if (failed == TRUE) { - error = dlerror(); - if (gssLib != NULL) dlclose(gssLib); - if (ftab != NULL) free(ftab); - } - return error; -} diff -r 4beba2c2a329 -r 2918e1146106 src/java.security.jgss/unix/native/libj2gss/NativeFunc.h --- a/src/java.security.jgss/unix/native/libj2gss/NativeFunc.h Fri Apr 13 03:05:19 2018 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,270 +0,0 @@ -/* - * Copyright (c) 2005, 2006, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -#ifndef NATIVE_FUNC_H -#define NATIVE_FUNC_H - -#include "gssapi.h" - -#ifndef TRUE -#define TRUE 1 -#endif - -#ifndef FALSE -#define FALSE 0 -#endif - -char* loadNative(const char *libName); - -/* function pointer definitions */ -typedef OM_uint32 (*RELEASE_NAME_FN_PTR) - (OM_uint32 *minor_status, - gss_name_t *name); - -typedef OM_uint32 (*IMPORT_NAME_FN_PTR) - (OM_uint32 *minor_status, - gss_buffer_t input_name_buffer, - gss_OID input_name_type, - gss_name_t *output_name); - -typedef OM_uint32 (*COMPARE_NAME_FN_PTR) - (OM_uint32 *minor_status, - gss_name_t name1, - gss_name_t name2, - int *name_equal); - -typedef OM_uint32 (*CANONICALIZE_NAME_FN_PTR) - (OM_uint32 *minor_status, - gss_name_t input_name, - gss_OID mech_type, - gss_name_t *output_name); - -typedef OM_uint32 (*EXPORT_NAME_FN_PTR) - (OM_uint32 *minor_status, - gss_name_t input_name, - gss_buffer_t exported_name); - -typedef OM_uint32 (*DISPLAY_NAME_FN_PTR) - (OM_uint32 *minor_status, - gss_name_t input_name, - gss_buffer_t output_name_buffer, - gss_OID *output_name_type); - -typedef OM_uint32 (*ACQUIRE_CRED_FN_PTR) - (OM_uint32 *minor_status, - gss_name_t desired_name, - OM_uint32 time_req, - gss_OID_set desired_mech, - gss_cred_usage_t cred_usage, - gss_cred_id_t *output_cred_handle, - gss_OID_set *actual_mechs, - OM_uint32 *time_rec); - -typedef OM_uint32 (*RELEASE_CRED_FN_PTR) - (OM_uint32 *minor_status, - gss_cred_id_t *cred_handle); - -typedef OM_uint32 (*INQUIRE_CRED_FN_PTR) - (OM_uint32 *minor_status, - gss_cred_id_t cred_handle, - gss_name_t *name, - OM_uint32 *lifetime, - gss_cred_usage_t *cred_usage, - gss_OID_set *mechanisms); - -typedef OM_uint32 (*IMPORT_SEC_CONTEXT_FN_PTR) - (OM_uint32 *minor_status, - gss_buffer_t interprocess_token, - gss_ctx_id_t *context_handle); - -typedef OM_uint32 (*INIT_SEC_CONTEXT_FN_PTR) - (OM_uint32 *minor_status, - gss_cred_id_t initiator_cred_handle, - gss_ctx_id_t *context_handle, - gss_name_t *target_name, - gss_OID mech_type, - OM_uint32 req_flags, - OM_uint32 time_req, - gss_channel_bindings_t input_chan_bindings, - gss_buffer_t input_token, - gss_OID *actual_mech_type, - gss_buffer_t output_token, - OM_uint32 *ret_flags, - OM_uint32 *time_rec); - -typedef OM_uint32 (*ACCEPT_SEC_CONTEXT_FN_PTR) - (OM_uint32 *minor_status, - gss_ctx_id_t *context_handle, - gss_cred_id_t acceptor_cred_handle, - gss_buffer_t input_token, - gss_channel_bindings_t input_chan_bindings, - gss_name_t *src_name, - gss_OID *mech_type, - gss_buffer_t output_token, - OM_uint32 *ret_flags, - OM_uint32 *time_rec, - gss_cred_id_t *delegated_cred_handle); - -typedef OM_uint32 (*INQUIRE_CONTEXT_FN_PTR) - (OM_uint32 *minor_status, - gss_ctx_id_t context_handle, - gss_name_t *src_name, - gss_name_t *targ_name, - OM_uint32 *lifetime_rec, - gss_OID *mech_type, - OM_uint32 *ctx_flags, - int *locally_initiated, - int *open); - -typedef OM_uint32 (*DELETE_SEC_CONTEXT_FN_PTR) - (OM_uint32 *minor_status, - gss_ctx_id_t *context_handle, - gss_buffer_t output_token); - -typedef OM_uint32 (*CONTEXT_TIME_FN_PTR) - (OM_uint32 *minor_status, - gss_ctx_id_t *context_handle, - OM_uint32 *time_rec); - -typedef OM_uint32 (*WRAP_SIZE_LIMIT_FN_PTR) - (OM_uint32 *minor_status, - gss_ctx_id_t context_handle, - int conf_req_flag, - gss_qop_t qop_req, - OM_uint32 req_output_size, - OM_uint32 *max_input_size); - -typedef OM_uint32 (*EXPORT_SEC_CONTEXT_FN_PTR) - (OM_uint32 *minor_status, - gss_ctx_id_t *context_handle, - gss_buffer_t interprocess_token); - -typedef OM_uint32 (*GET_MIC_FN_PTR) - (OM_uint32 *minor_status, - gss_ctx_id_t context_handle, - gss_qop_t qop_req, - gss_buffer_t message_buffer, - gss_buffer_t msg_token); - -typedef OM_uint32 (*VERIFY_MIC_FN_PTR) - (OM_uint32 *minor_status, - gss_ctx_id_t context_handle, - gss_buffer_t message_buffer, - gss_buffer_t token_buffer, - gss_qop_t *qop_state); - -typedef OM_uint32 (*WRAP_FN_PTR) - (OM_uint32 *minor_status, - gss_ctx_id_t context_handle, - int conf_req_flag, - gss_qop_t qop_req, - gss_buffer_t input_message_buffer, - int *conf_state, - gss_buffer_t output_message_buffer); - -typedef OM_uint32 (*UNWRAP_FN_PTR) - (OM_uint32 *minor_status, - gss_ctx_id_t context_handle, - gss_buffer_t input_message_buffer, - gss_buffer_t output_message_buffer, - int *conf_state, - gss_qop_t *qop_state); - -typedef OM_uint32 (*INDICATE_MECHS_FN_PTR) - (OM_uint32 *minor_status, - gss_OID_set *mech_set); - -typedef OM_uint32 (*INQUIRE_NAMES_FOR_MECH_FN_PTR) - (OM_uint32 *minor_status, - const gss_OID mechanism, - gss_OID_set *name_types); - -typedef OM_uint32 (*ADD_OID_SET_MEMBER_FN_PTR) - (OM_uint32 *minor_status, - gss_OID member_oid, - gss_OID_set *oid_set); - -typedef OM_uint32 (*DISPLAY_STATUS_FN_PTR) - (OM_uint32 *minor_status, - OM_uint32 status_value, - int status_type, - gss_OID mech_type, - OM_uint32 *message_context, - gss_buffer_t status_string); - -typedef OM_uint32 (*CREATE_EMPTY_OID_SET_FN_PTR) - (OM_uint32 *minor_status, - gss_OID_set *oid_set); - -typedef OM_uint32 (*RELEASE_OID_SET_FN_PTR) - (OM_uint32 *minor_status, - gss_OID_set *set); - -typedef OM_uint32 (*RELEASE_BUFFER_FN_PTR) - (OM_uint32 *minor_status, - gss_buffer_t buffer); - - -/* dynamically resolved functions from gss library */ - -typedef struct GSS_FUNCTION_TABLE { - gss_OID_set mechs; - RELEASE_NAME_FN_PTR releaseName; - IMPORT_NAME_FN_PTR importName; - COMPARE_NAME_FN_PTR compareName; - CANONICALIZE_NAME_FN_PTR canonicalizeName; - EXPORT_NAME_FN_PTR exportName; - DISPLAY_NAME_FN_PTR displayName; - ACQUIRE_CRED_FN_PTR acquireCred; - RELEASE_CRED_FN_PTR releaseCred; - INQUIRE_CRED_FN_PTR inquireCred; - IMPORT_SEC_CONTEXT_FN_PTR importSecContext; - INIT_SEC_CONTEXT_FN_PTR initSecContext; - ACCEPT_SEC_CONTEXT_FN_PTR acceptSecContext; - INQUIRE_CONTEXT_FN_PTR inquireContext; - DELETE_SEC_CONTEXT_FN_PTR deleteSecContext; - CONTEXT_TIME_FN_PTR contextTime; - WRAP_SIZE_LIMIT_FN_PTR wrapSizeLimit; - EXPORT_SEC_CONTEXT_FN_PTR exportSecContext; - GET_MIC_FN_PTR getMic; - VERIFY_MIC_FN_PTR verifyMic; - WRAP_FN_PTR wrap; - UNWRAP_FN_PTR unwrap; - INDICATE_MECHS_FN_PTR indicateMechs; - INQUIRE_NAMES_FOR_MECH_FN_PTR inquireNamesForMech; - ADD_OID_SET_MEMBER_FN_PTR addOidSetMember; - DISPLAY_STATUS_FN_PTR displayStatus; - CREATE_EMPTY_OID_SET_FN_PTR createEmptyOidSet; - RELEASE_OID_SET_FN_PTR releaseOidSet; - RELEASE_BUFFER_FN_PTR releaseBuffer; - -} GSS_FUNCTION_TABLE; - -typedef GSS_FUNCTION_TABLE *GSS_FUNCTION_TABLE_PTR; - -/* global GSS function table */ -GSS_FUNCTION_TABLE_PTR ftab; - -#endif diff -r 4beba2c2a329 -r 2918e1146106 test/jdk/java/security/testlibrary/Proc.java --- a/test/jdk/java/security/testlibrary/Proc.java Fri Apr 13 03:05:19 2018 +0200 +++ b/test/jdk/java/security/testlibrary/Proc.java Fri Apr 13 15:29:33 2018 +0800 @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -297,6 +297,9 @@ } if (debug != null) { System.out.println("PROC: " + debug + " cmdline: " + cmd); + for (String e : env.keySet()) { + System.out.print(e + "=" + env.get(e) + " "); + } for (String c : cmd) { if (c.indexOf('\\') >= 0 || c.indexOf(' ') > 0) { System.out.print('\'' + c + '\''); diff -r 4beba2c2a329 -r 2918e1146106 test/jdk/sun/security/krb5/auto/BasicProc.java --- a/test/jdk/sun/security/krb5/auto/BasicProc.java Fri Apr 13 03:05:19 2018 +0200 +++ b/test/jdk/sun/security/krb5/auto/BasicProc.java Fri Apr 13 15:29:33 2018 +0800 @@ -40,6 +40,7 @@ import java.util.Random; import java.util.Set; +import jdk.test.lib.Platform; import org.ietf.jgss.Oid; import sun.security.krb5.Config; @@ -239,10 +240,12 @@ pc.perm(new PropertyPermission("user.name", "read")); } else { Files.copy(Paths.get("base.ccache"), Paths.get(label + ".ccache")); - Files.setPosixFilePermissions(Paths.get(label + ".ccache"), - Set.of(PosixFilePermission.OWNER_READ, - PosixFilePermission.OWNER_WRITE)); - pc.env("KRB5CCNAME", label + ".ccache"); + if (!Platform.isWindows()) { + Files.setPosixFilePermissions(Paths.get(label + ".ccache"), + Set.of(PosixFilePermission.OWNER_READ, + PosixFilePermission.OWNER_WRITE)); + } + pc.env("KRB5CCNAME", "FILE:" + label + ".ccache"); // Do not try system ktab if ccache fails pc.env("KRB5_KTNAME", "none"); } @@ -310,7 +313,7 @@ .perm(new javax.security.auth.AuthPermission("doAs")); if (lib != null) { p.env("KRB5_CONFIG", CONF) - .env("KRB5_TRACE", "/dev/stderr") + .env("KRB5_TRACE", Platform.isWindows() ? "CON" : "/dev/stderr") .prop("sun.security.jgss.native", "true") .prop("sun.security.jgss.lib", lib) .prop("javax.security.auth.useSubjectCredsOnly", "false")