Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp3106519imm; Fri, 19 Oct 2018 05:20:11 -0700 (PDT) X-Google-Smtp-Source: ACcGV61XrJf0Qi33LmMpQWnBpjREtWBAwjXU3DwKz9/F2waDubpLsCMyiYMyui4NCx1Rjrrm/yyL X-Received: by 2002:a17:902:a702:: with SMTP id w2-v6mr33811962plq.334.1539951611873; Fri, 19 Oct 2018 05:20:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539951611; cv=none; d=google.com; s=arc-20160816; b=v9rF626DZmw93tdtM2RPYMP+QOKCwn4M1nk3hDb457g+KC5TjMB4Dan/tUFJdJSt6h 6pQlYChvpu0H+lKTwfSsy8I2mGN3enQIt7Ktl1MOVybFNe+sfdRKBe6N4cmn6xZ44A4V AmUJYHbVgg+bbsulJ6BZOYW1+meEZae2cfiIwXUGWmdRUra8VWB6ctDshlb0mPeffiCn IcGCmZW1wGqEAmKhWEoR6MsxreTmrKWyoQasGS41Sb12RiN5G4oWrSxXxEs1JApi2hTA n2S1U5xXuFysQFQYiLeYJ5GO2jZNmtnGa5GEgShM57B4j1BgMGlb44GwNyRffrF6K2g3 QBdg== 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-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=zpx9okRbwne3kIxyJRf//lOO+qtCKHAzkIVShzVgADI=; b=MQmeoLr+OzPMoUaA3qKfBIaS9T/FGPRmNiosGfZEQ7guFNaMy2xl51zQJvqQLQgq1D PgRechoCR1D6w3qKijRE7UoGrgYkIHRRZMn4w2BeXtNk/s+oI2dX6tz+i1I9lTsMy0HH XHvUKe/lXwwlST5wWAeJoINw6FNo8WIXxIsAw7Jgc2jcBr4sPm5jddI9dGA5CEK+x228 wq+ssruHQV21lS22ywx0ch/0IR5BW9vAwU70JIDDpnkH5TfTKIBe2ESPkKsaGD7/A9Gy shPbNP+TXFOOQkcPfp7rGR+fskrRYW6vymwWh9sQzs+l3fcFIEoSWiJwkFdQuR/JGd4B rjfw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=DWQ6zVLm; 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 m10-v6si23542459pgb.101.2018.10.19.05.19.55; Fri, 19 Oct 2018 05:20:11 -0700 (PDT) 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=DWQ6zVLm; 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 S1727509AbeJSUXr (ORCPT + 99 others); Fri, 19 Oct 2018 16:23:47 -0400 Received: from hqemgate14.nvidia.com ([216.228.121.143]:2729 "EHLO hqemgate14.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726542AbeJSUXr (ORCPT ); Fri, 19 Oct 2018 16:23:47 -0400 Received: from hqpgpgate102.nvidia.com (Not Verified[216.228.121.13]) by hqemgate14.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Fri, 19 Oct 2018 05:17:46 -0700 Received: from HQMAIL101.nvidia.com ([172.20.161.6]) by hqpgpgate102.nvidia.com (PGP Universal service); Fri, 19 Oct 2018 05:17:54 -0700 X-PGP-Universal: processed; by hqpgpgate102.nvidia.com on Fri, 19 Oct 2018 05:17:54 -0700 Received: from [10.26.11.35] (10.124.1.5) by HQMAIL101.nvidia.com (172.20.187.10) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Fri, 19 Oct 2018 12:17:42 +0000 Subject: Re: [PATCH v1 1/2] soc/tegra: pmc: Turn powergates_lock into spinlock To: Dmitry Osipenko , Thierry Reding CC: , References: <20180830183635.4474-1-digetx@gmail.com> <7369869e-e58f-3760-d428-b00fb9cd28d9@nvidia.com> <57c3b1a6-0a60-613e-a4e7-5d66c199b860@gmail.com> From: Jon Hunter Message-ID: Date: Fri, 19 Oct 2018 13:17:39 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.2.1 MIME-Version: 1.0 In-Reply-To: <57c3b1a6-0a60-613e-a4e7-5d66c199b860@gmail.com> X-Originating-IP: [10.124.1.5] X-ClientProxiedBy: HQMAIL104.nvidia.com (172.18.146.11) To HQMAIL101.nvidia.com (172.20.187.10) 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=1539951466; bh=zpx9okRbwne3kIxyJRf//lOO+qtCKHAzkIVShzVgADI=; 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=DWQ6zVLmDRljGy7bGL24WH+/E+13bLR0ET3bGefujA0NHw36/ANkP9yS87JzfSW5w Oi0ze9hUoOylRIn6+JqRNT7bh1wp4w1DZ0l7EE9jv4Y67Skcyo0PAdi9E8okO2N6VZ ya5EZKs+EiYzUhxgQ8k9jplxefcwyVQSKBldpBcI0fmtiOoYEqpGm6UeVtp3d/iFr8 hkUgankgb0Ceu4juAqnb0zLkLAN/fZuZCoaOLU81V5yqk7ts4pfSM+F/kQjOZQ8/2K Ow9EggZu7s/AuTGCt+H+O91SJmz/4ciRyI8QdXEPm9HCvbytuqXZjPH48u98BZI5ip 3SwppsAR/IQLA== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 15/10/2018 14:52, Dmitry Osipenko wrote: > On 10/15/18 3:52 PM, Jon Hunter wrote: >> >> On 30/08/18 19:36, Dmitry Osipenko wrote: >>> This fixes splats like the one below if CONFIG_DEBUG_ATOMIC_SLEEP=y >>> and machine (Tegra30) booted with SMP=n or all secondary CPU's are put >>> offline. >>> >>> BUG: sleeping function called from invalid context at kernel/locking/mutex.c:254 >>> in_atomic(): 1, irqs_disabled(): 128, pid: 0, name: swapper/0 >>> CPU: 0 PID: 0 Comm: swapper/0 Tainted: G C 4.18.0-next-20180821-00180-gc3ebb6544e44-dirty #823 >>> Hardware name: NVIDIA Tegra SoC (Flattened Device Tree) >>> [] (unwind_backtrace) from [] (show_stack+0x20/0x24) >>> [] (show_stack) from [] (dump_stack+0x94/0xa8) >>> [] (dump_stack) from [] (___might_sleep+0x13c/0x174) >>> [] (___might_sleep) from [] (__might_sleep+0x70/0xa8) >>> [] (__might_sleep) from [] (mutex_lock+0x2c/0x70) >>> [] (mutex_lock) from [] (tegra_powergate_is_powered+0x44/0xa8) >>> [] (tegra_powergate_is_powered) from [] (tegra30_cpu_rail_off_ready+0x30/0x74) >>> [] (tegra30_cpu_rail_off_ready) from [] (tegra30_idle_lp2+0xa0/0x108) >>> [] (tegra30_idle_lp2) from [] (cpuidle_enter_state+0x140/0x540) >>> [] (cpuidle_enter_state) from [] (cpuidle_enter+0x40/0x4c) >>> [] (cpuidle_enter) from [] (call_cpuidle+0x30/0x48) >>> [] (call_cpuidle) from [] (do_idle+0x238/0x28c) >>> [] (do_idle) from [] (cpu_startup_entry+0x28/0x2c) >>> [] (cpu_startup_entry) from [] (rest_init+0xd8/0xdc) >>> [] (rest_init) from [] (start_kernel+0x41c/0x430) >> >> Given the above, rather than converting to a spinlock I wonder if we are >> just better off dropping the mutex completely from >> tegra_powergate_is_powered()? Otherwise ... >> >>> Signed-off-by: Dmitry Osipenko >>> --- >>> drivers/soc/tegra/pmc.c | 36 ++++++++++++++++++------------------ >>> 1 file changed, 18 insertions(+), 18 deletions(-) >>> >>> diff --git a/drivers/soc/tegra/pmc.c b/drivers/soc/tegra/pmc.c >>> index 2d6f3fcf3211..d6bc9f66f1cd 100644 >>> --- a/drivers/soc/tegra/pmc.c >>> +++ b/drivers/soc/tegra/pmc.c >>> @@ -186,7 +186,7 @@ struct tegra_pmc_soc { >>> * @lp0_vec_phys: physical base address of the LP0 warm boot code >>> * @lp0_vec_size: size of the LP0 warm boot code >>> * @powergates_available: Bitmap of available power gates >>> - * @powergates_lock: mutex for power gate register access >>> + * @powergates_lock: lock for power gate register access >>> */ >>> struct tegra_pmc { >>> struct device *dev; >>> @@ -215,7 +215,7 @@ struct tegra_pmc { >>> u32 lp0_vec_size; >>> DECLARE_BITMAP(powergates_available, TEGRA_POWERGATE_MAX); >>> >>> - struct mutex powergates_lock; >>> + spinlock_t powergates_lock; >>> }; >>> >>> static struct tegra_pmc *pmc = &(struct tegra_pmc) { >>> @@ -288,10 +288,10 @@ static int tegra_powergate_set(unsigned int id, bool new_state) >>> if (id == TEGRA_POWERGATE_3D && pmc->soc->has_gpu_clamps) >>> return -EINVAL; >>> >>> - mutex_lock(&pmc->powergates_lock); >>> + spin_lock(&pmc->powergates_lock); >>> >>> if (tegra_powergate_state(id) == new_state) { >>> - mutex_unlock(&pmc->powergates_lock); >>> + spin_unlock(&pmc->powergates_lock); >>> return 0; >>> } >>> >>> @@ -300,7 +300,7 @@ static int tegra_powergate_set(unsigned int id, bool new_state) >>> err = readx_poll_timeout(tegra_powergate_state, id, status, >>> status == new_state, 10, 100000); >>> >>> - mutex_unlock(&pmc->powergates_lock); >>> + spin_unlock(&pmc->powergates_lock); >> >> ... the above readx_poll_timeout needs to be converted to the atomic >> version. Furthermore, the above 100ms timeout is probably not suited to >> spinlock. > > It's converted in the second patch. Seems mutex indeed could be dropped from tegra_powergate_is_powered, at least for now I can't recall why decided to keep the locking. Thank you for the review, I'll try to drop the mutex and come back with v2 if it will be fine. Sorry if you were waiting for my response, but yes sounds good to me. Cheers Jon -- nvpublic