diff options
author | James Housley <jim@thehousleys.net> | 2007-06-12 16:15:20 +0000 |
---|---|---|
committer | James Housley <jim@thehousleys.net> | 2007-06-12 16:15:20 +0000 |
commit | 6f59e19b91d2b1f0f05b94ec40f4f6e4d6cddbd3 (patch) | |
tree | 893c4cd2a7254cff95dc129475624b3c6d3784bd /lib | |
parent | 7800b56dc8835056743771af699d57b0b5b9da1f (diff) |
While connect and transfer works fine in non-blocking mode for the test
suite, transfer fails in the real world. So after connect set to blocking
as full non-blocking is migrated out.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/ssh.c | 16 |
1 files changed, 13 insertions, 3 deletions
@@ -302,6 +302,9 @@ static CURLcode ssh_statemach_act(struct connectdata *conn) break; } + /* Set libssh2 to non-blocking, since cURL is all non-blocking */ + libssh2_session_set_blocking(ssh->ssh_session, 0); + #ifdef CURL_LIBSSH2_DEBUG /* * Before we authenticate we should check the hostkey's fingerprint @@ -654,6 +657,16 @@ static CURLcode ssh_statemach_act(struct connectdata *conn) Curl_safefree(working_path); ssh->path = real_path; + /* + ***************************************** + ***************************************** + ** TEMPORARY ** + ***************************************** + ***************************************** + */ + /* Set libssh2 to non-blocking, since cURL is all non-blocking */ + libssh2_session_set_blocking(ssh->ssh_session, 1); + /* Connect is all done */ state(conn, SSH_STOP); } @@ -832,9 +845,6 @@ CURLcode Curl_ssh_connect(struct connectdata *conn, bool *done) #endif /* CURL_LIBSSH2_DEBUG */ #if (LIBSSH2_APINO >= 200706012030) - /* Set libssh2 to non-blocking, since cURL is all non-blocking */ - libssh2_session_set_blocking(ssh->ssh_session, 0); - state(conn, SSH_S_STARTUP); if (data->state.used_interface == Curl_if_multi) |