aboutsummaryrefslogtreecommitdiff
path: root/src/channels.c
diff options
context:
space:
mode:
authorAndreas Schneider <asn@cryptomilk.org>2013-09-17 11:23:56 +0200
committerAndreas Schneider <asn@cryptomilk.org>2013-09-17 11:23:56 +0200
commit4eae4d592cb9195cac49832bf3bd4052c418b948 (patch)
treeef9450a95de3c671f0a554eda282cc14c591eb63 /src/channels.c
parent566d842405f321daea005a453fff2fb6c3bb4a94 (diff)
downloadlibssh-4eae4d592cb9195cac49832bf3bd4052c418b948.tar.gz
libssh-4eae4d592cb9195cac49832bf3bd4052c418b948.tar.xz
libssh-4eae4d592cb9195cac49832bf3bd4052c418b948.zip
channels: Correctly handle timeouts in channel functions.
Diffstat (limited to 'src/channels.c')
-rw-r--r--src/channels.c19
1 files changed, 14 insertions, 5 deletions
diff --git a/src/channels.c b/src/channels.c
index 4d0fd354..33c88242 100644
--- a/src/channels.c
+++ b/src/channels.c
@@ -1611,7 +1611,11 @@ static int channel_request(ssh_channel channel, const char *request,
return SSH_OK;
}
pending:
- rc = ssh_handle_packets_termination(session,SSH_TIMEOUT_USER, ssh_channel_request_termination, channel);
+ rc = ssh_handle_packets_termination(session,
+ SSH_TIMEOUT_DEFAULT,
+ ssh_channel_request_termination,
+ channel);
+
if(session->session_state == SSH_SESSION_STATE_ERROR || rc == SSH_ERROR) {
channel->request_state = SSH_CHANNEL_REQ_STATE_ERROR;
}
@@ -2152,8 +2156,11 @@ static int global_request(ssh_session session, const char *request,
return SSH_OK;
}
pending:
- rc = ssh_handle_packets_termination(session, SSH_TIMEOUT_USER,
- ssh_global_request_termination, session);
+ rc = ssh_handle_packets_termination(session,
+ SSH_TIMEOUT_USER,
+ ssh_global_request_termination,
+ session);
+
if(rc==SSH_ERROR || session->session_state == SSH_SESSION_STATE_ERROR){
session->global_req_state = SSH_CHANNEL_REQ_STATE_ERROR;
}
@@ -2931,8 +2938,10 @@ int ssh_channel_get_exit_status(ssh_channel channel) {
if(channel == NULL) {
return SSH_ERROR;
}
- rc = ssh_handle_packets_termination(channel->session, SSH_TIMEOUT_USER,
- ssh_channel_exit_status_termination, channel);
+ rc = ssh_handle_packets_termination(channel->session,
+ SSH_TIMEOUT_DEFAULT,
+ ssh_channel_exit_status_termination,
+ channel);
if (rc == SSH_ERROR || channel->session->session_state ==
SSH_SESSION_STATE_ERROR)
return SSH_ERROR;