net: hdlc: In hdlc_rcv, check to make sure dev is an HDLC device
authorXie He <xie.he.0141@gmail.com>
Tue, 20 Oct 2020 01:31:52 +0000 (18:31 -0700)
committerJakub Kicinski <kuba@kernel.org>
Thu, 22 Oct 2020 00:20:19 +0000 (17:20 -0700)
commit01c4ceae0a38a0bdbfea6896f41efcd985a9c064
tree59b4c38e72b80fce49d910627cfbe92001ff494a
parent0ed37ac586c01fd5bf3f7559de79f1d621ccf192
net: hdlc: In hdlc_rcv, check to make sure dev is an HDLC device

The hdlc_rcv function is used as hdlc_packet_type.func to process any
skb received in the kernel with skb->protocol == htons(ETH_P_HDLC).
The purpose of this function is to provide second-stage processing for
skbs not assigned a "real" L3 skb->protocol value in the first stage.

This function assumes the device from which the skb is received is an
HDLC device (a device created by this module). It assumes that
netdev_priv(dev) returns a pointer to "struct hdlc_device".

However, it is possible that some driver in the kernel (not necessarily
in our control) submits a received skb with skb->protocol ==
htons(ETH_P_HDLC), from a non-HDLC device. In this case, the skb would
still be received by hdlc_rcv. This will cause problems.

hdlc_rcv should be able to recognize and drop invalid skbs. It should
first make sure "dev" is actually an HDLC device, before starting its
processing. This patch adds this check to hdlc_rcv.

Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2")
Cc: Krzysztof Halasa <khc@pm.waw.pl>
Signed-off-by: Xie He <xie.he.0141@gmail.com>
Link: https://lore.kernel.org/r/20201020013152.89259-1-xie.he.0141@gmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/wan/hdlc.c