tls_gnutls: Print the underlying IO error message and pass the error code through

Signed-off-by: Martin Storsjö <martin@martin.st>
pull/362/head
Martin Storsjö 4 years ago
parent 84ad471fce
commit b484e140ef
  1. 30
      libavformat/tls_gnutls.c

@ -51,6 +51,7 @@ typedef struct TLSContext {
gnutls_session_t session; gnutls_session_t session;
gnutls_certificate_credentials_t cred; gnutls_certificate_credentials_t cred;
int need_shutdown; int need_shutdown;
int io_err;
} TLSContext; } TLSContext;
void ff_gnutls_init(void) void ff_gnutls_init(void)
@ -73,6 +74,7 @@ void ff_gnutls_deinit(void)
static int print_tls_error(URLContext *h, int ret) static int print_tls_error(URLContext *h, int ret)
{ {
TLSContext *c = h->priv_data;
switch (ret) { switch (ret) {
case GNUTLS_E_AGAIN: case GNUTLS_E_AGAIN:
return AVERROR(EAGAIN); return AVERROR(EAGAIN);
@ -88,6 +90,12 @@ static int print_tls_error(URLContext *h, int ret)
av_log(h, AV_LOG_ERROR, "%s\n", gnutls_strerror(ret)); av_log(h, AV_LOG_ERROR, "%s\n", gnutls_strerror(ret));
break; break;
} }
if (c->io_err) {
av_log(h, AV_LOG_ERROR, "IO error: %s\n", av_err2str(c->io_err));
ret = c->io_err;
c->io_err = 0;
return ret;
}
return AVERROR(EIO); return AVERROR(EIO);
} }
@ -108,32 +116,36 @@ static int tls_close(URLContext *h)
static ssize_t gnutls_url_pull(gnutls_transport_ptr_t transport, static ssize_t gnutls_url_pull(gnutls_transport_ptr_t transport,
void *buf, size_t len) void *buf, size_t len)
{ {
URLContext *h = (URLContext*) transport; TLSContext *c = (TLSContext*) transport;
int ret = ffurl_read(h, buf, len); int ret = ffurl_read(c->tls_shared.tcp, buf, len);
if (ret >= 0) if (ret >= 0)
return ret; return ret;
if (ret == AVERROR_EXIT) if (ret == AVERROR_EXIT)
return 0; return 0;
if (ret == AVERROR(EAGAIN)) if (ret == AVERROR(EAGAIN)) {
errno = EAGAIN; errno = EAGAIN;
else } else {
errno = EIO; errno = EIO;
c->io_err = ret;
}
return -1; return -1;
} }
static ssize_t gnutls_url_push(gnutls_transport_ptr_t transport, static ssize_t gnutls_url_push(gnutls_transport_ptr_t transport,
const void *buf, size_t len) const void *buf, size_t len)
{ {
URLContext *h = (URLContext*) transport; TLSContext *c = (TLSContext*) transport;
int ret = ffurl_write(h, buf, len); int ret = ffurl_write(c->tls_shared.tcp, buf, len);
if (ret >= 0) if (ret >= 0)
return ret; return ret;
if (ret == AVERROR_EXIT) if (ret == AVERROR_EXIT)
return 0; return 0;
if (ret == AVERROR(EAGAIN)) if (ret == AVERROR(EAGAIN)) {
errno = EAGAIN; errno = EAGAIN;
else } else {
errno = EIO; errno = EIO;
c->io_err = ret;
}
return -1; return -1;
} }
@ -179,7 +191,7 @@ static int tls_open(URLContext *h, const char *uri, int flags, AVDictionary **op
gnutls_credentials_set(p->session, GNUTLS_CRD_CERTIFICATE, p->cred); gnutls_credentials_set(p->session, GNUTLS_CRD_CERTIFICATE, p->cred);
gnutls_transport_set_pull_function(p->session, gnutls_url_pull); gnutls_transport_set_pull_function(p->session, gnutls_url_pull);
gnutls_transport_set_push_function(p->session, gnutls_url_push); gnutls_transport_set_push_function(p->session, gnutls_url_push);
gnutls_transport_set_ptr(p->session, c->tcp); gnutls_transport_set_ptr(p->session, p);
gnutls_priority_set_direct(p->session, "NORMAL", NULL); gnutls_priority_set_direct(p->session, "NORMAL", NULL);
do { do {
if (ff_check_interrupt(&h->interrupt_callback)) { if (ff_check_interrupt(&h->interrupt_callback)) {

Loading…
Cancel
Save