diff options
Diffstat (limited to '')
| -rw-r--r-- | src/lib/libssl/bio_ssl.c | 21 |
1 files changed, 11 insertions, 10 deletions
diff --git a/src/lib/libssl/bio_ssl.c b/src/lib/libssl/bio_ssl.c index 420deb7fc9..af319af302 100644 --- a/src/lib/libssl/bio_ssl.c +++ b/src/lib/libssl/bio_ssl.c | |||
| @@ -398,17 +398,19 @@ static long ssl_ctrl(BIO *b, int cmd, long num, void *ptr) | |||
| 398 | } | 398 | } |
| 399 | break; | 399 | break; |
| 400 | case BIO_CTRL_POP: | 400 | case BIO_CTRL_POP: |
| 401 | /* ugly bit of a hack */ | 401 | /* Only detach if we are the BIO explicitly being popped */ |
| 402 | if (ssl->rbio != ssl->wbio) /* we are in trouble :-( */ | 402 | if (b == ptr) |
| 403 | { | 403 | { |
| 404 | BIO_free_all(ssl->wbio); | 404 | /* Shouldn't happen in practice because the |
| 405 | } | 405 | * rbio and wbio are the same when pushed. |
| 406 | if (b->next_bio != NULL) | 406 | */ |
| 407 | { | 407 | if (ssl->rbio != ssl->wbio) |
| 408 | CRYPTO_add(&b->next_bio->references,1,CRYPTO_LOCK_BIO); | 408 | BIO_free_all(ssl->wbio); |
| 409 | if (b->next_bio != NULL) | ||
| 410 | CRYPTO_add(&b->next_bio->references,-1,CRYPTO_LOCK_BIO); | ||
| 411 | ssl->wbio=NULL; | ||
| 412 | ssl->rbio=NULL; | ||
| 409 | } | 413 | } |
| 410 | ssl->wbio=NULL; | ||
| 411 | ssl->rbio=NULL; | ||
| 412 | break; | 414 | break; |
| 413 | case BIO_C_DO_STATE_MACHINE: | 415 | case BIO_C_DO_STATE_MACHINE: |
| 414 | BIO_clear_retry_flags(b); | 416 | BIO_clear_retry_flags(b); |
| @@ -543,7 +545,6 @@ BIO *BIO_new_ssl_connect(SSL_CTX *ctx) | |||
| 543 | return(ret); | 545 | return(ret); |
| 544 | err: | 546 | err: |
| 545 | if (con != NULL) BIO_free(con); | 547 | if (con != NULL) BIO_free(con); |
| 546 | if (ret != NULL) BIO_free(ret); | ||
| 547 | return(NULL); | 548 | return(NULL); |
| 548 | } | 549 | } |
| 549 | 550 | ||
