Received: by 2002:ab2:6857:0:b0:1ef:ffd0:ce49 with SMTP id l23csp2530596lqp; Mon, 25 Mar 2024 01:19:48 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVr2k0Tb2qSNFRjfJTR2vcZObcFWzIKnIdelZahxlHlrthOAnjdKBdBYkyBKPujAfXbAvvnDBFAKuFoIEyZCTYLG+9Pd3ql5aZHD1FGZA== X-Google-Smtp-Source: AGHT+IH4egi89vDXkFjXVWijgmgiSWvj97dG1auieq44Nfg3/7XcFQ4Eh3wCLf2ZyItuGRTpFPp1 X-Received: by 2002:ac2:5bd0:0:b0:515:642a:a1df with SMTP id u16-20020ac25bd0000000b00515642aa1dfmr4744183lfn.63.1711354788739; Mon, 25 Mar 2024 01:19:48 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711354788; cv=pass; d=google.com; s=arc-20160816; b=I+aFSi+SxMhLgyTvAYCLAlFzLP0kRYgIzBNOKKJdCrw6IM0KETT2Q8KJcrF1zMeIrW R1O2t9/fCaEcW5DesZK1IupR8fTLISYGBqNs9Ps81BacB89kIm1fkacLtG2i32KfKuyh bCkVT1vVfSdVdRkFnOw2gMe9nt36vSbhEe6fv3/fj7Y34BdWdSl0sh8p8lz5GExS9oat UspwHQWTn5pJKXz/qcjhd2jN5MZzniA2Qdt0hSxZr3I+S/KiLuPfq33xcI7UpuVBM+lH C821tKczIrrU09D8GXUhsQwB3h3s9iQDslYOkisLCp/XEhJOrKyR2mkmPFB1I5IHILmN JpCg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=Y45DOvJv+2SuqJrTHMj3ccelHPtKCEBQnOkPlhf44Zg=; fh=/5s2GkpjZkZdVYuzgiU4iok3EiBCuQywL+upIups42Q=; b=px1AojnQq/PwMcDVcHjjlw4zmT/Hdc+MWcujWCNuADdqR50LQ7DWKBtp2szvRqXhtR h5K5WC1kvPeQHjHiRTOFYBbqmSg/r9hIsNuvkihextRa4HEEjj7QGBYfNLCfEPcbeTYg HUl4KEpr18jZH9iPggdk/G7/CfqACcg64jdeWe2A1cwl/phIaeY3CiQOOAYeV04LXwlC vF5hd/69OPFZhKfI16GCUgUGIqZCsUXFEdhMduudnyTTgwrf7WEvMN4qEXFxAYgwse6A eYP9Cb4OZIq+D3h/3+tKfOMleCh25/pOcll2TbglqQ/21tubomlYo6Hp7v0XHdlwMafk Unsw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=TghkjD04; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-116039-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-116039-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [2604:1380:4601:e00::3]) by mx.google.com with ESMTPS id p14-20020a170906228e00b00a4729ef35c3si2282244eja.65.2024.03.25.01.19.48 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 Mar 2024 01:19:48 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-116039-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) client-ip=2604:1380:4601:e00::3; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=TghkjD04; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-116039-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-116039-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id 753591F3054D for ; Mon, 25 Mar 2024 08:19:48 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 241E62720EC; Mon, 25 Mar 2024 03:28:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="TghkjD04" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 77D9C130A62; Sun, 24 Mar 2024 23:37:05 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711323426; cv=none; b=XpM/MAU1Tvv6NxaKtVIl5ZIlLidsJB1R/X2+fHsSFZ7AW8LKoudlW56jmUuCjElbMSYSBTl2b4KsyzEH2kd5eVM8Cd4B44iTJKtn2RJ7WbHNB0NUW4POCCjAO2vBbgZMAQUA6C9oJ4iM9hKdWNQnB8J4tNfaTct10mkzIix6vuQ= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711323426; c=relaxed/simple; bh=xkio9LXk8a0yfT3MbDjP1BmFDPz+zLGtJQWcPfiV0CI=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=RheqyF95/w2/U4UKEMx0byyOAtfYP3KWM9XX82V6E3napSAQ7/l+m1iFNOo3E/WMCSUtnxrbDy9zjje6iR3FM3RgOVkuut1cdSgLlo60YrwXKhBVIBYiwFLKhHlk+OgQQiQjUo5lKzyGEzPdHCojMBDl0t+TewMcQj0pKGhybuU= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=TghkjD04; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 8DA55C43390; Sun, 24 Mar 2024 23:37:04 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1711323425; bh=xkio9LXk8a0yfT3MbDjP1BmFDPz+zLGtJQWcPfiV0CI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=TghkjD04cLSSD4KJzUi1tHE3Vfs91rqI3yoVyFGc+aQ7lICj6Vx9PgyTE8Rr6xebS sJnPXxMXlvdDu6DWDzpxBmAy6chv0ISeo4xsPtrIo/UCcwbOkl51UaDBkkpkGDI22a fz/Zz0fKJyyBYevwo3ZqQSwI+Py4MFHLxoVHN2THMi+QW2jWk8SKGZTLpGQ1A0ZiIf 14wgy6+Kdy57Yl8ebGQbI7bqUgrrnQpcubXD/2K3xorytycedhwf2cwCSIpHSryCvy OOdhwUmvApg7bEL70gmGXQLXs1M8y8pl+rUD7zg7MxYuAhduYu4J/+fGs1pHyeBmcD 5Oxt8rY9gnqKA== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Vinicius Costa Gomes , Richard Cochran , Pucha Himasekhar Reddy , Tony Nguyen , Sasha Levin Subject: [PATCH 5.15 127/317] igb: Fix missing time sync events Date: Sun, 24 Mar 2024 19:31:47 -0400 Message-ID: <20240324233458.1352854-128-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240324233458.1352854-1-sashal@kernel.org> References: <20240324233458.1352854-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit From: Vinicius Costa Gomes [ Upstream commit ee14cc9ea19ba9678177e2224a9c58cce5937c73 ] Fix "double" clearing of interrupts, which can cause external events or timestamps to be missed. The E1000_TSIRC Time Sync Interrupt Cause register can be cleared in two ways, by either reading it or by writing '1' into the specific cause bit. This is documented in section 8.16.1. The following flow was used: 1. read E1000_TSIRC into 'tsicr'; 2. handle the interrupts present into 'tsirc' and mark them in 'ack'; 3. write 'ack' into E1000_TSICR; As both (1) and (3) will clear the interrupt cause, if the same interrupt happens again between (1) and (3) it will be ignored, causing events to be missed. Remove the extra clear in (3). Fixes: 00c65578b47b ("igb: enable internal PPS for the i210") Acked-by: Richard Cochran Signed-off-by: Vinicius Costa Gomes Tested-by: Pucha Himasekhar Reddy (A Contingent worker at Intel) Signed-off-by: Tony Nguyen Signed-off-by: Sasha Levin --- drivers/net/ethernet/intel/igb/igb_main.c | 23 +++++------------------ 1 file changed, 5 insertions(+), 18 deletions(-) diff --git a/drivers/net/ethernet/intel/igb/igb_main.c b/drivers/net/ethernet/intel/igb/igb_main.c index eec0ad98c445f..03a4da6a14478 100644 --- a/drivers/net/ethernet/intel/igb/igb_main.c +++ b/drivers/net/ethernet/intel/igb/igb_main.c @@ -6800,44 +6800,31 @@ static void igb_extts(struct igb_adapter *adapter, int tsintr_tt) static void igb_tsync_interrupt(struct igb_adapter *adapter) { struct e1000_hw *hw = &adapter->hw; - u32 ack = 0, tsicr = rd32(E1000_TSICR); + u32 tsicr = rd32(E1000_TSICR); struct ptp_clock_event event; if (tsicr & TSINTR_SYS_WRAP) { event.type = PTP_CLOCK_PPS; if (adapter->ptp_caps.pps) ptp_clock_event(adapter->ptp_clock, &event); - ack |= TSINTR_SYS_WRAP; } if (tsicr & E1000_TSICR_TXTS) { /* retrieve hardware timestamp */ schedule_work(&adapter->ptp_tx_work); - ack |= E1000_TSICR_TXTS; } - if (tsicr & TSINTR_TT0) { + if (tsicr & TSINTR_TT0) igb_perout(adapter, 0); - ack |= TSINTR_TT0; - } - if (tsicr & TSINTR_TT1) { + if (tsicr & TSINTR_TT1) igb_perout(adapter, 1); - ack |= TSINTR_TT1; - } - if (tsicr & TSINTR_AUTT0) { + if (tsicr & TSINTR_AUTT0) igb_extts(adapter, 0); - ack |= TSINTR_AUTT0; - } - if (tsicr & TSINTR_AUTT1) { + if (tsicr & TSINTR_AUTT1) igb_extts(adapter, 1); - ack |= TSINTR_AUTT1; - } - - /* acknowledge the interrupts */ - wr32(E1000_TSICR, ack); } static irqreturn_t igb_msix_other(int irq, void *data) -- 2.43.0