Message ID | 20240329161730.47777-16-karol.kolacinski@intel.com (mailing list archive) |
---|---|
State | Superseded |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | Introduce ETH56G PHY model for E825C products | expand |
Context | Check | Description |
---|---|---|
netdev/tree_selection | success | Guessing tree name failed - patch did not apply |
On 3/29/2024 9:09 AM, Karol Kolacinski wrote: > From: Jacob Keller <jacob.e.keller@intel.com> > > Multiple places in the driver code need to convert enum ice_ptp_tmr_cmd > values into register bits for both the main timer and the PHY port > timers. The main MAC register has one bit scheme for timer commands, > while the PHY commands use a different scheme. > > The E810 and E830 devices use the same scheme for port commands as used > for the main timer. However, E822 and ETH56G hardware has a separate > scheme used by the PHY. > > Introduce helper functions to convert the timer command enumeration into > the register values, reducing some code duplication, and making it > easier to later refactor the individual port write commands. > > Signed-off-by: Jacob Keller <jacob.e.keller@intel.com> > Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@intel.com> > Reviewed-by: Arkadiusz Kubalewski <arkadiusz.kubalewski@intel.com> > Signed-off-by: Karol Kolacinski <karol.kolacinski@intel.com> > --- > drivers/net/ethernet/intel/ice/ice_ptp_hw.c | 140 ++++++++++++-------- > drivers/net/ethernet/intel/ice/ice_ptp_hw.h | 2 +- > 2 files changed, 89 insertions(+), 53 deletions(-) > > diff --git a/drivers/net/ethernet/intel/ice/ice_ptp_hw.c b/drivers/net/ethernet/intel/ice/ice_ptp_hw.c > index e86ca6cada79..c892b966c3b8 100644 > --- a/drivers/net/ethernet/intel/ice/ice_ptp_hw.c > +++ b/drivers/net/ethernet/intel/ice/ice_ptp_hw.c > @@ -227,40 +227,114 @@ static u64 ice_ptp_read_src_incval(struct ice_hw *hw) > } > > /** > - * ice_ptp_src_cmd - Prepare source timer for a timer command > - * @hw: pointer to HW structure > + * ice_ptp_tmr_cmd_to_src_reg - Convert to source timer command value > + * @hw: pointer to HW struct > * @cmd: Timer command > * > - * Prepare the source timer for an upcoming timer sync command. > + * Returns: the source timer command register value for the given PTP timer > + * command. > */ > -void ice_ptp_src_cmd(struct ice_hw *hw, enum ice_ptp_tmr_cmd cmd) > +static u32 ice_ptp_tmr_cmd_to_src_reg(struct ice_hw *hw, > + enum ice_ptp_tmr_cmd cmd) > { > - u32 cmd_val; > - u8 tmr_idx; > + u32 cmd_val, tmr_idx; > + > + switch (cmd) { > + case ICE_PTP_INIT_TIME: > + cmd_val = GLTSYN_CMD_INIT_TIME; > + break; > + case ICE_PTP_INIT_INCVAL: > + cmd_val = GLTSYN_CMD_INIT_INCVAL; > + break; > + case ICE_PTP_ADJ_TIME: > + cmd_val = GLTSYN_CMD_ADJ_TIME; > + break; > + case ICE_PTP_ADJ_TIME_AT_TIME: > + cmd_val = GLTSYN_CMD_ADJ_INIT_TIME; > + break; > + case ICE_PTP_NOP: > + case ICE_PTP_READ_TIME: > + cmd_val = GLTSYN_CMD_READ_TIME; > + break; > + default: > + dev_warn(ice_hw_to_dev(hw), > + "Ignoring unrecognized timer command %u\n", cmd); > + cmd_val = 0; > + } > > tmr_idx = ice_get_ptp_src_clock_index(hw); > - cmd_val = tmr_idx << SEL_CPK_SRC; > + > + return tmr_idx | cmd_val << SEL_CPK_SRC; This is not equivalent to what was returned before this patch. Is this supposed to return different values now? > +} > + > +/** > + * ice_ptp_tmr_cmd_to_port_reg- Convert to port timer command value > + * @hw: pointer to HW struct > + * @cmd: Timer command > + * > + * Note that some hardware families use a different command register value for > + * the PHY ports, while other hardware families use the same register values > + * as the source timer. > + * > + * Returns: the PHY port timer command register value for the given PTP timer > + * command. > + */ > +static u32 ice_ptp_tmr_cmd_to_port_reg(struct ice_hw *hw, > + enum ice_ptp_tmr_cmd cmd) > +{ > + u32 cmd_val, tmr_idx; > + > + /* Certain hardware families share the same register values for the > + * port register and source timer register. > + */ > + switch (hw->ptp.phy_model) { > + case ICE_PHY_E810: > + return ice_ptp_tmr_cmd_to_src_reg(hw, cmd) & TS_CMD_MASK_E810; > + default: > + break; > + } > > switch (cmd) { > case ICE_PTP_INIT_TIME: > - cmd_val |= GLTSYN_CMD_INIT_TIME; > + cmd_val = PHY_CMD_INIT_TIME; > break; > case ICE_PTP_INIT_INCVAL: > - cmd_val |= GLTSYN_CMD_INIT_INCVAL; > + cmd_val = PHY_CMD_INIT_INCVAL; > break; > case ICE_PTP_ADJ_TIME: > - cmd_val |= GLTSYN_CMD_ADJ_TIME; > + cmd_val = PHY_CMD_ADJ_TIME; > break; > case ICE_PTP_ADJ_TIME_AT_TIME: > - cmd_val |= GLTSYN_CMD_ADJ_INIT_TIME; > + cmd_val = PHY_CMD_ADJ_TIME_AT_TIME; > break; > case ICE_PTP_READ_TIME: > - cmd_val |= GLTSYN_CMD_READ_TIME; > + cmd_val = PHY_CMD_READ_TIME; > break; > case ICE_PTP_NOP: > + cmd_val = 0; > break; > + default: > + dev_warn(ice_hw_to_dev(hw), > + "Ignoring unrecognized timer command %u\n", cmd); > + cmd_val = 0; > } > > + tmr_idx = ice_get_ptp_src_clock_index(hw); > + > + return tmr_idx | cmd_val << SEL_PHY_SRC; Just pointing out that this is the same as the above function in case the previous needs to be changed. > +} > +
diff --git a/drivers/net/ethernet/intel/ice/ice_ptp_hw.c b/drivers/net/ethernet/intel/ice/ice_ptp_hw.c index e86ca6cada79..c892b966c3b8 100644 --- a/drivers/net/ethernet/intel/ice/ice_ptp_hw.c +++ b/drivers/net/ethernet/intel/ice/ice_ptp_hw.c @@ -227,40 +227,114 @@ static u64 ice_ptp_read_src_incval(struct ice_hw *hw) } /** - * ice_ptp_src_cmd - Prepare source timer for a timer command - * @hw: pointer to HW structure + * ice_ptp_tmr_cmd_to_src_reg - Convert to source timer command value + * @hw: pointer to HW struct * @cmd: Timer command * - * Prepare the source timer for an upcoming timer sync command. + * Returns: the source timer command register value for the given PTP timer + * command. */ -void ice_ptp_src_cmd(struct ice_hw *hw, enum ice_ptp_tmr_cmd cmd) +static u32 ice_ptp_tmr_cmd_to_src_reg(struct ice_hw *hw, + enum ice_ptp_tmr_cmd cmd) { - u32 cmd_val; - u8 tmr_idx; + u32 cmd_val, tmr_idx; + + switch (cmd) { + case ICE_PTP_INIT_TIME: + cmd_val = GLTSYN_CMD_INIT_TIME; + break; + case ICE_PTP_INIT_INCVAL: + cmd_val = GLTSYN_CMD_INIT_INCVAL; + break; + case ICE_PTP_ADJ_TIME: + cmd_val = GLTSYN_CMD_ADJ_TIME; + break; + case ICE_PTP_ADJ_TIME_AT_TIME: + cmd_val = GLTSYN_CMD_ADJ_INIT_TIME; + break; + case ICE_PTP_NOP: + case ICE_PTP_READ_TIME: + cmd_val = GLTSYN_CMD_READ_TIME; + break; + default: + dev_warn(ice_hw_to_dev(hw), + "Ignoring unrecognized timer command %u\n", cmd); + cmd_val = 0; + } tmr_idx = ice_get_ptp_src_clock_index(hw); - cmd_val = tmr_idx << SEL_CPK_SRC; + + return tmr_idx | cmd_val << SEL_CPK_SRC; +} + +/** + * ice_ptp_tmr_cmd_to_port_reg- Convert to port timer command value + * @hw: pointer to HW struct + * @cmd: Timer command + * + * Note that some hardware families use a different command register value for + * the PHY ports, while other hardware families use the same register values + * as the source timer. + * + * Returns: the PHY port timer command register value for the given PTP timer + * command. + */ +static u32 ice_ptp_tmr_cmd_to_port_reg(struct ice_hw *hw, + enum ice_ptp_tmr_cmd cmd) +{ + u32 cmd_val, tmr_idx; + + /* Certain hardware families share the same register values for the + * port register and source timer register. + */ + switch (hw->ptp.phy_model) { + case ICE_PHY_E810: + return ice_ptp_tmr_cmd_to_src_reg(hw, cmd) & TS_CMD_MASK_E810; + default: + break; + } switch (cmd) { case ICE_PTP_INIT_TIME: - cmd_val |= GLTSYN_CMD_INIT_TIME; + cmd_val = PHY_CMD_INIT_TIME; break; case ICE_PTP_INIT_INCVAL: - cmd_val |= GLTSYN_CMD_INIT_INCVAL; + cmd_val = PHY_CMD_INIT_INCVAL; break; case ICE_PTP_ADJ_TIME: - cmd_val |= GLTSYN_CMD_ADJ_TIME; + cmd_val = PHY_CMD_ADJ_TIME; break; case ICE_PTP_ADJ_TIME_AT_TIME: - cmd_val |= GLTSYN_CMD_ADJ_INIT_TIME; + cmd_val = PHY_CMD_ADJ_TIME_AT_TIME; break; case ICE_PTP_READ_TIME: - cmd_val |= GLTSYN_CMD_READ_TIME; + cmd_val = PHY_CMD_READ_TIME; break; case ICE_PTP_NOP: + cmd_val = 0; break; + default: + dev_warn(ice_hw_to_dev(hw), + "Ignoring unrecognized timer command %u\n", cmd); + cmd_val = 0; } + tmr_idx = ice_get_ptp_src_clock_index(hw); + + return tmr_idx | cmd_val << SEL_PHY_SRC; +} + +/** + * ice_ptp_src_cmd - Prepare source timer for a timer command + * @hw: pointer to HW structure + * @cmd: Timer command + * + * Prepare the source timer for an upcoming timer sync command. + */ +void ice_ptp_src_cmd(struct ice_hw *hw, enum ice_ptp_tmr_cmd cmd) +{ + u32 cmd_val = ice_ptp_tmr_cmd_to_src_reg(hw, cmd); + wr32(hw, GLTSYN_CMD, cmd_val); } @@ -3023,47 +3097,9 @@ static int ice_ptp_prep_phy_incval_e810(struct ice_hw *hw, u64 incval) */ static int ice_ptp_port_cmd_e810(struct ice_hw *hw, enum ice_ptp_tmr_cmd cmd) { - u32 cmd_val, val; - int err; + u32 val = ice_ptp_tmr_cmd_to_port_reg(hw, cmd); - switch (cmd) { - case ICE_PTP_INIT_TIME: - cmd_val = GLTSYN_CMD_INIT_TIME; - break; - case ICE_PTP_INIT_INCVAL: - cmd_val = GLTSYN_CMD_INIT_INCVAL; - break; - case ICE_PTP_ADJ_TIME: - cmd_val = GLTSYN_CMD_ADJ_TIME; - break; - case ICE_PTP_READ_TIME: - cmd_val = GLTSYN_CMD_READ_TIME; - break; - case ICE_PTP_ADJ_TIME_AT_TIME: - cmd_val = GLTSYN_CMD_ADJ_INIT_TIME; - break; - case ICE_PTP_NOP: - return 0; - } - - /* Read, modify, write */ - err = ice_read_phy_reg_e810(hw, ETH_GLTSYN_CMD, &val); - if (err) { - ice_debug(hw, ICE_DBG_PTP, "Failed to read GLTSYN_CMD, err %d\n", err); - return err; - } - - /* Modify necessary bits only and perform write */ - val &= ~TS_CMD_MASK_E810; - val |= cmd_val; - - err = ice_write_phy_reg_e810(hw, ETH_GLTSYN_CMD, val); - if (err) { - ice_debug(hw, ICE_DBG_PTP, "Failed to write back GLTSYN_CMD, err %d\n", err); - return err; - } - - return 0; + return ice_write_phy_reg_e810(hw, E810_ETH_GLTSYN_CMD, val); } /** diff --git a/drivers/net/ethernet/intel/ice/ice_ptp_hw.h b/drivers/net/ethernet/intel/ice/ice_ptp_hw.h index 3dce09af0d78..6246de3bacf3 100644 --- a/drivers/net/ethernet/intel/ice/ice_ptp_hw.h +++ b/drivers/net/ethernet/intel/ice/ice_ptp_hw.h @@ -485,7 +485,7 @@ int ice_cgu_get_output_pin_state_caps(struct ice_hw *hw, u8 pin_id, #define ETH_GLTSYN_SHADJ_H(_i) (0x0300037C + ((_i) * 32)) /* E810 timer command register */ -#define ETH_GLTSYN_CMD 0x03000344 +#define E810_ETH_GLTSYN_CMD 0x03000344 /* Source timer incval macros */ #define INCVAL_HIGH_M 0xFF