diff options
Diffstat (limited to 'net/core/neighbour.c')
| -rw-r--r-- | net/core/neighbour.c | 20 | 
1 files changed, 10 insertions, 10 deletions
| diff --git a/net/core/neighbour.c b/net/core/neighbour.c index a07249b59ae1..49dce9a82295 100644 --- a/net/core/neighbour.c +++ b/net/core/neighbour.c @@ -1031,7 +1031,7 @@ static void neigh_probe(struct neighbour *neigh)  static void neigh_timer_handler(struct timer_list *t)  {  	unsigned long now, next; -	struct neighbour *neigh = from_timer(neigh, t, timer); +	struct neighbour *neigh = timer_container_of(neigh, t, timer);  	unsigned int state;  	int notify = 0; @@ -1517,7 +1517,7 @@ out:  	return rc;  out_kfree_skb:  	rc = -EINVAL; -	kfree_skb(skb); +	kfree_skb_reason(skb, SKB_DROP_REASON_NEIGH_HH_FILLFAIL);  	goto out;  }  EXPORT_SYMBOL(neigh_resolve_output); @@ -1541,7 +1541,7 @@ int neigh_connected_output(struct neighbour *neigh, struct sk_buff *skb)  		err = dev_queue_xmit(skb);  	else {  		err = -EINVAL; -		kfree_skb(skb); +		kfree_skb_reason(skb, SKB_DROP_REASON_NEIGH_HH_FILLFAIL);  	}  	return err;  } @@ -1569,7 +1569,7 @@ static void neigh_managed_work(struct work_struct *work)  static void neigh_proxy_process(struct timer_list *t)  { -	struct neigh_table *tbl = from_timer(tbl, t, proxy_timer); +	struct neigh_table *tbl = timer_container_of(tbl, t, proxy_timer);  	long sched_next = 0;  	unsigned long now = jiffies;  	struct sk_buff *skb, *n; @@ -2430,12 +2430,12 @@ static int neightbl_valid_dump_info(const struct nlmsghdr *nlh,  {  	struct ndtmsg *ndtm; -	if (nlh->nlmsg_len < nlmsg_msg_size(sizeof(*ndtm))) { +	ndtm = nlmsg_payload(nlh, sizeof(*ndtm)); +	if (!ndtm) {  		NL_SET_ERR_MSG(extack, "Invalid header for neighbor table dump request");  		return -EINVAL;  	} -	ndtm = nlmsg_data(nlh);  	if (ndtm->ndtm_pad1  || ndtm->ndtm_pad2) {  		NL_SET_ERR_MSG(extack, "Invalid values in header for neighbor table dump request");  		return -EINVAL; @@ -2747,12 +2747,12 @@ static int neigh_valid_dump_req(const struct nlmsghdr *nlh,  	if (strict_check) {  		struct ndmsg *ndm; -		if (nlh->nlmsg_len < nlmsg_msg_size(sizeof(*ndm))) { +		ndm = nlmsg_payload(nlh, sizeof(*ndm)); +		if (!ndm) {  			NL_SET_ERR_MSG(extack, "Invalid header for neighbor dump request");  			return -EINVAL;  		} -		ndm = nlmsg_data(nlh);  		if (ndm->ndm_pad1  || ndm->ndm_pad2  || ndm->ndm_ifindex ||  		    ndm->ndm_state || ndm->ndm_type) {  			NL_SET_ERR_MSG(extack, "Invalid values in header for neighbor dump request"); @@ -2855,12 +2855,12 @@ static int neigh_valid_get_req(const struct nlmsghdr *nlh,  	struct ndmsg *ndm;  	int err, i; -	if (nlh->nlmsg_len < nlmsg_msg_size(sizeof(*ndm))) { +	ndm = nlmsg_payload(nlh, sizeof(*ndm)); +	if (!ndm) {  		NL_SET_ERR_MSG(extack, "Invalid header for neighbor get request");  		return -EINVAL;  	} -	ndm = nlmsg_data(nlh);  	if (ndm->ndm_pad1  || ndm->ndm_pad2  || ndm->ndm_state ||  	    ndm->ndm_type) {  		NL_SET_ERR_MSG(extack, "Invalid values in header for neighbor get request"); | 
