am e7184667: am 4f7c0843: Merge "libnl_2: Fix memory leaks" into ics-mr0
* commit 'e71846671e6dbb2ece3142be92b33ff85f713997': libnl_2: Fix memory leaks
This commit is contained in:
commit
af0a8b2a90
|
@ -39,16 +39,14 @@ fail:
|
|||
struct nl_cb *nl_cb_clone(struct nl_cb *orig)
|
||||
{
|
||||
struct nl_cb *new_cb;
|
||||
int new_refcnt;
|
||||
|
||||
new_cb = nl_cb_alloc(NL_CB_DEFAULT);
|
||||
if (new_cb == NULL)
|
||||
goto fail;
|
||||
|
||||
/* Preserve reference count and copy original */
|
||||
new_refcnt = new_cb->cb_refcnt;
|
||||
/* Copy original and set refcount to 1 */
|
||||
memcpy(new_cb, orig, sizeof(*orig));
|
||||
new_cb->cb_refcnt = new_refcnt;
|
||||
new_cb->cb_refcnt = 1;
|
||||
|
||||
return new_cb;
|
||||
fail:
|
||||
|
@ -84,9 +82,9 @@ struct nl_cb *nl_cb_get(struct nl_cb *cb)
|
|||
|
||||
void nl_cb_put(struct nl_cb *cb)
|
||||
{
|
||||
if (!cb)
|
||||
return;
|
||||
cb->cb_refcnt--;
|
||||
if (cb->cb_refcnt <= 0)
|
||||
free(cb);
|
||||
|
||||
}
|
||||
|
||||
|
|
|
@ -59,15 +59,14 @@ int nl_recv(struct nl_sock *sk, struct sockaddr_nl *nla, \
|
|||
{
|
||||
int rc = -1;
|
||||
int sk_flags;
|
||||
int RECV_BUF_SIZE;
|
||||
int RECV_BUF_SIZE = getpagesize();
|
||||
int errsv;
|
||||
struct iovec recvmsg_iov;
|
||||
struct msghdr msg;
|
||||
|
||||
/* Allocate buffer */
|
||||
RECV_BUF_SIZE = getpagesize();
|
||||
*buf = (unsigned char *) malloc(RECV_BUF_SIZE);
|
||||
if (!buf) {
|
||||
if (!(*buf)) {
|
||||
rc = -ENOMEM;
|
||||
goto fail;
|
||||
}
|
||||
|
@ -91,8 +90,11 @@ int nl_recv(struct nl_sock *sk, struct sockaddr_nl *nla, \
|
|||
errsv = errno;
|
||||
fcntl(sk->s_fd, F_SETFL, sk_flags);
|
||||
|
||||
if (rc < 0)
|
||||
if (rc < 0) {
|
||||
rc = -errsv;
|
||||
free(*buf);
|
||||
*buf = NULL;
|
||||
}
|
||||
|
||||
fail:
|
||||
return rc;
|
||||
|
@ -108,7 +110,6 @@ int nl_recvmsgs(struct nl_sock *sk, struct nl_cb *cb)
|
|||
int rc, cb_rc = NL_OK, done = 0;
|
||||
|
||||
do {
|
||||
|
||||
unsigned char *buf;
|
||||
int i, rem, flags;
|
||||
struct nlmsghdr *nlh;
|
||||
|
@ -127,7 +128,7 @@ int nl_recvmsgs(struct nl_sock *sk, struct nl_cb *cb)
|
|||
|
||||
/* Check for callbacks */
|
||||
|
||||
msg = (struct nl_msg *)malloc(sizeof(struct nl_msg));
|
||||
msg = (struct nl_msg *) malloc(sizeof(struct nl_msg));
|
||||
memset(msg, 0, sizeof(*msg));
|
||||
msg->nm_nlh = nlh;
|
||||
|
||||
|
@ -187,7 +188,6 @@ int nl_recvmsgs(struct nl_sock *sk, struct nl_cb *cb)
|
|||
if (done)
|
||||
break;
|
||||
}
|
||||
|
||||
free(buf);
|
||||
buf = NULL;
|
||||
|
||||
|
@ -197,7 +197,7 @@ int nl_recvmsgs(struct nl_sock *sk, struct nl_cb *cb)
|
|||
|
||||
success:
|
||||
fail:
|
||||
return rc;
|
||||
return rc;
|
||||
}
|
||||
|
||||
/* Send raw data over netlink socket */
|
||||
|
|
|
@ -31,7 +31,7 @@ int nl_socket_add_membership(struct nl_sock *sk, int group)
|
|||
}
|
||||
|
||||
/* Allocate new netlink socket. */
|
||||
struct nl_sock *nl_socket_alloc(void)
|
||||
static struct nl_sock *_nl_socket_alloc(void)
|
||||
{
|
||||
struct nl_sock *sk;
|
||||
struct timeval tv;
|
||||
|
@ -39,13 +39,13 @@ struct nl_sock *nl_socket_alloc(void)
|
|||
|
||||
sk = (struct nl_sock *) malloc(sizeof(struct nl_sock));
|
||||
if (!sk)
|
||||
goto fail;
|
||||
return NULL;
|
||||
memset(sk, 0, sizeof(*sk));
|
||||
|
||||
/* Get current time */
|
||||
|
||||
if (gettimeofday(&tv, NULL))
|
||||
return NULL;
|
||||
goto fail;
|
||||
else
|
||||
sk->s_seq_next = (int) tv.tv_sec;
|
||||
|
||||
|
@ -59,24 +59,36 @@ struct nl_sock *nl_socket_alloc(void)
|
|||
sk->s_peer.nl_pid = 0; /* Kernel */
|
||||
sk->s_peer.nl_groups = 0; /* No groups */
|
||||
|
||||
cb = (struct nl_cb *) malloc(sizeof(struct nl_cb));
|
||||
return sk;
|
||||
fail:
|
||||
free(sk);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Allocate new netlink socket. */
|
||||
struct nl_sock *nl_socket_alloc(void)
|
||||
{
|
||||
struct nl_sock *sk = _nl_socket_alloc();
|
||||
struct nl_cb *cb;
|
||||
|
||||
if (!sk)
|
||||
return NULL;
|
||||
|
||||
cb = nl_cb_alloc(NL_CB_DEFAULT);
|
||||
if (!cb)
|
||||
goto cb_fail;
|
||||
memset(cb, 0, sizeof(*cb));
|
||||
sk->s_cb = nl_cb_alloc(NL_CB_DEFAULT);
|
||||
|
||||
|
||||
sk->s_cb = cb;
|
||||
return sk;
|
||||
cb_fail:
|
||||
free(sk);
|
||||
fail:
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Allocate new socket with custom callbacks. */
|
||||
struct nl_sock *nl_socket_alloc_cb(struct nl_cb *cb)
|
||||
{
|
||||
struct nl_sock *sk = nl_socket_alloc();
|
||||
struct nl_sock *sk = _nl_socket_alloc();
|
||||
|
||||
if (!sk)
|
||||
return NULL;
|
||||
|
||||
|
@ -84,7 +96,6 @@ struct nl_sock *nl_socket_alloc_cb(struct nl_cb *cb)
|
|||
nl_cb_get(cb);
|
||||
|
||||
return sk;
|
||||
|
||||
}
|
||||
|
||||
/* Free a netlink socket. */
|
||||
|
@ -116,5 +127,3 @@ int nl_socket_get_fd(struct nl_sock *sk)
|
|||
{
|
||||
return sk->s_fd;
|
||||
}
|
||||
|
||||
|
||||
|
|
Loading…
Reference in New Issue