Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 90aa7993 authored by WANG Cong's avatar WANG Cong Committed by Greg Kroah-Hartman
Browse files

kcm: fix a null pointer dereference in kcm_sendmsg()



[ Upstream commit cd27b96bc13841ee7af25837a6ae86fee87273d6 ]

In commit 98e3862ca2b1 ("kcm: fix 0-length case for kcm_sendmsg()")
I tried to avoid skb allocation for 0-length case, but missed
a check for NULL pointer in the non EOR case.

Fixes: 98e3862ca2b1 ("kcm: fix 0-length case for kcm_sendmsg()")
Reported-by: default avatarDmitry Vyukov <dvyukov@google.com>
Cc: Tom Herbert <tom@herbertland.com>
Signed-off-by: default avatarCong Wang <xiyou.wangcong@gmail.com>
Acked-by: default avatarTom Herbert <tom@herbertland.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 14099354
Loading
Loading
Loading
Loading
+4 −2
Original line number Original line Diff line number Diff line
@@ -1044,9 +1044,11 @@ static int kcm_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)
	} else {
	} else {
		/* Message not complete, save state */
		/* Message not complete, save state */
partial_message:
partial_message:
		if (head) {
			kcm->seq_skb = head;
			kcm->seq_skb = head;
			kcm_tx_msg(head)->last_skb = skb;
			kcm_tx_msg(head)->last_skb = skb;
		}
		}
	}


	KCM_STATS_ADD(kcm->stats.tx_bytes, copied);
	KCM_STATS_ADD(kcm->stats.tx_bytes, copied);