available = bio_nread0(bio, buf);
if (num > available)
num = available;
- if (num <= 0)
+ if (num == 0)
return num;
b = bio->ptr;
static size_t bio_nwrite(BIO *bio, char **buf, size_t num)
{
- struct bio_bio_st *b=bio->ptr;
+ struct bio_bio_st *b;
size_t space;
space = bio_nwrite0(bio, buf);
if (num > space)
num = space;
- if (num <= 0)
+ if (num == 0)
return num;
+ b = bio->ptr;
+ assert(b != NULL);
b->len += num;
assert(b->len <= b->size);
ret = (long) b->request;
break;
+ case BIO_C_RESET_READ_REQUEST:
+ /* Reset request. (Can be useful after read attempts
+ * at the other side that are meant to be non-blocking,
+ * e.g. when probing SSL_read to see if any data is
+ * available.) */
+ b->request = 0;
+ ret = 1;
+ break;
+
case BIO_C_SHUTDOWN_WR:
/* similar to shutdown(..., SHUT_WR) */
b->closed = 1;
return BIO_ctrl(bio, BIO_C_GET_READ_REQUEST, 0, NULL);
}
+int BIO_ctrl_reset_read_request(BIO *bio)
+ {
+ return (BIO_ctrl(bio, BIO_C_RESET_READ_REQUEST, 0, NULL) != 0);
+ }
+
/* BIO_nread0/nread/nwrite0/nwrite are availabe only for BIO pairs for now
* (conceivably some other BIOs could allow non-copying reads and writes too.)