
This commit back ports the DPLL related commits from the upstream kernel that are identified by Intel to provide the expected SyncE/GNSS functionality. There are totally 46 back ported commits included the four commits I added are used to resolve the conflicts during back porting. The 0046 patch is cherry picked from kernel-6.9. The 0031-0045 patches are cherry picked from kernel-6.8. The 0001-0030 patches are cherry picked from kernel-6.7. We also change the in-tree ice driver version to 6.6.40-stx.2 from 6.6.40-stx.1. * To fix the conflict of 91e43ca0090b ("ice: fix linking when CONFIG_PTP_1588_CLOCK=n"), we cherry pick 12a5a28b565b ("ice: remove ICE_F_PTP_EXTTS feature flag") and 89776a6a702e ("ice: check netlist before enabling ICE_F_GNSS"). Adjust 12a5a28b565b because 0d1b22367ec2 ("ice: fix pin assignment for E810-T without SMA control") already included the part code of 12a5a28b565b. https://git.yoctoproject.org/linux-yocto/commit/?id=0d1b22367ec2 * Cherry pick 7049fd5df7 ("netlink: specs: remove redundant type keys from attributes in subsets") to fix the the conflict of c3c6ab95c397 ("dpll: spec: add support for pin-dpll signal phase offset/adjust.") * Cherry pick be16574609f1 ("ice: introduce hw->phy_model for handling PTP PHY differences") to fix the confilict of 6db5f2cd9ebb ("ice: dpll:fix output pin capabilities"). Verification: - Build kernel and out of tree modules success for rt and std. - Install success onto a All-in-One lab with rt kernel. - Boot up successfully in the lab. - interfaces are up and pass packets for rt and std. - Check dmesg to see DDP package is loaded successfully and the version is 1.3.36.0 for rt and std, that is same with the OOT ice-1.14.9 driver. - The SyncE/GNSS functionality tests were done by the network team. Story: 2011056 Task: 50797 Change-Id: I715480681c7c43d53b0a0126b34135562e9d02a0 Signed-off-by: Jiping Ma <jiping.ma2@windriver.com>
347 lines
9.8 KiB
Diff
347 lines
9.8 KiB
Diff
From 6add02878183b5256a0b01ee820f3e0cc878e15d Mon Sep 17 00:00:00 2001
|
|
From: Jacob Keller <jacob.e.keller@intel.com>
|
|
Date: Mon, 17 Jul 2023 15:17:13 -0700
|
|
Subject: [PATCH 28/46] ice: introduce hw->phy_model for handling PTP PHY
|
|
differences
|
|
|
|
The ice driver has PTP support which works across a couple of different
|
|
device families. The device families each have different PHY hardware which
|
|
have unique requirements for programming.
|
|
|
|
Today, there is E810-based hardware, and E822-based hardware. To handle
|
|
this, the driver checks the ice_is_e810() function to separate between the
|
|
two existing families of hardware.
|
|
|
|
Future development is going to add new hardware designs which have further
|
|
unique requirements. To make this easier, introduce a phy_model field to
|
|
the HW structure. This field represents what PHY model the current device
|
|
has, and is used to allow distinguishing which logic a particular device
|
|
needs.
|
|
|
|
This will make supporting future upcoming hardware easier, by providing an
|
|
obvious place to initialize the PHY model, and by already using switch/case
|
|
statements instead of the previous if statements.
|
|
|
|
Astute reviewers may notice that there are a handful of remaining checks
|
|
for ice_is_e810() left in ice_ptp.c These conflict with some other
|
|
cleanup patches in development, and will be fixed in the near future.
|
|
|
|
Signed-off-by: Jacob Keller <jacob.e.keller@intel.com>
|
|
Tested-by: Pucha Himasekhar Reddy <himasekharx.reddy.pucha@intel.com> (A Contingent worker at Intel)
|
|
Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
|
|
(cherry picked from commit be16574609f14c67efd89d5d8f9f19ab7724bfc9)
|
|
Signed-off-by: Jiping Ma <jiping.ma2@windriver.com>
|
|
---
|
|
drivers/net/ethernet/intel/ice/ice_ptp.c | 32 ++++--
|
|
drivers/net/ethernet/intel/ice/ice_ptp_hw.c | 102 ++++++++++++++++----
|
|
drivers/net/ethernet/intel/ice/ice_ptp_hw.h | 2 +
|
|
drivers/net/ethernet/intel/ice/ice_type.h | 8 ++
|
|
4 files changed, 117 insertions(+), 27 deletions(-)
|
|
|
|
diff --git a/drivers/net/ethernet/intel/ice/ice_ptp.c b/drivers/net/ethernet/intel/ice/ice_ptp.c
|
|
index c4270708a769..3648d3cccacc 100644
|
|
--- a/drivers/net/ethernet/intel/ice/ice_ptp.c
|
|
+++ b/drivers/net/ethernet/intel/ice/ice_ptp.c
|
|
@@ -1366,6 +1366,7 @@ ice_ptp_port_phy_restart(struct ice_ptp_port *ptp_port)
|
|
void ice_ptp_link_change(struct ice_pf *pf, u8 port, bool linkup)
|
|
{
|
|
struct ice_ptp_port *ptp_port;
|
|
+ struct ice_hw *hw = &pf->hw;
|
|
|
|
if (!test_bit(ICE_FLAG_PTP, pf->flags))
|
|
return;
|
|
@@ -1380,11 +1381,16 @@ void ice_ptp_link_change(struct ice_pf *pf, u8 port, bool linkup)
|
|
/* Update cached link status for this port immediately */
|
|
ptp_port->link_up = linkup;
|
|
|
|
- /* E810 devices do not need to reconfigure the PHY */
|
|
- if (ice_is_e810(&pf->hw))
|
|
+ switch (hw->phy_model) {
|
|
+ case ICE_PHY_E810:
|
|
+ /* Do not reconfigure E810 PHY */
|
|
return;
|
|
-
|
|
- ice_ptp_port_phy_restart(ptp_port);
|
|
+ case ICE_PHY_E822:
|
|
+ ice_ptp_port_phy_restart(ptp_port);
|
|
+ return;
|
|
+ default:
|
|
+ dev_warn(ice_pf_to_dev(pf), "%s: Unknown PHY type\n", __func__);
|
|
+ }
|
|
}
|
|
|
|
/**
|
|
@@ -2687,14 +2693,22 @@ static int ice_ptp_init_work(struct ice_pf *pf, struct ice_ptp *ptp)
|
|
*/
|
|
static int ice_ptp_init_port(struct ice_pf *pf, struct ice_ptp_port *ptp_port)
|
|
{
|
|
+ struct ice_hw *hw = &pf->hw;
|
|
+
|
|
mutex_init(&ptp_port->ps_lock);
|
|
|
|
- if (ice_is_e810(&pf->hw))
|
|
+ switch (hw->phy_model) {
|
|
+ case ICE_PHY_E810:
|
|
return ice_ptp_init_tx_e810(pf, &ptp_port->tx);
|
|
+ case ICE_PHY_E822:
|
|
+ kthread_init_delayed_work(&ptp_port->ov_work,
|
|
+ ice_ptp_wait_for_offsets);
|
|
|
|
- kthread_init_delayed_work(&ptp_port->ov_work,
|
|
- ice_ptp_wait_for_offsets);
|
|
- return ice_ptp_init_tx_e822(pf, &ptp_port->tx, ptp_port->port_num);
|
|
+ return ice_ptp_init_tx_e822(pf, &ptp_port->tx,
|
|
+ ptp_port->port_num);
|
|
+ default:
|
|
+ return -ENODEV;
|
|
+ }
|
|
}
|
|
|
|
/**
|
|
@@ -2715,6 +2729,8 @@ void ice_ptp_init(struct ice_pf *pf)
|
|
struct ice_hw *hw = &pf->hw;
|
|
int err;
|
|
|
|
+ ice_ptp_init_phy_model(hw);
|
|
+
|
|
/* If this function owns the clock hardware, it must allocate and
|
|
* configure the PTP clock device to represent it.
|
|
*/
|
|
diff --git a/drivers/net/ethernet/intel/ice/ice_ptp_hw.c b/drivers/net/ethernet/intel/ice/ice_ptp_hw.c
|
|
index 8ccd633d9c2e..9aef80ad5100 100644
|
|
--- a/drivers/net/ethernet/intel/ice/ice_ptp_hw.c
|
|
+++ b/drivers/net/ethernet/intel/ice/ice_ptp_hw.c
|
|
@@ -3275,6 +3275,21 @@ void ice_ptp_unlock(struct ice_hw *hw)
|
|
wr32(hw, PFTSYN_SEM + (PFTSYN_SEM_BYTES * hw->pf_id), 0);
|
|
}
|
|
|
|
+/**
|
|
+ * ice_ptp_init_phy_model - Initialize hw->phy_model based on device type
|
|
+ * @hw: pointer to the HW structure
|
|
+ *
|
|
+ * Determine the PHY model for the device, and initialize hw->phy_model
|
|
+ * for use by other functions.
|
|
+ */
|
|
+void ice_ptp_init_phy_model(struct ice_hw *hw)
|
|
+{
|
|
+ if (ice_is_e810(hw))
|
|
+ hw->phy_model = ICE_PHY_E810;
|
|
+ else
|
|
+ hw->phy_model = ICE_PHY_E822;
|
|
+}
|
|
+
|
|
/**
|
|
* ice_ptp_tmr_cmd - Prepare and trigger a timer sync command
|
|
* @hw: pointer to HW struct
|
|
@@ -3293,10 +3308,17 @@ static int ice_ptp_tmr_cmd(struct ice_hw *hw, enum ice_ptp_tmr_cmd cmd)
|
|
ice_ptp_src_cmd(hw, cmd);
|
|
|
|
/* Next, prepare the ports */
|
|
- if (ice_is_e810(hw))
|
|
+ switch (hw->phy_model) {
|
|
+ case ICE_PHY_E810:
|
|
err = ice_ptp_port_cmd_e810(hw, cmd);
|
|
- else
|
|
+ break;
|
|
+ case ICE_PHY_E822:
|
|
err = ice_ptp_port_cmd_e822(hw, cmd);
|
|
+ break;
|
|
+ default:
|
|
+ err = -EOPNOTSUPP;
|
|
+ }
|
|
+
|
|
if (err) {
|
|
ice_debug(hw, ICE_DBG_PTP, "Failed to prepare PHY ports for timer command %u, err %d\n",
|
|
cmd, err);
|
|
@@ -3338,10 +3360,17 @@ int ice_ptp_init_time(struct ice_hw *hw, u64 time)
|
|
|
|
/* PHY timers */
|
|
/* Fill Rx and Tx ports and send msg to PHY */
|
|
- if (ice_is_e810(hw))
|
|
+ switch (hw->phy_model) {
|
|
+ case ICE_PHY_E810:
|
|
err = ice_ptp_prep_phy_time_e810(hw, time & 0xFFFFFFFF);
|
|
- else
|
|
+ break;
|
|
+ case ICE_PHY_E822:
|
|
err = ice_ptp_prep_phy_time_e822(hw, time & 0xFFFFFFFF);
|
|
+ break;
|
|
+ default:
|
|
+ err = -EOPNOTSUPP;
|
|
+ }
|
|
+
|
|
if (err)
|
|
return err;
|
|
|
|
@@ -3373,10 +3402,17 @@ int ice_ptp_write_incval(struct ice_hw *hw, u64 incval)
|
|
wr32(hw, GLTSYN_SHADJ_L(tmr_idx), lower_32_bits(incval));
|
|
wr32(hw, GLTSYN_SHADJ_H(tmr_idx), upper_32_bits(incval));
|
|
|
|
- if (ice_is_e810(hw))
|
|
+ switch (hw->phy_model) {
|
|
+ case ICE_PHY_E810:
|
|
err = ice_ptp_prep_phy_incval_e810(hw, incval);
|
|
- else
|
|
+ break;
|
|
+ case ICE_PHY_E822:
|
|
err = ice_ptp_prep_phy_incval_e822(hw, incval);
|
|
+ break;
|
|
+ default:
|
|
+ err = -EOPNOTSUPP;
|
|
+ }
|
|
+
|
|
if (err)
|
|
return err;
|
|
|
|
@@ -3432,10 +3468,17 @@ int ice_ptp_adj_clock(struct ice_hw *hw, s32 adj)
|
|
wr32(hw, GLTSYN_SHADJ_L(tmr_idx), 0);
|
|
wr32(hw, GLTSYN_SHADJ_H(tmr_idx), adj);
|
|
|
|
- if (ice_is_e810(hw))
|
|
+ switch (hw->phy_model) {
|
|
+ case ICE_PHY_E810:
|
|
err = ice_ptp_prep_phy_adj_e810(hw, adj);
|
|
- else
|
|
+ break;
|
|
+ case ICE_PHY_E822:
|
|
err = ice_ptp_prep_phy_adj_e822(hw, adj);
|
|
+ break;
|
|
+ default:
|
|
+ err = -EOPNOTSUPP;
|
|
+ }
|
|
+
|
|
if (err)
|
|
return err;
|
|
|
|
@@ -3455,10 +3498,14 @@ int ice_ptp_adj_clock(struct ice_hw *hw, s32 adj)
|
|
*/
|
|
int ice_read_phy_tstamp(struct ice_hw *hw, u8 block, u8 idx, u64 *tstamp)
|
|
{
|
|
- if (ice_is_e810(hw))
|
|
+ switch (hw->phy_model) {
|
|
+ case ICE_PHY_E810:
|
|
return ice_read_phy_tstamp_e810(hw, block, idx, tstamp);
|
|
- else
|
|
+ case ICE_PHY_E822:
|
|
return ice_read_phy_tstamp_e822(hw, block, idx, tstamp);
|
|
+ default:
|
|
+ return -EOPNOTSUPP;
|
|
+ }
|
|
}
|
|
|
|
/**
|
|
@@ -3473,10 +3520,14 @@ int ice_read_phy_tstamp(struct ice_hw *hw, u8 block, u8 idx, u64 *tstamp)
|
|
*/
|
|
int ice_clear_phy_tstamp(struct ice_hw *hw, u8 block, u8 idx)
|
|
{
|
|
- if (ice_is_e810(hw))
|
|
+ switch (hw->phy_model) {
|
|
+ case ICE_PHY_E810:
|
|
return ice_clear_phy_tstamp_e810(hw, block, idx);
|
|
- else
|
|
+ case ICE_PHY_E822:
|
|
return ice_clear_phy_tstamp_e822(hw, block, idx);
|
|
+ default:
|
|
+ return -EOPNOTSUPP;
|
|
+ }
|
|
}
|
|
|
|
/**
|
|
@@ -3530,10 +3581,14 @@ int ice_get_pf_c827_idx(struct ice_hw *hw, u8 *idx)
|
|
*/
|
|
void ice_ptp_reset_ts_memory(struct ice_hw *hw)
|
|
{
|
|
- if (ice_is_e810(hw))
|
|
+ switch (hw->phy_model) {
|
|
+ case ICE_PHY_E822:
|
|
+ ice_ptp_reset_ts_memory_e822(hw);
|
|
+ break;
|
|
+ case ICE_PHY_E810:
|
|
+ default:
|
|
return;
|
|
-
|
|
- ice_ptp_reset_ts_memory_e822(hw);
|
|
+ }
|
|
}
|
|
|
|
/**
|
|
@@ -3552,10 +3607,14 @@ int ice_ptp_init_phc(struct ice_hw *hw)
|
|
/* Clear event err indications for auxiliary pins */
|
|
(void)rd32(hw, GLTSYN_STAT(src_idx));
|
|
|
|
- if (ice_is_e810(hw))
|
|
+ switch (hw->phy_model) {
|
|
+ case ICE_PHY_E810:
|
|
return ice_ptp_init_phc_e810(hw);
|
|
- else
|
|
+ case ICE_PHY_E822:
|
|
return ice_ptp_init_phc_e822(hw);
|
|
+ default:
|
|
+ return -EOPNOTSUPP;
|
|
+ }
|
|
}
|
|
|
|
/**
|
|
@@ -3571,12 +3630,17 @@ int ice_ptp_init_phc(struct ice_hw *hw)
|
|
*/
|
|
int ice_get_phy_tx_tstamp_ready(struct ice_hw *hw, u8 block, u64 *tstamp_ready)
|
|
{
|
|
- if (ice_is_e810(hw))
|
|
+ switch (hw->phy_model) {
|
|
+ case ICE_PHY_E810:
|
|
return ice_get_phy_tx_tstamp_ready_e810(hw, block,
|
|
tstamp_ready);
|
|
- else
|
|
+ case ICE_PHY_E822:
|
|
return ice_get_phy_tx_tstamp_ready_e822(hw, block,
|
|
tstamp_ready);
|
|
+ break;
|
|
+ default:
|
|
+ return -EOPNOTSUPP;
|
|
+ }
|
|
}
|
|
|
|
/**
|
|
diff --git a/drivers/net/ethernet/intel/ice/ice_ptp_hw.h b/drivers/net/ethernet/intel/ice/ice_ptp_hw.h
|
|
index d81e77386b54..4f71d4bfeadf 100644
|
|
--- a/drivers/net/ethernet/intel/ice/ice_ptp_hw.h
|
|
+++ b/drivers/net/ethernet/intel/ice/ice_ptp_hw.h
|
|
@@ -281,6 +281,8 @@ int ice_get_cgu_state(struct ice_hw *hw, u8 dpll_idx,
|
|
enum dpll_lock_status *dpll_state);
|
|
int ice_get_cgu_rclk_pin_info(struct ice_hw *hw, u8 *base_idx, u8 *pin_num);
|
|
|
|
+void ice_ptp_init_phy_model(struct ice_hw *hw);
|
|
+
|
|
#define PFTSYN_SEM_BYTES 4
|
|
|
|
#define ICE_PTP_CLOCK_INDEX_0 0x00
|
|
diff --git a/drivers/net/ethernet/intel/ice/ice_type.h b/drivers/net/ethernet/intel/ice/ice_type.h
|
|
index 5eb778d9ae64..4cd131546aa9 100644
|
|
--- a/drivers/net/ethernet/intel/ice/ice_type.h
|
|
+++ b/drivers/net/ethernet/intel/ice/ice_type.h
|
|
@@ -822,6 +822,13 @@ struct ice_mbx_data {
|
|
u16 async_watermark_val;
|
|
};
|
|
|
|
+/* PHY model */
|
|
+enum ice_phy_model {
|
|
+ ICE_PHY_UNSUP = -1,
|
|
+ ICE_PHY_E810 = 1,
|
|
+ ICE_PHY_E822,
|
|
+};
|
|
+
|
|
/* Port hardware description */
|
|
struct ice_hw {
|
|
u8 __iomem *hw_addr;
|
|
@@ -843,6 +850,7 @@ struct ice_hw {
|
|
u8 revision_id;
|
|
|
|
u8 pf_id; /* device profile info */
|
|
+ enum ice_phy_model phy_model;
|
|
|
|
u16 max_burst_size; /* driver sets this value */
|
|
|
|
--
|
|
2.43.0
|
|
|