• Siddaraju DH's avatar
    ice: make Tx and Rx vernier offset calibration independent · f029a343
    Siddaraju DH authored
    The Tx and Rx calibration and timestamp generation blocks are independent.
    However, the ice driver waits until both blocks are ready before
    configuring either block.
    
    This can result in delay of configuring one block because we have not yet
    received a packet in the other block.
    
    There is no reason to wait to finish programming Tx just because we haven't
    received a packet. Similarly there is no reason to wait to program Rx just
    because we haven't transmitted a packet.
    
    Instead of checking both offset status before programming either block,
    refactor the ice_phy_cfg_tx_offset_e822 and ice_phy_cfg_rx_offset_e822
    functions so that they perform their own offset status checks.
    Additionally, make them also check the offset ready bit to determine if
    the offset values have already been programmed.
    
    Call the individual configure functions directly in
    ice_ptp_wait_for_offset_valid. The functions will now correctly check
    status, and program the offsets if ready. Once the offset is programmed,
    the functions will exit quickly after just checking the offset ready
    register.
    
    Remove the ice_phy_calc_vernier_e822 in ice_ptp_hw.c, as well as the offset
    valid check functions in ice_ptp.c entirely as they are no longer
    necessary.
    
    With this change, the Tx and Rx blocks will each be enabled as soon as
    possible without waiting for the other block to complete calibration. This
    can enable timestamps faster in setups which have a low rate of transmitted
    or received packets. In particular, it can stop a situation where one port
    never receives traffic, and thus never finishes calibration of the Tx
    block, resulting in continuous faults reported by the ptp4l daemon
    application.
    Signed-off-by: default avatarSiddaraju DH <siddaraju.dh@intel.com>
    Signed-off-by: default avatarJacob Keller <jacob.e.keller@intel.com>
    Tested-by: Gurucharan G <gurucharanx.g@intel.com> (A Contingent worker at Intel)
    Signed-off-by: default avatarTony Nguyen <anthony.l.nguyen@intel.com>
    f029a343
ice_ptp_hw.c 89.8 KB