From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from firstgate.proxmox.com (firstgate.proxmox.com [212.224.123.68]) by lore.proxmox.com (Postfix) with ESMTPS id 1A0C01FF183 for ; Wed, 16 Jul 2025 15:08:25 +0200 (CEST) Received: from firstgate.proxmox.com (localhost [127.0.0.1]) by firstgate.proxmox.com (Proxmox) with ESMTP id 9CD1BF91F; Wed, 16 Jul 2025 15:08:53 +0200 (CEST) From: Gabriel Goller To: pve-devel@lists.proxmox.com Date: Wed, 16 Jul 2025 15:07:31 +0200 Message-Id: <20250716130837.585796-11-g.goller@proxmox.com> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250716130837.585796-1-g.goller@proxmox.com> References: <20250716130837.585796-1-g.goller@proxmox.com> MIME-Version: 1.0 X-SPAM-LEVEL: Spam detection results: 0 AWL -0.014 Adjusted score from AWL reputation of From: address BAYES_00 -1.9 Bayes spam probability is 0 to 1% DMARC_MISSING 0.1 Missing DMARC policy KAM_DMARC_STATUS 0.01 Test Rule for DKIM or SPF Failure with Strict Alignment RCVD_IN_MSPIKE_H2 0.001 Average reputation (+2) SPF_HELO_NONE 0.001 SPF: HELO does not publish an SPF Record SPF_PASS -0.001 SPF: sender matches SPF record Subject: [pve-devel] [PATCH proxmox-ve-rs v5 05/22] frr: add openfabric types X-BeenThere: pve-devel@lists.proxmox.com X-Mailman-Version: 2.1.29 Precedence: list List-Id: Proxmox VE development discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-To: Proxmox VE development discussion Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: pve-devel-bounces@lists.proxmox.com Sender: "pve-devel" Implement OpenFabric-specific variants of common enums that encapsulate protocol properties defined in proxmox-network-types. The primary addition is OpenFabricInterface, which stores protocol-specific timing parameters: HelloInterval (neighbor discovery frequency), CsnpInterval (database synchronization frequency), and HelloMultiplier (neighbor failure detection). Added `is_ipv6` flag to support FRR's command prefixing requirements during serialization for IPv6-specific commands (we need to add a 'ipv6' prefix to some commands). Signed-off-by: Gabriel Goller --- proxmox-frr/src/lib.rs | 1 + proxmox-frr/src/openfabric.rs | 88 +++++++++++++++++++++++++++++++++++ 2 files changed, 89 insertions(+) create mode 100644 proxmox-frr/src/openfabric.rs diff --git a/proxmox-frr/src/lib.rs b/proxmox-frr/src/lib.rs index 3a66fea63e63..42c602663226 100644 --- a/proxmox-frr/src/lib.rs +++ b/proxmox-frr/src/lib.rs @@ -1,3 +1,4 @@ +pub mod openfabric; use std::{fmt::Display, str::FromStr}; use thiserror::Error; diff --git a/proxmox-frr/src/openfabric.rs b/proxmox-frr/src/openfabric.rs new file mode 100644 index 000000000000..6e2a7200ab37 --- /dev/null +++ b/proxmox-frr/src/openfabric.rs @@ -0,0 +1,88 @@ +use std::fmt::Debug; +use std::fmt::Display; + +use proxmox_sdn_types::net::Net; + +use thiserror::Error; + +use crate::FrrWord; +use crate::FrrWordError; + +/// The name of a OpenFabric router. Is an FrrWord. +#[derive(Clone, Debug, PartialEq, Eq, Hash, PartialOrd, Ord)] +pub struct OpenfabricRouterName(FrrWord); + +impl From for OpenfabricRouterName { + fn from(value: FrrWord) -> Self { + Self(value) + } +} + +impl OpenfabricRouterName { + pub fn new(name: FrrWord) -> Self { + Self(name) + } +} + +impl Display for OpenfabricRouterName { + fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { + write!(f, "openfabric {}", self.0) + } +} + +/// All the properties a OpenFabric router can hold. +/// +/// These can serialized with a " " space prefix as they are in the `router openfabric` block. +#[derive(Clone, Debug, PartialEq, Eq, Hash, PartialOrd, Ord)] +pub struct OpenfabricRouter { + /// The NET address + pub net: Net, +} + +impl OpenfabricRouter { + pub fn new(net: Net) -> Self { + Self { net } + } + + pub fn net(&self) -> &Net { + &self.net + } +} + +/// The OpenFabric properties. +/// +/// This struct holds all the OpenFabric interface properties. The most important one here is the +/// fabric_id, which ties the interface to a fabric. When serialized these properties all get +/// prefixed with a space (" ") as they are inside the interface block. They serialize roughly to: +/// +/// ```text +/// interface ens20 +/// ip router openfabric +/// ipv6 router openfabric +/// openfabric hello-interval +/// openfabric hello-multiplier +/// openfabric csnp-interval +/// openfabric passive +/// ``` +/// +/// The is_ipv4 and is_ipv6 properties decide if we need to add `ip router openfabric`, `ipv6 +/// router openfabric`, or both. An interface can only be part of a single fabric. +#[derive(Clone, Debug, PartialEq, Eq, Hash, PartialOrd, Ord)] +pub struct OpenfabricInterface { + // Note: an interface can only be a part of a single fabric (so no vec needed here) + pub fabric_id: OpenfabricRouterName, + pub passive: Option, + pub hello_interval: Option, + pub csnp_interval: Option, + pub hello_multiplier: Option, + pub is_ipv4: bool, + pub is_ipv6: bool, +} + +#[derive(Error, Debug)] +pub enum OpenfabricInterfaceError { + #[error("Unknown error converting to OpenFabricInterface")] + UnknownError, + #[error("Error parsing frr word")] + FrrWordParse(#[from] FrrWordError), +} -- 2.39.5 _______________________________________________ pve-devel mailing list pve-devel@lists.proxmox.com https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel