Received: by 2002:a05:7412:419a:b0:f3:1519:9f41 with SMTP id i26csp3711924rdh; Tue, 28 Nov 2023 01:29:55 -0800 (PST) X-Google-Smtp-Source: AGHT+IF1VhYH1D2ZIM3oGzhwdR67xDJXFP8NluPe+GtOYGEGUXEjdJbjocI3zi7PTXXCAL1vxE7e X-Received: by 2002:a92:d98b:0:b0:35d:1ea0:f253 with SMTP id r11-20020a92d98b000000b0035d1ea0f253mr309742iln.20.1701163795558; Tue, 28 Nov 2023 01:29:55 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701163795; cv=none; d=google.com; s=arc-20160816; b=kvE5nvckdEcrfIbgrftUTrAP+8T1p4KDF4mN4KG1Cxhqp6iqjy8YFxGweD5r88sELN FB8xJMLSu2TqsP1wnPCjYia5Rcxa+WtXBXbgvxKUUXc+niFShqAmM2TRFgbVYqiV+Xnc gsSJ7cynjnGE8FFtRqC4L/YpL76nrzH6QQNDk0GGqeo6ybNtK7qmrBNP5WSI7xs6pmkD sqCA90WTZrqNtGjVxnPP2yIVXV4h560c2GCcqLbo3wyaXdkEjgt6dqxeDizAAYwSJrz3 oBRhqXMueF6lYzb6EuaEKa0wohGWmA31Edt5s3tqzWNEXEM4dWOo2OSGZ31N8nEO+cdg 4QAw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent :content-transfer-encoding:references:in-reply-to:date:cc:to:from :subject:message-id:dkim-signature; bh=qqtlxM7GFQZXHgjH0zB9XWmn8WNFIyJK5XRONp7hXak=; fh=G9cOrn+VgNEXERVWr5vBSag3glAXWCzIEi7jONTa3Yg=; b=Yc5OI30GXq1iqp1gfxzNLWOxLwae6+P8yg2vM9+/9n5R6b27nYcldJN88PdjlruYDq LdQhHG/rBrnxJ4jEfJsHkOcARqHRJQiUoX94z1+lzY1ladvsP+oi7A/c8QNzhXWRGQoR VUW7k30TSVWk1SltDMevZSqbWYiDPz6g4sXnYH+c6TekO5P0vsFlTK0oSMQHDYyq37YV BscfQCWd2sUvVmo8o/KAFaP9rruqFSgbzDwaT734yrwLoiA4kv+jjIUn49auYRAL6T8Q CgDeq0WxBF30DXEC0ZvxNIUEO8PYFkacdSLc5FLpW21WLsxz7q3ufTzrBgsrToKhlpy7 VR/Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=UDrH1IrH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from groat.vger.email (groat.vger.email. [23.128.96.35]) by mx.google.com with ESMTPS id x9-20020a63fe49000000b005bddb417affsi11615444pgj.291.2023.11.28.01.29.55 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 28 Nov 2023 01:29:55 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) client-ip=23.128.96.35; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=UDrH1IrH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by groat.vger.email (Postfix) with ESMTP id 13EA3809B75A; Tue, 28 Nov 2023 01:29:53 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at groat.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234626AbjK1J3f (ORCPT + 99 others); Tue, 28 Nov 2023 04:29:35 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60046 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230298AbjK1J3e (ORCPT ); Tue, 28 Nov 2023 04:29:34 -0500 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D121FDA for ; Tue, 28 Nov 2023 01:29:40 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1701163780; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=qqtlxM7GFQZXHgjH0zB9XWmn8WNFIyJK5XRONp7hXak=; b=UDrH1IrHyDzYV9jYQhChQ9x+3mqQdIbI0+1HsK19FtWBugBTqwtS5ptwITjpe0rRFBKBcu /msvrIG7yMnruSI7wl8sqAfj/c6CG/WJpurZRq6GTe9mu/d92om30gOePWhj6/l8BMTCf2 pBlj0wHiFKXW1cxv8iB42dVoW0NUiPQ= Received: from mail-ed1-f69.google.com (mail-ed1-f69.google.com [209.85.208.69]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-170-ssCoMIRIPmK3WJQw_Zz3Ew-1; Tue, 28 Nov 2023 04:29:36 -0500 X-MC-Unique: ssCoMIRIPmK3WJQw_Zz3Ew-1 Received: by mail-ed1-f69.google.com with SMTP id 4fb4d7f45d1cf-5450c83aa5dso468290a12.0 for ; Tue, 28 Nov 2023 01:29:36 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1701163775; x=1701768575; h=mime-version:user-agent:content-transfer-encoding:references :in-reply-to:date:cc:to:from:subject:message-id:x-gm-message-state :from:to:cc:subject:date:message-id:reply-to; bh=qqtlxM7GFQZXHgjH0zB9XWmn8WNFIyJK5XRONp7hXak=; b=wPyYQvOs9xBhvJ7qxFCjyV5d9wMKQo2gr7FhVmoLOwItXW+VM904Xq5rsnnY5qgTtK LyuvPhNcPL4RIYDYKU5+XJpoYQGWozzdLh0zVxG8igESrQsccZh6+ObfEuwxRE/PGe7P TMsKRZGUmXLq3FpTtD0g0Mq9IOxJdC4cKbo1ukxxEJ6oZ9vyHn2RjJv8T/MnsS58JxIh v2S0YTmRfFeoi0zwYWCSS8Z5TM59dy1sPiJ06+XudrVWT8L2CZk1ulC1lkr3iIFHn5iM Oh0pZZy4qfcclgDr1FbSdy+0YOBgP0KzzM0eH4TvYBmSWQlq+UFnHKTp3WYDgti7IiFJ Hm0g== X-Gm-Message-State: AOJu0YxisCE7LZ7lfVnli0LBK+R6DsH5vgCfvw3L4GBWc4L5RWzp1eNX 8CrcxhIq0yzynSVAQkLBjDe06/uO96jNupRH0hZOckZn3F04BDFVm/dlaaG3SGyheQUsmq00XYO OV+bVjMWYMlrHGbKRZqf5cH2E X-Received: by 2002:a05:6402:513:b0:54b:5052:e8dc with SMTP id m19-20020a056402051300b0054b5052e8dcmr4917096edv.1.1701163775087; Tue, 28 Nov 2023 01:29:35 -0800 (PST) X-Received: by 2002:a05:6402:513:b0:54b:5052:e8dc with SMTP id m19-20020a056402051300b0054b5052e8dcmr4917076edv.1.1701163774737; Tue, 28 Nov 2023 01:29:34 -0800 (PST) Received: from gerbillo.redhat.com (146-241-249-156.dyn.eolo.it. [146.241.249.156]) by smtp.gmail.com with ESMTPSA id c21-20020a056402101500b0053e5f67d637sm6108032edu.9.2023.11.28.01.29.33 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 28 Nov 2023 01:29:34 -0800 (PST) Message-ID: <5e8d805ba8e033d495c879d1f58c90dc1f3ea23b.camel@redhat.com> Subject: Re: [PATCH net-next v5 1/1] ptp: clockmatrix: support 32-bit address space From: Paolo Abeni To: Min Li , richardcochran@gmail.com, lee@kernel.org Cc: linux-kernel@vger.kernel.org, netdev@vger.kernel.org, Min Li Date: Tue, 28 Nov 2023 10:29:32 +0100 In-Reply-To: References: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable User-Agent: Evolution 3.46.4 (3.46.4-1.fc37) MIME-Version: 1.0 X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on groat.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (groat.vger.email [0.0.0.0]); Tue, 28 Nov 2023 01:29:53 -0800 (PST) Hi, I'm sorry for the late feedback, I have a few comments below... On Fri, 2023-11-24 at 15:20 -0500, Min Li wrote: > From: Min Li >=20 > We used to assume 0x2010xxxx address. Now that > we need to access 0x2011xxxx address, we need > to support read/write the whole 32-bit address space. >=20 > Signed-off-by: Min Li > --- > - Drop MAX_ABS_WRITE_PHASE_PICOSECONDS advised by Rahul > - Apply SCSR_ADDR to scrach register in idtcm_load_firmware advised by Si= mon > - Apply u32 to base in idtcm_output_enable advised by Simon > - Correct sync_ctrl0/1 parameter position for idtcm_write advised by Simo= n > - Restore adjphase function suggested by Rahul >=20 > drivers/ptp/ptp_clockmatrix.c | 69 ++-- > drivers/ptp/ptp_clockmatrix.h | 32 +- > include/linux/mfd/idt8a340_reg.h | 542 ++++++++++++++++--------------- > 3 files changed, 329 insertions(+), 314 deletions(-) >=20 > diff --git a/drivers/ptp/ptp_clockmatrix.c b/drivers/ptp/ptp_clockmatrix.= c > index f6f9d4adce04..8a48214adc26 100644 > --- a/drivers/ptp/ptp_clockmatrix.c > +++ b/drivers/ptp/ptp_clockmatrix.c > @@ -41,7 +41,7 @@ module_param(firmware, charp, 0); > static int _idtcm_adjfine(struct idtcm_channel *channel, long scaled_ppm= ); > =20 > static inline int idtcm_read(struct idtcm *idtcm, > - u16 module, > + u32 module, > u16 regaddr, If you change 'regaddr' type to u32, that will allow reducing some relevant 'noise' in the chunks below, avoid swapping the 'mudule' and 'regaddr' arguments from the callers. Such mentioned chunks are IMHO quite confusing/counter-intuitive, it would be better get rid of them regardless of the better diffstat. > u8 *buf, > u16 count) > @@ -50,7 +50,7 @@ static inline int idtcm_read(struct idtcm *idtcm, > } > =20 > static inline int idtcm_write(struct idtcm *idtcm, > - u16 module, > + u32 module, > u16 regaddr, Same here. > u8 *buf, > u16 count) > @@ -1395,6 +1396,20 @@ static int idtcm_set_pll_mode(struct idtcm_channel= *channel, > struct idtcm *idtcm =3D channel->idtcm; > int err; > u8 dpll_mode; > + u8 timeout =3D 0; > + > + /* Setup WF/WP timer for phase pull-in to work correctly */ > + err =3D idtcm_write(idtcm, channel->dpll_n, DPLL_WF_TIMER, > + &timeout, sizeof(timeout)); > + if (err) > + return err; > + > + if (mode =3D=3D PLL_MODE_WRITE_PHASE) > + timeout =3D 160; > + err =3D idtcm_write(idtcm, channel->dpll_n, DPLL_WP_TIMER, > + &timeout, sizeof(timeout)); > + if (err) > + return err; > =20 > err =3D idtcm_read(idtcm, channel->dpll_n, > IDTCM_FW_REG(idtcm->fw_ver, V520, DPLL_MODE), I think this chunk could/should go in a different patch: a first one is implementing the support for 32 bit address space, a 2nd is leveraging it to configure the PLL correctly. Cheers, Paolo