Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1559106ybh; Tue, 14 Jul 2020 00:39:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxF4mft2zlzT5cWqo1jPjE931/CeICoxP/5lDX2B3ZvK115M1S3gU6OeVhbZw6GWyWggA3w X-Received: by 2002:aa7:cb55:: with SMTP id w21mr3281614edt.380.1594712397561; Tue, 14 Jul 2020 00:39:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594712397; cv=none; d=google.com; s=arc-20160816; b=iREpD2ZddDmzKm4Avo5hUYRBcVu76uMOcVCbL3923dH7LVM6gRVIqIBiAt3USjKRUH we9lZxhDZOMbFkTOWz9TvLYfhaYgMwD7MawKzlWOKGxwQsuDOKQLws6jW72itSyBKsm+ 7qpvpOr/GctH3ObDwP0ZmgC3+CnVDnMM8HQNH8h0oso5pCMToTzdnAKs7f7lytAH+ue+ DEmqQRZDUIDW18wfS6yIpKrgPHHPfbNH2K0aBYIsuUKagV4kpeu3JPSkH4w/dsGQMmFq 6AcNe0otLWguvB1OPv72WZ9WpaTYQKsch/1ZyYlx2+D742rEcIB2iYW7wipPgpAF4Zob ntLw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :ironport-sdr:dkim-signature; bh=aTJ4UP1t6cxtbDS/ByHK9hhnsfuIhTctLjt+77p++aM=; b=YAXJf2xLE3MIYyvGU8A16e/N6qlc1mhi0MriYQHZ+4yqWhdaL56VnvtpwFYZ0U80Yb iPatQ37ee/2/QaHr3o18VkWUrNcqsv0gPrNNWdCEppsaFlOaPJO00rZhWnGeKkCwztP9 8+5B1t9nNMGWdoAShNqc43CBeLsyO7w5MgXapZv/b+t3sQ6/nJXD2qAOZabrc7Jmc7LS q5HMPW+5vH1DDGhVBt+TUuO2L1VgzMEKCC9/DPAztL387arCxdYZlsUq6hXyjRJQ/0t/ WPMYuFEuRln39sonSegK5rW2tXf+BJvT2X38HQ4kt+C72HzwGynEJlrNIZb/hhUCTAJi ZmgQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@microchip.com header.s=mchp header.b=O4m5d0Qr; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=microchip.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f20si10613374edc.220.2020.07.14.00.39.34; Tue, 14 Jul 2020 00:39:57 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=fail header.i=@microchip.com header.s=mchp header.b=O4m5d0Qr; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=microchip.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726858AbgGNHjK (ORCPT + 99 others); Tue, 14 Jul 2020 03:39:10 -0400 Received: from esa6.microchip.iphmx.com ([216.71.154.253]:43769 "EHLO esa6.microchip.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726798AbgGNHjH (ORCPT ); Tue, 14 Jul 2020 03:39:07 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=microchip.com; i=@microchip.com; q=dns/txt; s=mchp; t=1594712347; x=1626248347; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=YrFb0GHYJSVnxx4wY0JWDfV+FNkiN88T+WCC0hZkD+w=; b=O4m5d0Qrep/3jNfVUS4twiftgbc39CenohG62dMbnR5VnQpofwS64Il+ Zm2ADpdRSpSHCKTptglYz5sLhFh7FPlsDr0i5dC6kIEizgYlwJW9eUY94 gno0+n1W9l1pMKpbQa11XeZqsnm0zParq1GiCJrlVoyJtNV8q/jXW68eG tHGSMbhm4aRhwslGWxZxrmvZpKmALe7o1GSliDSnSTQpFC5xiy0rLJS23 rBfT8LXsQjZf+OuF5tTPJazN3CNBHzvorE4NadjySJFnAfWcRPMS77Qek NqKlC0isf8nWmjg4l7kO9n+Htx6WiyHz4FkrPJ5OqPk+aYQ619gat5pYV A==; IronPort-SDR: hKuQK8OKMZDBTHjzL14a5XyCISg80tgk/QGVvzlPYPqgyMIMqj3kxWwBHvQ6jCgr4DSMWNRIeu Bw1Y9jNUHkZcQziG5GDmHkXNHLVElb8mKDkHc/N8Nb5zLkToiWhgzY5AvswlKeEg3NlOcu6vYt dSeqK/QBDnJPdFI3CJ6tUp1UJxMaRujG2TnFVlktOFiu/6i1gNVSUF1Nqq1XFbpds43c87ydW9 ekzuUm7PDlJg2HMAwtDsGtHU0WGK3n4VkihDxoo0WB9PeMaflsSx71wtpKIn8MztphuKB/XY4c 3UM= X-IronPort-AV: E=Sophos;i="5.75,350,1589266800"; d="scan'208";a="19099951" Received: from smtpout.microchip.com (HELO email.microchip.com) ([198.175.253.82]) by esa6.microchip.iphmx.com with ESMTP/TLS/AES256-SHA256; 14 Jul 2020 00:39:06 -0700 Received: from chn-vm-ex03.mchp-main.com (10.10.85.151) by chn-vm-ex04.mchp-main.com (10.10.85.152) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1979.3; Tue, 14 Jul 2020 00:39:06 -0700 Received: from soft-dev3.localdomain (10.10.115.15) by chn-vm-ex03.mchp-main.com (10.10.85.151) with Microsoft SMTP Server id 15.1.1979.3 via Frontend Transport; Tue, 14 Jul 2020 00:39:03 -0700 From: Horatiu Vultur To: , , , , , , , , , , CC: Horatiu Vultur Subject: [PATCH net-next v4 02/12] bridge: uapi: mrp: Extend MRP attributes for MRP interconnect Date: Tue, 14 Jul 2020 09:34:48 +0200 Message-ID: <20200714073458.1939574-3-horatiu.vultur@microchip.com> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200714073458.1939574-1-horatiu.vultur@microchip.com> References: <20200714073458.1939574-1-horatiu.vultur@microchip.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Extend the existing MRP netlink attributes to allow to configure MRP Interconnect: IFLA_BRIDGE_MRP_IN_ROLE - the parameter type is br_mrp_in_role which contains the interconnect id, the ring id, the interconnect role(MIM or MIC) and the port ifindex that represents the interconnect port. IFLA_BRIDGE_MRP_IN_STATE - the parameter type is br_mrp_in_state which contains the interconnect id and the interconnect state. IFLA_BRIDGE_MRP_IN_TEST - the parameter type is br_mrp_start_in_test which contains the interconnect id, the interval at which to send MRP_InTest frames, how many test frames can be missed before declaring the interconnect ring open and the period which represents for how long to send MRP_InTest frames. Signed-off-by: Horatiu Vultur --- include/uapi/linux/if_bridge.h | 53 +++++++++++++++++++++++++++++++++ include/uapi/linux/mrp_bridge.h | 38 +++++++++++++++++++++++ 2 files changed, 91 insertions(+) diff --git a/include/uapi/linux/if_bridge.h b/include/uapi/linux/if_bridge.h index c114c1c2bd533..d840a3e37a37c 100644 --- a/include/uapi/linux/if_bridge.h +++ b/include/uapi/linux/if_bridge.h @@ -167,6 +167,9 @@ enum { IFLA_BRIDGE_MRP_RING_ROLE, IFLA_BRIDGE_MRP_START_TEST, IFLA_BRIDGE_MRP_INFO, + IFLA_BRIDGE_MRP_IN_ROLE, + IFLA_BRIDGE_MRP_IN_STATE, + IFLA_BRIDGE_MRP_START_IN_TEST, __IFLA_BRIDGE_MRP_MAX, }; @@ -245,6 +248,37 @@ enum { #define IFLA_BRIDGE_MRP_INFO_MAX (__IFLA_BRIDGE_MRP_INFO_MAX - 1) +enum { + IFLA_BRIDGE_MRP_IN_STATE_UNSPEC, + IFLA_BRIDGE_MRP_IN_STATE_IN_ID, + IFLA_BRIDGE_MRP_IN_STATE_STATE, + __IFLA_BRIDGE_MRP_IN_STATE_MAX, +}; + +#define IFLA_BRIDGE_MRP_IN_STATE_MAX (__IFLA_BRIDGE_MRP_IN_STATE_MAX - 1) + +enum { + IFLA_BRIDGE_MRP_IN_ROLE_UNSPEC, + IFLA_BRIDGE_MRP_IN_ROLE_RING_ID, + IFLA_BRIDGE_MRP_IN_ROLE_IN_ID, + IFLA_BRIDGE_MRP_IN_ROLE_ROLE, + IFLA_BRIDGE_MRP_IN_ROLE_I_IFINDEX, + __IFLA_BRIDGE_MRP_IN_ROLE_MAX, +}; + +#define IFLA_BRIDGE_MRP_IN_ROLE_MAX (__IFLA_BRIDGE_MRP_IN_ROLE_MAX - 1) + +enum { + IFLA_BRIDGE_MRP_START_IN_TEST_UNSPEC, + IFLA_BRIDGE_MRP_START_IN_TEST_IN_ID, + IFLA_BRIDGE_MRP_START_IN_TEST_INTERVAL, + IFLA_BRIDGE_MRP_START_IN_TEST_MAX_MISS, + IFLA_BRIDGE_MRP_START_IN_TEST_PERIOD, + __IFLA_BRIDGE_MRP_START_IN_TEST_MAX, +}; + +#define IFLA_BRIDGE_MRP_START_IN_TEST_MAX (__IFLA_BRIDGE_MRP_START_IN_TEST_MAX - 1) + struct br_mrp_instance { __u32 ring_id; __u32 p_ifindex; @@ -270,6 +304,25 @@ struct br_mrp_start_test { __u32 monitor; }; +struct br_mrp_in_state { + __u32 in_state; + __u16 in_id; +}; + +struct br_mrp_in_role { + __u32 ring_id; + __u32 in_role; + __u32 i_ifindex; + __u16 in_id; +}; + +struct br_mrp_start_in_test { + __u32 interval; + __u32 max_miss; + __u32 period; + __u16 in_id; +}; + struct bridge_stp_xstats { __u64 transition_blk; __u64 transition_fwd; diff --git a/include/uapi/linux/mrp_bridge.h b/include/uapi/linux/mrp_bridge.h index bee3665402129..6aeb13ef0b1ec 100644 --- a/include/uapi/linux/mrp_bridge.h +++ b/include/uapi/linux/mrp_bridge.h @@ -21,11 +21,22 @@ enum br_mrp_ring_role_type { BR_MRP_RING_ROLE_MRA, }; +enum br_mrp_in_role_type { + BR_MRP_IN_ROLE_DISABLED, + BR_MRP_IN_ROLE_MIC, + BR_MRP_IN_ROLE_MIM, +}; + enum br_mrp_ring_state_type { BR_MRP_RING_STATE_OPEN, BR_MRP_RING_STATE_CLOSED, }; +enum br_mrp_in_state_type { + BR_MRP_IN_STATE_OPEN, + BR_MRP_IN_STATE_CLOSED, +}; + enum br_mrp_port_state_type { BR_MRP_PORT_STATE_DISABLED, BR_MRP_PORT_STATE_BLOCKED, @@ -36,6 +47,7 @@ enum br_mrp_port_state_type { enum br_mrp_port_role_type { BR_MRP_PORT_ROLE_PRIMARY, BR_MRP_PORT_ROLE_SECONDARY, + BR_MRP_PORT_ROLE_INTER, }; enum br_mrp_tlv_header_type { @@ -45,6 +57,10 @@ enum br_mrp_tlv_header_type { BR_MRP_TLV_HEADER_RING_TOPO = 0x3, BR_MRP_TLV_HEADER_RING_LINK_DOWN = 0x4, BR_MRP_TLV_HEADER_RING_LINK_UP = 0x5, + BR_MRP_TLV_HEADER_IN_TEST = 0x6, + BR_MRP_TLV_HEADER_IN_TOPO = 0x7, + BR_MRP_TLV_HEADER_IN_LINK_DOWN = 0x8, + BR_MRP_TLV_HEADER_IN_LINK_UP = 0x9, BR_MRP_TLV_HEADER_OPTION = 0x7f, }; @@ -118,4 +134,26 @@ struct br_mrp_oui_hdr { __u8 oui[MRP_OUI_LENGTH]; }; +struct br_mrp_in_test_hdr { + __be16 id; + __u8 sa[ETH_ALEN]; + __be16 port_role; + __be16 state; + __be16 transitions; + __be32 timestamp; +}; + +struct br_mrp_in_topo_hdr { + __u8 sa[ETH_ALEN]; + __be16 id; + __be16 interval; +}; + +struct br_mrp_in_link_hdr { + __u8 sa[ETH_ALEN]; + __be16 port_role; + __be16 id; + __be16 interval; +}; + #endif -- 2.27.0