diff options
| author | Tom Gundersen <teg@jklm.no> | 2015-08-27 21:38:36 +0200 | 
|---|---|---|
| committer | Tom Gundersen <teg@jklm.no> | 2015-08-27 21:38:36 +0200 | 
| commit | 4a316c44aa6222f3abc7ed2d50d00a0817cd4466 (patch) | |
| tree | a66424ffac18c715c70fce1484366cd3c7a9415d /src/libsystemd-network/sd-ipv4ll.c | |
| parent | d56cc298808b2dbfa28ae893d6f47f34df3196b1 (diff) | |
| parent | c2c940bda03a07fbacfa3df2590ed865ec3dcc22 (diff) | |
Merge pull request #1055 from poettering/dhcp-updates
Various networkd and dhcp updates
Diffstat (limited to 'src/libsystemd-network/sd-ipv4ll.c')
| -rw-r--r-- | src/libsystemd-network/sd-ipv4ll.c | 42 | 
1 files changed, 25 insertions, 17 deletions
| diff --git a/src/libsystemd-network/sd-ipv4ll.c b/src/libsystemd-network/sd-ipv4ll.c index f080c5c0a7..0fc05e1484 100644 --- a/src/libsystemd-network/sd-ipv4ll.c +++ b/src/libsystemd-network/sd-ipv4ll.c @@ -26,7 +26,6 @@  #include "util.h"  #include "siphash24.h"  #include "list.h" -#include "refcnt.h"  #include "random-util.h"  #include "ipv4ll-internal.h" @@ -68,7 +67,7 @@ typedef enum IPv4LLState {  } IPv4LLState;  struct sd_ipv4ll { -        RefCount n_ref; +        unsigned n_ref;          IPv4LLState state;          int index; @@ -598,30 +597,39 @@ int sd_ipv4ll_stop(sd_ipv4ll *ll) {  }  sd_ipv4ll *sd_ipv4ll_ref(sd_ipv4ll *ll) { -        if (ll) -                assert_se(REFCNT_INC(ll->n_ref) >= 2); + +        if (!ll) +                return NULL; + +        assert(ll->n_ref >= 1); +        ll->n_ref++;          return ll;  }  sd_ipv4ll *sd_ipv4ll_unref(sd_ipv4ll *ll) { -        if (ll && REFCNT_DEC(ll->n_ref) == 0) { -                ll->receive_message = -                        sd_event_source_unref(ll->receive_message); -                ll->fd = safe_close(ll->fd); -                ll->timer = sd_event_source_unref(ll->timer); +        if (!ll) +                return NULL; -                sd_ipv4ll_detach_event(ll); +        assert(ll->n_ref >= 1); +        ll->n_ref--; -                free(ll->random_data); -                free(ll->random_data_state); -                free(ll); +        if (ll->n_ref > 0) +                return ll; -                return NULL; -        } +        ll->receive_message = sd_event_source_unref(ll->receive_message); +        ll->fd = safe_close(ll->fd); -        return ll; +        ll->timer = sd_event_source_unref(ll->timer); + +        sd_ipv4ll_detach_event(ll); + +        free(ll->random_data); +        free(ll->random_data_state); +        free(ll); + +        return NULL;  }  DEFINE_TRIVIAL_CLEANUP_FUNC(sd_ipv4ll*, sd_ipv4ll_unref); @@ -636,7 +644,7 @@ int sd_ipv4ll_new(sd_ipv4ll **ret) {          if (!ll)                  return -ENOMEM; -        ll->n_ref = REFCNT_INIT; +        ll->n_ref = 1;          ll->state = IPV4LL_STATE_INIT;          ll->index = -1;          ll->fd = -1; | 
