linux/drivers/net/wan
Xie He 59e6db9d27 drivers/net/wan/hdlc_fr: Correctly handle special skb->protocol values
[ Upstream commit 8306266c1d ]

The fr_hard_header function is used to prepend the header to skbs before
transmission. It is used in 3 situations:
1) When a control packet is generated internally in this driver;
2) When a user sends an skb on an Ethernet-emulating PVC device;
3) When a user sends an skb on a normal PVC device.

These 3 situations need to be handled differently by fr_hard_header.
Different headers should be prepended to the skb in different situations.

Currently fr_hard_header distinguishes these 3 situations using
skb->protocol. For situation 1 and 2, a special skb->protocol value
will be assigned before calling fr_hard_header, so that it can recognize
these 2 situations. All skb->protocol values other than these special ones
are treated by fr_hard_header as situation 3.

However, it is possible that in situation 3, the user sends an skb with
one of the special skb->protocol values. In this case, fr_hard_header
would incorrectly treat it as situation 1 or 2.

This patch tries to solve this issue by using skb->dev instead of
skb->protocol to distinguish between these 3 situations. For situation
1, skb->dev would be NULL; for situation 2, skb->dev->type would be
ARPHRD_ETHER; and for situation 3, skb->dev->type would be ARPHRD_DLCI.

This way fr_hard_header would be able to distinguish these 3 situations
correctly regardless what skb->protocol value the user tries to use in
situation 3.

Cc: Krzysztof Halasa <khc@pm.waw.pl>
Signed-off-by: Xie He <xie.he.0141@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2020-11-05 11:08:43 +01:00
..
lmc
.gitignore
c101.c
cosa.c
cosa.h
dlci.c
dscc4.c
farsync.c
farsync.h
fsl_ucc_hdlc.c net/wan/fsl_ucc_hdlc: reject muram offsets above 64K 2020-02-24 08:34:40 +01:00
fsl_ucc_hdlc.h
hd64570.c
hd64570.h
hd64572.c
hd64572.h
hdlc_cisco.c drivers/net/wan/hdlc: Set skb->protocol before transmitting 2020-10-07 08:00:06 +02:00
hdlc_fr.c drivers/net/wan/hdlc_fr: Correctly handle special skb->protocol values 2020-11-05 11:08:43 +01:00
hdlc_ppp.c drivers/net/wan/hdlc: Set skb->protocol before transmitting 2020-10-07 08:00:06 +02:00
hdlc_raw_eth.c net: hdlc_raw_eth: Clear the IFF_TX_SKB_SHARING flag after calling ether_setup 2020-10-29 09:54:57 +01:00
hdlc_raw.c
hdlc_x25.c
hdlc.c net: hdlc: In hdlc_rcv, check to make sure dev is an HDLC device 2020-10-29 09:54:57 +01:00
hostess_sv11.c
ixp4xx_hss.c wan: ixp4xx_hss: fix compile-testing on 64-bit 2020-02-24 08:34:46 +01:00
Kconfig net: wan: wanxl: use allow to pass CROSS_COMPILE_M68k for rebuilding firmware 2020-09-26 18:01:31 +02:00
lapbether.c drivers/net/wan/lapbether: Make skb->protocol consistent with the header 2020-10-07 08:00:06 +02:00
Makefile net: wan: wanxl: use $(M68KCC) instead of $(M68KAS) for rebuilding firmware 2020-09-26 18:01:31 +02:00
n2.c
pc300too.c
pci200syn.c
sbni.c
sbni.h
sdla.c net: wan: sdla: Fix cast from pointer to integer of different size 2020-02-01 09:37:08 +00:00
sealevel.c
slic_ds26522.c
slic_ds26522.h
wanxl.c
wanxl.h
wanxlfw.inc_shipped
wanxlfw.S
x25_asy.c drivers/net/wan/x25_asy: Fix to make it work 2020-07-31 18:37:47 +02:00
x25_asy.h
z85230.c
z85230.h