Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp4449845ybz; Tue, 28 Apr 2020 11:30:08 -0700 (PDT) X-Google-Smtp-Source: APiQypJBF7FJNV5/kUyYgB6ZM70Fkcs6jONU9bt8g7q/KZOhegzoRvjDLBt+9mHO7rgHRI6UaR29 X-Received: by 2002:aa7:cb43:: with SMTP id w3mr23250370edt.95.1588098608775; Tue, 28 Apr 2020 11:30:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588098608; cv=none; d=google.com; s=arc-20160816; b=LJJhr2ZdLGzZg8+Cx+9qi7fHcOBJxPUhSbfxJCAQNrP0vFojfFA/uAlN6h74AANpDy wfRJBCTHyfEVUCe6cJvbKRlYfrS+Bwitgu3EI0vw1upaoOUYQ8tiX/8W6ZIbvuANRNAD L5gP5RHyFBNhTXHoNY4FF/XJAz3J3igA/+bxZN8wGKtRHzw1Y89sVB55IKDhzwdtjK2+ X9t8csP+oGeLNAfU9PuAIXd9ZcIKKX6dQnWAsoPQZXCM6wwV6M3/sMXp7gZD7wXQfYtv WLLLuG316ETJs6Md+/PBeXdCka+gduMhid5SdwC7kPvhK2qSJpHqeQZ10VEVIxet5k/K vzEg== 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=J2RwgpFzKDvRjLHUAXBMj92jBNhak2vT94lJa6Uaf523K/cvK/s/CeroZjwhYuJy7X +64EryeLQfJHUdNg7am8J37eBQjMXRtpaZsAEI9mH4KXOlFlvf9Mg6x7wcyEdkCW8i90 IlujPXmRmJLbh1gBL2tKRDh5eIuOldDEnNE8zSwY6lFSGMcKYhUS9QT/JESjRUsgSGkq cgOjl2OuQ+mkencwF8sfHq+VqwvAzj/0qnXmmPMtPgGeqAyonCBIONbzWzEd0cF3D+pE vw990RrpVhVcZBaMiqLKOmWByg6NEn0db+FUwg1jSP7Ct22WcHFpR1KSa3Fka4ufB0Jj JLMg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=yf3fobAA; 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 h24si1949999edv.469.2020.04.28.11.29.45; Tue, 28 Apr 2020 11:30:08 -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=yf3fobAA; 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 S1729040AbgD1S1l (ORCPT + 99 others); Tue, 28 Apr 2020 14:27:41 -0400 Received: from mail.kernel.org ([198.145.29.99]:39754 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729004AbgD1S1c (ORCPT ); Tue, 28 Apr 2020 14:27:32 -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 386F2208E0; Tue, 28 Apr 2020 18:27:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1588098451; bh=/AT+BPEtbgPhVXoYP8gxORxx9FEIM787m91UbGqpI24=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=yf3fobAAQPdSuyI2jB6c8/oW6LbjDsL9ajGiiA4ezhNMon4fSY/2pXQyYyTIV/Kbi UB9CmxU1VakV/MZ34C6qgTOFNSNFHAPKvFfZKJ3cITNYyWVwhSw1PSDssIJDGALK5Z SwbGtuF+ILlzZooEVH/JGOa3l3Ot294e8UayuyDs= 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.6 046/167] cxgb4: fix large delays in PTP synchronization Date: Tue, 28 Apr 2020 20:23:42 +0200 Message-Id: <20200428182230.896691289@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200428182225.451225420@linuxfoundation.org> References: <20200428182225.451225420@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