summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornp <np@FreeBSD.org>2013-08-23 18:54:27 +0000
committernp <np@FreeBSD.org>2013-08-23 18:54:27 +0000
commit7701451891612b65bfb8fdb92a2f12b21967a6e0 (patch)
treedf608d357bc4b2e58e91a3a4d83503bae2540a09
parent0cc58eba5c0724beb3429505a5ed0c11585d640e (diff)
downloadFreeBSD-src-7701451891612b65bfb8fdb92a2f12b21967a6e0.zip
FreeBSD-src-7701451891612b65bfb8fdb92a2f12b21967a6e0.tar.gz
Fix implementation of sock_getname.
MFC after: 1 week
-rw-r--r--sys/ofed/include/linux/net.h10
1 files changed, 5 insertions, 5 deletions
diff --git a/sys/ofed/include/linux/net.h b/sys/ofed/include/linux/net.h
index f47acf9..f84dee2 100644
--- a/sys/ofed/include/linux/net.h
+++ b/sys/ofed/include/linux/net.h
@@ -44,7 +44,7 @@ static inline int
sock_getname(struct socket *so, struct sockaddr *addr, int *sockaddr_len,
int peer)
{
- struct sockaddr **nam;
+ struct sockaddr *nam;
int error;
nam = NULL;
@@ -52,15 +52,15 @@ sock_getname(struct socket *so, struct sockaddr *addr, int *sockaddr_len,
if ((so->so_state & (SS_ISCONNECTED|SS_ISCONFIRMING)) == 0)
return (-ENOTCONN);
- error = (*so->so_proto->pr_usrreqs->pru_peeraddr)(so, nam);
+ error = (*so->so_proto->pr_usrreqs->pru_peeraddr)(so, &nam);
} else
- error = (*so->so_proto->pr_usrreqs->pru_sockaddr)(so, nam);
+ error = (*so->so_proto->pr_usrreqs->pru_sockaddr)(so, &nam);
if (error)
return (-error);
- *addr = **nam;
+ *addr = *nam;
*sockaddr_len = addr->sa_len;
- free(*nam, M_SONAME);
+ free(nam, M_SONAME);
return (0);
}
OpenPOWER on IntegriCloud