diff options
| author | djm <> | 2010-10-01 22:59:01 +0000 |
|---|---|---|
| committer | djm <> | 2010-10-01 22:59:01 +0000 |
| commit | 8922d4bc4a8b8893d72a48deb2cdf58215f98505 (patch) | |
| tree | 939b752540947d33507b3acc48d76a8bfb7c3dc3 /src/lib/libssl/bio_ssl.c | |
| parent | 76262f7bf9262f965142b1b2b2105cb279c5c696 (diff) | |
| download | openbsd-8922d4bc4a8b8893d72a48deb2cdf58215f98505.tar.gz openbsd-8922d4bc4a8b8893d72a48deb2cdf58215f98505.tar.bz2 openbsd-8922d4bc4a8b8893d72a48deb2cdf58215f98505.zip | |
resolve conflicts, fix local changes
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 | ||
