net: netlink_getname, packet_getname -- use DECLARE_SOCKADDR guard
authorCyrill Gorcunov <gorcunov@openvz.org>
Sun, 8 Nov 2009 05:51:19 +0000 (05:51 +0000)
committerDavid S. Miller <davem@davemloft.net>
Wed, 11 Nov 2009 04:54:41 +0000 (20:54 -0800)
Use guard DECLARE_SOCKADDR in a few more places which allow
us to catch if the structure copied back is too big.

Signed-off-by: Cyrill Gorcunov <gorcunov@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/netlink/af_netlink.c
net/packet/af_packet.c
net/unix/af_unix.c

index aea805c98da3ee5b6312277c29c55cf92fc80ae3..f30d596dbc584e801fa0194cab2f3b9494e2e3bc 100644 (file)
@@ -708,7 +708,7 @@ static int netlink_getname(struct socket *sock, struct sockaddr *addr,
 {
        struct sock *sk = sock->sk;
        struct netlink_sock *nlk = nlk_sk(sk);
-       struct sockaddr_nl *nladdr = (struct sockaddr_nl *)addr;
+       DECLARE_SOCKADDR(struct sockaddr_nl *, nladdr, addr);
 
        nladdr->nl_family = AF_NETLINK;
        nladdr->nl_pad = 0;
index 3304caa65347a66b2b39fad947f53217e6585eb5..c620bd9ae3de96d2f597619b6fc7709cc7f8a74a 100644 (file)
@@ -1537,7 +1537,7 @@ static int packet_getname(struct socket *sock, struct sockaddr *uaddr,
        struct net_device *dev;
        struct sock *sk = sock->sk;
        struct packet_sock *po = pkt_sk(sk);
-       struct sockaddr_ll *sll = (struct sockaddr_ll *)uaddr;
+       DECLARE_SOCKADDR(struct sockaddr_ll *, sll, uaddr);
 
        if (peer)
                return -EOPNOTSUPP;
index 178d3af2a6054819f40f9d1212912c2df6dd5d0f..7553ea6edd8f1020c3727e2f1151192db45edeae 100644 (file)
@@ -1259,7 +1259,7 @@ static int unix_getname(struct socket *sock, struct sockaddr *uaddr, int *uaddr_
 {
        struct sock *sk = sock->sk;
        struct unix_sock *u;
-       struct sockaddr_un *sunaddr = (struct sockaddr_un *)uaddr;
+       DECLARE_SOCKADDR(struct sockaddr_un *, sunaddr, uaddr);
        int err = 0;
 
        if (peer) {