1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

gnrc_sock: adapt for *_recv_buf() API change

This commit is contained in:
Martine S. Lenders 2020-04-01 13:00:54 +02:00
parent 58685af8a6
commit d934579817
No known key found for this signature in database
GPG Key ID: CCD317364F63286F
3 changed files with 32 additions and 25 deletions

View File

@ -45,13 +45,6 @@ static void _callback_put(void *arg)
}
#endif
void sock_recv_buf_free(void *buf_ctx)
{
if (buf_ctx) {
gnrc_pktbuf_release(buf_ctx);
}
}
#ifdef SOCK_HAS_ASYNC
static void _netapi_cb(uint16_t cmd, gnrc_pktsnip_t *pkt, void *ctx)
{

View File

@ -90,20 +90,21 @@ ssize_t sock_ip_recv(sock_ip_t *sock, void *data, size_t max_len,
uint32_t timeout, sock_ip_ep_t *remote)
{
void *pkt = NULL, *ctx = NULL;
ssize_t res;
uint8_t *ptr = data;
ssize_t res, ret = 0;
bool nobufs = false;
assert((sock != NULL) && (data != NULL) && (max_len > 0));
res = sock_ip_recv_buf(sock, &pkt, &ctx, timeout, remote);
if (res >= 0) {
while ((res = sock_ip_recv_buf(sock, &pkt, &ctx, timeout, remote)) > 0) {
if (res > (ssize_t)max_len) {
res = -ENOBUFS;
nobufs = true;
continue;
}
else if (res != 0) {
memcpy(data, pkt, res);
}
sock_recv_buf_free(ctx);
memcpy(ptr, pkt, res);
ptr += res;
ret += res;
}
return res;
return (nobufs) ? -ENOBUFS : ((res < 0) ? res : ret);
}
ssize_t sock_ip_recv_buf(sock_ip_t *sock, void **data, void **buf_ctx,
@ -114,6 +115,12 @@ ssize_t sock_ip_recv_buf(sock_ip_t *sock, void **data, void **buf_ctx,
int res;
assert((sock != NULL) && (data != NULL) && (buf_ctx != NULL));
if (*buf_ctx != NULL) {
*data = NULL;
gnrc_pktbuf_release(*buf_ctx);
*buf_ctx = NULL;
return 0;
}
if (sock->local.family == 0) {
return -EADDRNOTAVAIL;
}

View File

@ -177,20 +177,21 @@ ssize_t sock_udp_recv(sock_udp_t *sock, void *data, size_t max_len,
uint32_t timeout, sock_udp_ep_t *remote)
{
void *pkt = NULL, *ctx = NULL;
ssize_t res;
uint8_t *ptr = data;
ssize_t res, ret = 0;
bool nobufs = false;
assert((sock != NULL) && (data != NULL) && (max_len > 0));
res = sock_udp_recv_buf(sock, &pkt, &ctx, timeout, remote);
if (res >= 0) {
while ((res = sock_udp_recv_buf(sock, &pkt, &ctx, timeout, remote)) > 0) {
if (res > (ssize_t)max_len) {
res = -ENOBUFS;
nobufs = true;
continue;
}
else if (res != 0) {
memcpy(data, pkt, res);
}
sock_recv_buf_free(ctx);
memcpy(ptr, pkt, res);
ptr += res;
ret += res;
}
return res;
return (nobufs) ? -ENOBUFS : ((res < 0) ? res : ret);
}
ssize_t sock_udp_recv_buf(sock_udp_t *sock, void **data, void **buf_ctx,
@ -202,6 +203,12 @@ ssize_t sock_udp_recv_buf(sock_udp_t *sock, void **data, void **buf_ctx,
int res;
assert((sock != NULL) && (data != NULL) && (buf_ctx != NULL));
if (*buf_ctx != NULL) {
*data = NULL;
gnrc_pktbuf_release(*buf_ctx);
*buf_ctx = NULL;
return 0;
}
if (sock->local.family == AF_UNSPEC) {
return -EADDRNOTAVAIL;
}