Upstream code has this function in a different place, so move it to match the upstream code.
Signed-off-by: Anatoly Burakov <anatoly.bura...@intel.com> --- drivers/net/ice/base/ice_ptp_hw.c | 127 +++++++++++++++--------------- drivers/net/ice/base/ice_type.h | 6 ++ 2 files changed, 69 insertions(+), 64 deletions(-) diff --git a/drivers/net/ice/base/ice_ptp_hw.c b/drivers/net/ice/base/ice_ptp_hw.c index 7413fc891f..f287834a4d 100644 --- a/drivers/net/ice/base/ice_ptp_hw.c +++ b/drivers/net/ice/base/ice_ptp_hw.c @@ -2321,70 +2321,6 @@ ice_get_phy_tx_tstamp_ready_eth56g(struct ice_hw *hw, u8 port, return 0; } -#define ICE_DEVID_MASK 0xFFF8 - -/** - * 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) -{ - unsigned int phy; - - for (phy = 0; phy < MAX_PHYS_PER_ICE; phy++) - hw->phy_addr[phy] = 0; - - switch (hw->device_id & ICE_DEVID_MASK) { - case ICE_DEV_ID_E825C_BACKPLANE & ICE_DEVID_MASK: - hw->phy_addr[0] = eth56g_dev_0; - hw->phy_addr[1] = eth56g_dev_1; - hw->num_phys = ICE_PHYS_PER_CPLX_C825X; - hw->phy_ports = ICE_PORTS_PER_PHY_C825X; - hw->max_phy_port = ice_is_nac_dual(hw) ? - ICE_PORTS_PER_PHY_C825X : - ICE_PHYS_PER_CPLX_C825X * ICE_PORTS_PER_PHY_C825X; - break; - default: - goto e8xx; - } - - ice_sb_access_ena_eth56g(hw, true); - for (phy = 0; phy < hw->num_phys; phy++) - if (hw->phy_addr[phy]) { - int err; - u32 phy_rev; - - err = ice_read_phy_eth56g_raw_lp(hw, phy, - PHY_REG_REVISION, - &phy_rev, true); - if (err) { - hw->phy_model = ICE_PHY_UNSUP; - return; - } - - if (phy_rev != PHY_REVISION_ETH56G) { - hw->phy_model = ICE_PHY_UNSUP; - return; - } - } - - hw->phy_model = ICE_PHY_ETH56G; - - return; -e8xx: - - if (ice_is_e810(hw)) - hw->phy_model = ICE_PHY_E810; - else - hw->phy_model = ICE_PHY_E822; - - hw->phy_ports = ICE_NUM_EXTERNAL_PORTS; - hw->max_phy_port = ICE_NUM_EXTERNAL_PORTS; -} - /* E822 family functions * * The following functions operate on the E822 family of devices. @@ -5643,6 +5579,69 @@ void ice_ptp_unlock(struct ice_hw *hw) wr32(hw, PFTSYN_SEM + (PFTSYN_SEM_BYTES * hw->pf_id), 0); } +#define ICE_DEVID_MASK 0xFFF8 + +/** + * 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) +{ + unsigned int phy; + + for (phy = 0; phy < MAX_PHYS_PER_ICE; phy++) + hw->phy_addr[phy] = 0; + + switch (hw->device_id & ICE_DEVID_MASK) { + case ICE_DEV_ID_E825C_BACKPLANE & ICE_DEVID_MASK: + hw->phy_addr[0] = eth56g_dev_0; + hw->phy_addr[1] = eth56g_dev_1; + hw->num_phys = ICE_PHYS_PER_CPLX_C825X; + hw->phy_ports = ICE_PORTS_PER_PHY_C825X; + hw->max_phy_port = ice_is_nac_dual(hw) ? + ICE_PORTS_PER_PHY_C825X : + ICE_PHYS_PER_CPLX_C825X * ICE_PORTS_PER_PHY_C825X; + break; + default: + goto e8xx; + } + + ice_sb_access_ena_eth56g(hw, true); + for (phy = 0; phy < hw->num_phys; phy++) + if (hw->phy_addr[phy]) { + int err; + u32 phy_rev; + + err = ice_read_phy_eth56g_raw_lp(hw, phy, + PHY_REG_REVISION, + &phy_rev, true); + if (err) { + hw->phy_model = ICE_PHY_UNSUP; + return; + } + + if (phy_rev != PHY_REVISION_ETH56G) { + hw->phy_model = ICE_PHY_UNSUP; + return; + } + } + + hw->phy_model = ICE_PHY_ETH56G; + + return; +e8xx: + + if (ice_is_e810(hw)) + hw->phy_model = ICE_PHY_E810; + else + hw->phy_model = ICE_PHY_E822; + hw->phy_ports = ICE_NUM_EXTERNAL_PORTS; + hw->max_phy_port = ICE_NUM_EXTERNAL_PORTS; +} + /** * ice_ptp_write_port_cmd - Prepare a single PHY port for a timer command * @hw: pointer to HW struct diff --git a/drivers/net/ice/base/ice_type.h b/drivers/net/ice/base/ice_type.h index c74da348a3..2754a5a7ca 100644 --- a/drivers/net/ice/base/ice_type.h +++ b/drivers/net/ice/base/ice_type.h @@ -1696,4 +1696,10 @@ struct ice_aq_get_set_rss_lut_params { /* AQ API version for FW auto drop reports */ #define ICE_FW_API_AUTO_DROP_MAJ 1 #define ICE_FW_API_AUTO_DROP_MIN 4 + +static inline bool +ice_is_nac_dual(struct ice_hw *hw) +{ + return !!(hw->dev_caps.nac_topo.mode & ICE_NAC_TOPO_DUAL_M); +} #endif /* _ICE_TYPE_H_ */ -- 2.43.0