net: netlink_getname, packet_getname -- use DECLARE_SOCKADDR guard
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>
This commit is contained in:
Родитель
37e8273cd3
Коммит
13cfa97bef
|
@ -708,7 +708,7 @@ static int netlink_getname(struct socket *sock, struct sockaddr *addr,
|
||||||
{
|
{
|
||||||
struct sock *sk = sock->sk;
|
struct sock *sk = sock->sk;
|
||||||
struct netlink_sock *nlk = nlk_sk(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_family = AF_NETLINK;
|
||||||
nladdr->nl_pad = 0;
|
nladdr->nl_pad = 0;
|
||||||
|
|
|
@ -1537,7 +1537,7 @@ static int packet_getname(struct socket *sock, struct sockaddr *uaddr,
|
||||||
struct net_device *dev;
|
struct net_device *dev;
|
||||||
struct sock *sk = sock->sk;
|
struct sock *sk = sock->sk;
|
||||||
struct packet_sock *po = pkt_sk(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)
|
if (peer)
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
|
@ -1259,7 +1259,7 @@ static int unix_getname(struct socket *sock, struct sockaddr *uaddr, int *uaddr_
|
||||||
{
|
{
|
||||||
struct sock *sk = sock->sk;
|
struct sock *sk = sock->sk;
|
||||||
struct unix_sock *u;
|
struct unix_sock *u;
|
||||||
struct sockaddr_un *sunaddr = (struct sockaddr_un *)uaddr;
|
DECLARE_SOCKADDR(struct sockaddr_un *, sunaddr, uaddr);
|
||||||
int err = 0;
|
int err = 0;
|
||||||
|
|
||||||
if (peer) {
|
if (peer) {
|
||||||
|
|
Загрузка…
Ссылка в новой задаче