From patchwork Thu Apr 22 23:06:45 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Mohammad Athari Bin Ismail X-Patchwork-Id: 12219241 X-Patchwork-Delegate: kuba@kernel.org Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-16.8 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 1C9A7C433ED for ; Thu, 22 Apr 2021 23:07:09 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id F3EDF60E0C for ; Thu, 22 Apr 2021 23:07:08 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239821AbhDVXHn (ORCPT ); Thu, 22 Apr 2021 19:07:43 -0400 Received: from mga07.intel.com ([134.134.136.100]:60916 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235977AbhDVXHm (ORCPT ); Thu, 22 Apr 2021 19:07:42 -0400 IronPort-SDR: VLDgnOw0v/bAeHDYa8/PO11uQqMGPdTcLWkGplLIEk2ftbVZfyakNxCjiGNUCgmNSR/f4w8hDs h2E4fKN4puOQ== X-IronPort-AV: E=McAfee;i="6200,9189,9962"; a="259941511" X-IronPort-AV: E=Sophos;i="5.82,244,1613462400"; d="scan'208";a="259941511" Received: from orsmga005.jf.intel.com ([10.7.209.41]) by orsmga105.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Apr 2021 16:07:06 -0700 IronPort-SDR: iw6rdYTWxrrSYSa6YB+4+iC0FdoUaaTo3F0ZPS8xiL2TagiWR3ZgrCaWavKz6TjiEKv2mqdwhI G/HHPSJDKDnA== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.82,244,1613462400"; d="scan'208";a="603374991" Received: from mismail5-ilbpg0.png.intel.com ([10.88.229.82]) by orsmga005.jf.intel.com with ESMTP; 22 Apr 2021 16:07:02 -0700 From: mohammad.athari.ismail@intel.com To: Alexandre Torgue , Jose Abreu , "David S . Miller" , Jakub Kicinski , Andrew Lunn , Heiner Kallweit , Russell King Cc: Ong Boon Leong , Voon Weifeng , Wong Vee Khee , netdev@vger.kernel.org, linux-kernel@vger.kernel.org, mohammad.athari.ismail@intel.com Subject: [PATCH v2 net-next] net: pcs: Enable pre-emption packet for 10/100Mbps Date: Fri, 23 Apr 2021 07:06:45 +0800 Message-Id: <20210422230645.23736-1-mohammad.athari.ismail@intel.com> X-Mailer: git-send-email 2.17.1 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org X-Patchwork-Delegate: kuba@kernel.org From: Mohammad Athari Bin Ismail Set VR_MII_DIG_CTRL1 bit-6(PRE_EMP) to enable pre-emption packet for 10/100Mbps by default. This setting doesn`t impact pre-emption capability for other speeds. Signed-off-by: Mohammad Athari Bin Ismail --- v2 changelog: -Removed useless (). Comment fron Leon Romanovsky. --- drivers/net/pcs/pcs-xpcs.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/drivers/net/pcs/pcs-xpcs.c b/drivers/net/pcs/pcs-xpcs.c index 944ba105cac1..ea33842eb0f4 100644 --- a/drivers/net/pcs/pcs-xpcs.c +++ b/drivers/net/pcs/pcs-xpcs.c @@ -66,6 +66,7 @@ /* VR_MII_DIG_CTRL1 */ #define DW_VR_MII_DIG_CTRL1_MAC_AUTO_SW BIT(9) +#define DW_VR_MII_DIG_CTRL1_PRE_EMP BIT(6) /* VR_MII_AN_CTRL */ #define DW_VR_MII_AN_CTRL_TX_CONFIG_SHIFT 3 @@ -666,6 +667,10 @@ static int xpcs_config_aneg_c37_sgmii(struct mdio_xpcs_args *xpcs) * PHY about the link state change after C28 AN is completed * between PHY and Link Partner. There is also no need to * trigger AN restart for MAC-side SGMII. + * + * For pre-emption, the setting is :- + * 1) VR_MII_DIG_CTRL1 Bit(6) [PRE_EMP] = 1b (Enable pre-emption packet + * for 10/100Mbps) */ ret = xpcs_read(xpcs, MDIO_MMD_VEND2, DW_VR_MII_AN_CTRL); if (ret < 0) @@ -686,7 +691,7 @@ static int xpcs_config_aneg_c37_sgmii(struct mdio_xpcs_args *xpcs) if (ret < 0) return ret; - ret |= DW_VR_MII_DIG_CTRL1_MAC_AUTO_SW; + ret |= DW_VR_MII_DIG_CTRL1_MAC_AUTO_SW | DW_VR_MII_DIG_CTRL1_PRE_EMP; return xpcs_write(xpcs, MDIO_MMD_VEND2, DW_VR_MII_DIG_CTRL1, ret); }