From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.4 required=3.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,USER_AGENT_SANE_1 autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 8A5FCC54FCC for ; Tue, 21 Apr 2020 13:52:24 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 64D9720672 for ; Tue, 21 Apr 2020 13:52:24 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=nvidia.com header.i=@nvidia.com header.b="Lk9jYjfP" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729013AbgDUNwV (ORCPT ); Tue, 21 Apr 2020 09:52:21 -0400 Received: from hqnvemgate26.nvidia.com ([216.228.121.65]:19493 "EHLO hqnvemgate26.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726018AbgDUNwU (ORCPT ); Tue, 21 Apr 2020 09:52:20 -0400 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate26.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Tue, 21 Apr 2020 06:52:07 -0700 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Tue, 21 Apr 2020 06:52:19 -0700 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Tue, 21 Apr 2020 06:52:19 -0700 Received: from DRHQMAIL107.nvidia.com (10.27.9.16) by HQMAIL101.nvidia.com (172.20.187.10) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Tue, 21 Apr 2020 13:52:19 +0000 Received: from [10.26.73.24] (10.124.1.5) by DRHQMAIL107.nvidia.com (10.27.9.16) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Tue, 21 Apr 2020 13:52:13 +0000 Subject: Re: [PATCH v8 00/22] Move PMC clocks into Tegra PMC driver To: Sowjanya Komatineni , , , , , , , , , , , CC: , , , , , , , , , , References: <1578986667-16041-1-git-send-email-skomatineni@nvidia.com> From: Jon Hunter Message-ID: <64b70163-05be-e4f9-2dbc-5088ac2a3af9@nvidia.com> Date: Tue, 21 Apr 2020 14:52:11 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.7.0 MIME-Version: 1.0 In-Reply-To: <1578986667-16041-1-git-send-email-skomatineni@nvidia.com> X-Originating-IP: [10.124.1.5] X-ClientProxiedBy: HQMAIL111.nvidia.com (172.20.187.18) To DRHQMAIL107.nvidia.com (10.27.9.16) Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1587477127; bh=hjjS0JQg56LMa2hsOmUjZTwWnjMR0RWAjOoiGrJkbAY=; h=X-PGP-Universal:Subject:To:CC:References:From:Message-ID:Date: User-Agent:MIME-Version:In-Reply-To:X-Originating-IP: X-ClientProxiedBy:Content-Type:Content-Language: Content-Transfer-Encoding; b=Lk9jYjfPpLlOqRr5AbmrjlUC9KNhtGOH0OZSHO7/OIQHTks9n/vQDizGV8Ub24Huo 6zpsAgFj98JGmSH0MSBYfBpHE18KLtebs+x/s2O9JdMGSQA7UTseS/cWO5mwlVX/Ig +JR11z51NrgqA4t2oqA0i20/Y6+2hoR1FpvZDRuDeGBfGtJTpXIpd4yi950Th/6zxZ CosHmfilPOz7DES5kpI1ZaFUbzPzkPUzPbU6CyVL+KX9Cf0IXThqJtbITeiZpEllo8 7+SMIX2+jiVy3DYERO3ES6TQKxscVGlhgKXW7XiWtZeCeYSviHewH0BUo5JUJX+V9h acZR2Ytx9bgUA== Sender: devicetree-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org On 14/01/2020 07:24, Sowjanya Komatineni wrote: > This patch series moves Tegra PMC clocks from clock driver to pmc driver > along with the device trees changes and audio driver which uses one of > the pmc clock for audio mclk. > > 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 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 Tegra > PMC driver with PMC as clock provider and removes them from Tegra clock > driver. > > PMC clock clk_out_1 is dedicated for audio mclk from Tegra30 thru Tegra210 > and clock driver does inital parent configuration for it and enables them. > But this clock should be taken care by audio driver as there is no need > to have this clock pre enabled. > > So, this series also includes patch that updates ASoC utils to take > care of parent configuration for mclk if device tree don't specify > initial parent configuration using assigned-clock-parents and enable > audio mclk during utils init. > > DTs are also updated to use clk_out_1 as audio mclk rather than extern1. > > This series also includes a patch for mclk fallback to extern1 when > retrieving mclk fails to have this backward compatible of new DT with > old kernels. On the current mainline kernel I am seeing the following WARNING on boot for tegra20-ventana, tegra30-cardhu-a04 and tegra124-jetson-tk1 ... [ 10.723511] ------------[ cut here ]------------ [ 10.730901] WARNING: CPU: 0 PID: 126 at /dvs/git/dirty/git-master_l4t-upstream/kernel/drivers/clk/clk.c:954 clk_core_disable+0xf4/0x280 [ 10.745986] cdev1 already disabled [ 10.752309] Modules linked in: snd_soc_tegra_wm8903(+) snd_soc_tegra20_i2s snd_soc_tegra_utils snd_soc_tegra_pcm snd_soc_wm8903 snd_soc_core ac97_bus snd_pcm_dmaengine snd_pcm snd_timer snd soundcore snd_soc_tegra20_das [ 10.778071] CPU: 0 PID: 126 Comm: systemd-udevd Not tainted 5.7.0-rc2-next-20200420-g6735c84f78e4 #1 [ 10.790485] Hardware name: NVIDIA Tegra SoC (Flattened Device Tree) [ 10.800088] [] (unwind_backtrace) from [] (show_stack+0x10/0x14) [ 10.811227] [] (show_stack) from [] (dump_stack+0xc0/0xd4) [ 10.821863] [] (dump_stack) from [] (__warn+0xe0/0xf8) [ 10.832118] [] (__warn) from [] (warn_slowpath_fmt+0x74/0xb8) [ 10.843006] [] (warn_slowpath_fmt) from [] (clk_core_disable+0xf4/0x280) [ 10.854863] [] (clk_core_disable) from [] (clk_core_disable_lock+0x18/0x24) [ 10.867021] [] (clk_core_disable_lock) from [] (tegra_asoc_utils_set_rate+0x74/0x2b4 [snd_soc_tegra_utils]) [ 10.882055] [] (tegra_asoc_utils_set_rate [snd_soc_tegra_utils]) from [] (tegra_asoc_utils_init+0x94/0xb90 [snd_soc_tegra_utils]) [ 10.899177] [] (tegra_asoc_utils_init [snd_soc_tegra_utils]) from [] (tegra_wm8903_driver_probe+0x294/0x310 [snd_soc_tegra_wm8903]) [ 10.916562] [] (tegra_wm8903_driver_probe [snd_soc_tegra_wm8903]) from [] (platform_drv_probe+0x48/0x98) [ 10.931678] [] (platform_drv_probe) from [] (really_probe+0x218/0x348) [ 10.943886] [] (really_probe) from [] (driver_probe_device+0x60/0x168) [ 10.956140] [] (driver_probe_device) from [] (device_driver_attach+0x58/0x60) [ 10.969029] [] (device_driver_attach) from [] (__driver_attach+0x80/0xbc) [ 10.981613] [] (__driver_attach) from [] (bus_for_each_dev+0x74/0xb4) [ 10.993891] [] (bus_for_each_dev) from [] (bus_add_driver+0x164/0x1e8) [ 11.006298] [] (bus_add_driver) from [] (driver_register+0x7c/0x114) [ 11.018586] [] (driver_register) from [] (do_one_initcall+0x54/0x22c) [ 11.031016] [] (do_one_initcall) from [] (do_init_module+0x60/0x210) [ 11.043370] [] (do_init_module) from [] (load_module+0x1f9c/0x2480) [ 11.055684] [] (load_module) from [] (sys_finit_module+0xac/0xd8) [ 11.067843] [] (sys_finit_module) from [] (__sys_trace_return+0x0/0x20) [ 11.080560] Exception stack(0xede3bfa8 to 0xede3bff0) [ 11.089988] bfa0: b6eb9a8c 00000000 00000010 b6eb91bc 00000000 b6eb9cd0 [ 11.102625] bfc0: b6eb9a8c 00000000 fca6e200 0000017b 00555918 bea799ac 00000000 00564640 [ 11.115289] bfe0: bea798a8 bea79898 b6eb3951 b6f61f42 [ 11.124833] ---[ end trace 3752c80347dfd3ca ]--- It appears that some of the patches in this series made v5.7-rc1 but not all and I am guessing the ASoC changes are the ones we are missing to avoid this. Sowjanya, any ideas on the best way to resolve this for v5.7? Cheers Jon -- nvpublic