mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-10 12:57:06 +09:00
ice: check the return of ice_ptp_gettimex64
commited22d9c8d1upstream. Clang static analysis reports this issue time64.h:69:50: warning: The left operand of '+' is a garbage value set_normalized_timespec64(&ts_delta, lhs.tv_sec + rhs.tv_sec, ~~~~~~~~~~ ^ In ice_ptp_adjtime_nonatomic(), the timespec64 variable 'now' is set by ice_ptp_gettimex64(). This function can fail with -EBUSY, so 'now' can have a gargbage value. So check the return. Fixes:06c16d89d2("ice: register 1588 PTP clock device object for E810 devices") Signed-off-by: Tom Rix <trix@redhat.com> Tested-by: Gurucharan G <gurucharanx.g@intel.com> (A Contingent worker at Intel) Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
7e8da99644
commit
b3615ea66b
@@ -846,9 +846,12 @@ exit:
|
||||
static int ice_ptp_adjtime_nonatomic(struct ptp_clock_info *info, s64 delta)
|
||||
{
|
||||
struct timespec64 now, then;
|
||||
int ret;
|
||||
|
||||
then = ns_to_timespec64(delta);
|
||||
ice_ptp_gettimex64(info, &now, NULL);
|
||||
ret = ice_ptp_gettimex64(info, &now, NULL);
|
||||
if (ret)
|
||||
return ret;
|
||||
now = timespec64_add(now, then);
|
||||
|
||||
return ice_ptp_settime64(info, (const struct timespec64 *)&now);
|
||||
|
||||
Reference in New Issue
Block a user