Received: by 10.223.185.116 with SMTP id b49csp4859306wrg; Tue, 27 Feb 2018 04:00:45 -0800 (PST) X-Google-Smtp-Source: AH8x224ORFY6FgXfsWAZ3XKKgbaRkBb/pzZ4DfhbX69a/gCvC+h+U766a9eewipDEL+qnZBpX2Ht X-Received: by 2002:a17:902:57c6:: with SMTP id g6-v6mr12950059plj.358.1519732845091; Tue, 27 Feb 2018 04:00:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519732845; cv=none; d=google.com; s=arc-20160816; b=Ge5/wZA3Z0EXybJrxygrgAlfXUoR9KMPZxJXWbq+U+ClzgiDOhVt5Gwpz8RxC0v6Im c+IXpE7awYULWdEC2oZoxHHHMYtmHOLyqg42oGxRP3Nua3lCQ5klc0KgMPNzSU3s95mG 1jkfW1gppPL163tO8ohronFMruLFj8hmOLjLIg3G/0vsTF7YCp42n6C67mKEuf/ZTO3l MGjaCzgj4woytN33stoWhfGX733o4j+dpZKKaP0huXNDsXQtoE6dx6EPe4lPi/UNSOBD wMPjmWB23z4SD/gLKhVd8dUnDXawCRMlf7QDkfoEK0yEeF+mwzjCNW98Km9m6WcOalrR 487Q== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :arc-authentication-results; bh=6z8bTiZHvw2NKVY0KL3cI0fhbE8OktqQj63DF88J/mU=; b=Ybt8nplzdqOIsdVOHWJK07SLddrd4DHMiC5lmUbky53Xa6EYCJX1Idchmnd+tzGlLk zTGtNvQviS8jUFTGrAbsDHxlt+XtQrWpmxdGy0N2leici7UjiaTglfjyztCplZppKVHu WbI4yk8J1nMJwjgGGB1Jew2bUDtV4u5r0BuM1V24Ky8eS8Qi5rpHermh8Vz5ieJSZ/BI tnXyJwnX//QvPwWBFG49PAbEhFBMcG0K8JR6J7GhRPMIB/c1Ap+r+3ihpbR5lDD8YKYo fywhlQXXDhCSC7m0HVD8mYnyLdwm0uIIYx9P5IyV1V4SpRFwejHsw2gXPe4wPitW5+/y qX9g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=nPBWbOac; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b1si6948192pgn.191.2018.02.27.04.00.30; Tue, 27 Feb 2018 04:00:45 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=nPBWbOac; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753121AbeB0L7h (ORCPT + 99 others); Tue, 27 Feb 2018 06:59:37 -0500 Received: from mail-lf0-f66.google.com ([209.85.215.66]:37119 "EHLO mail-lf0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752207AbeB0L7e (ORCPT ); Tue, 27 Feb 2018 06:59:34 -0500 Received: by mail-lf0-f66.google.com with SMTP id y19so27104800lfd.4; Tue, 27 Feb 2018 03:59:32 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=6z8bTiZHvw2NKVY0KL3cI0fhbE8OktqQj63DF88J/mU=; b=nPBWbOacgYD48uZgCQMD7lG7Vcf9Es3YsQkaDcfgJyLS9uOoATVnRC2XXhK3h3SOrG ojPWJfO3ZeEjuk2jomkWT3DicJ1Tm8krXmRs5ijqlZOYPq6z817+8NXa/lZN2+pzJ5HD tNDWUsg0dunAcQsVIvuxbndC8sqMSE5Ms0KsSaSUzo5bIZ1t2Zi6TGuyOyQ5xjFol4ny 0CArBuT23q/KBrwFY0lNelagqWXGrpzm+K0q48guf6IuA39JxYB3kj3+9bVR+UMT95OD 64I1XqMPrd468YeTKEparqKgLip9t6u+hV1GxVDoeq8XcDXbzyY2PZi57NTR5nM0W3mR xkKA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=6z8bTiZHvw2NKVY0KL3cI0fhbE8OktqQj63DF88J/mU=; b=R1adbp+ZtnXaeCiyyAFXZlmB+E5EUqiBRfM1Lpl1Dz9ymJamaWb6HA73FuIKbh1UwY oEfScXTf+PhfLbnd9iNMSj4OWrVod+sRCoER+E+/xjir52zdXzDWteyYHM/564URpSB2 V96S7M+OzWc172Ch9N+BtpwFNyAhBGw1fyucP54YHJ3HRQyQKvRA5U0QxKfuJEI6XjvK D6Mo8nYUwTcFfERY5bTqQTL8Pt9B//bCQ4AjuIuZudfmM8RT8QksSUj8KVYksdxuEJX6 XB9MnyjQwbHPKXSEj2oV6DZp1vZodVHE7zlOjEo3Pz2Wg+CwBj5Tvwg8zZvfFgAm2QTH gHlw== X-Gm-Message-State: APf1xPADeIAe81V+4qLsWSlBx75CwX1SwuD/DNxnFF8w0Tp4gYrEBWWC avAovDKojmcTVOxyWhdTTtJq2zmV X-Received: by 10.46.20.30 with SMTP id u30mr10579101ljd.12.1519732771876; Tue, 27 Feb 2018 03:59:31 -0800 (PST) Received: from [192.168.1.145] (ppp109-252-55-234.pppoe.spdop.ru. [109.252.55.234]) by smtp.googlemail.com with ESMTPSA id l5sm2528043lje.58.2018.02.27.03.59.30 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 27 Feb 2018 03:59:31 -0800 (PST) Subject: Re: [PATCH] clk: tegra: fix pllu rate configuration To: Marcel Ziswiler , "linux-tegra@vger.kernel.org" , "pdeschrijver@nvidia.com" Cc: "linux-kernel@vger.kernel.org" , "jonathanh@nvidia.com" , "mturquette@baylibre.com" , "pgaikwad@nvidia.com" , "sboyd@kernel.org" , "thierry.reding@gmail.com" , "linux-clk@vger.kernel.org" References: <20180222230451.15515-1-marcel@ziswiler.com> <31f039e8-9afc-22d1-d478-a7f41db0dace@gmail.com> <1519686262.6374.3.camel@toradex.com> From: Dmitry Osipenko Message-ID: Date: Tue, 27 Feb 2018 14:59:11 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <1519686262.6374.3.camel@toradex.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 27.02.2018 02:04, Marcel Ziswiler wrote: > On Mon, 2018-02-26 at 15:42 +0300, Dmitry Osipenko wrote: >> On 23.02.2018 02:04, Marcel Ziswiler wrote: >>> Turns out latest upstream U-Boot does not configure/enable pllu >>> which >>> leaves it at some default rate of 500 kHz: >>> >>> root@apalis-t30:~# cat /sys/kernel/debug/clk/clk_summary | grep >>> pll_u >>> pll_u 3 3 0 500000 >>> 0 >>> >>> Of course this won't quite work leading to the following messages: >>> >>> [ 6.559593] usb 2-1: new full-speed USB device number 2 using >>> tegra- >>> ehci >>> [ 11.759173] usb 2-1: device descriptor read/64, error -110 >>> [ 27.119453] usb 2-1: device descriptor read/64, error -110 >>> [ 27.389217] usb 2-1: new full-speed USB device number 3 using >>> tegra- >>> ehci >>> [ 32.559454] usb 2-1: device descriptor read/64, error -110 >>> [ 47.929777] usb 2-1: device descriptor read/64, error -110 >>> [ 48.049658] usb usb2-port1: attempt power cycle >>> [ 48.759475] usb 2-1: new full-speed USB device number 4 using >>> tegra- >>> ehci >>> [ 59.349457] usb 2-1: device not accepting address 4, error -110 >>> [ 59.509449] usb 2-1: new full-speed USB device number 5 using >>> tegra- >>> ehci >>> [ 70.069457] usb 2-1: device not accepting address 5, error -110 >>> [ 70.079721] usb usb2-port1: unable to enumerate USB device >>> >>> Fix this by actually allowing the rate also being set from within >>> the Linux kernel. >>> >>> Signed-off-by: Marcel Ziswiler >>> >>> --- >>> >>> drivers/clk/tegra/clk-pll.c | 2 ++ >>> 1 file changed, 2 insertions(+) >>> >>> diff --git a/drivers/clk/tegra/clk-pll.c b/drivers/clk/tegra/clk- >>> pll.c >>> index 7c369e21c91c..830d1c87fa7c 100644 >>> --- a/drivers/clk/tegra/clk-pll.c >>> +++ b/drivers/clk/tegra/clk-pll.c >>> @@ -1151,6 +1151,8 @@ static const struct clk_ops >>> tegra_clk_pllu_ops = { >>> .enable = clk_pllu_enable, >>> .disable = clk_pll_disable, >>> .recalc_rate = clk_pll_recalc_rate, >>> + .round_rate = clk_pll_round_rate, >>> + .set_rate = clk_pll_set_rate, >>> }; >>> >>> static int _pll_fixed_mdiv(struct tegra_clk_pll_params >>> *pll_params, >>> >> >> Tegra's USB PHY driver only enables clock and clk driver doesn't >> specify the >> clock rate in the init table. Could you please clarify where in the >> kernels code >> PLL_U rate is getting set? > > I guess that would be according to the following table isn't it: > > https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree > /drivers/clk/tegra/clk-tegra30.c?h=v4.16-rc3#n287 > I see now that T30 has PLL_U in the init table [0], but T20 doesn't. There is only one 480MHz rate defined in PLL_U lookup table. PLL_U also provides 12MHz and 60MHz outputs using fixed dividers and hence PLL_U shouldn't need set/round_rate(), we can't change PLL_U rate at all and only enable / disable it. Looks like for some reason PLL_U enabling fails without set/round_rate, but then PHY driver should fail to probe [1]. Is it the case? Do you know why PLL_U isn't actually getting enabled in HW? It is quite fishy, seems like clk driver / framework bug or I'm missing something. [0] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/drivers/clk/tegra/clk-tegra30.c?h=v4.16-rc3#n1274 [1] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/drivers/usb/phy/phy-tegra-usb.c?h=v4.16-rc3#n777