Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp6030308ybc; Wed, 27 Nov 2019 13:43:09 -0800 (PST) X-Google-Smtp-Source: APXvYqyEmZPGAip+F9mJ5uQ0mHczIhf551V5XtyPUaRglAd6iSVUqjEqph45z6Ru93f1YVyCsMos X-Received: by 2002:a17:906:25cb:: with SMTP id n11mr49357791ejb.239.1574890989411; Wed, 27 Nov 2019 13:43:09 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574890989; cv=none; d=google.com; s=arc-20160816; b=AL/X0yIpVGDxNs0FLLC7rToLZ+C1KnT6Mpe5JfVZAFvjS+jnbs/KrlNVBVhVcUNi61 Bx2TWRG4/FrUdmthbp1QcnLc8X2BMeNeOck3DuTR/Jc24LjWxEvM/KYe/p4VCvEFdTiK jtCdSbydBtyOPQv1bpZllD991vt+nGwc7m5LxKTrVNrACzXFASOCEflpMDB065Ptxda5 WOvNUIjB0NNzRO2ZbgORj6zcKxvtqpV7QrlRjJYWANzNLCYoKM3JCPBf9TsF5ZIwy27A L5mCGmoGDoQ5YtUo2rekQyEdsCAvIBbrOQ4Dfu1aOKuE37y/ETJLenoP6DXYb8ofMg3R 3RGA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:dkim-signature:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:references:cc:to:from:subject; bh=ag/e8mQxwalbYL9n6zyLqVUDKe4qzyB/v1O/jPgJV40=; b=YG22RTclt3J+J4GFS81Bo0QDjH4m7zyJAcAgi4zsAdlmAHNYnOmNG3/z6ptvD9nxcg LwmdoVjT8ydj/x07ZYp78+hHWjWqzXb8nspbWk/QR/z8E8WdMXDxFONEtLnOAtgu0wll xs5FbWhZ0h0wLF4EYsjUxuq/t2CDqg9CPDYf9115TuZNS/YEl/OIfQxjX+4VVHFaRh/h 1BygEfgKhtak2gdCIqzr2b7sRbYUFDV8o+SiiYHUGXt1o3AGms7fGA0kXKTOx9rGi5PB nxWUmkDLWZM3fWMPdhgvzkUPxsqJ4ToUq6Qm4mm7T/hmOM3axVaL01JWN3kC/kgOm0Ih 2gMg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=SAtZ9YUt; 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=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d3si11319930eds.75.2019.11.27.13.42.46; Wed, 27 Nov 2019 13:43:09 -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=@nvidia.com header.s=n1 header.b=SAtZ9YUt; 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=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729752AbfK0Vi2 (ORCPT + 99 others); Wed, 27 Nov 2019 16:38:28 -0500 Received: from hqemgate16.nvidia.com ([216.228.121.65]:9089 "EHLO hqemgate16.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729787AbfK0Vi1 (ORCPT ); Wed, 27 Nov 2019 16:38:27 -0500 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqemgate16.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Wed, 27 Nov 2019 13:38:28 -0800 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Wed, 27 Nov 2019 13:38:26 -0800 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Wed, 27 Nov 2019 13:38:26 -0800 Received: from [10.2.169.149] (10.124.1.5) by HQMAIL107.nvidia.com (172.20.187.13) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Wed, 27 Nov 2019 21:38:24 +0000 Subject: Re: [PATCH v2 00/11] Move PMC clocks into Tegra PMC driver From: Sowjanya Komatineni To: Dmitry Osipenko , , , , CC: , , , , , , , , , , , , , , , , , , , , , References: <1574830773-14892-1-git-send-email-skomatineni@nvidia.com> <79e7bd6a-f138-1e7d-6e0b-435adde3b3e5@gmail.com> <04b093fe-5eff-1ad2-9a8a-7674dcb2318a@nvidia.com> Message-ID: Date: Wed, 27 Nov 2019 13:38:27 -0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.7.2 MIME-Version: 1.0 In-Reply-To: <04b093fe-5eff-1ad2-9a8a-7674dcb2318a@nvidia.com> X-Originating-IP: [10.124.1.5] X-ClientProxiedBy: HQMAIL105.nvidia.com (172.20.187.12) To HQMAIL107.nvidia.com (172.20.187.13) Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: quoted-printable Content-Language: en-US DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1574890708; bh=ag/e8mQxwalbYL9n6zyLqVUDKe4qzyB/v1O/jPgJV40=; h=X-PGP-Universal:Subject:From:To:CC:References:Message-ID:Date: User-Agent:MIME-Version:In-Reply-To:X-Originating-IP: X-ClientProxiedBy:Content-Type:Content-Transfer-Encoding: Content-Language; b=SAtZ9YUtxEa8WiMlSA/tZg+9XyWCOH/DHlLFI+Y1pbbxw2Yl6Z0et9e41GWd7Tp9/ gZ2o3QVJlN0wyZqd2NMHdwYV8qZdN9Kv0Jigz8+tpKnUc1eyDCBMORiQXeh6md1XXv HXnRwOlTgEymcOk0lYjWVms0Xypilqeo3DyrUZHrb9fRaOwis0e/81yhkcFNAVIgmn 8i7DC6Q38IRF12t6st4VG5vQlaItv9Ii/GG0M9xC63RTuzoBWn4IAuCcTqL8nKIaQ1 dq3+fJQosNdV78eBnoxa7Y55UCUiUuBDbWTyHWpIKDTmsBcdbe0KQj6+ivDLBo1VFV fAJOF3lSasT7A== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/27/19 9:02 AM, Sowjanya Komatineni wrote: > > On 11/27/19 6:31 AM, Dmitry Osipenko wrote: >> 27.11.2019 07:59, Sowjanya Komatineni =D0=BF=D0=B8=D1=88=D0=B5=D1=82: >>> Tegra PMC has clk_out_1, clk_out_2, clk_out_3 and blink controls which >>> are currently registered by Tegra clock driver using clk_regiser_mux=20 >>> and >>> clk_register_gate which performs direct Tegra PMC register access. >>> >>> When Tegra PMC is in secure mode, any access from non-secure world will >>> not go through. >>> >>> This patch series adds these Tegra PMC clocks and blink controls to=20 >>> Tegra >>> PMC driver with PMC as clock provider and removed them from Tegra clock >>> driver. This also adds PMC specific clock id's to use in device tree=20 >>> and >>> removed clock ids of PMC clock from Tegra clock driver. >>> >>> This series also includes patch to update clock provider from tegra_car >>> to pmc in the device tree tegra210-smaug.dts that uses clk_out_2=20 >>> from PMC. >>> >>> [v2]:=C2=A0=C2=A0=C2=A0 Changes between v1 and v2 are >>> =C2=A0=C2=A0=C2=A0=C2=A0- v2 includes patches for adding clk_out_1, clk= _out_2, clk_out_3, >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 blink controls to Tegra PMC driver and r= emoving clk-tegra-pmc. >>> =C2=A0=C2=A0=C2=A0=C2=A0- feedback related to pmc clocks in Tegra PMC d= river from v1 >>> =C2=A0=C2=A0=C2=A0=C2=A0- Removed patches for WB0 PLLM overrides and PL= LE IDDQ PMC=20 >>> programming >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 by the clock driver using helper functio= ns from Tegra PMC. >>> >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 Note: >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 To use helper functions from PMC driver,= PMC early init need to >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 happen prior to using helper functions a= nd these helper=20 >>> functions are >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 for PLLM Override and PLLE IDDQ programm= ing in PMC during=20 >>> PLLM/PLLE >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 clock registration which happen in clock= _init prior to Tegra PMC >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 probe. >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 Moving PLLM/PLLE clocks registration to = happen after Tegra PMC >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 impacts other clocks EMC, MC and corresp= onding tegra_emc_init and >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 tegra_mc_init. >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 This implementation of configuring PMC r= egisters thru helper >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 functions in clock driver needs proper c= hanges across PMC, Clock, >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 EMC and MC inits to have it work across = all Tegra platforms. >>> >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 Currently PLLM Override is not enabled i= n the bootloader so=20 >>> proper >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 patches for this fix will be taken care = separately. >> Hello Sowjanya, >> >> Could you please clarify what do you mean by "PLLM Override not enabled >> in bootloader"? >> >> There is T124 Nyan Big Chromebook which is supported in upstream kernel, >> it has PLLM Override set by bootloader. I also have T30 Nexus 7 tablet >> which has the PLLM Override set by bootloader as well. It's not clear to >> me whether this patch series is supposed to break these devices. If the >> breakage is the case here, then I'm afraid you can't postpone supporting >> the PLLM Override and a full-featured implementation is needed. > > Hi Dmitry, > > Secure boot currently is enabled only on Tegra210 and Tegra210=20 > bootloader doesn't enable PLLM override. > > So PLLM override/PLLE IDDQ being in clock driver currently will not=20 > break on any of existing Tegra platforms. > >> >> I briefly tried to test this series on T30 and this time it doesn't hang >> on boot, but somehow WiFi MMC card detection is broken. AFAIK, the WiFi >> chip uses the Blink clock source and the clock should be enabled by the >> MMC core because this is how DT part looks like: >> >> brcm_wifi_pwrseq: wifi-pwrseq { >> =C2=A0=C2=A0=C2=A0=C2=A0compatible =3D "mmc-pwrseq-simple"; >> =C2=A0=C2=A0=C2=A0=C2=A0clocks =3D <&pmc TEGRA_PMC_CLK_BLINK>; >> =C2=A0=C2=A0=C2=A0=C2=A0clock-names =3D "ext_clock"; >> =C2=A0=C2=A0=C2=A0=C2=A0reset-gpios =3D=C2=A0 <&gpio TEGRA_GPIO(D, 3) GP= IO_ACTIVE_LOW>; >> =C2=A0=C2=A0=C2=A0=C2=A0post-power-on-delay-ms =3D <300>; >> =C2=A0=C2=A0=C2=A0=C2=A0power-off-delay-us =3D <300>; >> }; >> >> BTW, I=C2=A0 tried this series on a T20 device which also uses the Blink >> clock for WiFi card and it works. So looks like this patchset has some >> problem in regards to the T30 PMC clocks implementation. >> >> [snip] > > Blink init state is set to true for both Tegra20 and Tegra30 and all=20 > go through the same blink programming sequence. > > Will try to add more debug messages to dump registers and will test=20 > blink through device tree on T30 and will get back... > > define value for BLINK uses BIT macro instead of just position. Will fix=20 this in v3.