Commit f614e536 authored by Louis Peens's avatar Louis Peens Committed by David S. Miller

nfp: flower: fix ABI mismatch between driver and firmware

Fix an issue where the driver wrongly detected ipv6 neighbour updates
from the NFP as corrupt. Add a reserved field on the kernel side so
it is similar to the ipv4 version of the struct and has space for the
extra bytes from the card.

Fixes: 9ea9bfa1 ("nfp: flower: support ipv6 tunnel keep-alive messages from fw")
Signed-off-by: default avatarLouis Peens <louis.peens@netronome.com>
Signed-off-by: default avatarSimon Horman <simon.horman@netronome.com>
Acked-by: default avatarJakub Kicinski <kuba@kernel.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 2a63866c
...@@ -61,6 +61,7 @@ struct nfp_tun_active_tuns { ...@@ -61,6 +61,7 @@ struct nfp_tun_active_tuns {
* @flags: options part of the request * @flags: options part of the request
* @tun_info.ipv6: dest IPv6 address of active route * @tun_info.ipv6: dest IPv6 address of active route
* @tun_info.egress_port: port the encapsulated packet egressed * @tun_info.egress_port: port the encapsulated packet egressed
* @tun_info.extra: reserved for future use
* @tun_info: tunnels that have sent traffic in reported period * @tun_info: tunnels that have sent traffic in reported period
*/ */
struct nfp_tun_active_tuns_v6 { struct nfp_tun_active_tuns_v6 {
...@@ -70,6 +71,7 @@ struct nfp_tun_active_tuns_v6 { ...@@ -70,6 +71,7 @@ struct nfp_tun_active_tuns_v6 {
struct route_ip_info_v6 { struct route_ip_info_v6 {
struct in6_addr ipv6; struct in6_addr ipv6;
__be32 egress_port; __be32 egress_port;
__be32 extra[2];
} tun_info[]; } tun_info[];
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment