From c49cd446a8f1667d670f8f25ea989944f115181c Mon Sep 17 00:00:00 2001 From: Erik Ekman Date: Wed, 11 Oct 2023 20:57:52 +0200 Subject: [PATCH] pkg/lwip: Allow setting netif active state --- pkg/lwip/contrib/_netif.c | 26 +++++++++++++++++++++----- 1 file changed, 21 insertions(+), 5 deletions(-) diff --git a/pkg/lwip/contrib/_netif.c b/pkg/lwip/contrib/_netif.c index 4991ee0d6f..a931e68f1a 100644 --- a/pkg/lwip/contrib/_netif.c +++ b/pkg/lwip/contrib/_netif.c @@ -18,6 +18,7 @@ #include "fmt.h" #include "lwip/netif/compat.h" +#include "lwip/netifapi.h" #include "net/netif.h" int netif_get_name(netif_t *iface, char *name) @@ -85,13 +86,28 @@ int netif_get_opt(netif_t *iface, netopt_t opt, uint16_t context, int netif_set_opt(netif_t *iface, netopt_t opt, uint16_t context, void *value, size_t value_len) { - (void)iface; - (void)opt; (void)context; - (void)value; - (void)value_len; + int res = -ENOTSUP; + lwip_netif_t *lwip_netif = (lwip_netif_t*) iface; + struct netif *netif = &lwip_netif->lwip_netif; - return -ENOTSUP; + switch (opt) { + case NETOPT_ACTIVE: { + assert(value_len >= sizeof(netopt_enable_t)); + netopt_enable_t *state = value; + if (*state == NETOPT_ENABLE) { + netifapi_netif_set_up(netif); + } else { + netifapi_netif_set_down(netif); + } + res = 0; + } + break; + default: + break; + } + + return res; } /** @} */