From nobody Sun Apr 5 21:14:43 2026 Received: from mail-ed1-f44.google.com (mail-ed1-f44.google.com [209.85.208.44]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 75FB43A9628 for ; Tue, 24 Feb 2026 16:49:30 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.44 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1771951771; cv=none; b=o+tm9yeTdN/sqPHPOnSDLWCoVOho7U1Ul1RVnmwiySBG2u5fEZY80k/+Ae1alEfeEJokwvCLPr9Hi1H06K0zHBdSH2PEoXQzSpfmLl2MbM3+biBesSYI7XnrS100/QwmvHqlU8TgtB067AdmVO2/yNUfiGe79Ji9/RYI0Se/6vk= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1771951771; c=relaxed/simple; bh=N68rztWaSPFT7EWLTVeEBYTiTamnBZR2Ck1uIkEXnO8=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=THHbLxBoWox6/CsF1T2y83UmHI++/yrVSjYJdop3lY/rbzEAV3nyhEb+34cw2X70jDhiDcnk+i/Ym4MvH3GT7g9tKtpDikgBI6y4Md57bCcg7BWoQwg00fwpzg/khjg1C5sEKDRC5XHVkE7DXyb2KLyw2fJUVhsrpq3eSwYtL5w= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=I+DBacZZ; arc=none smtp.client-ip=209.85.208.44 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="I+DBacZZ" Received: by mail-ed1-f44.google.com with SMTP id 4fb4d7f45d1cf-65bfc858561so10975841a12.2 for ; Tue, 24 Feb 2026 08:49:30 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1771951769; x=1772556569; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=K4JY4FtMQMrcvknA0R7jnHnULTW5UTmi+8FwqfvcNko=; b=I+DBacZZ659GtZSjo2xTWDrwOTf1zgFxvaQ6ubfHzKAM/VSbfn6MoCfIntTfFznzdA lTy0bS4i+lripc7iq4gXX8+gDf1g5lufp1UUTgEmdxHn5XJ9OgkwEtAxHqWSHXCEGZkK RqmPWuk95auLnFKUIb3b8MH5c6Wdk+du5u3pLkkh1RKrRh776bJP+vPcF60xKpmvUl4+ EFDQPk49ciz07tVChVDznzGH7XlK7VTT9hPqP/xzxVsc9srYEjcExEX1NpLwff0VkR9O XhKLxt0Xei0DJnls32zxOw+/ts7/KdJNTFB/7V98kQRYRU0z7XNmltZWll7WSgoICZ49 f0Jg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1771951769; x=1772556569; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=K4JY4FtMQMrcvknA0R7jnHnULTW5UTmi+8FwqfvcNko=; b=cc/j3NsRCDIwQ7NWbhXfHlMCzQLtKKqmJ2goRu+9XVBijjc58khIdKPSsK9RNWofbF PtAHnroijz9GpPa+VSypbx+s55lKVLpYI9PI7u8J33bYmxxFzCJdM74/VMmEJDD3t6ph 30qzRpkWoRs9ZYhJlEmYzqgewUg4T9OYWdQqdh9evFHNOomZeey0Qr/AxxuRktGNYIJH bOPQPB+ZxeztYUK3K1ws2F7qe8fSz5uLv0stRbmh+AbhZsiSC0KGkJJu3gm/K0m/y4zG /1mPnyqa5R5UwIFZp8EcMi3M33/bviC+d0bMlKv1lZ21CI5FySNUa/XajQ4elIzMMrmy qKog== X-Forwarded-Encrypted: i=1; AJvYcCVJEjQyh0sfmKMMxmqnkDcR5trEVFDR6nvGvUNGSbGYBi3HWSVruMI9sLU3HIw+KyUQ5wMpKw3kj3+iBFA=@vger.kernel.org X-Gm-Message-State: AOJu0YxtIEnEzuAOsrn2limWdu1IFOkssUJaietmz55ZlH0ilkUju8cZ p/hWS72Vl0fazrbkyMT2AHNyqvM5FhiA3L2g7x+ecZdLqloBZ3OZnG1q X-Gm-Gg: ATEYQzz8OLkEqXHZFQZN4Sr35jC1Y+uXY5uE3q35kXL+wO94RmacdMe/EnnSl2eGniN zqyqRHg8o4pzBi9ShOd/ykASL8xZpvs4Q3kfq2x8rkRfpzyBc3H5hj4JuoGjOxx651VmDmFOEn5 kVF3tsSNthT3FkeD1xETgpDFW8jkGXRuyPUa1JaFThAcqL3Zl7uUsQ5CpYBUF9lIqVuq2czLFwh XpB9YGeiJbwMDys2/9OMgambKk9m8ZAF2V8wEwgs+L9q5oGasvrCnuJJy0wkMHhkyay99NcHy7b EYpzuqAMCQm8a3ldIbzmXBMUyuJUVRaStHMb6/MqV8llvcP/4JEyi8cNJES+a7j297ks7PgoeDI F2jqRPDX99KKlFUhtTnjhYzSVN7jskkOPnWBpRlwE0bdwFiZcHTlpbeCJ18I9+yYpKLZq31wahN VR+fDAz3+n9Fnw9dTQREUff6JgUXQT93CuCEMAhIir3FUeSQ3nqCdnZyVZXV91xCS/4X5EeRqCB BJbcWnE7Z6WEl2laqi1YKDFSl+HY7uXf6y4BMYN/eyzE6XTKZhg8bMQKWsgFulN9BPt X-Received: by 2002:a05:6402:24da:b0:65b:fa9f:fce4 with SMTP id 4fb4d7f45d1cf-65ea4f1d6demr5539931a12.27.1771951768246; Tue, 24 Feb 2026 08:49:28 -0800 (PST) Received: from cs-874966990260-default.europe-west4-a.c.i2f7e30109524dc12-tp.internal (30.49.91.34.bc.googleusercontent.com. [34.91.49.30]) by smtp.gmail.com with ESMTPSA id 4fb4d7f45d1cf-65eab9a077asm3771023a12.4.2026.02.24.08.49.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 24 Feb 2026 08:49:27 -0800 (PST) From: Artem Lytkin To: Andrew Lunn , Heiner Kallweit , Russell King , FUJITA Tomonori , Trevor Gross Cc: "David S . Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Miguel Ojeda , netdev@vger.kernel.org, rust-for-linux@vger.kernel.org, linux-kernel@vger.kernel.org, Artem Lytkin Subject: [PATCH net-next v3 1/2] rust: net: phy: add speed() getter to Device Date: Tue, 24 Feb 2026 16:49:25 +0000 Message-ID: <20260224164926.1760-2-iprintercanon@gmail.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260224164926.1760-1-iprintercanon@gmail.com> References: <20260224043211.1747-1-iprintercanon@gmail.com> <20260224164926.1760-1-iprintercanon@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Add a speed() getter to phy::Device that reads the current link speed from the phy_device struct. This is needed by PHY drivers that must detect speed changes in their read_status callback. Signed-off-by: Artem Lytkin --- rust/kernel/net/phy.rs | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/rust/kernel/net/phy.rs b/rust/kernel/net/phy.rs index 3ca99db5cccf..3812f8fd3e49 100644 --- a/rust/kernel/net/phy.rs +++ b/rust/kernel/net/phy.rs @@ -158,6 +158,14 @@ pub fn is_autoneg_completed(&self) -> bool { bit_field.get(15, 1) =3D=3D AUTONEG_COMPLETED } =20 + /// Gets the current link speed. + pub fn speed(&self) -> i32 { + let phydev =3D self.0.get(); + // SAFETY: The struct invariant ensures that we may access + // this field without additional synchronization. + unsafe { (*phydev).speed } + } + /// Sets the speed of the PHY. pub fn set_speed(&mut self, speed: u32) { let phydev =3D self.0.get(); --=20 2.43.0