diff options
author | Petr Machata <petrm@mellanox.com> | 2019-07-29 20:26:14 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2019-07-29 22:55:05 +0200 |
commit | c6b36bdd04b5c22b2705f7ae561d4f3b4d8a0ac3 (patch) | |
tree | 7fd2b3791d13981164a268fcf7c64c36ce70b81f /net/sctp/socket.c | |
parent | net: spider_net: Mark expected switch fall-through (diff) | |
download | linux-c6b36bdd04b5c22b2705f7ae561d4f3b4d8a0ac3.tar.xz linux-c6b36bdd04b5c22b2705f7ae561d4f3b4d8a0ac3.zip |
mlxsw: spectrum_ptp: Increase parsing depth when PTP is enabled
Spectrum systems have a configurable limit on how far into the packet they
parse. By default, the limit is 96 bytes.
An IPv6 PTP packet is layered as Ethernet/IPv6/UDP (14+40+8 bytes), and
sequence ID of a PTP event is only available 32 bytes into payload, for a
total of 94 bytes. When an additional 802.1q header is present as
well (such as when ptp4l is running on a VLAN port), the parsing limit is
exceeded. Such packets are not recognized as PTP, and are not timestamped.
Therefore generalize the current VXLAN-specific parsing depth setting to
allow reference-counted requests from other modules as well. Keep it in the
VXLAN module, because the MPRS register also configures UDP destination
port number used for VXLAN, and is thus closely tied to the VXLAN code
anyway.
Then invoke the new interfaces from both VXLAN (in obvious places), as well
as from PTP code, when the (global) timestamping configuration changes from
disabled to enabled or vice versa.
Fixes: 8748642751ed ("mlxsw: spectrum: PTP: Support SIOCGHWTSTAMP, SIOCSHWTSTAMP ioctls")
Signed-off-by: Petr Machata <petrm@mellanox.com>
Reviewed-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sctp/socket.c')
0 files changed, 0 insertions, 0 deletions