diff options
author | Joan Lledó <joanlluislledo@gmail.com> | 2019-05-02 11:55:01 +0200 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2019-05-02 23:58:37 +0200 |
commit | 7a229a28593f35e05ceb622f1051b7dd07a78679 (patch) | |
tree | b8b2ec17faf639f5ff3fbd78f31418667d10108b /lwip | |
parent | 31ff1ee3d4b344a5c17fb04f5cf100db6222ecf0 (diff) | |
download | hurd-7a229a28593f35e05ceb622f1051b7dd07a78679.tar.gz hurd-7a229a28593f35e05ceb622f1051b7dd07a78679.tar.bz2 hurd-7a229a28593f35e05ceb622f1051b7dd07a78679.zip |
lwip: Error handling when calling update_if()
* lwip/lwip-util.c:
* Check for errors when calling update_if()
inside a thread-safe context.
Message-Id: <20190502095502.10926-4-jlledom@member.fsf.org>
Diffstat (limited to 'lwip')
-rw-r--r-- | lwip/lwip-util.c | 62 |
1 files changed, 33 insertions, 29 deletions
diff --git a/lwip/lwip-util.c b/lwip/lwip-util.c index 2d3c954c..4f632185 100644 --- a/lwip/lwip-util.c +++ b/lwip/lwip-util.c @@ -35,17 +35,6 @@ #include <netif/hurdtunif.h> #include <netif/hurdloopif.h> -struct update_if_args { - struct netif *netif; - uint32_t addr; - uint32_t netmask; - uint32_t peer; - uint32_t broadcast; - uint32_t gateway; - uint32_t * addr6; - uint8_t * addr6_prefix_len; -}; - /* * Detect the proper module for the given device name * and returns its init callback @@ -244,6 +233,19 @@ init_ifs (void *arg) return; } +/* Args for update_if() */ +struct update_if_args +{ + struct netif *netif; + uint32_t addr; + uint32_t netmask; + uint32_t peer; + uint32_t broadcast; + uint32_t gateway; + uint32_t *addr6; + uint8_t *addr6_prefix_len; +}; + /* * Change the IP configuration of an interface */ @@ -251,8 +253,7 @@ static void update_if (void *arg) { int i; - - struct update_if_args *args = (struct update_if_args*)arg; + struct update_if_args *args = (struct update_if_args *) arg; netif_set_addr (args->netif, (ip4_addr_t *) & args->addr, (ip4_addr_t *) & args->netmask, @@ -275,7 +276,7 @@ update_if (void *arg) for (i = 0; i < LWIP_IPV6_NUM_ADDRESSES; i++) *(args->addr6_prefix_len + i) = 64; - free(args); + free (args); return; } @@ -343,19 +344,22 @@ configure_device (struct netif *netif, uint32_t addr, uint32_t netmask, if (!ipv4config_is_valid (addr, netmask, gateway, broadcast)) err = EINVAL; - else { - /* Call update_if() inside the tcpip_thread */ - struct update_if_args *arg = calloc (1, sizeof (struct update_if_args)); - arg->netif = netif; - arg->addr = addr; - arg->netmask = netmask; - arg->peer = peer; - arg->broadcast = broadcast; - arg->gateway = gateway; - arg->addr6 = addr6; - arg->addr6_prefix_len = addr6_prefix_len; - err = tcpip_callback(update_if, arg); - } - - return err; + else + { + /* Call update_if() inside the tcpip_thread */ + struct update_if_args *arg = calloc (1, sizeof (struct update_if_args)); + arg->netif = netif; + arg->addr = addr; + arg->netmask = netmask; + arg->peer = peer; + arg->broadcast = broadcast; + arg->gateway = gateway; + arg->addr6 = addr6; + arg->addr6_prefix_len = addr6_prefix_len; + err = tcpip_callback (update_if, arg); + if (err) + return err; + } + + return errno; } |