From 04f4e9849434bf06c89ed13b941f5b969d142373 Mon Sep 17 00:00:00 2001 From: Jeffrey Altman Date: Sat, 13 Mar 2004 18:28:39 +0000 Subject: [PATCH] registry-call-optimizations-20040313 Do not read the same value from the registry three times in the same function. --- src/WINNT/client_creds/afskfw.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/WINNT/client_creds/afskfw.c b/src/WINNT/client_creds/afskfw.c index 13e1fc931..0e2e03e6f 100644 --- a/src/WINNT/client_creds/afskfw.c +++ b/src/WINNT/client_creds/afskfw.c @@ -3205,6 +3205,7 @@ ObtainTokensFromUserIfNeeded(HWND hWnd) #endif /* USE_FSPROBE */ DWORD CurrentState; char HostName[64]; + int use_kfw = KFW_is_available(); CurrentState = 0; memset(HostName, '\0', sizeof(HostName)); @@ -3216,7 +3217,7 @@ ObtainTokensFromUserIfNeeded(HWND hWnd) return; } - if ( KFW_is_available() ) { + if ( use_kfw ) { code = pkrb5_init_context(&ctx); if ( code ) goto cleanup; } @@ -3233,7 +3234,7 @@ ObtainTokensFromUserIfNeeded(HWND hWnd) rc = pktc_GetToken(&aserver, &atoken, sizeof(atoken), &aclient); - if ( KFW_is_available() ) { + if ( use_kfw ) { code = pkrb5_timeofday(ctx, &now); if ( code ) now = 0; @@ -3281,7 +3282,7 @@ ObtainTokensFromUserIfNeeded(HWND hWnd) #ifdef USE_FSPROBE serverReachable = cellPing(NULL); #else - if ( KFW_is_available() ) { + if ( use_kfw ) { // If we can't use the FSProbe interface we can attempt to forge // a kinit and if we can back an invalid user error we know the // kdc is at least reachable @@ -3346,7 +3347,7 @@ ObtainTokensFromUserIfNeeded(HWND hWnd) if ( IsDebuggerPresent() ) OutputDebugString("Server Reachable\n"); - if ( KFW_is_available() ) { + if ( use_kfw ) { #ifdef USE_MS2MIT KFW_import_windows_lsa(); #endif /* USE_MS2MIT */ -- 2.39.5