Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp2932451pxb; Mon, 18 Oct 2021 05:05:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzOcdvthHP6/NbYPOi81OOIZqWFLIkfOlBWSLlxsiR58GXQn8+HocFBKhI8vn1vTYuOZege X-Received: by 2002:a17:90b:1d85:: with SMTP id pf5mr32425948pjb.64.1634558703901; Mon, 18 Oct 2021 05:05:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634558703; cv=none; d=google.com; s=arc-20160816; b=sdW/nERaXEUBOrXCmxzChEw6EB9h8msNxjNcjxLKSa/3eJroYwebaJy+2RLGnRxAYb xVOtqhD1ldCCJZC4NrgcPlnOxCXtuFJoMHi0PuAx2FZNiP0Pr2OKrCakgXLgjyTgH9vz 6SHmxLFulR/H67DC83D95rYQGB8hOO+5wt5znVXRAE4M7AcenOIhRiEpyWXI7LMIQAKJ Gy90TvY64d/9wRKasCEsezKpGpHxrZemtk8/l8EQZLbljEUpSxhReWMjTWmW4KKqqTgJ kHm0WCB2UyHMr/sbctkp5pDolIwFobDIdWTvGMEyO+o5Q0XLmy61Bke9g+2atZv9aglw bJ7g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:in-reply-to:date:subject :cc:to:from:user-agent:references:dkim-signature; bh=Nce8CnTyXfjSYzZLWq3ZfLvVXKy7UFb5OiCTyZIfNRc=; b=Vvx/Xk9DqvbX3nNaHgDO5TGCkccfkZx2WVO+Z/TwfJDpsame5h9w7GB+0aVbxjnm1Y 9oqcmYggCV/dE1ATmu7pKOwWRlMTsWhuDuwjJac6SRGCNOiAPJjSVx81ShAW39RAS168 GKWBFx50ey9af+iZZLF/FfZjWo0xAAvYNeiv8H98UyFt02qksFX6B8xMXyjV9XnuFhso Xm0D0VMM3ZoMJYAD19Wxlqw8V8TXlY5/JI8BNX3/SAE55ffa+1DD51YKHno7BUvm/KXA T9dybqR8v4pnARHLtmIddkSJjhT1X5MLHK0arFJtC4rCShzM+kapRHi4FNJNKjUIJUVc 6UGg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20210112.gappssmtp.com header.s=20210112 header.b=Y4CMeyS1; 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 c8si28439440pjq.55.2021.10.18.05.04.50; Mon, 18 Oct 2021 05:05:03 -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=@baylibre-com.20210112.gappssmtp.com header.s=20210112 header.b=Y4CMeyS1; 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 S231167AbhJRMFo (ORCPT + 99 others); Mon, 18 Oct 2021 08:05:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42732 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229519AbhJRMFo (ORCPT ); Mon, 18 Oct 2021 08:05:44 -0400 Received: from mail-wr1-x433.google.com (mail-wr1-x433.google.com [IPv6:2a00:1450:4864:20::433]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 08BE5C06161C for ; Mon, 18 Oct 2021 05:03:33 -0700 (PDT) Received: by mail-wr1-x433.google.com with SMTP id r10so40861441wra.12 for ; Mon, 18 Oct 2021 05:03:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20210112.gappssmtp.com; s=20210112; h=references:user-agent:from:to:cc:subject:date:in-reply-to :message-id:mime-version; bh=Nce8CnTyXfjSYzZLWq3ZfLvVXKy7UFb5OiCTyZIfNRc=; b=Y4CMeyS1ouEtK5Ad+kDBkh67k4nmqAkkPHRJPN9dpWDa+uGSy2Z3Zeav22R8cZljbP tuxsJMy9ET32WGEOrUkKL6N/emDzt7NZxLDeJs62Ulv2MFF16CZT3Lm5+0p3+JEqmJ7t wX8kqnSv5BBP+GTXhwXtDfLJvXfBL+LVxayBomhNpSAX1H7JA6jjC3glDocERmmgwHgK wZezYIzYz1eMjupsn5JFEk8WgTemVvWdUrGeS+IKqh6fIB5ZsjZ9Y2MlGaCJqIlV06is fnvhWrU2IPtjklJkfHCc9IgvttnFZ57OnMbevVXhgfoCl7DwRXjVhLV6rmADRxOt8uaE ZU7w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:references:user-agent:from:to:cc:subject:date :in-reply-to:message-id:mime-version; bh=Nce8CnTyXfjSYzZLWq3ZfLvVXKy7UFb5OiCTyZIfNRc=; b=8Ne/GXHORzKe9mK1/Atbd+Zj/aYvjCmPh15ATJ+zCIrbvpBUqhCTY2VALv+OLOBMdj 3bOoYEHmr6j6hA1WkqEvpziRU1dooG79DCP2hqDqGFrR8IoWOGTh8KQU5fih59aPyOkB EjsKTbqhiE+TwP0LIc225/pfYPxnk2fzmUxXXHrEGwgkzvioo8Xf+skDKHjQqlt16frB WyCPWAXMchJGSp6UmG9+eeOXetOupx5Qcdh/OGF4LAOB9resG0efcnYmCC/Z0XAdOVmi XCFaDTMS81HZc9txzL/IFcS38sPBaFiaaTzkfF8zbx7iME0CWLGZNRGlq2S6wBQp5jfQ dExQ== X-Gm-Message-State: AOAM531iWRL4eqy8GFX+2SqvNZ3zkP3pmBtw+g4kdB03mMRQSqfyn5NR DWD9tE+26NCpDepfc7rDNz8S0RJUkFxcFw== X-Received: by 2002:adf:bbc2:: with SMTP id z2mr35865595wrg.359.1634558611593; Mon, 18 Oct 2021 05:03:31 -0700 (PDT) Received: from localhost (laubervilliers-658-1-213-31.w90-63.abo.wanadoo.fr. [90.63.244.31]) by smtp.gmail.com with ESMTPSA id t11sm12386134wrz.65.2021.10.18.05.03.31 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Oct 2021 05:03:31 -0700 (PDT) References: <20211016145939.15643-1-martin.blumenstingl@googlemail.com> <1j5ytuvdmw.fsf@starbuckisacylon.baylibre.com> User-agent: mu4e 1.6.6; emacs 27.1 From: Jerome Brunet To: Martin Blumenstingl Cc: linux-amlogic@lists.infradead.org, Neil Armstrong , linux-clk@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Christian Hewitt Subject: Re: [PATCH] clk: meson: gxbb: Add the spread spectrum bit for MPLL0 on GXBB Date: Mon, 18 Oct 2021 13:55:32 +0200 In-reply-to: Message-ID: <1jmtn6tu99.fsf@starbuckisacylon.baylibre.com> MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon 18 Oct 2021 at 13:44, Martin Blumenstingl wrote: > Hi Jerome, > > On Mon, Oct 18, 2021 at 12:19 PM Jerome Brunet wrote: >> >> >> On Sat 16 Oct 2021 at 16:59, Martin Blumenstingl wrote: >> >> > Christian reports that 48kHz audio does not work on his WeTek Play 2 >> > (which uses a GXBB SoC), while 44.1kHz audio works fine on the same >> > board. He also reports that 48kHz audio works on GXL and GXM SoCs, >> > which are using an (almost) identical AIU (audio controller). >> >> The above is a bit "personal" - it is not great fit for the commit >> description. Please rephrase or put it in comment section bellow > sure, I can rephrase that > > [...] >> > Add the SSEN (spread spectrum enable) bit and add the >> > CLK_MESON_MPLL_SPREAD_SPECTRUM flag to enable this bit for MPLL0. Do >> > this for GXBB *only* since GXL doesn't seem to care if this bit is set >> > or not, meaning that meson-clk-msr always sees (approximately) the same >> > frequency as common clock framework. >> >> 1 - it is odd that we need to poke a bit in the register related to the >> fixed PLL but ok ... >> 2 - 3.14 does yes, 4.9 does not soooo ... no real proof there > The fact that 4.9 doesn't do it is also no proof for anything either. > Amlogic hasn't ported forward GXBB support to their 4.9 kernel. Even > "mesongxbb.dtsi" is missing there [0] > So in my opinion the code from Amlogic's patched 4.9 kernel cannot be > used as reference for anything GXBB related. Only the 3.14 code can be > used as reference. > > [...] >> So 2 things: >> - If this bit really enables spread spectrum on MPLL0 (or worse, the >> Fixed PLL) - checking clk measure is not enough. It is just a mean of >> the rate seen by the SoC itself. You would not see the effect of the >> spread spectrum here ... you need to capture the clock output with a >> scope for that. > I suspect that a board with pin headers is needed to route the signal there? > Personally I don't have any GXBB board(s). > >> - Or the bit is incorrectly documented (or DDS0_SSEN does not mean >> spread spectrum). If it is not a spread spectrum function, then this >> patch seems to indicate it is and it is misleading. >> >> Either way, I'm not OK with it. >> >> To me, the rate drop that happens when you flip this bit looks more like >> the effect SDM_EN should have. >> >> Could you check the internal values (n2 and sdm) compare this to the >> output rate you actually get ? see if this leads to anything ? does >> SDM_EN really has an effect on this MPLL ? it is a combination of both ? > Christian has provided a dump of the HHI registers (via userspace, > regmap makes them accessible). > On GXBB WP2 HHI_MPLL_CNTL7 is set to 0x0006f208 > On GXL Le Potato (which he used for comparison as it wasn't affected > by the MPLL0 issue) HHI_MPLL_CNTL7 is set to 0x0006b208 > > If you're interested in the full HHI register dump you can find it here: [1] > GXBB WP2 is on the left and GXL Le Potato is on the right. > > The difference here is BIT(14). un-setting BIT(14) (documented as > EN_DDS0) did not change anything according to Christian's test. > That also means that SDM, SDM_EN and N2 have the expected values. > I manually did the maths: > (2000000000Hz * 16384) / ((16384 * 6) + 12808) = 294909640.7Hz > which matches what clk_summary sees: > 294909641Hz ... and (2000000000Hz * 16384) / ((16384 * 6) = 333MHz which is fairly close to what you get w/o flipping the bit > > Just to clarify that I am not wasting Christian's time when I ask him > to test something: > next up we'll set SDM_EN to 0 (instead of 1) and see the reaction using clk-msr? > For example yes. I am asking check a bit more what this bit does and what it does not: - I need confirmation whether or not it does spread spectrum. Yes this needs to be observed on a SoC pin, like MCLK with a fairly low divider to the averaging effect which could partially mask spread spectrum. - Get an idea what it actually does. The 2 calculations above are an hint. (Spread spectrum does not change the rate mean value) > > Best regards, > Martin > > > [0] https://github.com/hardkernel/linux/tree/db88db3864c5d6903fb11f6528874887d1c473ce/arch/arm64/boot/dts/amlogic > [1] https://pastebin.com/raw/1cjPFsfa