diff options
Diffstat (limited to 'clientloop.c')
-rw-r--r-- | clientloop.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/clientloop.c b/clientloop.c index 23c2f2396..311dc1393 100644 --- a/clientloop.c +++ b/clientloop.c | |||
@@ -111,6 +111,10 @@ | |||
111 | #include "msg.h" | 111 | #include "msg.h" |
112 | #include "roaming.h" | 112 | #include "roaming.h" |
113 | 113 | ||
114 | #ifdef GSSAPI | ||
115 | #include "ssh-gss.h" | ||
116 | #endif | ||
117 | |||
114 | /* import options */ | 118 | /* import options */ |
115 | extern Options options; | 119 | extern Options options; |
116 | 120 | ||
@@ -1608,6 +1612,15 @@ client_loop(int have_pty, int escape_char_arg, int ssh2_chan_id) | |||
1608 | /* Do channel operations unless rekeying in progress. */ | 1612 | /* Do channel operations unless rekeying in progress. */ |
1609 | if (!rekeying) { | 1613 | if (!rekeying) { |
1610 | channel_after_select(readset, writeset); | 1614 | channel_after_select(readset, writeset); |
1615 | |||
1616 | #ifdef GSSAPI | ||
1617 | if (options.gss_renewal_rekey && | ||
1618 | ssh_gssapi_credentials_updated(GSS_C_NO_CONTEXT)) { | ||
1619 | debug("credentials updated - forcing rekey"); | ||
1620 | need_rekeying = 1; | ||
1621 | } | ||
1622 | #endif | ||
1623 | |||
1611 | if (need_rekeying || packet_need_rekeying()) { | 1624 | if (need_rekeying || packet_need_rekeying()) { |
1612 | debug("need rekeying"); | 1625 | debug("need rekeying"); |
1613 | xxx_kex->done = 0; | 1626 | xxx_kex->done = 0; |