IFLA_BRIDGE_MODE,
        IFLA_BRIDGE_VLAN_INFO,
        IFLA_BRIDGE_VLAN_TUNNEL_INFO,
+       IFLA_BRIDGE_MRP,
        __IFLA_BRIDGE_MAX,
 };
 #define IFLA_BRIDGE_MAX (__IFLA_BRIDGE_MAX - 1)
        __u32 pad2;
 };
 
+enum {
+       IFLA_BRIDGE_MRP_UNSPEC,
+       IFLA_BRIDGE_MRP_INSTANCE,
+       IFLA_BRIDGE_MRP_PORT_STATE,
+       IFLA_BRIDGE_MRP_PORT_ROLE,
+       IFLA_BRIDGE_MRP_RING_STATE,
+       IFLA_BRIDGE_MRP_RING_ROLE,
+       IFLA_BRIDGE_MRP_START_TEST,
+       __IFLA_BRIDGE_MRP_MAX,
+};
+
+struct br_mrp_instance {
+       __u32 ring_id;
+       __u32 p_ifindex;
+       __u32 s_ifindex;
+};
+
+struct br_mrp_port_role {
+       __u32 ring_id;
+       __u32 role;
+};
+
+struct br_mrp_ring_state {
+       __u32 ring_id;
+       __u32 ring_state;
+};
+
+struct br_mrp_ring_role {
+       __u32 ring_id;
+       __u32 ring_role;
+};
+
+struct br_mrp_start_test {
+       __u32 ring_id;
+       __u32 interval;
+       __u32 max_miss;
+       __u32 period;
+};
+
+#define IFLA_BRIDGE_MRP_MAX (__IFLA_BRIDGE_MRP_MAX - 1)
+
 struct bridge_stp_xstats {
        __u64 transition_blk;
        __u64 transition_fwd;
 
--- /dev/null
+/* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
+
+#ifndef _UAPI_LINUX_MRP_BRIDGE_H_
+#define _UAPI_LINUX_MRP_BRIDGE_H_
+
+#include <linux/types.h>
+#include <linux/if_ether.h>
+
+#define MRP_MAX_FRAME_LENGTH           200
+#define MRP_DEFAULT_PRIO               0x8000
+#define MRP_DOMAIN_UUID_LENGTH         16
+#define MRP_VERSION                    1
+#define MRP_FRAME_PRIO                 7
+
+enum br_mrp_ring_role_type {
+       BR_MRP_RING_ROLE_DISABLED,
+       BR_MRP_RING_ROLE_MRC,
+       BR_MRP_RING_ROLE_MRM,
+};
+
+enum br_mrp_ring_state_type {
+       BR_MRP_RING_STATE_OPEN,
+       BR_MRP_RING_STATE_CLOSED,
+};
+
+enum br_mrp_port_state_type {
+       BR_MRP_PORT_STATE_DISABLED,
+       BR_MRP_PORT_STATE_BLOCKED,
+       BR_MRP_PORT_STATE_FORWARDING,
+       BR_MRP_PORT_STATE_NOT_CONNECTED,
+};
+
+enum br_mrp_port_role_type {
+       BR_MRP_PORT_ROLE_PRIMARY,
+       BR_MRP_PORT_ROLE_SECONDARY,
+       BR_MRP_PORT_ROLE_NONE,
+};
+
+enum br_mrp_tlv_header_type {
+       BR_MRP_TLV_HEADER_END = 0x0,
+       BR_MRP_TLV_HEADER_COMMON = 0x1,
+       BR_MRP_TLV_HEADER_RING_TEST = 0x2,
+       BR_MRP_TLV_HEADER_RING_TOPO = 0x3,
+       BR_MRP_TLV_HEADER_RING_LINK_DOWN = 0x4,
+       BR_MRP_TLV_HEADER_RING_LINK_UP = 0x5,
+};
+
+struct br_mrp_tlv_hdr {
+       __u8 type;
+       __u8 length;
+};
+
+struct br_mrp_end_hdr {
+       struct br_mrp_tlv_hdr hdr;
+};
+
+struct br_mrp_common_hdr {
+       __u16 seq_id;
+       __u8 domain[MRP_DOMAIN_UUID_LENGTH];
+};
+
+struct br_mrp_ring_test_hdr {
+       __u16 prio;
+       __u8 sa[ETH_ALEN];
+       __u16 port_role;
+       __u16 state;
+       __u16 transitions;
+       __u32 timestamp;
+};
+
+struct br_mrp_ring_topo_hdr {
+       __u16 prio;
+       __u8 sa[ETH_ALEN];
+       __u16 interval;
+};
+
+struct br_mrp_ring_link_hdr {
+       __u8 sa[ETH_ALEN];
+       __u16 port_role;
+       __u16 interval;
+       __u16 blocked;
+};
+
+#endif