diff options
Diffstat (limited to 'net/sctp/socket.c')
| -rw-r--r-- | net/sctp/socket.c | 12 | 
1 files changed, 10 insertions, 2 deletions
diff --git a/net/sctp/socket.c b/net/sctp/socket.c index e34ca9cc116..0b9ee34ad35 100644 --- a/net/sctp/socket.c +++ b/net/sctp/socket.c @@ -111,12 +111,12 @@ static void sctp_sock_migrate(struct sock *, struct sock *,  static char *sctp_hmac_alg = SCTP_COOKIE_HMAC_ALG;  extern struct kmem_cache *sctp_bucket_cachep; -extern int sysctl_sctp_mem[3]; +extern long sysctl_sctp_mem[3];  extern int sysctl_sctp_rmem[3];  extern int sysctl_sctp_wmem[3];  static int sctp_memory_pressure; -static atomic_t sctp_memory_allocated; +static atomic_long_t sctp_memory_allocated;  struct percpu_counter sctp_sockets_allocated;  static void sctp_enter_memory_pressure(struct sock *sk) @@ -2932,6 +2932,7 @@ static int sctp_setsockopt_peer_primary_addr(struct sock *sk, char __user *optva  	struct sctp_association	*asoc = NULL;  	struct sctp_setpeerprim	prim;  	struct sctp_chunk	*chunk; +	struct sctp_af		*af;  	int 			err;  	sp = sctp_sk(sk); @@ -2959,6 +2960,13 @@ static int sctp_setsockopt_peer_primary_addr(struct sock *sk, char __user *optva  	if (!sctp_state(asoc, ESTABLISHED))  		return -ENOTCONN; +	af = sctp_get_af_specific(prim.sspp_addr.ss_family); +	if (!af) +		return -EINVAL; + +	if (!af->addr_valid((union sctp_addr *)&prim.sspp_addr, sp, NULL)) +		return -EADDRNOTAVAIL; +  	if (!sctp_assoc_lookup_laddr(asoc, (union sctp_addr *)&prim.sspp_addr))  		return -EADDRNOTAVAIL;  |