|  | /* SPDX-License-Identifier: GPL-2.0-or-later */ | 
|  |  | 
|  | #ifndef _BR_PRIVATE_MRP_H_ | 
|  | #define _BR_PRIVATE_MRP_H_ | 
|  |  | 
|  | #include "br_private.h" | 
|  | #include <uapi/linux/mrp_bridge.h> | 
|  |  | 
|  | #define MRP_OPT_PADDING		0x2 | 
|  |  | 
|  | struct br_mrp { | 
|  | /* list of mrp instances */ | 
|  | struct hlist_node		list; | 
|  |  | 
|  | struct net_bridge_port __rcu	*p_port; | 
|  | struct net_bridge_port __rcu	*s_port; | 
|  | struct net_bridge_port __rcu	*i_port; | 
|  |  | 
|  | u32				ring_id; | 
|  | u16				in_id; | 
|  | u16				prio; | 
|  |  | 
|  | enum br_mrp_ring_role_type	ring_role; | 
|  | u8				ring_role_offloaded; | 
|  | enum br_mrp_ring_state_type	ring_state; | 
|  | u32				ring_transitions; | 
|  |  | 
|  | enum br_mrp_in_role_type	in_role; | 
|  | u8				in_role_offloaded; | 
|  | enum br_mrp_in_state_type	in_state; | 
|  | u32				in_transitions; | 
|  |  | 
|  | struct delayed_work		test_work; | 
|  | u32				test_interval; | 
|  | unsigned long			test_end; | 
|  | u32				test_count_miss; | 
|  | u32				test_max_miss; | 
|  | bool				test_monitor; | 
|  |  | 
|  | struct delayed_work		in_test_work; | 
|  | u32				in_test_interval; | 
|  | unsigned long			in_test_end; | 
|  | u32				in_test_count_miss; | 
|  | u32				in_test_max_miss; | 
|  |  | 
|  | u32				seq_id; | 
|  |  | 
|  | struct rcu_head			rcu; | 
|  | }; | 
|  |  | 
|  | /* This type is returned by br_mrp_switchdev functions that allow to have a SW | 
|  | * backup in case the HW can't implement completely the protocol. | 
|  | * BR_MRP_NONE - means the HW can't run at all the protocol, so the SW stops | 
|  | *               configuring the node anymore. | 
|  | * BR_MRP_SW - the HW can help the SW to run the protocol, by redirecting MRP | 
|  | *             frames to CPU. | 
|  | * BR_MRP_HW - the HW can implement completely the protocol. | 
|  | */ | 
|  | enum br_mrp_hw_support { | 
|  | BR_MRP_NONE, | 
|  | BR_MRP_SW, | 
|  | BR_MRP_HW, | 
|  | }; | 
|  |  | 
|  | /* br_mrp.c */ | 
|  | int br_mrp_add(struct net_bridge *br, struct br_mrp_instance *instance); | 
|  | int br_mrp_del(struct net_bridge *br, struct br_mrp_instance *instance); | 
|  | int br_mrp_set_port_state(struct net_bridge_port *p, | 
|  | enum br_mrp_port_state_type state); | 
|  | int br_mrp_set_port_role(struct net_bridge_port *p, | 
|  | enum br_mrp_port_role_type role); | 
|  | int br_mrp_set_ring_state(struct net_bridge *br, | 
|  | struct br_mrp_ring_state *state); | 
|  | int br_mrp_set_ring_role(struct net_bridge *br, struct br_mrp_ring_role *role); | 
|  | int br_mrp_start_test(struct net_bridge *br, struct br_mrp_start_test *test); | 
|  | int br_mrp_set_in_state(struct net_bridge *br, struct br_mrp_in_state *state); | 
|  | int br_mrp_set_in_role(struct net_bridge *br, struct br_mrp_in_role *role); | 
|  | int br_mrp_start_in_test(struct net_bridge *br, | 
|  | struct br_mrp_start_in_test *test); | 
|  |  | 
|  | /* br_mrp_switchdev.c */ | 
|  | int br_mrp_switchdev_add(struct net_bridge *br, struct br_mrp *mrp); | 
|  | int br_mrp_switchdev_del(struct net_bridge *br, struct br_mrp *mrp); | 
|  | enum br_mrp_hw_support | 
|  | br_mrp_switchdev_set_ring_role(struct net_bridge *br, struct br_mrp *mrp, | 
|  | enum br_mrp_ring_role_type role); | 
|  | int br_mrp_switchdev_set_ring_state(struct net_bridge *br, struct br_mrp *mrp, | 
|  | enum br_mrp_ring_state_type state); | 
|  | enum br_mrp_hw_support | 
|  | br_mrp_switchdev_send_ring_test(struct net_bridge *br, struct br_mrp *mrp, | 
|  | u32 interval, u8 max_miss, u32 period, | 
|  | bool monitor); | 
|  | int br_mrp_port_switchdev_set_state(struct net_bridge_port *p, u32 state); | 
|  | int br_mrp_port_switchdev_set_role(struct net_bridge_port *p, | 
|  | enum br_mrp_port_role_type role); | 
|  | enum br_mrp_hw_support | 
|  | br_mrp_switchdev_set_in_role(struct net_bridge *br, struct br_mrp *mrp, | 
|  | u16 in_id, u32 ring_id, | 
|  | enum br_mrp_in_role_type role); | 
|  | int br_mrp_switchdev_set_in_state(struct net_bridge *br, struct br_mrp *mrp, | 
|  | enum br_mrp_in_state_type state); | 
|  | enum br_mrp_hw_support | 
|  | br_mrp_switchdev_send_in_test(struct net_bridge *br, struct br_mrp *mrp, | 
|  | u32 interval, u8 max_miss, u32 period); | 
|  |  | 
|  | /* br_mrp_netlink.c  */ | 
|  | int br_mrp_ring_port_open(struct net_device *dev, u8 loc); | 
|  | int br_mrp_in_port_open(struct net_device *dev, u8 loc); | 
|  |  | 
|  | /* MRP protocol data units */ | 
|  | struct br_mrp_tlv_hdr { | 
|  | __u8 type; | 
|  | __u8 length; | 
|  | }; | 
|  |  | 
|  | struct br_mrp_common_hdr { | 
|  | __be16 seq_id; | 
|  | __u8 domain[MRP_DOMAIN_UUID_LENGTH]; | 
|  | }; | 
|  |  | 
|  | struct br_mrp_ring_test_hdr { | 
|  | __be16 prio; | 
|  | __u8 sa[ETH_ALEN]; | 
|  | __be16 port_role; | 
|  | __be16 state; | 
|  | __be16 transitions; | 
|  | __be32 timestamp; | 
|  | } __attribute__((__packed__)); | 
|  |  | 
|  | struct br_mrp_in_test_hdr { | 
|  | __be16 id; | 
|  | __u8 sa[ETH_ALEN]; | 
|  | __be16 port_role; | 
|  | __be16 state; | 
|  | __be16 transitions; | 
|  | __be32 timestamp; | 
|  | } __attribute__((__packed__)); | 
|  |  | 
|  | struct br_mrp_oui_hdr { | 
|  | __u8 oui[MRP_OUI_LENGTH]; | 
|  | }; | 
|  |  | 
|  | struct br_mrp_sub_option1_hdr { | 
|  | __u8 type; | 
|  | __u8 data[MRP_MANUFACTURE_DATA_LENGTH]; | 
|  | }; | 
|  |  | 
|  | #endif /* _BR_PRIVATE_MRP_H */ |