From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id D39834584B; Thu, 22 Aug 2024 21:48:27 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 1575742F71; Thu, 22 Aug 2024 21:48:20 +0200 (CEST) Received: from mgamail.intel.com (mgamail.intel.com [192.198.163.14]) by mails.dpdk.org (Postfix) with ESMTP id 1899942F71; Thu, 22 Aug 2024 21:48:17 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1724356099; x=1755892099; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=igI137w5B1jTu4Q2k6vzezRUMi8FOCRrJhXpkUuHLng=; b=CPrLbw6ONpYFFA5Fi5Y0DhLeURE9FJC9pCpSxPsVM1GU+47lUvTLZ+09 47wFUEudVsk9iSJDLEOWXWHNi5PNegdeX6nKl5KiPC6V3/+AXm++InkAi 1OgrhgtFjO16JcTM77JyR/MpE1iFD+rlm4jb2sTtbWUxDpHqnhF2Kz7Ws hCEogm8CnXYvzzcbUd9aS3cXPuYSPyxCs13JxSz6BxVcHzhfwcnR3nkmS lRmzWAQ1XSTEN+DrkI5CW+YlbAyUFqM3WDMtw1D/lF+lCsYa6Z+stoiGK B0ekTnPdVcX+VGQRRu5Me4VHfX/TYDzrNBWJnOsEFmnUkco4/AoJpmn4v Q==; X-CSE-ConnectionGUID: EBNF1cp5Q168Ajq3fcdNJw== X-CSE-MsgGUID: mplro+u+Tyq4mrsnJUmWmQ== X-IronPort-AV: E=McAfee;i="6700,10204,11172"; a="22979667" X-IronPort-AV: E=Sophos;i="6.10,168,1719903600"; d="scan'208";a="22979667" Received: from orviesa002.jf.intel.com ([10.64.159.142]) by fmvoesa108.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Aug 2024 12:48:18 -0700 X-CSE-ConnectionGUID: 7oFmvhM6SAmQPfPp9F+iSg== X-CSE-MsgGUID: qiUvHcP7TX2extH5+f6OBQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.10,168,1719903600"; d="scan'208";a="92301386" Received: from unknown (HELO npf-hyd-clx-03..) ([10.145.170.182]) by orviesa002.jf.intel.com with ESMTP; 22 Aug 2024 12:48:15 -0700 From: Soumyadeep Hore To: bruce.richardson@intel.com, ian.stokes@intel.com, aman.deep.singh@intel.com Cc: dev@dpdk.org, shaiq.wani@intel.com, stable@dpdk.org Subject: [PATCH v2 02/12] net/ice: updates for ptp init in E825C Date: Thu, 22 Aug 2024 18:53:36 +0000 Message-ID: <20240822185346.221885-3-soumyadeep.hore@intel.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240822185346.221885-1-soumyadeep.hore@intel.com> References: <20240822095612.216214-1-soumyadeep.hore@intel.com> <20240822185346.221885-1-soumyadeep.hore@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org The implementation was done incorrectly assuming the TS PLL parameters would be similar to E822/E823 devices. Fix it by using proper values. Define access to SB (sideband) for second PHY and CGU devices in case of E825C devices. In E825C soft straps of CGU cannot be read from HW, and therefore it must be hard coded to default values. Fixes: 620ecf247c22 ("net/ice/base: support E825-C Tx clock changing") Cc: stable@dpdk.org Signed-off-by: Soumyadeep Hore --- drivers/net/ice/base/ice_cgu_regs.h | 19 +++++++ drivers/net/ice/base/ice_common.c | 4 ++ drivers/net/ice/base/ice_ptp_consts.h | 75 +++++++++++++++++++++++++++ drivers/net/ice/base/ice_ptp_hw.c | 75 ++++++++++++++++++--------- drivers/net/ice/base/ice_ptp_hw.h | 21 ++++++++ 5 files changed, 169 insertions(+), 25 deletions(-) diff --git a/drivers/net/ice/base/ice_cgu_regs.h b/drivers/net/ice/base/ice_cgu_regs.h index f24f4746dd..4d831959bf 100644 --- a/drivers/net/ice/base/ice_cgu_regs.h +++ b/drivers/net/ice/base/ice_cgu_regs.h @@ -64,6 +64,17 @@ union nac_cgu_dword11_e825c { u32 val; }; +#define NAC_CGU_DWORD16_E825C 0x40 +union nac_cgu_dword16_e825c { + struct { + u32 synce_remndr : 6; + u32 synce_phlmt_en : 1; + u32 misc13 : 17; + u32 tspll_ck_refclkfreq : 8; + } field; + u32 val; +}; + #define NAC_CGU_DWORD19 0x4c union nac_cgu_dword19 { struct { @@ -120,6 +131,13 @@ union nac_cgu_dword23_e825c { u32 val; }; +union nac_cgu_dword24_e825c { + struct { + u32 tspll_fbdiv_frac : 32; + } field; + u32 val; +}; + #define NAC_CGU_DWORD24 0x60 union nac_cgu_dword24 { struct { @@ -134,6 +152,7 @@ union nac_cgu_dword24 { u32 val; }; + #define TSPLL_CNTR_BIST_SETTINGS 0x344 union tspll_cntr_bist_settings { struct { diff --git a/drivers/net/ice/base/ice_common.c b/drivers/net/ice/base/ice_common.c index 48d5fff42a..4750076b7d 100644 --- a/drivers/net/ice/base/ice_common.c +++ b/drivers/net/ice/base/ice_common.c @@ -2585,6 +2585,10 @@ ice_parse_1588_func_caps(struct ice_hw *hw, struct ice_hw_func_caps *func_p, info->clk_src = ((number & ICE_TS_CLK_SRC_M) != 0); clk_freq = (number & ICE_TS_CLK_FREQ_M) >> ICE_TS_CLK_FREQ_S; + if (ice_is_e825c(hw)) { + info->clk_src = ICE_CLK_SRC_TCX0; + clk_freq = ICE_TIME_REF_FREQ_156_250; + } if (clk_freq < NUM_ICE_TIME_REF_FREQ) { info->time_ref = (enum ice_time_ref_freq)clk_freq; } else { diff --git a/drivers/net/ice/base/ice_ptp_consts.h b/drivers/net/ice/base/ice_ptp_consts.h index bd0258f437..d1f4fd2738 100644 --- a/drivers/net/ice/base/ice_ptp_consts.h +++ b/drivers/net/ice/base/ice_ptp_consts.h @@ -157,6 +157,81 @@ const struct ice_cgu_pll_params_e822 e822_cgu_params[NUM_ICE_TIME_REF_FREQ] = { }, }; +const +struct ice_cgu_pll_params_e825c e825c_cgu_params[NUM_ICE_TIME_REF_FREQ] = { + /* ICE_TIME_REF_FREQ_25_000 -> 25 MHz */ + { + /* tspll_ck_refclkfreq */ + 0x19, + /* tspll_ndivratio */ + 1, + /* tspll_fbdiv_intgr */ + 320, + /* tspll_fbdiv_frac */ + 0, + }, + + /* ICE_TIME_REF_FREQ_122_880 -> 122.88 MHz */ + { + /* tspll_ck_refclkfreq */ + 0x29, + /* tspll_ndivratio */ + 3, + /* tspll_fbdiv_intgr */ + 195, + /* tspll_fbdiv_frac */ + 1342177280, + }, + + /* ICE_TIME_REF_FREQ_125_000 -> 125 MHz */ + { + /* tspll_ck_refclkfreq */ + 0x3E, + /* tspll_ndivratio */ + 2, + /* tspll_fbdiv_intgr */ + 128, + /* tspll_fbdiv_frac */ + 0, + }, + + /* ICE_TIME_REF_FREQ_153_600 -> 153.6 MHz */ + { + /* tspll_ck_refclkfreq */ + 0x33, + /* tspll_ndivratio */ + 3, + /* tspll_fbdiv_intgr */ + 156, + /* tspll_fbdiv_frac */ + 1073741824, + }, + + /* ICE_TIME_REF_FREQ_156_250 -> 156.25 MHz */ + { + /* tspll_ck_refclkfreq */ + 0x1F, + /* tspll_ndivratio */ + 5, + /* tspll_fbdiv_intgr */ + 256, + /* tspll_fbdiv_frac */ + 0, + }, + + /* ICE_TIME_REF_FREQ_245_760 -> 245.76 MHz */ + { + /* tspll_ck_refclkfreq */ + 0x52, + /* tspll_ndivratio */ + 3, + /* tspll_fbdiv_intgr */ + 97, + /* tspll_fbdiv_frac */ + 2818572288, + }, +}; + /* * struct ice_vernier_info_e822 * diff --git a/drivers/net/ice/base/ice_ptp_hw.c b/drivers/net/ice/base/ice_ptp_hw.c index 004f659eae..e574ae6d4f 100644 --- a/drivers/net/ice/base/ice_ptp_hw.c +++ b/drivers/net/ice/base/ice_ptp_hw.c @@ -362,10 +362,11 @@ ice_cfg_cgu_pll_e825c(struct ice_hw *hw, enum ice_time_ref_freq *clk_freq, enum ice_clk_src *clk_src) { union tspll_ro_lock_e825c ro_lock; + union nac_cgu_dword16_e825c dw16; union nac_cgu_dword23_e825c dw23; + union nac_cgu_dword24_e825c dw24; union nac_cgu_dword19 dw19; union nac_cgu_dword22 dw22; - union nac_cgu_dword24 dw24; union nac_cgu_dword9 dw9; int err; @@ -380,8 +381,8 @@ ice_cfg_cgu_pll_e825c(struct ice_hw *hw, enum ice_time_ref_freq *clk_freq, } if (*clk_src == ICE_CLK_SRC_TCX0 && - *clk_freq != ICE_TIME_REF_FREQ_25_000) { - ice_warn(hw, "TCX0 only supports 25 MHz frequency\n"); + *clk_freq != ICE_TIME_REF_FREQ_156_250) { + ice_warn(hw, "TCX0 only supports 156.25 MHz frequency\n"); return ICE_ERR_PARAM; } @@ -393,6 +394,10 @@ ice_cfg_cgu_pll_e825c(struct ice_hw *hw, enum ice_time_ref_freq *clk_freq, if (err) return err; + err = ice_read_cgu_reg_e82x(hw, NAC_CGU_DWORD16_E825C, &dw16.val); + if (err) + return err; + err = ice_read_cgu_reg_e82x(hw, NAC_CGU_DWORD23_E825C, &dw23.val); if (err) return err; @@ -403,7 +408,7 @@ ice_cfg_cgu_pll_e825c(struct ice_hw *hw, enum ice_time_ref_freq *clk_freq, /* Log the current clock configuration */ ice_debug(hw, ICE_DBG_PTP, "Current CGU configuration -- %s, clk_src %s, clk_freq %s, PLL %s\n", - dw24.field.ts_pll_enable ? "enabled" : "disabled", + dw23.field.ts_pll_enable ? "enabled" : "disabled", ice_clk_src_str(dw23.field.time_ref_sel), ice_clk_freq_str(dw9.field.time_ref_freq_sel), ro_lock.field.plllock_true_lock_cri ? "locked" : "unlocked"); @@ -418,19 +423,43 @@ ice_cfg_cgu_pll_e825c(struct ice_hw *hw, enum ice_time_ref_freq *clk_freq, return err; } - /* Set the frequency */ + if (dw9.field.time_sync_en) { + dw9.field.time_sync_en = 0; + + err = ice_write_cgu_reg_e82x(hw, NAC_CGU_DWORD9, + dw9.val); + if (err) + return err; + } + + /* Set the frequency and enable the correct receiver */ dw9.field.time_ref_freq_sel = *clk_freq; + if (*clk_src == ICE_CLK_SRC_TCX0) { + dw9.field.time_ref_en = 0; + dw9.field.clk_eref0_en = 1; + } else { + dw9.field.time_ref_en = 1; + dw9.field.clk_eref0_en = 0; + } + dw9.field.time_sync_en = 1; err = ice_write_cgu_reg_e82x(hw, NAC_CGU_DWORD9, dw9.val); if (err) return err; + /* Choose the referenced frequency */ + dw16.field.tspll_ck_refclkfreq = + e825c_cgu_params[*clk_freq].tspll_ck_refclkfreq; + err = ice_write_cgu_reg_e82x(hw, NAC_CGU_DWORD16_E825C, dw16.val); + if (err) + return err; + /* Configure the TS PLL feedback divisor */ err = ice_read_cgu_reg_e82x(hw, NAC_CGU_DWORD19, &dw19.val); if (err) return err; - dw19.field.tspll_fbdiv_intgr = e822_cgu_params[*clk_freq].feedback_div; - dw19.field.tspll_ndivratio = 1; + dw19.field.tspll_fbdiv_intgr = e825c_cgu_params[*clk_freq].tspll_fbdiv_intgr; + dw19.field.tspll_ndivratio = e825c_cgu_params[*clk_freq].tspll_ndivratio; err = ice_write_cgu_reg_e82x(hw, NAC_CGU_DWORD19, dw19.val); if (err) @@ -441,7 +470,8 @@ ice_cfg_cgu_pll_e825c(struct ice_hw *hw, enum ice_time_ref_freq *clk_freq, if (err) return err; - dw22.field.time1588clk_div = e822_cgu_params[*clk_freq].post_pll_div; + /* those two are constant for E825C */ + dw22.field.time1588clk_div = 5; dw22.field.time1588clk_sel_div2 = 0; err = ice_write_cgu_reg_e82x(hw, NAC_CGU_DWORD22, dw22.val); @@ -453,14 +483,14 @@ ice_cfg_cgu_pll_e825c(struct ice_hw *hw, enum ice_time_ref_freq *clk_freq, if (err) return err; - dw23.field.ref1588_ck_div = e822_cgu_params[*clk_freq].refclk_pre_div; + dw23.field.ref1588_ck_div = REF1588_CK_DIV; dw23.field.time_ref_sel = *clk_src; err = ice_write_cgu_reg_e82x(hw, NAC_CGU_DWORD23_E825C, dw23.val); if (err) return err; - dw24.field.tspll_fbdiv_frac = e822_cgu_params[*clk_freq].frac_n_div; + dw24.field.tspll_fbdiv_frac = e825c_cgu_params[*clk_freq].tspll_fbdiv_frac; err = ice_write_cgu_reg_e82x(hw, NAC_CGU_DWORD24, dw24.val); if (err) @@ -486,11 +516,9 @@ ice_cfg_cgu_pll_e825c(struct ice_hw *hw, enum ice_time_ref_freq *clk_freq, } /* Log the current clock configuration */ - ice_debug(hw, ICE_DBG_PTP, "New CGU configuration -- %s, clk_src %s, clk_freq %s, PLL %s\n", - dw24.field.ts_pll_enable ? "enabled" : "disabled", + ice_debug(hw, ICE_DBG_PTP, "New CGU configuration -- clk_src %s, clk_freq %s\n", ice_clk_src_str(dw23.field.time_ref_sel), - ice_clk_freq_str(dw9.field.time_ref_freq_sel), - ro_lock.field.plllock_true_lock_cri ? "locked" : "unlocked"); + ice_clk_freq_str(dw9.field.time_ref_freq_sel)); *clk_freq = (enum ice_time_ref_freq)dw9.field.time_ref_freq_sel; *clk_src = (enum ice_clk_src)dw23.field.time_ref_sel; @@ -770,7 +798,10 @@ static int ice_init_cgu_e82x(struct ice_hw *hw) ice_warn(hw, "Failed to lock TS PLL to predefined frequency. Retrying with fallback frequency.\n"); /* Try to lock to internal 25 MHz TCXO as a fallback */ - time_ref_freq = ICE_TIME_REF_FREQ_25_000; + if (hw->phy_model == ICE_PHY_ETH56G) + time_ref_freq = ICE_TIME_REF_FREQ_156_250; + else + time_ref_freq = ICE_TIME_REF_FREQ_25_000; clk_src = ICE_CLK_SRC_TCX0; if (ice_is_e825c(hw)) err = ice_cfg_cgu_pll_e825c(hw, &time_ref_freq, @@ -2328,21 +2359,15 @@ ice_start_phy_timer_eth56g(struct ice_hw *hw, u8 port) */ static void ice_sb_access_ena_eth56g(struct ice_hw *hw, bool enable) { - u32 regval; - /* Enable reading and writing switch and PHY registers over the * sideband queue. */ -#define PF_SB_REM_DEV_CTL_SWITCH_READ BIT(1) -#define PF_SB_REM_DEV_CTL_PHY0 BIT(2) - regval = rd32(hw, PF_SB_REM_DEV_CTL); + u32 regval = rd32(hw, PF_SB_REM_DEV_CTL); + if (enable) - regval |= (PF_SB_REM_DEV_CTL_SWITCH_READ | - PF_SB_REM_DEV_CTL_PHY0); + regval |= (cgu | eth56g_dev_0 | eth56g_dev_1); else - regval &= ~(PF_SB_REM_DEV_CTL_SWITCH_READ | - PF_SB_REM_DEV_CTL_PHY0); - + regval &= ~(cgu | eth56g_dev_0 | eth56g_dev_1); wr32(hw, PF_SB_REM_DEV_CTL, regval); } diff --git a/drivers/net/ice/base/ice_ptp_hw.h b/drivers/net/ice/base/ice_ptp_hw.h index 9357dfd327..5d6636c0d1 100644 --- a/drivers/net/ice/base/ice_ptp_hw.h +++ b/drivers/net/ice/base/ice_ptp_hw.h @@ -122,6 +122,27 @@ struct ice_cgu_pll_params_e822 { extern const struct ice_cgu_pll_params_e822 e822_cgu_params[NUM_ICE_TIME_REF_FREQ]; +/** + * struct ice_cgu_pll_params_e825c + * @tspll_ck_refclkfreq: tspll_ck_refclkfreq selection + * @tspll_ndivratio: ndiv ratio that goes directly to the pll + * @tspll_fbdiv_intgr: TS PLL integer feedback divide + * @tspll_fbdiv_frac: TS PLL fractional feedback divide + * + * Clock Generation Unit parameters used to program the PLL based on the + * selected TIME_REF/TCXO frequency. + */ +struct ice_cgu_pll_params_e825c { + u32 tspll_ck_refclkfreq; + u32 tspll_ndivratio; + u32 tspll_fbdiv_intgr; + u32 tspll_fbdiv_frac; +}; + +extern const struct +ice_cgu_pll_params_e825c e825c_cgu_params[NUM_ICE_TIME_REF_FREQ]; +#define REF1588_CK_DIV 0 + /* Table of constants related to possible TIME_REF sources */ extern const struct ice_time_ref_info_e822 e822_time_ref[NUM_ICE_TIME_REF_FREQ]; -- 2.43.0