1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

pkg/lwip: ease debugging

This commit is contained in:
Marian Buschsieweke 2022-07-01 10:02:15 +02:00
parent a1ee44e114
commit f590c18f7f
No known key found for this signature in database
GPG Key ID: CB8E3238CE715A94
2 changed files with 30 additions and 5 deletions

View File

@ -14,6 +14,11 @@ LWIP_MODULE_MAKEFILE = $(RIOTBASE)/Makefile.base
.PHONY: $(LWIP_MODULES)
CFLAGS += -Wno-address
# When compiled e.g. with `CFLAGS += -DIP6_DEBUG=LWIP_DBG_ON`, debug output
# does not use the correct format specifiers and compilation fails. (All
# instances were differently named but same sized integer types, e.g. %lx
# for printing int when sizeof(int) == sizeof(long int).)
CFLAGS += -Wno-format
make_module = +$(QQ)"$(MAKE)" -C $(2) -f $(LWIP_MODULE_MAKEFILE) MODULE=$(1)

View File

@ -37,6 +37,9 @@
#error "lwip_sock needs IPv4 or IPv6 support"
#endif
#define ENABLE_DEBUG 0
#include "debug.h"
/**
* @brief Checks if an address family is *not* supported by the lwIP
* implementation
@ -594,6 +597,7 @@ ssize_t lwip_sock_sendv(struct netconn *conn, const iolist_t *snips,
return res;
}
if (ip_addr_isany_val(remote_addr)) {
DEBUG("[lwip_sock_sendv] remote_addr is all zero\n");
return -EINVAL;
}
}
@ -622,12 +626,28 @@ ssize_t lwip_sock_sendv(struct netconn *conn, const iolist_t *snips,
ip_addr_t addr;
u16_t port;
if (((remote != NULL) &&
(remote->netif != SOCK_ADDR_ANY_NETIF) &&
(netconn_getaddr(conn, &addr, &port, 1) == 0) &&
(remote->netif != lwip_sock_bind_addr_to_netif(&addr)))) {
if ((remote != NULL)
&& (remote->netif != SOCK_ADDR_ANY_NETIF)
&& (netconn_getaddr(conn, &addr, &port, 1) == 0)) {
if (IS_ACTIVE(ENABLE_DEBUG)) {
DEBUG("[lwip_sock_sendv] sending from: \"");
/* lwip's ip_addr_debug triggers a -Waddress warning when
* compiled with the ESP toolchain. In absence of a upstream
* solution, we just disable the warning here. */
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Waddress"
ip_addr_debug_print(LWIP_DBG_ON, &addr);
#pragma GCC diagnostic pop
DEBUG("\"\n");
}
uint16_t netif = lwip_sock_bind_addr_to_netif(&addr);
if (remote->netif != netif) {
DEBUG("[lwip_sock_sendv] lwip_sock_bind_addr_to_netif() "
"returned %u, but expected %u\n",
(unsigned)netif, (unsigned)remote->netif);
return -EINVAL;
}
}
tmp = conn;
}
else {