18d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt/* 28d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt * IEEE 802.1X-2004 Authenticator - State dump 3fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt * Copyright (c) 2002-2013, Jouni Malinen <j@w1.fi> 48d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt * 5c5ec7f57ead87efa365800228aa0b09a12d9e6c4Dmitry Shmidt * This software may be distributed under the terms of the BSD license. 6c5ec7f57ead87efa365800228aa0b09a12d9e6c4Dmitry Shmidt * See README for more details. 78d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt */ 88d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 98d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#include "includes.h" 108d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 118d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#include "common.h" 128d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#include "eap_server/eap.h" 138d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#include "eapol_auth_sm.h" 148d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#include "eapol_auth_sm_i.h" 158d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 168d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline const char * port_type_txt(PortTypes pt) 178d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 188d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt switch (pt) { 198d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case ForceUnauthorized: return "ForceUnauthorized"; 208d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case ForceAuthorized: return "ForceAuthorized"; 218d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case Auto: return "Auto"; 228d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt default: return "Unknown"; 238d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt } 248d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 258d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 268d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 278d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline const char * port_state_txt(PortState ps) 288d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 298d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt switch (ps) { 308d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case Unauthorized: return "Unauthorized"; 318d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case Authorized: return "Authorized"; 328d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt default: return "Unknown"; 338d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt } 348d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 358d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 368d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 378d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline const char * ctrl_dir_txt(ControlledDirection dir) 388d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 398d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt switch (dir) { 408d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case Both: return "Both"; 418d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case In: return "In"; 428d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt default: return "Unknown"; 438d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt } 448d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 458d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 468d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 478d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline const char * auth_pae_state_txt(int s) 488d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 498d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt switch (s) { 508d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_PAE_INITIALIZE: return "INITIALIZE"; 518d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_PAE_DISCONNECTED: return "DISCONNECTED"; 528d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_PAE_CONNECTING: return "CONNECTING"; 538d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_PAE_AUTHENTICATING: return "AUTHENTICATING"; 548d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_PAE_AUTHENTICATED: return "AUTHENTICATED"; 558d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_PAE_ABORTING: return "ABORTING"; 568d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_PAE_HELD: return "HELD"; 578d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_PAE_FORCE_AUTH: return "FORCE_AUTH"; 588d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_PAE_FORCE_UNAUTH: return "FORCE_UNAUTH"; 598d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_PAE_RESTART: return "RESTART"; 608d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt default: return "Unknown"; 618d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt } 628d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 638d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 648d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 658d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline const char * be_auth_state_txt(int s) 668d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 678d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt switch (s) { 688d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case BE_AUTH_REQUEST: return "REQUEST"; 698d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case BE_AUTH_RESPONSE: return "RESPONSE"; 708d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case BE_AUTH_SUCCESS: return "SUCCESS"; 718d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case BE_AUTH_FAIL: return "FAIL"; 728d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case BE_AUTH_TIMEOUT: return "TIMEOUT"; 738d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case BE_AUTH_IDLE: return "IDLE"; 748d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case BE_AUTH_INITIALIZE: return "INITIALIZE"; 758d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case BE_AUTH_IGNORE: return "IGNORE"; 768d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt default: return "Unknown"; 778d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt } 788d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 798d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 808d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 818d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline const char * reauth_timer_state_txt(int s) 828d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 838d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt switch (s) { 848d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case REAUTH_TIMER_INITIALIZE: return "INITIALIZE"; 858d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case REAUTH_TIMER_REAUTHENTICATE: return "REAUTHENTICATE"; 868d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt default: return "Unknown"; 878d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt } 888d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 898d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 908d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 918d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline const char * auth_key_tx_state_txt(int s) 928d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 938d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt switch (s) { 948d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_KEY_TX_NO_KEY_TRANSMIT: return "NO_KEY_TRANSMIT"; 958d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case AUTH_KEY_TX_KEY_TRANSMIT: return "KEY_TRANSMIT"; 968d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt default: return "Unknown"; 978d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt } 988d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 998d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1008d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1018d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline const char * key_rx_state_txt(int s) 1028d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1038d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt switch (s) { 1048d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case KEY_RX_NO_KEY_RECEIVE: return "NO_KEY_RECEIVE"; 1058d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case KEY_RX_KEY_RECEIVE: return "KEY_RECEIVE"; 1068d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt default: return "Unknown"; 1078d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt } 1088d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1098d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1108d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1118d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline const char * ctrl_dir_state_txt(int s) 1128d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1138d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt switch (s) { 1148d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case CTRL_DIR_FORCE_BOTH: return "FORCE_BOTH"; 1158d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt case CTRL_DIR_IN_OR_BOTH: return "IN_OR_BOTH"; 1168d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt default: return "Unknown"; 1178d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt } 1188d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1198d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1208d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 121fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidtint eapol_auth_dump_state(struct eapol_state_machine *sm, char *buf, 122fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt size_t buflen) 1238d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 124fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt char *pos, *end; 125fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt int ret; 126fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 127fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt pos = buf; 128fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt end = pos + buflen; 129fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 130fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt ret = os_snprintf(pos, end - pos, "aWhile=%d\nquietWhile=%d\n" 131fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "reAuthWhen=%d\n", 132fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->aWhile, sm->quietWhile, sm->reAuthWhen); 133fb45fd5cfed8bdccd0859c7fc05449fc187e2d06Dmitry Shmidt if (os_snprintf_error(end - pos, ret)) 134fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return pos - buf; 135fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt pos += ret; 136fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 1378d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#define _SB(b) ((b) ? "TRUE" : "FALSE") 138fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt ret = os_snprintf(pos, end - pos, 139fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authAbort=%s\n" 140fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authFail=%s\n" 141fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authPortStatus=%s\n" 142fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authStart=%s\n" 143fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authTimeout=%s\n" 144fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authSuccess=%s\n" 145fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "eapFail=%s\n" 146fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "eapolEap=%s\n" 147fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "eapSuccess=%s\n" 148fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "eapTimeout=%s\n" 149fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "initialize=%s\n" 150fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "keyAvailable=%s\n" 151fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "keyDone=%s\n" 152fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "keyRun=%s\n" 153fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "keyTxEnabled=%s\n" 154fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "portControl=%s\n" 155fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "portEnabled=%s\n" 156fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "portValid=%s\n" 157fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "reAuthenticate=%s\n", 158fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->authAbort), 159fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->authFail), 160fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt port_state_txt(sm->authPortStatus), 161fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->authStart), 162fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->authTimeout), 163fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->authSuccess), 164fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eap_if->eapFail), 165fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eapolEap), 166fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eap_if->eapSuccess), 167fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eap_if->eapTimeout), 168fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->initialize), 169fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eap_if->eapKeyAvailable), 170fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->keyDone), _SB(sm->keyRun), 171fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->keyTxEnabled), 172fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt port_type_txt(sm->portControl), 173fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eap_if->portEnabled), 174fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->portValid), 175fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->reAuthenticate)); 176fb45fd5cfed8bdccd0859c7fc05449fc187e2d06Dmitry Shmidt if (os_snprintf_error(end - pos, ret)) 177fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return pos - buf; 178fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt pos += ret; 179fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 180fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt ret = os_snprintf(pos, end - pos, 181fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "auth_pae_state=%s\n" 182fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "eapolLogoff=%s\n" 183fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "eapolStart=%s\n" 184fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "eapRestart=%s\n" 185fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "portMode=%s\n" 186fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "reAuthCount=%d\n" 187fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "quietPeriod=%d\n" 188fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "reAuthMax=%d\n" 189fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authEntersConnecting=%d\n" 190fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authEapLogoffsWhileConnecting=%d\n" 191fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authEntersAuthenticating=%d\n" 192fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authAuthSuccessesWhileAuthenticating=%d\n" 193fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authAuthTimeoutsWhileAuthenticating=%d\n" 194fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authAuthFailWhileAuthenticating=%d\n" 195fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authAuthEapStartsWhileAuthenticating=%d\n" 196fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authAuthEapLogoffWhileAuthenticating=%d\n" 197fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authAuthReauthsWhileAuthenticated=%d\n" 198fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authAuthEapStartsWhileAuthenticated=%d\n" 199fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "authAuthEapLogoffWhileAuthenticated=%d\n", 200fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt auth_pae_state_txt(sm->auth_pae_state), 201fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eapolLogoff), 202fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eapolStart), 203fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eap_if->eapRestart), 204fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt port_type_txt(sm->portMode), 205fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->reAuthCount, 206fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->quietPeriod, sm->reAuthMax, 207fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->authEntersConnecting, 208fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->authEapLogoffsWhileConnecting, 209fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->authEntersAuthenticating, 210fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->authAuthSuccessesWhileAuthenticating, 211fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->authAuthTimeoutsWhileAuthenticating, 212fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->authAuthFailWhileAuthenticating, 213fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->authAuthEapStartsWhileAuthenticating, 214fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->authAuthEapLogoffWhileAuthenticating, 215fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->authAuthReauthsWhileAuthenticated, 216fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->authAuthEapStartsWhileAuthenticated, 217fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->authAuthEapLogoffWhileAuthenticated); 218fb45fd5cfed8bdccd0859c7fc05449fc187e2d06Dmitry Shmidt if (os_snprintf_error(end - pos, ret)) 219fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return pos - buf; 220fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt pos += ret; 221fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 222fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt ret = os_snprintf(pos, end - pos, 223fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "be_auth_state=%s\n" 224fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "eapNoReq=%s\n" 225fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "eapReq=%s\n" 226fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "eapResp=%s\n" 227fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "serverTimeout=%d\n" 228fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "backendResponses=%d\n" 229fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "backendAccessChallenges=%d\n" 230fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "backendOtherRequestsToSupplicant=%d\n" 231fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "backendAuthSuccesses=%d\n" 232fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "backendAuthFails=%d\n", 233fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt be_auth_state_txt(sm->be_auth_state), 234fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eap_if->eapNoReq), 235fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eap_if->eapReq), 236fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->eap_if->eapResp), 237fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->serverTimeout, 238fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->backendResponses, 239fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->backendAccessChallenges, 240fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->backendOtherRequestsToSupplicant, 241fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->backendAuthSuccesses, 242fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->backendAuthFails); 243fb45fd5cfed8bdccd0859c7fc05449fc187e2d06Dmitry Shmidt if (os_snprintf_error(end - pos, ret)) 244fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return pos - buf; 245fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt pos += ret; 246fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 247fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt ret = os_snprintf(pos, end - pos, 248fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "reauth_timer_state=%s\n" 249fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "reAuthPeriod=%d\n" 250fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "reAuthEnabled=%s\n", 251fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt reauth_timer_state_txt(sm->reauth_timer_state), 252fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt sm->reAuthPeriod, 253fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->reAuthEnabled)); 254fb45fd5cfed8bdccd0859c7fc05449fc187e2d06Dmitry Shmidt if (os_snprintf_error(end - pos, ret)) 255fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return pos - buf; 256fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt pos += ret; 257fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 258fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt ret = os_snprintf(pos, end - pos, 259fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "auth_key_tx_state=%s\n", 260fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt auth_key_tx_state_txt(sm->auth_key_tx_state)); 261fb45fd5cfed8bdccd0859c7fc05449fc187e2d06Dmitry Shmidt if (os_snprintf_error(end - pos, ret)) 262fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return pos - buf; 263fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt pos += ret; 264fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 265fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt ret = os_snprintf(pos, end - pos, 266fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "key_rx_state=%s\n" 267fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "rxKey=%s\n", 268fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt key_rx_state_txt(sm->key_rx_state), 269fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->rxKey)); 270fb45fd5cfed8bdccd0859c7fc05449fc187e2d06Dmitry Shmidt if (os_snprintf_error(end - pos, ret)) 271fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return pos - buf; 272fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt pos += ret; 273fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 274fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt ret = os_snprintf(pos, end - pos, 275fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "ctrl_dir_state=%s\n" 276fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "adminControlledDirections=%s\n" 277fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "operControlledDirections=%s\n" 278fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt "operEdge=%s\n", 279fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt ctrl_dir_state_txt(sm->ctrl_dir_state), 280fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt ctrl_dir_txt(sm->adminControlledDirections), 281fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt ctrl_dir_txt(sm->operControlledDirections), 282fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt _SB(sm->operEdge)); 283fb45fd5cfed8bdccd0859c7fc05449fc187e2d06Dmitry Shmidt if (os_snprintf_error(end - pos, ret)) 284fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return pos - buf; 285fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt pos += ret; 2868d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#undef _SB 287fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 288fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return pos - buf; 2898d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 290