Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp4471917ybz; Tue, 28 Apr 2020 11:52:27 -0700 (PDT) X-Google-Smtp-Source: APiQypJQslDb2dNRw6mKBSH2iATUwfTJ6mEcwwS8xtd0CNb8f72P/YeGrLwhuSnlGxofiZA5Z6ln X-Received: by 2002:a05:6402:1a49:: with SMTP id bf9mr14619929edb.189.1588099947630; Tue, 28 Apr 2020 11:52:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588099947; cv=none; d=google.com; s=arc-20160816; b=cO8E7XyI7/ektpiUYYMzqAyEeJbGBnlKW+iT9VKGSUHgdAEebfZMLVNbeltd2G2TXw 6xAzC2blWxDO73IKI/574tESuQzpQNQehkPpv0/ykLiWQM8DcPnUW5OfuI31XFR2BUj6 LIrCAWlHxrM9+ASTS4KGJ7vvNd1I7g6Q3ua6+k1GxROMP0Os5wVu1dNPk3jCesZ/A6np EfwexYZfQRzNQ1qv4R8jRvK8s1uimLpYedLApxQUDlgf4DrOjGPnDbOeH81L/002fV0g EyTKws9cnGh3oDOK9yNuy8uO5+6qA9E5qMe1IhR6M2UroVEOsKofDFCihx7SjMbIcQmP 58Dg== 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=mKdVJIpgmfW+CqLpi2jx1WN4LbCMs047HY1WnouTLQQ=; b=WBBRo/cus7j69i/MBUdSwfoQL9oqB+HOwlsh+nEJ5F7up/R3h6N7eMQvy0YgHN720q F1kJsoY6bfAXnsgn1IsUjpjTpjeJBFn98osXptKi7GNIRREUTG8F+sTzS6GOXPSOS9I4 nPd2sWKvoMugbPA+nmlw/rJo1UCBWkjAHzxY1sZM38BXs8As03+F4PblNsA+m8u1Py8I rFo9R/3QZProhIbaI/OhctJmZHJ35sVthe/0n46zACW9yFUGPmv0eAfP5BXTXub+pPds tbIUXcFDjKDUuOg9VdgiTG1Zga0DsuscMeVfXQZy8y5geu01bIUM4IvGkXuNhgdjCaEG FuCA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=1GQYsOeB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u10si2023062edl.591.2020.04.28.11.52.04; Tue, 28 Apr 2020 11:52:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=1GQYsOeB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730633AbgD1Sia (ORCPT + 99 others); Tue, 28 Apr 2020 14:38:30 -0400 Received: from mail.kernel.org ([198.145.29.99]:56914 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730629AbgD1Si1 (ORCPT ); Tue, 28 Apr 2020 14:38:27 -0400 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 8AA752085B; Tue, 28 Apr 2020 18:38:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1588099107; bh=/AT+BPEtbgPhVXoYP8gxORxx9FEIM787m91UbGqpI24=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=1GQYsOeBPNCxoqdYiba6MFwtdRgDF/ygM6b+1jBTK4uExxnNWVPAzrK2D211cWUBH 8eWMpH7u40w9qLuEDzW3eFRoT7BlaM8I8ZxzYKTM+p9UOSAm0R9EIXGfv8ctjeoSap Vle9qPd4CwJu8ec1jfXZkGMuYaRwv/T88VkEanJk= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Manoj Malviya , Rahul Lakkireddy , "David S. Miller" Subject: [PATCH 5.4 057/168] cxgb4: fix large delays in PTP synchronization Date: Tue, 28 Apr 2020 20:23:51 +0200 Message-Id: <20200428182239.139390413@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200428182231.704304409@linuxfoundation.org> References: <20200428182231.704304409@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: Rahul Lakkireddy [ Upstream commit bd019427bf3623ee3c7d2845cf921bbf4c14846c ] Fetching PTP sync information from mailbox is slow and can take up to 10 milliseconds. Reduce this unnecessary delay by directly reading the information from the corresponding registers. Fixes: 9c33e4208bce ("cxgb4: Add PTP Hardware Clock (PHC) support") Signed-off-by: Manoj Malviya Signed-off-by: Rahul Lakkireddy Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/ethernet/chelsio/cxgb4/cxgb4_ptp.c | 27 +++++-------------------- drivers/net/ethernet/chelsio/cxgb4/t4_regs.h | 3 ++ 2 files changed, 9 insertions(+), 21 deletions(-) --- a/drivers/net/ethernet/chelsio/cxgb4/cxgb4_ptp.c +++ b/drivers/net/ethernet/chelsio/cxgb4/cxgb4_ptp.c @@ -311,32 +311,17 @@ static int cxgb4_ptp_adjtime(struct ptp_ */ static int cxgb4_ptp_gettime(struct ptp_clock_info *ptp, struct timespec64 *ts) { - struct adapter *adapter = (struct adapter *)container_of(ptp, - struct adapter, ptp_clock_info); - struct fw_ptp_cmd c; + struct adapter *adapter = container_of(ptp, struct adapter, + ptp_clock_info); u64 ns; - int err; - memset(&c, 0, sizeof(c)); - c.op_to_portid = cpu_to_be32(FW_CMD_OP_V(FW_PTP_CMD) | - FW_CMD_REQUEST_F | - FW_CMD_READ_F | - FW_PTP_CMD_PORTID_V(0)); - c.retval_len16 = cpu_to_be32(FW_CMD_LEN16_V(sizeof(c) / 16)); - c.u.ts.sc = FW_PTP_SC_GET_TIME; - - err = t4_wr_mbox(adapter, adapter->mbox, &c, sizeof(c), &c); - if (err < 0) { - dev_err(adapter->pdev_dev, - "PTP: %s error %d\n", __func__, -err); - return err; - } + ns = t4_read_reg(adapter, T5_PORT_REG(0, MAC_PORT_PTP_SUM_LO_A)); + ns |= (u64)t4_read_reg(adapter, + T5_PORT_REG(0, MAC_PORT_PTP_SUM_HI_A)) << 32; /* convert to timespec*/ - ns = be64_to_cpu(c.u.ts.tm); *ts = ns_to_timespec64(ns); - - return err; + return 0; } /** --- a/drivers/net/ethernet/chelsio/cxgb4/t4_regs.h +++ b/drivers/net/ethernet/chelsio/cxgb4/t4_regs.h @@ -1900,6 +1900,9 @@ #define MAC_PORT_CFG2_A 0x818 +#define MAC_PORT_PTP_SUM_LO_A 0x990 +#define MAC_PORT_PTP_SUM_HI_A 0x994 + #define MPS_CMN_CTL_A 0x9000 #define COUNTPAUSEMCRX_S 5