Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp6031874ybc; Wed, 27 Nov 2019 13:45:11 -0800 (PST) X-Google-Smtp-Source: APXvYqwRWFLRC9fDTJ7yAJ4EBD+yZv4LjK9P0CKJ8gbYt6jO0lv6aKR/YPAZxSawvVSoPTGRcjVf X-Received: by 2002:a17:906:32d3:: with SMTP id k19mr51215892ejk.75.1574891111407; Wed, 27 Nov 2019 13:45:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574891111; cv=none; d=google.com; s=arc-20160816; b=ZO1cNeS1DIcRZ8fIlj1DcVMHS1uWe0qYvWzHMKIvC78GEOtkidP56sQWI9tyOn7WMh CBlFGJ1YAtgtz6bDOfTYRVv817yetJCzgR/X1DrklfpiqKx8V3Uwf5isoI7LVs7HPlsJ dbvgiZ3JyJ1kwOv/o47UD86PQM3meUlhDfMPw7JDW6wzzJsCF8gjT24P8b3GHOcyXes4 hYtsFRpUkCJaFgUHId5cDeaTW20NXrZFreL95O1bGHZr/aKxElyTetKaapn1pP9UYyq7 xKzPA5+LLK97r80lgnRLeSJoyFPHVgJIP4XWGHISfhV8SNrMAIXKknzJrB96K6GqVKra F9bQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=84knfPhdwkvm0UpGQmqFXF9MeBHfEw46cJC5G716lNw=; b=eyawRaX8ifVIiDPUA5g2Wff9Mpf4bRlnjybLQx3fFdU1+EMNgiwvcqioVHlWe6Ajk/ OeX8edBVHHGYCPt3wX5jtkufwRmjagGz3utk8tEMkvPnxZPbsOkBI4LtJdri9WjEW91V D6w/zbaJRNA/mw4uKRZIiJpF8+g+lojP+GqQgBVtIfCoKBb2CC6fcJFMZvDaGuvEhe8E cmiHaZO2Uk1F5jST+vGaQNMrE3fPbTrwQQIdXFZ7gUVAnBd+pamesY3FpfB+3sYXgaUI 76Rhlnpci5VvYnMxpBP4vLFlLeLsPtkrCjw0IgksKK8H86B6Nnx3Se+2iFz4nEK5wMWg bf5Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=xF7guyWL; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q6si9907314eja.282.2019.11.27.13.44.47; Wed, 27 Nov 2019 13:45:11 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=xF7guyWL; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729661AbfK0Vkl (ORCPT + 99 others); Wed, 27 Nov 2019 16:40:41 -0500 Received: from mail.kernel.org ([198.145.29.99]:49230 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729345AbfK0Umk (ORCPT ); Wed, 27 Nov 2019 15:42:40 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id C4C3E21787; Wed, 27 Nov 2019 20:42:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1574887359; bh=uOQtTCLHEwtW2ut6Q0nPb0g093HpDJgAfOS0CS1GpVI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=xF7guyWLGVGrTPmCxHpslmFtoXAUeRdkc82UQOrOmF7o/nkDMIEn2qi7iVcQAvvaF kCZ7u5Ihzd1c3g8VbjHp/2ByVtaaVJ0hyrjdXH67oOw1Qlpko72uwyzCvpucjuklFm ENQVn3jsf1nFxQDM2LGUQ8W87n9TLmy9jYhO+icw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jacob Keller , Richard Cochran , Thomas Gleixner , Miroslav Lichvar , Aaron Brown , Jeff Kirsher , Sasha Levin Subject: [PATCH 4.9 081/151] igb: shorten maximum PHC timecounter update interval Date: Wed, 27 Nov 2019 21:31:04 +0100 Message-Id: <20191127203035.945658108@linuxfoundation.org> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191127203000.773542911@linuxfoundation.org> References: <20191127203000.773542911@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Miroslav Lichvar [ Upstream commit 094bf4d0e9657f6ea1ee3d7e07ce3970796949ce ] The timecounter needs to be updated at least once per ~550 seconds in order to avoid a 40-bit SYSTIM timestamp to be misinterpreted as an old timestamp. Since commit 500462a9d ("timers: Switch to a non-cascading wheel"), scheduling of delayed work seems to be less accurate and a requested delay of 540 seconds may actually be longer than 550 seconds. Shorten the delay to 480 seconds to be sure the timecounter is updated in time. This fixes an issue with HW timestamps on 82580/I350/I354 being off by ~1100 seconds for few seconds every ~9 minutes. Cc: Jacob Keller Cc: Richard Cochran Cc: Thomas Gleixner Signed-off-by: Miroslav Lichvar Tested-by: Aaron Brown Signed-off-by: Jeff Kirsher Signed-off-by: Sasha Levin --- drivers/net/ethernet/intel/igb/igb_ptp.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/drivers/net/ethernet/intel/igb/igb_ptp.c b/drivers/net/ethernet/intel/igb/igb_ptp.c index 9eb9b68f8935e..ae1f963b60923 100644 --- a/drivers/net/ethernet/intel/igb/igb_ptp.c +++ b/drivers/net/ethernet/intel/igb/igb_ptp.c @@ -65,9 +65,15 @@ * * The 40 bit 82580 SYSTIM overflows every * 2^40 * 10^-9 / 60 = 18.3 minutes. + * + * SYSTIM is converted to real time using a timecounter. As + * timecounter_cyc2time() allows old timestamps, the timecounter + * needs to be updated at least once per half of the SYSTIM interval. + * Scheduling of delayed work is not very accurate, so we aim for 8 + * minutes to be sure the actual interval is shorter than 9.16 minutes. */ -#define IGB_SYSTIM_OVERFLOW_PERIOD (HZ * 60 * 9) +#define IGB_SYSTIM_OVERFLOW_PERIOD (HZ * 60 * 8) #define IGB_PTP_TX_TIMEOUT (HZ * 15) #define INCPERIOD_82576 BIT(E1000_TIMINCA_16NS_SHIFT) #define INCVALUE_82576_MASK GENMASK(E1000_TIMINCA_16NS_SHIFT - 1, 0) -- 2.20.1