diff options
Diffstat (limited to 'drivers/net/ethernet/intel/ice/ice_ptp.c')
| -rw-r--r-- | drivers/net/ethernet/intel/ice/ice_ptp.c | 32 | 
1 files changed, 16 insertions, 16 deletions
| diff --git a/drivers/net/ethernet/intel/ice/ice_ptp.c b/drivers/net/ethernet/intel/ice/ice_ptp.c index 74de7d8b17ac..a999fface272 100644 --- a/drivers/net/ethernet/intel/ice/ice_ptp.c +++ b/drivers/net/ethernet/intel/ice/ice_ptp.c @@ -2857,10 +2857,8 @@ static int ice_ptp_rebuild_owner(struct ice_pf *pf)  	/* Write the increment time value to PHY and LAN */  	err = ice_ptp_write_incval(hw, ice_base_incval(pf)); -	if (err) { -		ice_ptp_unlock(hw); -		return err; -	} +	if (err) +		goto err_unlock;  	/* Write the initial Time value to PHY and LAN using the cached PHC  	 * time before the reset and time difference between stopping and @@ -2873,10 +2871,8 @@ static int ice_ptp_rebuild_owner(struct ice_pf *pf)  		ts = ktime_to_timespec64(ktime_get_real());  	}  	err = ice_ptp_write_init(pf, &ts); -	if (err) { -		ice_ptp_unlock(hw); -		return err; -	} +	if (err) +		goto err_unlock;  	/* Release the global hardware lock */  	ice_ptp_unlock(hw); @@ -2900,6 +2896,10 @@ static int ice_ptp_rebuild_owner(struct ice_pf *pf)  	ice_ptp_enable_all_extts(pf);  	return 0; + +err_unlock: +	ice_ptp_unlock(hw); +	return err;  }  /** @@ -3032,18 +3032,14 @@ static int ice_ptp_init_owner(struct ice_pf *pf)  	/* Write the increment time value to PHY and LAN */  	err = ice_ptp_write_incval(hw, ice_base_incval(pf)); -	if (err) { -		ice_ptp_unlock(hw); -		goto err_exit; -	} +	if (err) +		goto err_unlock;  	ts = ktime_to_timespec64(ktime_get_real());  	/* Write the initial Time value to PHY and LAN */  	err = ice_ptp_write_init(pf, &ts); -	if (err) { -		ice_ptp_unlock(hw); -		goto err_exit; -	} +	if (err) +		goto err_unlock;  	/* Release the global hardware lock */  	ice_ptp_unlock(hw); @@ -3063,6 +3059,10 @@ err_clk:  	pf->ptp.clock = NULL;  err_exit:  	return err; + +err_unlock: +	ice_ptp_unlock(hw); +	return err;  }  /** | 
